@charset "UTF-8";
/* CSS Document */
	/*
font-family: 'Lato', sans-serif;
	*/
/*************************************************************************************************************************
* reset
*************************************************************************************************************************/
html{ height: 100%; overflow-y: scroll; font-size: 62.5%;}
body{ height: 100%; margin: 0; padding: 0; font-family: "ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro","メイリオ",Meiryo, Osaka,"ＭＳ Ｐゴシック","MS PGothic","sans-serif"; text-align: justify; text-justify: inter-ideograph; -webkit-text-size-adjust: 100%; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
img{ width: 100%; max-width: 100%; height: auto; border: 0; vertical-align: bottom;}
svg{ vertical-align: bottom;}
form{ margin: 0; padding: 0;}
p{ margin: 0; padding: 0;}
a, a:hover{ text-decoration: none; outline: none;}
h1, h2, h3, h4, h5, h6{ margin: 0; padding: 0; font-size: 0; line-height: 0;}
ul, dl, dt, dd{ margin: 0; padding: 0;}
li, ol{ margin: 0; padding: 0; list-style: none;}
table{ border: 0; border-collapse: collapse; border-spacing: 0;}
caption, th{ text-align: left;}
header, nav, main, article, aside, section, footer{ display: block;}
button{ background-color: transparent; border: none; cursor: pointer; outline: none; padding: 0; appearance: none; }
*{ box-sizing: border-box;}
video { border: none; outline: none; filter: drop-shadow(0px 0px #000); }

/**********************************************************
*　追加ベース
**********************************************************/
body.is-fixed {
	/*position: fixed;*/
}

button{
	cursor: pointer;
}

.l-wrapper {
	width: calc(100% - 40px);
	margin-left: auto;
	margin-right: auto;
}

@media screen and (min-width: 681px) {
	
	.l-wrapper { width: 1000px; }
	
}

.sp-only { display: none !important; }
.sp-only-2 { display: none !important; }
.pc-only { display: block !important; }
.pc-only-2 { display: inline-block !important; }

@media screen and (max-width: 680px) {
	
	.sp-only { display: block !important; }
	.sp-only-2 { display: inline-block !important; }
	.pc-only { display: none !important; }
	.pc-only-2 { display: none !important; }
	
}
@media screen and (min-width: 1801px) {
	.no-lpc { display: none; }
}
html, body { scrollbar-width: none; -ms-overflow-style: none; }
body{ height: 100%; font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif; font-weight: 500; color: #333; }
@media print, screen and (min-width:681px) {
	
	body{ min-width: 1200px;}
	
}

/*	iOS Sarafi Hack	*/
_::-webkit-full-page-media,
_:future,
:root .something {  }



/*.aos__overflow--hidden{ overflow: hidden; }*/


.caption{font: 500 12px/16px 'YakuHanJP_Noto', 'Noto Sans JP', sans-serif; margin-top: 10px;}


.btn { display: flex; align-items: center; border-style: solid; border-width: 1px; }
.btn--center { justify-content: center; }

.btn--white { border-color: #fff; }
.btn--detail { display: flex; justify-content: center; align-items: center; width: 280px; height: 54px; background-color: #fff; border-radius: 28px; border-color: #004fa2; margin-left: auto; margin-right: auto; font-size: 1.6rem; font-weight: 700; letter-spacing: 0.2em; color: #000; transition: all 400ms ease; }
.btn--detail:after { width: 9px; height: 14px; background: url("../img/ico_arrow.png") no-repeat 50% 50%/100% auto; transform: rotate(-90deg); margin-left: 80px; content: ""; }
.btn--detail:hover { background-color: #004fa2; color: #fff; }
.btn--detail:hover:after { background-image: url("../img/ico_arrow_white.png"); }


.upper-ttl { font-family: 'Lato', sans-serif; font-size: 1.3rem; font-weight: 700; letter-spacing: 0.2em; }
.main-ttl { font-size: 3.4rem; line-height: 1.35; }
.cont-txt  { font-size: 1.5rem; line-height: 2.14; }
.ttl--blue { background: #004fa2; border-radius: 5px; padding: 5px 15px 7px; font-size: 1.5rem; font-weight: 500; line-height: 1.74; color: #fff; }

@media print, screen and (min-width:681px) {
	.upper-ttl { font-size: 1.5rem; }
	.main-ttl { font-size: 4.5rem; line-height: 1.35; }
	.cont-txt  { font-size: 1.6rem; line-height: 2.2; }
	.ttl--blue { foant-size: 1.6rem; line-height: 1.74; }
}

.ktkn { font-size: inherit; letter-spacing: -0.05em; }

.header { position: fixed; top: 22px; left: 18px; z-index: 500; transition: all 400ms ease; }




/*.header__inner { position: relative; display: flex; justify-content: space-between; align-items: center; height: 60px; padding-left: 18px; padding-right: 10px; z-index: 5; }*/
.header__logo { display: flex; flex-wrap: wrap; align-items: center; z-index: 500; }
.header__logo__img a {  }
.header__logo__img a svg { width: auto; height: 16px; }

.header__logo__fac { position: relative; margin-left: 14px; padding-left: 14px; font-size: 1.6rem; line-height: 24px; }
.header__logo__fac:before { position: absolute; left: 0; top: 0; width: 1px; height: 100%; background-color: rgba(255,255,255,0.5); content: ""; }
.header__logo__txt { width: 100%; margin-top: 10px; font-size: 1.2rem; line-height: 1; }

.header__navtrg { position: fixed; top: 10px; right: 10px; display: flex; flex-direction: column; justify-content: center; align-items: center; width: 40px; height: 40px; background: #ffe600; border-radius: 6px; z-index: 500; }
.header__navtrg__stripes { position: relative; width: 13px; height: 10px; }
.header__navtrg__stripes span { position: absolute; transition: all .4s; width: 100%; height: 1px; background: #333; }
.header__navtrg__stripes span:nth-of-type(1) { top: 0; left: 0; }
.header__navtrg__stripes span:nth-of-type(2) { top: 50%; transform: translateY(-50%); left: 0; }
.header__navtrg__stripes span:nth-of-type(3) { bottom: 0; left: 0; }
.header__navtrg::after { content: "MENU"; margin-top: 5px; font: 500 0.6rem "Roboto", sans-serif; }
.header__navtrg.active::after { content: "CLOSE"; }
.header__navtrg.active .header__navtrg__stripes span { top: 50%; left: 50%; }
.header__navtrg.active .header__navtrg__stripes span:nth-of-type(1) { transform: translate(-50%, -50%) rotate(-45deg); }
.header__navtrg.active .header__navtrg__stripes span:nth-of-type(3) { transform: translate(-50%, -50%) rotate(45deg); }
.header__navtrg.active .header__navtrg__stripes span:nth-of-type(2) { width: 0; }
.header__navtrg.active .header__navtrg::after { content: "CLOSE"; }

.nav.active .header__navtrg__stripes span { }

.header.fac-on .header__logo__img a svg path { transition: .4s; }
.header.fac-on .header__logo__img a svg path { fill: #333 !important; }

/*	図書館2F 基本非表示*/
._for2f { display: none; }
@media print, screen and (max-width:680px) {
	
	.header.active .header__logo__img a svg path { transition: .4s; }
	.header.active .header__logo__img a svg path { fill: #333 !important; }
	
}
.nav { position: fixed; top: 0; right: -100%; display:block; width: 100%; height: 100svh; background: #fff; padding: 0 30px 0; transition: all .4s ease; z-index: 450; }
.nav.active { right: 0; }
.nav__inner { height: calc(100svh - 80px); margin-top: 80px; overflow: scroll; -ms-overflow-style: none; scrollbar-width: none; }
.menu-list { margin-bottom: 40px; }
.menu-list li { border-bottom: 1px solid #ccc; }
.menu-list a { position: relative; display: flex; align-items: center; padding: 14px 35px 14px 15px; font-size: 1.3rem; font-weight: 400; line-height: 1.4; color: #333; text-decoration: none; cursor: pointer; }
.menu-list a::after { position: absolute; top: 50%; transform: translateY(-50%) rotate(45deg); right: 15px; width: 5px; height: 5px; border-top: 1px solid #000; border-right: 1px solid #000; content: ""; }
.item-parent > a::before { margin-right: 5px; font-size: 1.1rem; color: #f15a24; content: '\25CF'; }
.item-child > a { padding-left: 40px; }
.item-child > a::before { position: absolute; left: 24px; top: 50%; transform: translateY(-50%); display: block; width: 10px; height: 1px; background: #f15a24; content: ""; }

@media print, screen and (min-width:681px) {
	.header { top: 46px; left: 40px; }
	.header:after { display: none; }
	.header__inner { width: 100%; height: 120px; margin-left: auto; margin-right: auto; padding-left: 40px; padding-right: 20px; }
	
	.header__logo__img a { transition: .4s; }
	.header__logo__img a:hover { opacity: .75; }
	.header__logo__img a svg { height: 30px; }
	.header__logo__fac { margin-left: 20px; padding-left: 20px; font-size: 2.0rem; line-height: 26px; }
	.header__logo__txt { width: auto; margin-top: 0; margin-left: 30px; }
	.nav { max-width: 440px; }
	
.header__navtrg { top: 30px; right: 20px; width: 60px; height: 60px; border-radius: 8px; }
.header__navtrg__stripes { width: 20px; height: 16px; }
.header__navtrg__stripes span { height: 2px; }
.header__navtrg::after { font-size: 0.8rem; }
	
	.nav { right: -440px; }
	.nav.active { right: 0; }
	.nav__inner { margin-top: 110px; padding-bottom: 60px; }
	
	.menu-list a { transition: .4s; }
	.menu-list a::after { transition: .4s; }
	.menu-list a:hover::after { right: 10px; }
}

@media print, screen and (min-width:1201px) {
	
	
	
}

#sub .header__logo__img a svg path { fill: #333 !important; }




@media screen and (min-width: 681px) {
	
	
}


/**********************************************************
*　常時固定ボタン
**********************************************************/
.fixed-button {
	position: fixed;
	bottom: 0;
	z-index: 10;
	width: 100%;
	opacity: 0;
	transform: translateY(100%);
	transition: 0.5s;
}

.fixed-button__btn a { display: flex; justify-content: center; align-items: center; width: 100%; height: 60px; background-color: #fccf00; transition: 0.4s; font-size: 1.4rem; line-height: 1; color: #000; }
.fixed-button__btn a:hover { background-color: #d8aa1e; }
.fixed-button__btn a:visited,
.fixed-button__btn a:active { color: #000; }


.fixed-button.is-visible { opacity: 1; transform: translateY(0); }

@media screen and (min-width: 681px) {
	.fixed-button {
		bottom: auto;
		top: 50%;
		right: 0;
		transform: translate(100%, -50%);
		width: auto;
	}
	.fixed-button__btn a { width: 66px; height: 310px; border-radius: 10px 0 0 10px; writing-mode: vertical-rl; }
	.fixed-button__btn a:after { width: 7px; height: 10px; background: url("../img/ico_arrow.png") no-repeat 50% 50%/100% auto; margin-top: 20px; content: ""; }

	.fixed-button__btn:not(:last-child) {
		margin-bottom: 10px;
	}

	.fixed-button.is-visible { transform: translate(0, -65%); opacity: 1; }
}

.img__fit{ height: inherit; object-fit: cover; font-family: 'object-fit: cover'; }/*IE・Edge用コード*/


/*************************************************************************************************************************
* slick style
*************************************************************************************************************************/
.sl-dots .slick-dots { bottom: -52px; }
.sl-dots .slick-dots li { margin: 0 4px; }
.slick-dots li { width: 16px; height: 16px; }
.slick-dots li button { width: 10px; height: 10px; background-color: #fff; border: 1px solid #004fa2; border-radius: 50%;  margin: 4px; padding: 0; 
}
.slick-dots li button::before { display: none; }
.sl-dots li.slick-active button { background-color: #004fa2; }



/**********************************************************
*　Common Things
**********************************************************/
#grabbable._cursor { cursor: grab; }
.entire-wrap { position: fixed; width: 100%; height: 100svh; overflow: auto; scrollbar-width: none; -ms-overflow-style: none; user-select: none; }
.entire-wrap::-webkit-scrollbar { display: none; }




.entire-map { position: relative; overflow: hidden; margin: 0 auto; }
.entire-map__bg-wrap { position: relative; z-index: -1; }
.entire-map__bg-wrap::before { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); display: block; width: calc(100% - 4px); height: calc(100% - 4px); border: 2px solid #fff; content: ""; z-index: 10; }
.ani--mph { position: absolute; top: 50%; left: 50%; transform: translate(-50.3%, -49.6%); width: 150%; max-width: none; z-index: 10; pointer-events: none; }
.entire-map__bg { max-width: none; width: auto; height: 100svh; user-select: none; pointer-events: none; }

.obj, .trg { position: absolute; }
.obj img { width: auto; height: 100svh; }

.trg { aspect-ratio: 1/1; }
.trg__label { position: absolute; top: -30px; left: 50%; transform: translateX(-50%) scaleY(0); transform-origin: 50% 100%; transition: transform 0.4s cubic-bezier(0.34, 1.56, 0.64, 1); display: flex; justify-content: center; align-items: center; height: 40px; background: #fff; border: 4px solid #f15a24; border-radius: 20px; padding: 0 12px 2px;font-size: 1.6rem; font-weight: 700; line-height: 1; text-align: center; white-space: nowrap; color: #4d4d4d; transition: .4s; cursor: pointer; z-index: 50; }
.trg__label::before { position: absolute; top: calc(100% + 4px); left: 50%; transform: translateX(-50%); display: block; width: 0px; height: 0px; border-style: solid; border-width: 12px 12px 0 12px; border-color: #F15A24 transparent transparent transparent; content: ""; }
.trg__label._on { transform: translateX(-50%) scaleY(1); }


.trg__btn { position: relative; width: 100%; height: 100%; border: none; cursor: pointer; z-index: 300; }
@media only screen and (max-width: 680px) {
	.trg__label { transform: translateX(-50%) scaleY(0.0); }
	.trg__label._on { transform: translateX(-50%) scale(0.7, 0.7); }
}
@media only screen and (min-width: 681px) {
	.trg__btn:hover+.trg__label { background: #f15a24; color: #fff; }
	.trg__label:hover { background: #f15a24; color: #fff; }
}


/*	Facilities	*/
.fac-wrap { position: fixed; top: 0; left: -100%; display: block; width: 100%; height: 100svh; background: #fff; padding: 0; transition: all .4s ease; z-index: 400; }
.fac-wrap.active { left: 0; }
.fac-scr { display: flex; align-items: center; height: 100%; }
.fac__cont {  }
.fac { display: none; }
.fac.is-shown { display: block; }
.fac__inside { max-height: calc(100svh - 80px); margin-top: 80px; padding: 40px 30px; overflow: auto; -ms-overflow-style: none; scrollbar-width: none; }
.fac__inside::-webkit-scrollbar { display: none; }
.fac__ttl { font-size: 2.4rem; font-weight: 700; line-height: 1.5; }
.fac__txt { margin-top: 18px; font-size: 1.3rem; font-weight: 400; line-height: 1.846; text-align: justify; }
.fac__txt__link { font-weight: 700; text-decoration: underline; color: #0071bc; }
.fac__close { display: flex; justify-content: center; align-items: center; width: 100%; height: 40px; background: #e6e6e6; border-radius: 6px; margin-top: 70px; font: 500 1.3rem "Roboto", sans-serif; line-height: 1; letter-spacing: 0.02em; color: #333; }
.fac__close span { position: relative; width: 10px; height: 10px; margin-right: 10px; }
.fac__close span::before,
.fac__close span::after { position: absolute; top: 50%; left: 50%; display: block; width: 150%; height: 1px; background: #000; content: ""; }
.fac__close span::before { transform: translate(-50%, -50%) rotate(45deg); }
.fac__close span::after { transform: translate(-50%, -50%) rotate(-45deg); }
@media only screen and (max-width: 680px) {
	.fac__logo,
	.fac__close--outside { display: none; }
	.fac__ttl { text-align: center; }
	.fac__inner { display: flex; overflow-x: auto; gap: 10px; margin-top: 25px; margin-right: -30px; padding-right: 30px; -ms-overflow-style: none; scrollbar-width: none; }
	.fac__inner::-webkit-scrollbar { display: none; }
	.fac__cont { flex: 0 0 80%; scroll-snap-align: start; }
	.fac__cont img { display: block; width: 100%; height: auto; }
	.fac__inner--single .fac__cont { flex: 1; }
}
@media only screen and (min-width: 681px) {
	.fac__close--inside { display: none; }
	.fac-wrap { max-width: 70%; }
	.fac__inside { position: relative; }
	.fac__inner { display: grid; grid-template-columns: repeat(2, 1fr); grid-template-rows: repeat(2, 1fr); grid-column-gap: 40px; grid-row-gap: 40px; }

	.fac__cont:nth-child(1) { grid-area: 1 / 1 / 2 / 2; }
	.fac__cont:nth-child(2) { grid-area: 2 / 1 / 3 / 2; }
	.fac__cont:nth-child(3) { grid-area: 2 / 2 / 3 / 3; }
	.fac__ttltxt { grid-area: 1 / 2 / 2 / 3 !important; align-self: center; }
	.fac__ttl__sub { font-size: 80%; }
	.fac__inside { max-height: calc(100svh - 120px); margin-top: 120px; padding: 0 100px 100px; }
	.fac__inside::-webkit-scrollbar { display: none; }
	.fac__ttl { font-size: 3.6rem; line-height: 1.388; }
	.fac--gsc1 .fac__ttltxt .fac__ttl,
	.fac--gsc2 .fac__ttltxt .fac__ttl,
	.fac--gsc3 .fac__ttltxt .fac__ttl { letter-spacing: -0.04em; }
	.fac__txt { margin-top: 26px; font-size: 1.4rem; line-height: 2; }

	.fac__close { position: absolute; top: 30px; right: 30px; flex-direction: column; width: 60px; height: 60px; border-radius: 8px; margin-top: 0; font-size: 0.8rem; transition: .4s; z-index: 600; }
	.fac__close span { width: 18px; height: 18px; margin-right: 0; margin-bottom: 3px; }
	.fac__close span::before,
	.fac__close span::after { width: 100%; height: 2px; transition: .4s; }
	.fac__close:hover { background: #333; color: #e6e6e6; }
	.fac__close:hover span::before,
	.fac__close:hover span::after { background: #e6e6e6; }
	
	.fac__logo { position: absolute; top: 45px; left: 40px; }
	.fac__logo__img {  }
	.fac__logo__img a { display: block; }
	.fac__logo__img a svg { width: auto; height: 30px; }
	.fac__logo__img a svg path { fill: #333 !important; }
}
@media only screen and (min-width: 1729px) {
	.fac-wrap { max-width: 50%; }
}


/*	Floor Trigger	*/
.trg--floor .trg__btn { clip-path: polygon(0 0, 100% 35%, 100% 100%, 0 65%); }
.trg__loc-label { position: absolute; left: 50%; transform: translateX(-50%); display: flex; justify-content: center; align-items: center; width: 72px; height: 72px; background: #f15a24; border-radius: 50%; transition: .4s; cursor: pointer; }
.trg__loc-label span { position: relative; display: flex; justify-content: center; align-items: center; width: 52px; height: 52px; background: #fff; border-radius: 50%; font-family: "Roboto", sans-serif; font-size: 1.6rem; font-weight: 700; line-height: 1; text-align: center; white-space: nowrap; color: #4d4d4d; z-index: 10; transition: .4s; }
.trg__loc-label::before { position: absolute; left: 50%; transform: translateX(-50%); top: 15%; display: block; width: 100%; aspect-ratio: 1/1.5; background: url("../img/obj_loc-label.svg") no-repeat center/contain; content: ""; z-index: 0; }


@media only screen and (max-width: 680px) {
	.trg__loc-label { transform: translateX(-50%) scale(0.7); }
}
@media only screen and (min-width: 681px) {
	.trg__loc-label:hover span { background: #f15a24; color: #fff; }
	.trg--floor .trg__btn:hover+.trg__loc-label span { background: #f15a24; color: #fff; }
}


/*	Guidance	*/
.guidance-wrap { position: fixed; top: 0; left: 0; display: flex; width: 100%; height: 100%; align-items: center; justify-content: center; z-index: 1000; }
.guidance-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgba(0,0,0,0.3); z-index:  0; }
.guidance-overlay--white { background: rgba(255,255,255,0.5); }
.guidance { position: relative; display: block; width: calc(100% - 60px); max-width: 560px; background: #fff; border-radius: 20px; margin: 0 auto; padding: 25px 20px 30px; box-shadow: 20px 20px 40px 0px rgba(0,0,0,0.1); box-sizing: border-box; z-index:  100; }
.guidance__close-btn { position: absolute; top: -10px; right: -10px; display: block; width: 34px; height: 34px; background: #ffe600; border: none; border-radius: 50%; cursor: pointer; }
.guidance__close-btn::before,
.guidance__close-btn::after { position: absolute; top: 50%; left: 50%; width: 14px; height: 2px; background: #333; content: ""; }
.guidance__close-btn::before { transform: translate(-50%,-50%) rotate(45deg); }
.guidance__close-btn::after { transform: translate(-50%,-50%) rotate(-45deg); }
.guidance__ttl { font-size: 1.8rem; font-weight: 700; line-height: 1.4; text-align: center; }
.guidance__ttl__small { margin-right: 5px; font-size: 1.4rem; }
.guidance__txt { margin-top: 14px; font-size: 1.2rem; font-weight: 400; line-height: 1.8334; text-align: justify; }
.guidance__sl-wrap { position: relative; width: 100%; margin-top: 11px; margin-bottom: 0 !important; overflow: hidden; }
.guidance__sl { display: none; width: 100%; }
.guidance__sl.active { display: block; }
.guidance__sl__img { width: 100%; margin: 0 auto 15px; border: 1px solid #eee; }
.guidance__sl__img img { display: block; width: 100%; }
.guidance__sl__txt { margin: 0; padding: 0 10px; font-size: 1.3rem; line-height: 1.6923; text-align: center; }
/*
.guidance__dots { display: flex; margin: 20px 0; align-items: center; justify-content: center; }
.guidance__dot { display: block; width: 8px; height: 8px; background: #ccc; border-radius: 50%; margin: 0 4px; }
.guidance__dot.active { background: #00bfa5; }
*/
.guidance-wrap .slick-dots { position: relative; bottom: auto; display: flex !important; justify-content: center; align-items: center; margin: 11px auto 12px; padding: 0; list-style: none; pointer-events: none; }
.guidance-wrap .slick-dots li { display: flex; justify-content: center; align-items: center; margin: 0; }
.guidance-wrap .slick-dots li button { display: block; width: 8px;  height: 8px; padding: 0; border: none; border-radius: 50%; background-color: #ccc;  text-indent: -9999px;  font-size: 0;  cursor: pointer; transition: background-color 0.3s ease; }
.guidance-wrap .slick-dots li.slick-active button { background-color: #00bfa5; }
.guidance-wrap .slick-next { position: relative; display: flex; justify-content: center; align-items: center; width: 100%; height: 40px; background: #00bfa5; border: none; border-radius: 6px; padding-bottom: 1px; font-size: 1.5rem; font-weight: 700; line-height: 1; text-align: center; color: #fff; cursor: pointer; }


.guidance__btn-wrap { position: relative; width: 100%; height: 40px; }

.guidance__btn { position: relative; display: flex; justify-content: center; align-items: center; width: 100%; height: 40px; background: #00bfa5; border: none; border-radius: 6px; padding-bottom: 1px; font-size: 1.5rem; font-weight: 700; line-height: 1; text-align: center; color: #fff; cursor: pointer; }
.guidance__btn--top { position: absolute; top: 0; left: 0; width: 100%; height: 100%; transition: opacity 0.3s ease, visibility 0.3s ease; }
.guidance__btn--start { opacity: 0; visibility: hidden; pointer-events: none; }
.guidance__btn-wrap.is-second-slide .guidance__btn--next { opacity: 0; visibility: hidden; pointer-events: none; }
.guidance__btn-wrap.is-second-slide .guidance__btn--start { opacity: 1; visibility: visible; pointer-events: auto; }
.guidance__btn--sub { max-width: 300px; margin-top: 25px; margin-left: auto; margin-right: auto; }
.guidance__btn::after { position: absolute; top: 50%; transform: translateY(-50%) rotate(45deg); right: 18px; width: 4px; height: 4px; border-top: 2px solid #fff; border-right: 2px solid #fff; content: ""; }
@media only screen and (max-width:  680px) { 
	.guidance__sl__txt { margin-left: -10px; margin-right: -10px; }
	.guidance__sl-btn { width: calc(100% - 60px); margin-left: auto; margin-right: auto; }
	.guidance__btn--sub { width: calc(100% - 60px); }
}
@media only screen and (min-width:  681px) {
	.guidance { max-width: 400px; padding: 45px 25px 25px; }
	.guidance--sub { max-width: 560px; padding: 45px 50px 50px; }
	.guidance__close-btn { width: 36px; height: 36px; }
	.guidance__close-btn::before { width: 18px; }
	.guidance__close-btn::after { width: 18px; }
	.guidance__ttl { font-size: 22px; margin-bottom: 20px; }
	
	.guidance__ttl--sub { font-size: 3.6rem; }
	.guidance__ttl__small { margin-right: 5px; font-size: 2.8rem; }
	.guidance__txt { margin-top: 4px; font-size: 1.4rem; line-height: 2; }
	.guidance__sl__txt { font-size: 15px; }
	.guidance__dots { margin: 25px 0; }
	.guidance__btn-wrap { height: 50px; }
	.guidance__btn { height: 50px; font-size: 18px; line-height: 50px; transition: .4s; }
	.guidance__btn:hover { filter: brightness(110%); }
	.guidance__btn::after { right: 20px; width: 6px; height: 6px; }
	.guidance__btn--sub { margin-top: 33px; }
}


/*	Caution	*/
.caution-btn { position: fixed; bottom: 10px; right: 10px; display: flex; justify-content: center; align-items: center; width: 40px; height: 40px; background: #fff; border-radius: 50%; }
.caution-btn::before { width: 22px; height: 20px; background: url("../img/icon_caution.svg") no-repeat center/contain; content: ""; }
.caution { position: fixed; left: 0; bottom: 0; width: 100%; background: #fff; border-radius: 30px 30px 0 0; padding: 30px 30px 30px; z-index: 100; }
.caution__txt { display: flex; font-size: 1.3rem; font-weight: 700; line-height: 1; text-align: center; }
.caution__txt::before { width: 34px; height: 30px; background: url("../img/icon_caution.svg") no-repeat center/contain; content: ""; }
.caution__close { display: flex; justify-content: center; align-items: center; width: 100%; height: 40px; background: #e6e6e6; border-radius: 6px; margin-top: 20px; font: 500 1.3rem "Roboto", sans-serif; line-height: 1; letter-spacing: 0.02em; color: #333; }
.caution__close span { position: relative; width: 10px; height: 10px; margin-right: 10px; }
.caution__close span::before,
.caution__close span::after { position: absolute; top: 50%; left: 50%; display: block; width: 150%; height: 1px; background: #000; content: ""; }
.caution__close span::before { transform: translate(-50%, -50%) rotate(45deg); }
.caution__close span::after { transform: translate(-50%, -50%) rotate(-45deg); }


@media only screen and (max-width: 680px) {
	.caution { bottom: -100%; transition: .4s; }
	.caution._on { bottom: 0; }
	.caution__txt { flex-direction: column; justify-content: center; align-items: center; margin-left: -10px; margin-right: -10px; }
	.caution__txt::before { margin-bottom: 13px; }
}
@media only screen and (min-width:  681px) {
	.caution__close,
	.caution-btn { display: none; }
	.caution { display: inline-flex; align-items: center; left: auto; right: 30px; bottom: 30px; width: auto; height: 50px; border-radius: 8px; padding: 0 14px 0 14px; }
.caution__txt { align-items: center; font-size: 1.1rem; font-weight: 400; text-align: left; }
.caution__txt::before { width: 24px; height: 22px; margin-right: 10px; }
}

/**********************************************************
*　Mainvisual for Subpages
**********************************************************/
