@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Outfit:wght@100..900&display=swap');

html {
	scroll-behavior: smooth;
}

body {
	margin: 0;
	padding: 0;
	font-family: "Noto Sans JP", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
	color: #222;
}
img {
	vertical-align: top;
}
*, *::before, *::after {
	box-sizing: border-box;
}


/* -----------------------------------------------
   Header
-------------------------------------------------- */
header {
	width: 1100px;
	margin: 0 auto;
	padding: 13px 0 5px;
}

h1 {
	font-size: 12px;
	margin: 0;
	padding: 0;
	color: #8D8D8D;
	font-weight: normal;
}
div.navWrap {
	display: flex;
	justify-content: space-between;
}
div.logo {
	width: 286px;
	height: 72px;
	margin-top: 7px;
}

nav {
	margin-top: -10px;
}
nav ul {
	margin: 0;
	padding: 0;
	display: flex;
}
nav ul li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}

nav ul:first-of-type {
	align-items: flex-end;
	padding-bottom: .7em;
	justify-content: flex-end;
}
nav ul:first-of-type li {
	font-size: 12px;
	margin-right: 2em;
}
nav ul:first-of-type li:last-of-type {
	margin-right: 0;
}

nav ul:last-of-type {
	padding-top: .5em;
	justify-content: flex-end;
	padding-bottom: 1em;
	border-top: 1px solid #D9D9D9;
	width: fit-content;
}
nav ul:last-of-type li {
	padding: 0 1em;
	border-right: 1px solid #D9D9D9;
}
nav ul:last-of-type li:last-of-type {
	border-right: none;
}

nav ul li a {
	display: block;
	text-decoration: none;
	color: #222;
	font-weight: 600;
	transition: all .3s ease;
}
nav ul li a:hover {
	color: #2F39C8;
}
a.search {
	padding: .5em 2em .7em 3.8em;
	color: #FFF;
	font-size: 16px;
	border-radius: 6px;
	letter-spacing: 1px;
	background-color: #2F39C8;
	position: relative;
	transition: opacity .3s ease;
}
a.search:hover {
	color: #FFF;
	opacity: .7;
}
a.search::before {
	display: block;
	position: absolute;
	width: 20px;
	height: 18px;
	top: calc(50% - 9px);
	left: 35px;
	content: '';
	background-image: url("../images/logo_s_w.png");
	background-size: contain;
	background-repeat:no-repeat;
	
}


/* -----------------------------------------------
   Main Area
-------------------------------------------------- */
main {
	display: block;
	width: 100%;
	margin: 0;
	padding: 0;
	border-top: 1px solid #D9D9D9;
	box-shadow: inset 0px 4px 4px rgba(245,245,245,1);
}


/* メインイメージ
------------------------------------------------------------------- */
div.mainImage {
	width: 1100px;
	margin: 20px auto;
	padding: 15px 0 0 0;
	background: #EDEDED;
	text-align: center;
}
div.mainImage a {
	opacity: 1;
	transition: opacity .3s ease;
}
div.mainImage a:hover {
	opacity: .6;
}

div.mi_v2 {
	width: 1100px;
	margin: 20px auto;
	padding: 10px 0;
	background: #EDEDED;
	text-align: center;
}


/* 地図から選ぶ
------------------------------------------------------------------- */
article.search-map {
	width: 1100px;
	margin: 0 auto;
	padding: 12px;
	background-image: linear-gradient(0deg, rgba(32, 39, 133, 1), rgba(236, 238, 252, 1) 40% 60%, rgba(32, 39, 133, 1));
}
article.search-map section {
	min-height: 580px;
	padding: 20px 30px 30px;
	border: 1px solid #DEDEDE;
	background-color: #FFF;
	background-image: url("../images/area_map_japan.png");
	background-repeat: no-repeat;
	background-size: 398px auto;
	background-position: center 50px;
	position: relative;
}
article.search-map h2 {
	position: relative;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
	
	margin: 0;
	padding: 5px;
	font-size: 1.8em;
	line-height: 1.2;
	z-index: 30;
}
article.search-map h2 span.cap_s {
	font-size: .7em;
}
article.search-map h2 span.cap_s span {
	padding: 0 0 0 3px;
	font-size: 1.5em;
}
article.search-map h2 span.tume {
	margin-left: -12px;
}
article.search-map section::before {
	position: absolute;
	display: block;
	content: '';
	width: 68px;
	height: 77px;
	top: -10px;
	left: -1px;
	background-image: url("../images/area_illust_glass.png");
	background-size: contain;
	background-repeat: no-repeat;
	filter: drop-shadow(3px 3px 3px rgba(160, 160, 160, 0.4));
	z-index: 0;
}
article.search-map section::after {
	position: absolute;
	display: block;
	content: '';
	width: 92px;
	height: 224px;
	top: -20px;
	left: 500px;
	background-image: url("../images/area_illust_man.png");
	background-size: contain;
	background-repeat: no-repeat;
	z-index: 0;
}

article.search-map div.area {
	position: absolute;
	width: 180px;
	padding: 0;
	border: 1px solid #E0E0E0;
	border-top: 3px solid #CCC;
	font-size: 14px;
	background-image: linear-gradient(180deg, rgba(233, 233, 233, 1), rgba(255, 255, 255, 1) 10%);
	z-index: 40;
}
article.search-map div.area-s {
	width: 100px;
}
article.search-map div.area h3 {
	width: 100%;
	margin: 0;
	font-size: 13px;
	font-weight: 600;
	text-align: center;
	padding: 8px 0 10px;
	border: 1px solid #FFF;
}
article.search-map div.area ul {
	width: 100%;
	margin: 0;
	padding: 0 16px 14px;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
article.search-map div.area li {
	width: calc(50% - 2px);
	margin: 0 0 4px;
	padding: 0;
	list-style-type: none;
}
article.search-map div.area-s li {
	width: 100%;
}
article.search-map div.area li.large {
	width: 100%;
}
article.search-map div.area li a {
	display: block;
	position: relative;
	width: 100%;
	padding: 3px 4px 4px 16px;
	border: 1px solid #D7D7D7;
	border-radius: 3px;
	text-decoration: none;
	color: #222;
	font-size: 12px;
	font-weight: 500;
	background-image: linear-gradient(0deg, rgba(240, 240, 240, 1), rgba(255, 255, 255, 1) 100%);
	opacity: 1;
	transition: opacity .3s ease;
}
article.search-map div.area li a.disable {
	opacity: .3;
	pointer-events: none;
}
article.search-map div.area li.large a {
	padding: 3px 0 4px 0;
	text-align: center;
}
article.search-map div.area li a:hover {
	opacity: .5;
}
article.search-map div.area li a::before {
	display: block;
	position: absolute;
	top: 6px;
	left: 6px;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	content: "\f0da";
	color: #868686;
}
article.search-map div.area li.large a::before {
	left: calc(50% - 1.8em);
}
article.search-map div.hkd-thk li.large a::before {
	left: calc(50% - 2.3em);
}

/* 北海道・東北 */
article.search-map div.hkd-thk {
	top: 40px;
	right: 40px;
	border-top: 3px solid #2FB2E2;
}
article.search-map div.hkd-thk li a::before { color: #2FB2E2; }

/* 甲信越 */
article.search-map div.kse {
	top: 160px;
	right: 240px;
	border-top: 3px solid #42C4B1;
}
article.search-map div.kse li a::before { color: #42C4B1; }

/* 関東 */
article.search-map div.knt {
	top: 240px;
	right: 40px;
	border-top: 3px solid #1B92EF;
}
article.search-map div.knt li a::before { color: #1B92EF; }

/* 北陸 */
article.search-map div.hrk {
	top: 120px;
	left: 430px;
	border-top: 3px solid #93C22C;
}
article.search-map div.hrk li a::before { color: #93C22C; }

/* 東海 */
article.search-map div.tki {
	top: 330px;
	right: 240px;
	border-top: 3px solid #AAD966;
}
article.search-map div.tki li a::before { color: #AAD966; }

/* 近畿 */
article.search-map div.knk {
	top: 140px;
	left: 230px;
	border-top: 3px solid #E0B428;
}
article.search-map div.knk li a::before { color: #E0B428; }

/* 中国 */
article.search-map div.cgk {
	top: 160px;
	left: 30px;
	border-top: 3px solid #FB8224;
}
article.search-map div.cgk li a::before { color: #FB8224; }

/* 四国 */
article.search-map div.skk {
	top: 420px;
	right: 440px;
	border-top: 3px solid #F46761; }
article.search-map div.skk li a::before { color: #F46761; }

/* 九州・沖縄 */
article.search-map div.ksh-okn {
	top: 328px;
	left: 130px;
	border-top: 3px solid #F73337;
}
article.search-map div.ksh-okn li a::before { color: #F73337; }


/* メインエリア下段
----------------------------------------------------------- */
div.contentsWrap {
	width: 1100px;
	margin: 30px auto 50px;
	display: flex;
	justify-content: space-between;
}
div.leftBox {
	width: 720px;
}
div.rightBox {
	width: 350px;
}

/* 保険の達人はここが違う */
article.atfirst {
	width: 100%;
	margin: 0 auto;
	padding: 12px;
	background-image: linear-gradient(0deg, rgba(32, 39, 133, 1), rgba(236, 238, 252, 1) 40% 60%, rgba(32, 39, 133, 1));
}
article.atfirst section {
	position: relative;
	padding: 0 10px 10px;
	border: 1px solid #DEDEDE;
	background-color: #FFF;
	
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
}
article.atfirst section h2 {
	margin: 20px 0 25px 130px;
	font-size: 2em;
	font-weight: 600;
}
article.atfirst section h2::before {
	position: absolute;
	display: block;
	content: '';
	width: 92px;
	height: 110px;
	top: -18px;
	left: 30px;
	background-image: url("../images/label_atFirst.png");
	background-size: contain;
	background-repeat: no-repeat;
	filter: drop-shadow(0px 0px 5px rgba(160, 160, 160, 0.5));
	z-index: 0;
}
article.atfirst section dl {
	position: relative;
	margin: 0;
	padding: 30px 30px 35px 50px;
	background: #FCF9F2;
}
article.atfirst section dt {
	font-size: 1em;
}
article.atfirst section dt span {
	font-size: 1.5em;
}
article.atfirst section dd {
	margin-bottom: .6em;
	font-size: 1.5em;
	margin-top: -1.43em;
	margin-left: 3em;
}
article.atfirst section dd:nth-of-type(2),
article.atfirst section dd:nth-of-type(3) {
	margin-top: -1.85em;
}
article.atfirst section dd span {
	font-size: 1.4em;
}
article.atfirst section dd:last-of-type {
	margin-bottom: 0;
}
article.atfirst section dl::after {
	position: absolute;
	display: block;
	content: '';
	width: 100px;
	height: 275px;
	top: -70px;
	right: 28px;
	background-image: url("../images/top_womain_image.png");
	background-size: contain;
	background-repeat: no-repeat;
}
article.atfirst section a {
	position: relative;
	color: #222;
	text-decoration: none;
	transition: opacity .3s ease;
}
article.atfirst section a:hover {
	opacity: .4;
}
article.atfirst section a::after {
	display: block;
	position: absolute;
	top: 9px;
	right: -15px;
	font-size: 16px;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	content: "\f0da";
	color: #F00;
}
article.atfirst section h2 a::after {
	top: 15px;
}

/* よくあるご質問・ニュースリリース */
article.faq,
article.news {
	position: relative;
	width: 100%;
	margin: 30px 0 0;
	padding: 0 0 0 130px;
	box-sizing: border-box;
}
article.faq h2,
article.news h2 {
	margin: 0;
	padding: 20px 0 0;
	font-size: 1.7em;
	font-family: "Noto Serif JP", serif;
	font-optical-sizing: auto;
	font-weight: 600;
	font-style: normal;
}
article.faq ul,
article.news ul {
	margin: 20px 0;
	padding: 0;
	font-size: 1em;
}
article.faq li, 
article.news li {
	position: relative;
	margin: 0;
	padding: .5em 0;
	list-style-type: none;
}
article.faq a,
article.news a {
	color: #222;
	transition: opacity .3s ease;
}
article.faq a:hover,
article.news a:hover {
	opacity: .4;
}
article.faq h2 a,
article.news h2 a {
	position: relative;
	display: inline-block;
    vertical-align: middle;
	margin-bottom: .5em;
	padding-left: 1em;
	font-size: .5em;
	
	font-family: "Noto Sans JP", serif;
	font-optical-sizing: auto;
	font-weight: 400;
	font-style: normal;
}
article.faq h2 a::after,
article.news h2 a::after {
	display: block;
	position: absolute;
	top: 3px;
	left: 0;
	font-size: 14px;
	font-family: "Font Awesome 6 Free";
	font-weight: 900;
	content: "\f0da";
	color: #F00;
}

article.faq::after {
	position: absolute;
	display: block;
	content: '';
	width: 72px;
	height: 172px;
	top: 20px;
	left: 28px;
	background-image: url("../images/top_faq_image.png");
	background-size: contain;
	background-repeat: no-repeat;
}
article.faq li {
	padding-left: 2.5em;
}
article.faq li::before {
	display: block;
	position: absolute;
	top: 9px;
	left: 0;
	padding: 3px 8px 8px;
	font-size: 16px;
	content: "Q";
	background: #1E2087;
	color: #FFF;
	line-height: 1;
}

article.news::after {
	position: absolute;
	display: block;
	content: '';
	width: 103px;
	height: 190px;
	top: 20px;
	left: 0px;
	background-image: url("../images/top_news_image.png");
	background-size: contain;
	background-repeat: no-repeat;
}
article.news li {
	display: flex;
}
article.news li span {
	display: block;
}
article.news li a {
	display: block;
	margin-left: 1.2em;
	line-height: 1.4;
}

/* おすすめ保険ランキング */
article.ranking {
	width: 100%;
}
article.ranking a {
	display: block;
	transition: opacity .3s ease;
}
article.ranking a:hover {
	opacity: .6;
}
article.ranking a img {
	width: 100%;
	height: auto;
}

/* 今月の達人 */
article.pickup {
	width: 100%;
	margin-top: 15px;
}
article.pickup img {
	width: 100%;
	height: auto;
}
article.pickup h2 {
	margin: 0;
	padding: 0;
}
div.tatsujinBox {
	margin: -22px 0 0 0;
	padding: 25px;
	box-sizing: border-box;
	border: 1px solid #D9D9D9;
	background: #FCF9F2;
}
section.photo {
	border: 1px solid #FFF;
}
section.profile {
}
section.profile p {
	font-size: 14px;
	line-height: 1.5;
}
section.profile h3 {
	margin: .6em 0 0;
	padding: 0;
	font-size: 24px;
	font-weight: 400;
}
section.profile h3 span.prefecture {
	display: inline-block;
	vertical-align: middle;
	margin: -2px 0 0 20px;
	padding: 2px 10px 4px;
	font-size: 13px;
	background: #BBB;
	color: #FFF;
	letter-spacing: 1px;
}
section.profile h3 span.hokkaido-tohoku { background: #15B7F1; }
section.profile h3 span.kanto           { background: #0B92F2; }
section.profile h3 span.hokuriku        { background: #9AB53A; }
section.profile h3 span.tokai           { background: #ABE456; }
section.profile h3 span.kinki           { background: #EBBC00; }
section.profile h3 span.chugoku         { background: #FF8200; }
section.profile h3 span.shikoku         { background: #FF5E54; }
section.profile h3 span.kyushu-okinawa  { background: #FA3232; }

section.profile h3 a {
	color: #222;
	transition: opacity .3s ease;
}
section.profile h3 a:hover {
	opacity: .5;
}
section.profile h3 + p {
	margin: .2em 0 0 0;
}
section.profile p.comments {
	margin: 1.2em 0 0;
	padding: 0;
	line-height: 1.7;
	text-align: justify;
	text-justify: inter-ideograph;
}
ul.qualification {
	margin: 1px 0 0 0;
	padding: 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
ul.qualification li {
	width: calc((100% - 1px) / 2);
	margin: 0;
	padding: 8px 0 9px;
	list-style-type: none;
	line-height: 1;
	font-size: 12px;
	color: #FFF;
	background: #6678DC;
	text-align: center;
	border-bottom: 1px solid #FFF;
}
ul.qualification li.hidden {
	opacity: .3;
}


/* -----------------------------------------------
   シェアボタン
-------------------------------------------------- */
div.share {
	width: 1100px;
	margin: 0 auto;
	padding: 12px 0;
}
div.share ul {
	list-style-type: none;
	margin: 0;
	padding: 0;
	display: flex;
}
div.share ul li {
	position: relative;
	margin: 0;
}
div.share ul li:first-of-type {
	margin-right: 10px;
}
div.share ul li:nth-of-type(2) {
	z-index: 10;
}
div.share ul li:nth-of-type(3) {
	margin-left: -10px;
	z-index: 0;
}
div.share ul li:last-of-type {
	margin-left: -10px;
}


/* -----------------------------------------------
   企業広告募集
-------------------------------------------------- */
div.adsBox {
	width: 1100px;
	margin: 0 auto;
	padding: 20px 0;
	border-top: 1px solid #D9D9D9;
}
div.adsBox ul {
	margin: 0;
	padding: 0;
	list-style-type: none;
	
	display: flex;
	justify-content: space-between;
}
div.adsBox ul li {
	width: calc((100% - 80px) / 5);
	height: 60px;
	margin: 0;
	padding: 0;
	border: 1px solid #D9D9D9;
	background: #F0F0F0;
	box-sizing: border-box;
	position: relative;
}
div.adsBox ul li::after {
	display: block;
	position: absolute;
	content: '';
	width: 200px;
	height: 56px;
	border: 1px solid #FFF;
	top: 1px;
	left: 1px;
	pointer-events: none;
}
div.adsBox ul li img {
	width: 200px;
	height: 56px;
}
div.adsBox ul li a {
	transition: opacity .3s ease;
}
div.adsBox ul li a:hover {
	opacity: .6;
}


/* -----------------------------------------------
   Footer
-------------------------------------------------- */
footer {
	width: 1100px;
	margin: 0 auto;
	border-top: 1px solid #D9D9D9;
}
footer ul.fNav {
	margin: 0;
	padding: 1em 0;
	display: flex;
	justify-content: center;
}
footer ul.fNav li {
	margin: 0 1em;
	padding: 0;
	list-style-type: none;
	font-size: 12px;
}

div.fWrap {
	width: 100%;
	padding: 15px 0 0 0;
	border-top: 1px solid #D9D9D9;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}

p.copyright {
	margin: 0;
	padding: 22px 0;
	font-size: 13px;
	text-align: right;
	font-family: "Outfit", serif;
	font-optical-sizing: auto;
	font-weight: 300;
	font-style: normal;
}

footer a {
	color: #222;
	transition: color .2s ease;
}
footer a:hover {
	color: #8C8C8C;
}

div.fWrap a {
	display: block;
	color: #FFF;
	font-weight: bold;
	text-decoration: none;
}
div.fWrap a img {
	width: 206px;
	height: auto;
	transition: opacity .3s ease;
}
div.fWrap a:hover img {
	opacity: .6;
}
