*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
	line-height: 1; /* for iOS-Safari 必須 */
}

h1, h2, h3, h4, h5, h6 {
	font-weight: normal;
}

html, body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, form, fieldset, input, textarea, p, blockquote, th, td {
	margin: 0;
	padding: 0;
}

body {
	min-width: 360px;
}

#datepicker {
	padding-bottom: 20px;
}

.ui-datepicker {
	width: 99% !important;
	padding: 0;
}

.ui-widget {
	font-size: 0.9em;
}

.ui-datepicker table {
	font-size: 0.7em;
}

.ui-widget-header {
	border: none;
	background: none;
}

.ui-datepicker-week-end {
	background: #ffe0e0;
}

.ui-datepicker-calendar .ui-state-default {
	border: none;
	font-size: 16px;
}

.ui-state-active {
	background: #007fff !important;
	color: #fff !important;
}

h1 {
	font-family: 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'メイリオ', Meiryo, 'ＭＳ Ｐゴシック', Osaka, sans-serif;
	font-weight: bold;
	height: 40px;
	font-size: 22px;
	padding: 10px 14px 0 48px;
	background-image: url("/img/kanji.svg");
	background-repeat: no-repeat;
	background-size: 40px;
	float: left;
	text-shadow: 0 0 3px #888;
}

h2 {
	padding: 30px;
	font-size: 32px;
	text-align: center;
	clear: both;
}

header {
	height: 60px;
	padding: 8px;
	font-size: 20px;
	border-bottom: 1px #aaaaaa solid;
}

header div {
	font-size: 14px;
	color: #666;
	vertical-align: middle;
	height: 40px;
	display: table-cell;
	line-height: 1.2;
	padding-right: 90px;
}

#mainimg {
	width: 100%;
	text-align: center;
}

#mainimg img {
	width: 100%;
	max-width: 300px;
}

.chuc {
	margin-left: 8px;
	color: #444;
	font-size: 14px;
}

.chu1 {
	text-align: center;
	margin-top: 12px;
	color: #888;
	font-size: 12px;
}


#main {
	width: 100%;
	max-width: 860px;
	margin-left: auto;
	margin-right: auto;
	font-size: 18px;
	padding: 8px;
}

.footermenu {
	color: #444;
	font-size: 14px;
	margin-bottom: 8px;
}

.footermenu a {
	color: #444;
}

footer {
	margin: 20px 0;
	padding: 20px 0;
	font-family: Roboto, arial, sans-serif;
	font-size: 11px;
	color: #aaa;
	position: absolute;
	left: 50%;
	transform: translate(-50%, -50%);
	text-align: center;
}

footer a {
	color: #aaa;
	text-decoration: none;
}

section {
	width: 100%;
	max-width: 860px;
	margin-left: auto;
	margin-right: auto;
	font-size: 18px;
	padding: 8px;
}

#desc {
	color: #000;
	font-size: 22px;
	border-radius: 4px;
	margin: 10px auto;
	max-width: 800px;
	padding: 20px;
	background-color: #f0f0f0;
}

#desc li {
	list-style-type: none;
	line-height: 1.8;
}

#desc li:before {
	margin-right: 10px;
	content: '';
	display: inline-block;
	height: 1em;
	width: 1em;
	background-image: url('/img/ok.svg');
	background-size: contain;
	background-repeat: no-repeat;
	padding-left: 10px;
}

.btn1 {
	background: #3498db;
	background-image: -webkit-linear-gradient(top, #3498db, #2980b9);
	background-image: -moz-linear-gradient(top, #3498db, #2980b9);
	background-image: -ms-linear-gradient(top, #3498db, #2980b9);
	background-image: -o-linear-gradient(top, #3498db, #2980b9);
	background-image: linear-gradient(to bottom, #3498db, #2980b9);
	border-radius: 8px;
	color: #ffffff;
	font-size: 24px;
	padding: 12px 20px 10px 20px;
	text-decoration: none;
}

.btn1:hover {
	cursor: pointer;
	background: #3cb0fd;
	background-image: -webkit-linear-gradient(top, #3cb0fd, #3498db);
	background-image: -moz-linear-gradient(top, #3cb0fd, #3498db);
	background-image: -ms-linear-gradient(top, #3cb0fd, #3498db);
	background-image: -o-linear-gradient(top, #3cb0fd, #3498db);
	background-image: linear-gradient(to bottom, #3cb0fd, #3498db);
	text-decoration: none;
}

.btnSmall {
	background: #3498db;
	background-image: -webkit-linear-gradient(top, #3498db, #2980b9);
	background-image: -moz-linear-gradient(top, #3498db, #2980b9);
	background-image: -ms-linear-gradient(top, #3498db, #2980b9);
	background-image: -o-linear-gradient(top, #3498db, #2980b9);
	background-image: linear-gradient(to bottom, #3498db, #2980b9);
	border-radius: 4px;
	color: #ffffff;
	padding: 6px 10px 6px 10px;
	text-decoration: none;
	border: none;
}

.btnSmall:hover {
	background: #3cb0fd;
	background-image: -webkit-linear-gradient(top, #3cb0fd, #3498db);
	background-image: -moz-linear-gradient(top, #3cb0fd, #3498db);
	background-image: -ms-linear-gradient(top, #3cb0fd, #3498db);
	background-image: -o-linear-gradient(top, #3cb0fd, #3498db);
	background-image: linear-gradient(to bottom, #3cb0fd, #3498db);
	text-decoration: none;
}

input[type="submit"] {
	border: none;
	-webkit-appearance: button; /* for Mac-Safari */
}

#ivname {
	padding: 4px;
	font-size: 24px;
	width: 100%;
}

#tbl1 {
	width: 100%;
}

.demo {
	text-align: center;
	font-size: 20px;
	margin-bottom: 20px;
}

.demo a {
	padding: 8px;
}

.demo a:hover {
	background-color: #cef;
}

.lbl1 {
	margin-top: 18px;
	margin-bottom: 8px;
	font-size: 20px;
}

.lbl2 {
	margin-top: 8px;
	font-size: 16px;
}

.txtcenter {
	text-align: center;
	text-align: -moz-center;
}

.recaptcha {
	margin-left: calc(50% - 150px);
	margin-bottom: 16px;
}

.whatsnew {
	font-size: 14px;
	background-color: #d00;
	color: #fff;
	border-radius: 2px;
	padding: 3px;
	margin-left: 4px;
	vertical-align: middle;
	font-family: "Trebuchet MS", sans-serif;
}

.slider {
	display: inline;
	width: 100%;
}

.slider img {
	width: 100%;
	height: auto;
	max-height: 480px;
}

.caption {
	max-width: 100%;
	position: absolute;
	top: 50px;
	background: rgba(51, 51, 51, 0.8);
	color: white;
	font-size: 32px;
	padding: 20px;
	text-shadow: -1px 1px 0 rgba(0, 0, 0, 1);
}

.img100 {
	width: 100%;
	border: 3px solid #eee;
	border-radius: 4px;
}

.arrow-down {
	text-align: center;
}

.icon {
	width: 24px;
	height: 24px;
	vertical-align: middle;
}

.ad-amazon {
	text-align: center;
	margin-top: 24px;
}

#captcha {
	text-align: center;
	padding-bottom: 16px;
}

#imgCaptcha {
	vertical-align: middle;
}

#tbxCaptcha {
	width: 100px;
	padding: 4px;
	font-size: 24px;
	margin: 5px;
}

.txtred {
	color: #f00;
}

.social-bar {
	display: flex;
	justify-content: center;
	align-items: center;
}

.social {
	display: table-cell;
	float: left;
	margin-left: 8px;
}

.red {
	color: #c00;
}

.information {
	overflow-y: scroll;
	font-size: 18px;
	margin-top: 8px;
	line-height: 1.5;
	border: 2px solid #0a0;
	border-radius: 4px;
	padding: 12px;
}

.information div {
	line-height: 1.5;
}

.information img {
	max-width: 80%;
	border: 1px solid #ddd;
	padding: 4px;
	border-radius: 4px;
	margin-bottom: 12px;
}

.information i {
	color: #c00;
}

.info-title {
	background-color: #0a0;
	border-radius: 4px;
	padding: 4px;
	color: #fff;
	margin-bottom: 4px;
}

.info-title > i {
	color: #fff;
}

.anniversary-title {
	font-size: 40px;
	font-weight: bold;
	text-shadow: 0 0 6px #f00;
	-moz-text-shadow: 0 0 6px #f00;
	-webkit-text-shadow: 0 0 6px #f00;
}

.anniversary {
	text-align: center;
	padding: 16px 0;
}

.anniversary > p {
	line-height: 1.5;
}

.anniversary > img {
	width: 100%;
}

.fb-like {
	transform: scale(1.1);
	-webkit-transform: scale(1.1);
	-moz-transform: scale(1.1);
}

/* FB bug hack */
.fb-like iframe {
	width: 200px !important;
}

.tayori {
	margin: 16px 0;
}

.tayori h3 {
	line-height: 1.5;
	color: #005000;
}

.tayori p {
	line-height: 1.5;
	padding-top: 12px;
	text-indent: 1em;
}

.tayori > time {
	line-height: 1.5;
	padding-top: 8px;
	text-align: right;
	font-size: 14px;
	display: block;
}

.tayori img {
	width: calc(100% - 24px);
}

.ads > ins {
	text-align: center;
	margin: 16px;
}

.contents {
	margin-top: 14px;
	border-top: 4px solid #9e9;
}

.contents time {
	margin: 10px 0;
	font-size: 14px;
	display: block;
}

.new::after {
	margin-left: 6px;
	content: 'NEW';
	color: #f00;
}

.insimg {
	width: 100%;
	max-width: 300px;
	max-height: 300px;
	object-fit: contain;
}

.footer {
	text-align: center;
	margin: 40px 0;
	font-size: 12px;
}

.footer a {
	padding: 4px;
	color: #888;
	text-decoration: none;
}

.footer a:hover {
	background-color: #ff8;
}

mark {
	background-color: #ff8;
}

@media all and (max-width: 700px) {
	#desc {
		font-size: 18px;
	}

	.caption {
		font-size: 18px;
	}

	header div {
		font-size: 12px;
		line-height: 1;
	}
}
