@charset "utf-8";
/*フラット02 ピンク 1カラム*/
@import url("//fonts.googleapis.com/css2?family=Montserrat:wght@400;700&display=swap");
@import url("//use.fontawesome.com/releases/v5.6.1/css/all.css");

/* --------- 共通 --------- */
#wrap {
	background-color: #fff;
	min-width: 1000px;
}

/* Windows 用 Medium 指定の游ゴシック */
@font-face {
	font-family: "Yu Gothic M";
	src: local("Yu Gothic Medium");
}

@font-face {
	font-family: YuGothicM;
	src: local("Yu Gothic Medium");
}

/* font-weight: bold の時は通常どおり Bold 書体を使わせる */
@font-face {
	font-family: "Yu Gothic M";
	src: local("Yu Gothic Bold");
	font-weight: bold;
}

body {
	font-family: "Montserrat", Verdana, -apple-system, BlinkMacSystemFont, "Helvetica Neue", HelveticaNeue, "Segoe UI", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 20px;
	color: #423929;
	letter-spacing: 0.5px;
	font-kerning: auto;
	line-height: 1.8;
}

.serif

/*, #name, h2, .article h3, .gallery h3, .article h4, .article h5, .article h6, #topMenu .topMenu li a, .article.concept*/
	{
	font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN W3", HiraMinProN-W3, "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "Yu Mincho", "游明朝体", "YuMincho", "游明朝", "HGS明朝E", "ＭＳ Ｐ明朝", "MS PMincho", serif;
}

.serif {
	font-size: 120%;
	font-feature-settings: "palt";
}


/*リンク体裁*/
a {
	color: #1D94C6;
	text-decoration: none;
	font-weight: bold;
}

.article a {
	text-decoration: underline;
}

a:hover {
	color: #2FAFCB;
	font-weight: bold;
	text-decoration: none;
}

.footer a:hover,
.footer p a:hover {
	color: #fff;
	font-weight: bold;
}

.ams-build a,
.ams-build a:hover {
	font-weight: normal;
}

#mainArticles a:hover img,
#sideBanners a:hover img,
div.freeHtml a:hover img,
div.image img.gallery:hover {
	filter: alpha(opacity=75);
	-moz-opacity: 0.75;
	opacity: 0.75;
}

.sideBanner_body a:hover,
.thumb a:hover,
.image a:hover {
	filter: alpha(opacity=80);
	opacity: 0.8;
}

/*リンクボタン*/
a.btn {
	display: flex;
	padding: 16px;
	text-align: center;
	text-decoration: none;
	font-size: 16px;
	font-weight: bold;
	border: none;
	color: #FFF;
	border-radius: 6px;
	justify-content: center;
	background: rgb(142, 161, 221);
	background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgb(79 102 173) 100%);
	box-shadow: 0 2px 0 #7a78cd;
	padding: 4px 14px;
	border-radius: 4px;
}

a.btn:hover {
	color: #fff;
	border: none;
	text-decoration: none;
	background: rgb(142, 161, 221);
	background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgb(79 102 173) 100%);
}

.freeHtml a.btn {
	color: #FFF;
	background: rgb(142, 161, 221);
	background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgb(79 102 173) 100%);
	border-radius: 4px;
	box-shadow: 0 2px 0 #7a78cd;
}

.freeHtml a.btn:hover {
	color: #FFF;
	background: rgb(142, 161, 221);
	background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgb(79 102 173) 100%);
	border-radius: 4px;
	opacity: 0.8;
}

/*サイト案内*/
ul.guide li {
	width: 394px;
	float: left;
	margin-right: 8px;
}

ul.guide li:last-of-type {
	margin: 0;
}

/*----------------- ヘッダー -----------------*/
#topMenu,
#wrap #title {
	background: none;
}

#mainImage {
	background-color: #fff;
}

#wrap_body {
	padding-top: 0;
	position: relative;
}

div#toolbar {
	display: none;
}

#wrap #title {
	padding: 0 0 64px;
	padding: 0;
	height: 164px;
	width: 100%;
}

h1,
h1 a {
	margin-bottom: 0;
	overflow: hidden;
	text-indent: 110%;
	white-space: nowrap;
}

/*メインイメージ*/
.mainImage img,
.mainImage #slider li img {
	max-width: 100%;
	min-width: 1000px;
	width: 100%;
	height: auto;
}

/*トップメニュー*/
#topMenu {
	background: #ffeeea;
	top: 104px;
	min-height: 64px;
	height: 64px;
}

#topMenu_outer {
	background: none;
	margin: 0 auto;
}

#topMenu .topMenu li {
	padding: 0;
	box-sizing: border-box;
	background: none;
}

#topMenu .topMenu li a {
	width: auto;
	font-size: 16px;
	letter-spacing: 0.05em;
	background: none;
	font-weight: bold;
}


/*----------------- コンテンツ -----------------*/
/*レイアウト*/
html {
	scroll-behavior: smooth;
}

div#contents {
	background: #eef5f7;
}

div#pankuz {
	width: 1000px;
	margin: 24px auto;
}

.mainArticles .article {
	padding-bottom: 0px;
	border-bottom: none;
}

.article.max {
	margin: 0;
	padding: 24px 0;
	background: #17a2b8;
}

.mainArticles .article.zero_margin,
.mainArticles .gallery.zero_margin {
	margin-bottom: 0;
	padding-bottom: 0;
}

.mainArticles .article.zero_margin .article_body,
.mainArticles .gallery.zero_margin .article_body {
	border-radius: 16px 16px 0 0;
	padding-bottom: 0;
}

.mainArticles .article.no_border,
.mainArticles .gallery.no_border {
	margin-top: 0;
	padding-top: 0;
}

.mainArticles .article.no_border .article_body,
.mainArticles .gallery.no_border .article_body {
	border-radius: 0 0 16px 16px;
	padding-top: 0;
}

.mainArticles .article.zero_margin.no_border .article_body,
.mainArticles .gallery.zero_margin.no_border .article_body {
	border-radius: 0;
}


.article p {
	margin-bottom: 16px;
}

#mainContents,
#footer_outer,
#mainArticles,
.mainArticles .article,
.mainArticles div.gallery {
	width: 100%;
	min-width: 1000px;
	margin-bottom: 48px;
}

#title_outer,
div#title_body,
div.article_body,
div#footer_body,
#topMenu_outer,
#topMenu_body,
#topMenu .topMenu,
#mainTopics,
#listTopics {
	width: 1000px;
	min-width: 1000px;
	margin: 0 auto;
}

#mainArticles h2,
#mainServices h2,
#mainTopics h2,
#listTopics h2 {
	width: 1000px;
	min-width: 1000px;
	margin: 0 auto 1.5em;
}

.mainArticles .article.max .article_body,
.mainArticles .article.max .article_body .image,
.mainArticles .article.max .article_body img {
	width: 100%;
	min-width: 800px;
}

.article_body {
	padding: 24px;
	box-sizing: border-box;
	border-radius: 16px;
}

/*字詰め*/
#name,
h2,
h3,
h4,
h5,
h6,
.article.concept {
	font-feature-settings: "palt";
}

/*大見出し*/
#mainArticles h2,
#listTopics h2 {
	margin-bottom: 40px;
	padding-bottom: 24px;
	text-align: center;
	font-size: 30px;
	font-weight: bold;
	color: #1D94C6;
	border-bottom: none;
	letter-spacing: 0;
	line-height: 1;
	border-bottom: #1D94C6 2px solid;
}

/*小見出し*/
.mainContents .article h3,
.mainContents div.gallery h3,
#mainServices h2,
#mainTopics h2 {
	margin: 8px 0 24px;
	font-size: 28px;
	color: #282768;
	border-bottom: none;
	line-height: 1.25;
	padding: 24px 16px 24px 0;
	background: none;
	font-weight: bold;
	letter-spacing: 0;
	text-align: center;
	display: inline-flex;
	flex-wrap: wrap;
	flex-direction: column;
	margin: 0 auto;
	width: 100%;
}

.mainContents .article h3:after,
.mainContents div.gallery h3:after,
#mainTopics h2:after {
	content: "";
	margin: 20px auto;
	height: 2px;
	width: 30%;
	background-image: linear-gradient(to right, rgba(0, 0, 0, 0), rgba(163, 255, 175, 0.025) 1%, rgba(163, 255, 175, 0.05) 2%, rgba(163, 255, 175, 0.1) 3%, rgba(163, 255, 175, 0.2) 5%, rgba(30, 149, 198) 35%, rgba(98, 131, 145) 50%, rgba(30, 149, 198) 65%, rgba(163, 255, 175, 0.3) 95%, rgba(163, 255, 175, 0.1)97%, rgba(163, 255, 175, 0.05) 98%, rgba(163, 255, 175, 0.25) 99%, rgba(0, 0, 0, 0));
	border-radius: 20px;
}

.article h3 a,
.article h3 a:hover {
	color: #282768;
	text-decoration: none;
}

/*見出し4*/
.article h4 {
	font-size: 20px;
	padding: 8px 20px;
	background: #1D94C6;
	border-radius: 1px;
	margin-bottom: 1em;
	color: #FFF;
	display: flex;
}

/*見出し5*/
.article h5 {
	padding: 0;
	padding-left: .75em;
	border-bottom: none;
	margin: 0 0 1em;
	font-weight: bold;
	font-size: 18px;
	color: #282768;
	line-height: 2;
	letter-spacing: 0.1em;
	border-left: solid 4px #1D94C6;
}

.article.max h5 {
	margin: 0 0 1em;
}

/*見出し6*/
.article h6 {
	font-size: 16px;
	background: none;
	display: flex;
	padding: 4px 8px;
	margin-bottom: 1em;
	justify-content: left;
	align-items: baseline;
	border-bottom: solid 1px #1D94C6;
}

.article h6:before {
	content: "▲";
	transform: rotate(90deg) scale(0.75);
	color: #1D94C6;
	font-weight: bold;
	margin-right: 8px;
}

/*見出し幅調整*/
.article.max h3,
.article.max h4,
.article.max h5,
.article.max h6,
.article.max p {
	width: 1000px;
	min-width: 1000px;
	margin-right: auto;
	margin-left: auto;
}

/*最新情報*/
#mainTopics {
	padding-bottom: 16px;
	margin: 80px auto 120px;
	border: solid 4px #1D94C6;
}

.mainTopics .topics {
	border-bottom: none;
}

#mainTopics .topics li .thumb,
#mainTopics .topics li .thumb img {
	max-width: 100px;
	max-height: 100px;
}

#mainTopics .topics li .date,
.mainTopics .topics li .date {
	font-size: 16px;
	color: #282768;
}

#mainTopics .topics h3,
.mainTopics .topics li h3 {
	font-size: 18px;
}

.mainTopics .topics li h3 a {
	text-decoration: underline;
}

#mainTopics .topics .description,
.mainTopics .topics li .description {
	font-size: 16px;
	color: #222;
	margin-top: 0px;
}

#mainTopics .topics li .more a,
.mainTopics .topics li .more {
	padding: 8px 16px;
	font-size: 16px;
	font-weight: bold;
	color: #fff;
}

.mainTopics .topics li .more a {
	border: none;
	background: rgb(142, 161, 221);
	/* background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgba(126, 145, 203, 1) 100%); */
	background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgb(79 102 173) 100%);
	padding: 4px 14px;
	border-radius: 4px;
	color: #fff;
	padding: 8px 16px;
	box-shadow: 0 2px 0 #7a78cd;
}

.mainTopics .topics li .more a:hover {
	border: none;
	color: #FFF;
	opacity: 0.8;
}

.mainTopics .topics {
	width: 100%;
	min-width: 1000px;
	padding: 0;
	margin: 0px 0 15px;
}

.mainTopics .topics li {
	padding: 40px 0px;
	font-size: 16px;
}

#mainTopics .listview a {
	background: none;
	padding-left: 0;
	text-decoration: none;
	letter-spacing: 0.1em;
	font-size: 16px;
}


/*サブメニュー*/
#mainServices h2 {
	margin-bottom: 0;
}

#mainServices .services {
	width: 100%;
	min-width: 1000px;
	padding: 0;
	margin: 0 auto;
	border-bottom: 1px solid #e9e9e9;
}

.mainServices .services li {
	width: 456px;
	padding: 16px;
	border-bottom: dotted 1px #ddd;
	float: left;
}

.mainServices .services li:last-child {
	border-bottom: none;
}

.mainServices .service h3 {
	width: auto;
	overflow: hidden;
	margin-bottom: 12px;
	font-size: 18px;
	font-weight: normal;
}

.mainServices .service .description {
	width: 70%;
	margin-bottom: 16px;
	overflow: hidden;
	font-size: 14px;
	/* display: none; */
}

.mainServices .service .more a {
	background-image: none;
	background-repeat: none;
	width: 24%;
	height: 32px;
	text-indent: 0;
	display: block;
	float: right;
	font-size: 14px;
	color: #fff;
	background: #fec5cc;
	text-align: center;
	line-height: 32px;
	border-radius: 3px;
}

.mainServices .service .more a:hover {
	background: #8155b7;
}

/*リスト*/
.article ul,
.article ol {
	margin-bottom: 1em;
}

/*チェック*/
ul.check {
	list-style: outside none;
	line-height: 2;
	padding-left: 2.5em;
	margin-bottom: 1em;
}

ul.check li {
	position: relative;
	font-weight: normal;
	margin: 0 3em 0 0;
	line-height: 1.5;
	padding: .25em 0 .5em;
}

ul.check li strong {
	font-family: "Yu Gothic M";
}

ul.check li::before {
	display: block;
	content: '';
	position: absolute;
	top: 0.4em;
	left: -2em;
	width: 0.9em;
	height: 0.5em;
	border-left: 4px solid #ff8787;
	border-bottom: 4px solid #fec5cc;
	-webkit-transform: rotate(-45deg);
	transform: rotate(-45deg);
}

/*FAQ*/
ul.faq li.qus,
ul.faq li.ans {
	display: block;
	margin-bottom: 20px;
	padding-left: 45px;
}

ul.faq li.qus::before,
ul.faq li.ans::before {
	border-radius: 4px;
	color: #A296AF;
	display: inline-block;
	height: 32px;
	line-height: 32px;
	margin: 0 8px 0 -40px;
	text-align: center;
	width: 32px;
}

ul.faq li.qus::before {
	content: "Q";
	border: solid 1px #A296AF;
}

ul.faq li.ans::before {
	background-color: #A296AF;
	color: #fff;
	content: "A";
}

/*症状リスト*/
ul.symptoms {
	background: #A0DDA8;
	border-radius: 4px;
	padding: .5em 1em;
	margin-bottom: 1em;
	width: auto;
	display: flow-root;
}

ul.symptoms li {
	display: inline-block;
	margin-right: 1em;
	margin-left: 1em;
	font-weight: bold;
}

ul.symptoms li:before {
	content: "●";
	margin-left: -1em;
	font-family: sans-serif;
	color: #358f41;
}


ul.glaucoma {
	background: #fbf9f3;
	border-radius: 4px;
	padding: .5em 1em;
	margin-bottom: 1em;
	width: auto;
	display: flow-root;
}

ul.glaucoma li {
	display: inline-block;
	margin-right: 1em;
	margin-left: 1em;
}

ul.glaucoma li:before {
	content: "〇";
	margin-left: -1em;
	font-family: sans-serif;
	color: #fec5cc;
	font-weight: bold;
	transform: none;
}

/*写真*/
.image {
	border-radius: 4px;
}

.mainArticles .article_right .image {
	margin: 0 0 1em 24px;
}

.mainArticles .article_left .image {
	margin: 0 24px 1em 0;
}

.mainArticles .article img {
	margin-bottom: 0;
}

.mainArticles .article .article_body.article_center .image,
.mainArticles .article .article_body.article_center img {
	max-width: 100%;
	width: auto;
}

.mainArticles .article .article_body.article_center .image {
	margin: 0 auto 1em;
}

.mainArticles .article_left .image,
.mainArticles .article_right .image,
.mainArticles .article_right img,
.mainArticles .article_left img {
	max-width: 480px;
	width: auto;
}

.mainArticles .article.mini .article_left .image,
.mainArticles .article.mini .article_right .image,
.mainArticles .article.mini .article_right img,
.mainArticles .article.mini .article_left img {
	max-width: 320px;
	width: auto;
}

.mainArticles .article.sita .article_body {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	flex-direction: column;
}

.mainArticles .article.sita .article_body .image {
	order: 1;
}

.mainArticles .article.sita img {
	max-width: 320px;
	max-height: 320px;
	width: auto;
}

/*ギャラリー*/
.comment {
	text-align: center;
	font-weight: bold;
	font-feature-settings: "palt";
}

.gallery_grid li.galleryGrid .galleryGrid_outer {
	padding: 4px;
}

.gallery.example .galleryGrid_body {
	box-sizing: border-box;
}

.gallery.example .comment {
	border-top: solid 4px #17a2b8;
	font-weight: normal;
	line-height: 1.25;
}

.gallery.menu .comment {
	background: #fec5cc;
	color: #fff;
	padding: 8px 0;
}

.gallery_grid li.galleryGrid .image {
	margin-bottom: 0;
}

/*map*/
.article.map iframe {
	width: 50% !important;
	height: 454px !important;
}

/*コンセプト*/
.article.concept {
	letter-spacing: 2px;
	font-size: 120%;
	background: #f9f7f4;
	padding: 40px 0;
}

/*----------------- テーブル関連 -----------------*/
/*デフォルトテーブル*/
.article table:not(.contactTable) {
	border-collapse: collapse;
	border-left: 1px solid #ccc;
	border-spacing: 0;
	border-top: 1px solid #ccc;
	margin: 10px auto;
}

.article table:not(.contactTable) td,
.article table:not(.contactTable) th {
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
	height: auto;
	padding: 10px;
	box-sizing: border-box;
}

.article table:not(.contactTable) th {
	background-color: #f7f7f7;
	text-align: center;
}

/*ノーマルテーブル*/
#contents table.normalTbl {
	border: none;
	background: none;
	border-collapse: collapse;
	border-spacing: 0;
	margin: 1em auto;
	width: 100%;
}

#contents table.normalTbl th {
	border: none;
	background: none;
	border-bottom: 2px solid #1D94C6;
	color: #423929;
	height: auto;
	width: 25%;
	line-height: 150%;
	padding: 16px;
	text-align: left;
	vertical-align: middle;
	white-space: nowrap;
	background: none;
}

#contents table.normalTbl td {
	border: none;
	background: none;
	border-bottom: 2px solid #ccc;
	height: auto;
	line-height: 150%;
	padding: 16px;
}

#contents table.normalTbl thead th {
	width: auto;
	background: #bbbcde;
	color: #fff;
	border-right: solid 2px #fff;
}

#contents table.normalTbl.ex td:nth-child(3) {
	text-align: right;
	width: 10%;
}

#contents table.normalTbl.ex td:nth-child(4) {
	text-align: center;
	width: 20%;
}


/*診療時間*/
#contents .table {
	width: 100%;
	margin-bottom: 1rem;
	color: #212529;
	border: none;
	margin: 20px auto;
	width: fit-content;
}

#contents .table td,
#contents .table th {
	border: none;
	padding: 6px 16px;
	vertical-align: top;
	border-top: 1px solid #A296AF;
	background: none;
}

#contents .table thead th {
	border: none;
	vertical-align: bottom;
	border-bottom: 1px solid #A296AF;
	background: none;
}

#contents .table tr th:first-of-type {
	border-right: solid 1px #A296AF;
}

#contents .table tbody tr:last-of-type th,
#contents .table tbody tr:last-of-type td {
	border-top: solid 1px #A296AF;
	border-top: none;
}

#contents .table tbody td {
	text-align: center;
}

/*診療時間*/
#contents table.time,
.about table.time {
	width: 100%;
	border: none;
}

#contents table.time {
	margin-bottom: 1em;
}

#contents table.time th,
.about table.time th {
	background: #1D94C6;
	border: none;
	border-right: solid 1px #fff;
	border-bottom: solid 1px #fff;
	color: #fff;
}

#contents table.time td,
.about table.time td {
	text-align: center;
	border-right: solid 1px #f5f5f5;
	border-bottom: solid 1px #f5f5f5;
	background: #FFF;
}

/* 表組フロー */
table#flowTbl {
	border-collapse: collapse;
	border-spacing: 0;
	border: none;
	margin: 0 auto 1em;
	width: 100%;
}

#flowTbl td {
	border-radius: 6px;
	display: block;
	height: auto;
	margin-bottom: 56px;
	padding: 30px 40px;
	position: relative;
	color: #282768;
	background: #d8d2df;
	border: none;
}

#flowTbl td h4 {
	background: none;
	padding: 0;
	color: #A296AF;
}

#flowTbl td::after {
	color: #A296AF;
	content: "▼";
	font-family: monospace;
	font-size: 48px;
	left: 0;
	right: 0;
	top: 90%;
	bottom: auto;
	position: absolute;
	text-align: center;
	transform: scaleY(0.5);
}

#flowTbl tr:last-child td::after {
	display: none;
}

#flowTbl td strong {
	color: #A296AF;
	display: block;
	font-size: 130%;
	font-weight: bold;
}

/*フロー2*/
.article table.articleFlow {
	width: 100%;
	border: none;
}

.article table.articleFlow td {
	border: 4px solid #A296AF;
	border-radius: 8px;
	display: block;
	height: auto;
	margin-bottom: 56px;
	padding: 20px 40px;
	position: relative;
}

.article table.articleFlow td img {
	margin: auto;
	display: block;
}

.article table.articleFlow td:after {
	content: "";
	position: absolute;
	top: 100%;
	left: 50%;
	transform: translateX(-50%);
	border-top: 20px solid #A296AF;
	border-right: 30px solid transparent;
	border-left: 30px solid transparent;
}

.article table.articleFlow td.last {
	border: none;
}

.article table.articleFlow td.last:after {
	content: none;
}

.article table.articleFlow td div {
	float: left;
	width: 100%;
	display: contents;
}

.article table.articleFlow td img {
	float: left;
}


/*記事フロー*/
.mainArticles .article.articleFlow {
	position: relative;
	margin: 66px auto;
	overflow: visible;
}

.mainArticles .article.articleFlow .article_body {
	border-radius: 10px;
	display: block;
	position: relative;
	box-sizing: border-box;
	padding: 30px;
	overflow: visible;
	color: #282768;
	background: #d8d2df;
}

.mainArticles .article.articleFlow.first {
	margin-top: 0px;
}

.mainArticles .article.articleFlow::after {
	content: "";
	display: block;
	width: 22px;
	height: 22px;
	border-right: 3px solid #282768;
	border-bottom: 3px solid #282768;
	position: absolute;
	left: 50%;
	bottom: -40px;
	margin-left: -11px;
	-webkit-transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-o-transform: rotate(45deg);
	transform: rotate(45deg);
	box-sizing: border-box;
}

.mainArticles .article.articleFlow.last::after {
	display: none;
}

.mainArticles .article.articleFlow h6 {
	font-size: 22px;
	text-align: left;
	line-height: 1.4;
	color: #282768;
	margin: 0.8em 0 0.8em 0.2em;
	position: relative;
	padding: 0;
	display: block;
	border-bottom: none;
}

.mainArticles .article.articleFlow h6::first-letter {
	color: #282768;
	font-weight: bold;
	font-size: 150%;
	margin-right: 0.3em;
	padding-right: 10px;
}

.mainArticles .article.articleFlow h6:before {
	display: none;
}

.mainArticles .article.articleFlow img {
	margin-bottom: 15px;
	max-width: 260px;
}

/* 問い合わせフォーム */
p.envelope {
	padding: 1em;
	box-sizing: border-box;
	border: 4px solid #fec5cc;
	text-align: center;
}

#article_contact,
#article_company {
	width: 1000px;
	padding: 0px;
	background-color: #fff;
	border: none;
}

table.contactTable {
	border-collapse: collapse;
	border-spacing: 0;
	border-left: none;
	border-top: none;
	border-bottom: none;
	margin: 16px auto;
	width: 1000px;
}

table.contactTable tr th {
	border-bottom: 1px solid #fec5cc;
	border-right: none;
	color: #fec5cc;
	background-color: none;
	height: auto;
	line-height: 150%;
	padding: 16px;
	text-align: left;
	vertical-align: middle;
	width: 30%;
}

table.contactTable td {
	border-bottom: 1px solid #CCC;
	border-right: none;
	height: auto;
	line-height: 150%;
	padding: 20px 30px;
}

table.contactTable label input {
	margin-left: 10px;
	margin-right: 5px;
	border: 0px;
}

table.contactTable input.textField {
	border: solid 1px #999;
	width: 100%;
}

table.contactTable .textField {
	width: 100%;
	font-size: 16px;
}

table.contactTable tr.must th {
	background-position: 95% center;
	background-repeat: no-repeat;
	padding: 0 40px 0 16px;
}

table.contactTable select {
	font-size: 100%;
	width: 100%;
}

table.contactTable label {
	font-size: 100%;
	width: 100%;
	display: inline-block;
}

table.contactTable input.button {
	background-image: none;
	background-color: #fec5cc;
	border: solid 1px #fec5cc;
	color: #fff;
	display: block;
	font-size: 16px;
	height: 50px;
	letter-spacing: 5px;
	margin: 0 10% 0 25%;
	outline: none;
	width: 20%;
	padding: 8px 0;
	border-radius: 6px;
	float: left;
}

table.contactTable input.button:hover {
	background-image: none;
	background-color: #fff;
	border: solid 1px #fec5cc;
	color: #fec5cc;
	cursor: pointer;
}

table.contactTable input[type="button"] {
	background-image: none;
	background-color: #ccc;
	border: none;
	color: #525252;
	display: block;
	font-size: 16px;
	height: 50px;
	letter-spacing: 5px;
	margin: 0 25% 0 0;
	outline: none;
	width: 20%;
	padding: 8px 0;
	border-radius: 6px;
	float: left;
}

table.contactTable input[type="button"]:hover {
	background-image: none;
	background-color: #525252;
	color: #fff;
	cursor: pointer;
}

.contact-note {
	font-size: 12px;
}

#article_contact_ext {
	font-size: 14px;
	border: none;
}

table.contactTable .th_headline {
	font-weight: bold;
	color: #fff;
	background: #fec5cc;
	border: none;
	text-align: center;
}

.validator-form .validator-valid {
	background-color: #e9fff1;
}

.validator-form .validator-field.validator-invalid {
	background-color: #ffeaea;
}

/*確認画面*/
form.ams-form-submit.validator-form {
	padding: 0 4%;
}

/*個人情報保護方針*/
ol.pp {
	padding-left: 1.55em;
}

ol.pp li {
	list-style-type: decimal;
	padding: 5px;
}

ul.notes {
	list-style-type: none;
	margin-left: 1em;
}

ul.notes li::before {
	content: "◆";
	margin-left: -1em;
	font-family: sans-serif;
}

ul.ps {
	list-style-type: none;
	margin-left: 1em;
}

ul.ps li::before {
	content: "※";
	margin-left: -1em;
	font-family: sans-serif;
}

ul.maru {
	list-style-type: none;
	margin-left: 1em;
}

ul.maru li::before {
	content: "●";
	margin-left: -1em;
	font-family: sans-serif;
}

ul.marumaru {
	list-style-type: none;
	margin-left: 1em;
}

ul.marumaru li::before {
	content: "○";
	margin-left: -1em;
	font-family: sans-serif;
}

/*サイド*/
#sideContents {
	color: #5f3f32;
	background: #A0DDA8;
}

.sideServices h2,
.sideMobile h2 {
	font-size: 16px;
}

.sideMobile h2 {
	padding: 20px 0 20px 45px;
}

.sideMobile p {
	font-size: 14px;
}

.sideBlogCategories h2,
.sideBlogDates h2 {
	font-size: 1em;
	color: #5f3f32;
}

.sideBlogCategories a,
.sideBlogDates a {
	padding: 0 15px;
	font-size: 1em;
}

div#sideBlogCategories {
	width: 34%;
	float: left;
}

div#sideBlogDates {
	width: 32%;
	float: left;
}

#sideContact {
	bottom: 0;
}

.sideServices ul li a {
	padding: 12px 15px 10px 27px;
	font-size: 16px;
}

.sideServices ul li a,
.sideBlogCategories a,
.sideBlogDates a {
	color: #5f3f32;
	font-weight: normal;
}

.sideServices ul li a:hover,
.sideBlogCategories a:hover,
.sideBlogDates a:hover {
	color: #5f3f32;
	font-weight: bold;
}

#sideBanners li img {
	width: auto !important;
	max-width: 240px;
	padding: 0;
}

/*自由HTML*/

.sideBlogCategories h2:before,
.sideBlogDates h2:before {
	background: none;
}

.sideBlogCategories h2:before,
.sideBlogDates h2:before,
.sideBlogCategories h2:after,
.sideBlogDates h2:after {
	content: none;
}

/*フッタ*/
#footer {
	background: url(/materials/172749065059801.jpg) no-repeat center center;
	background-size: cover;
	background-attachment: fixed;
}

.footer li a,
.footer * {
	font-size: 16px;
	color: #fff;
	font-weight: normal;
}

#sideContents_outer {
	width: 1000px;
	min-width: 1000px;
	padding: 30px 0;
}

.footer .topMenu {
	width: 88%;
	text-align: center;
	margin: 0 auto;
	display: flex;
	gap: 20px;
	justify-content: center;
}

.footer li {
	width: auto;
	margin: 0;
}

.footer .copyright {
	text-align: center;
}

.box2 {
	padding: 0.5em 1em;
	margin: 2em 0;
	font-weight: bold;
	color: #fec5cc;
	/*文字色*/
	background: #FFF;
	border: solid 3px #fec5cc;
	/*線*/
	border-radius: 10px;
	/*角の丸み*/
}

.box2 p {
	margin: 0;
	padding: 0;
}



.badgeList {
	display: flex;
	flex-wrap: wrap;
	align-items: center;
	justify-content: center;
	gap: 8px;
}

.badgeList>* {
	background: rgb(142, 161, 221);
	background: linear-gradient(90deg, rgba(142, 161, 221, 1) 0%, rgba(126, 145, 203, 1) 100%);
	background: #1D94C6;
	border: solid 2px #1D94C6;
	padding: 4px 14px;
	border-radius: 3px;
	color: #fff;
	font-weight: bold;
	box-sizing: border-box;
}

.badgeList + * {
	text-align: center;
}

p:has(+.badgeList) {
	text-align: center;
}

.tableList {
	display: flex;
	flex-wrap: wrap;
	border-collapse: collapse;
}

.tableList>* {
	padding: 4px 14px;
	border: solid 1px #ccc;
}

.ul>* {
	margin-left: 1.5em;
	list-style-type: disc;
}



ol.merit {
	counter-reset: number;
	list-style-type: none;
	padding: 0.5em;
}

ol.merit li {
	position: relative;
	padding-left: 30px;
	line-height: 1.5em;
	padding: 0.5em 0.5em 0.5em 30px;
}

ol.merit li:before {
	position: absolute;
	counter-increment: number;
	content: counter(number);
	display: flex;
	justify-content: center;
	background: #358f41;
	color: white;
	font-family: 'Avenir', 'Arial Black', 'Arial', sans-serif;
	font-weight: bold;
	font-size: 15px;
	border-radius: 50%;
	left: 0;
	width: 25px;
	height: 25px;
	line-height: 25px;
	text-align: center;
	top: 0.8em;
}



/*-------------------------------------------
* フッターサイド
-------------------------------------------*/
.side {
	overflow: hidden;
	padding: 20px;
	background: #FFF;
	box-sizing: border-box;
	line-height: 1.5;
	font-size: 1rem;
	color: #282768;
}

.side-text_l {
	float: left;
	width: 45%;
}

.side-text_r {
	float: right;
	width: 55%;
}

.side-text .side-text_r {
	text-align: center;
}

.shop-title {
	padding-bottom: 0px;
	font-size: 14px;
}

.side-logo {
	text-align: center;
}

.side-logo img {
	max-width: 400px;
}

.shop {
	padding-bottom: 10px;
	font-weight: bold;
	font-size: 18px;
}

.add {
	padding: 10px 0;
}

.address {
	text-align: center;
}

.tel {
	font-size: 40px;
	font-weight: bold;
	text-align: center;
	margin-top: 0;
	color: #1D94C6;
}

.time {
	line-height: 1.6em;
	padding-top: 5px;
	padding-bottom: 5px;
}

.side table.time {
	border-collapse: collapse;
}


/*マーカー*/
span[style*="Lime"] {
	background-color: transparent !important;
	background: linear-gradient(transparent 70%, #dbd0e6 0) repeat scroll 0 0;
}

span[style*="Yellow"] {
	background-color: transparent !important;
	background: linear-gradient(transparent 70%, #FEA 0) repeat scroll 0 0;
}



.mainArticles .article.bg {
	margin-top: 15px;
	background: #A0DDA8;
	margin-bottom: 2em;
	margin-right: 0;
	margin-left: 0;
	padding-top: 1em;
	padding-bottom: 1em;
	padding-right: 30px;
	padding-left: 35px;
	box-sizing: border-box;
}

.mainArticles .article.bg .article_body {
	position: relative;
}

.mainArticles .article.flowCardArticle {
	overflow: visible;
	position: relative;
}

.mainArticles .article.flowCardArticle .article_body {
	display: flex;
	justify-content: space-between;
}

.m-auto {
	margin: auto;
}

.card {
	background: #FFF;
	padding: 20px;
	box-shadow: 0 3px 30px rgba(29, 148, 198, .3);
	display: flex;
	flex-direction: column;
	margin-bottom: 20px;
	width: -webkit-fill-available;
}

.sm {
	font-size: 0.9em;
}

.flex {
	display: flex;
}

.flex2col {
	justify-content: space-between;
	gap: 10px;
}

.flex2col>* {
	width: auto;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

/*-------------------------------
* ヘッダーカスタム
-------------------------------*/
#wrap {
	padding-top: 160px;
}

#wrap #title {
	position: fixed;
	top: 20px;
	z-index: 100;
	height: auto;
	display: flex;
	justify-content: start;
	align-items: center;
	width: 100%;
	height: 140px;
	background: none;
	/* box-shadow: 0 3px 30px rgba(125, 139, 200, .3); */
}

#title_outer {
	width: 1100px;
	min-width: 900px;
	margin: auto;
	position: relative;
	height: 140px;
	display: flex;
	align-items: center;
	background: #FFF;
	box-shadow: 0 3px 30px rgba(125, 139, 200, .3);
	border-radius: 8px;
}

div#title_body {
	width: auto;
	min-width: auto;
	display: inline-block;
	height: auto;
	margin: 0;
	/* position: absolute; */
	/* left: 20px; */
	padding: 0px;
}

#wrap #title .description {
	display: none;
}

h1 a {
	display: block;
	width: 384px;
	background: url(/materials/174522096971601.png) left center no-repeat;
	height: 60px;
	background-size: 384px;
}

h1 a:hover {
	opacity: 0.8;
}

#topMenu {
	background: #ffeeea;
	top: 20px;
	left: 455px;
	right: unset;
	min-height: unset;
	height: unset;
	width: auto;
	box-sizing: border-box;
	position: fixed;
	z-index: 101;
	width: 100%;
}

#topMenu_outer {
	width: auto;
	min-width: auto;
	position: relative;
	width: 1000px;
	margin: 0 auto;
}

/* #topMenu_body, */
#topMenu .topMenu {
	width: auto;
	min-width: auto;
	margin: 0;
	position: absolute;
	/* left: 320px; */
	left: 0;
	height: 110px;
	display: flex;
	justify-content: center;
	align-items: center;
}

#topMenu .topMenu li {
	width: auto;
	height: 50px;
	display: flex;
	justify-content: center;
	align-items: center;
}

#topMenu .topMenu li a {
	line-height: normal;
	padding: 8px;
	color: #1D94C6;
}

#topMenu .topMenu li a:hover {
	color: A0DDA8;
}

#mainImage {
	margin-top: -150px;
	/* height: 100vh; */
}

div#mainImage_outer {
	max-width: 1008px;
	width: 100%;
	margin: 0 auto;
}

div#mainImage_outer,
div#mainImage_body {
	height: 100%;
}

.mainImage img,
.mainImage #slider li img {
	max-width: unset;
	min-width: unset;
	object-fit: cover;
	height: 100%;
	width: 100%;
	object-position: bottom right;
}



/*編集画面*/
body.ams-build #title,
body.ams-build #topMenu {
	position: static !important;
	min-height: 50px;
}

body.ams-build #mainImage {
	margin-top: 0;
}

body.ams-build #wrap {
	padding-top: 0 !important;
}

/*修正*/
#mainImage {
	margin-top: 0;
}

#topMenu {
	/* left: 50%; */
	/* transform: translateX(-50%); */
	top: 140px;
	background: rgba(255, 255, 255, 0.8);
	left: 0;
}

#topMenu .topMenu {
	position: static;
	height: auto;
}

#wrap #title {
	background: rgba(255, 255, 255, 0.8);
	background: #A0DDA8;
	top: 0;
}

#title_outer {
	box-shadow: unset;
	background: unset;
	background: url("/materials/174953921968801.png") no-repeat right center;
	background-size: 650px;
}

#topMenu .topMenu li {
	width: calc(100% / 5);
}

#wrap {
	padding-top: 190px;
}

.mainImage #slider li {
	height: auto !important;
}




.article.information .article_body{
	padding: 40px;
	margin: 80px auto 0px;
    border: solid 4px #1D94C6;
	border-radius: 0;
}
.mainContents .article.information h3{
	padding-top: 0;
}
.article table.topicsTable {
	width: 100%;
	margin: 0 auto;
	border-left:unset;
}

.article table.topicsTable td{
	border-right:unset;
	border-bottom:1px dashed #CCC;
}

.article table.topicsTable tr:last-child td{
	border-bottom-style:solid;
}