﻿@charset "utf-8";
html {
    min-height: 100vh;
}
body {
    font-size: 10px;
}
@media(min-width:801px) {
    html {
        background: #ccc;
    }
    body {
        background: #ccc;
    }    
}

*{
    box-sizing: border-box;
}
.-ico {
    display: inline-block;
    position:relative;
    padding-left:35px;
}

.l-header {
    width: 92%;
    margin: 0 auto;
    padding: 20px 0 0;
}
.l-header .logo img {
    height: 28px;
    width: auto;
}

.l-wrapper {
    background: #fff;
    min-width: 320px;
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}
.l-wrapper > .inner {
    padding: 30px 0 10px;
}
.p-box_intro {
    padding: 0 5% 30px;
}
.e-label {
    font-size: 13px;
    position:relative;
    color: #004E97;
    margin-bottom: 5px;
}
.hl-high_map {
    font-size: 22px;
    color: #fff;
    background: #004E97;
    font-weight: normal;
    padding: 12px 15px 10px ;
    margin-bottom: 15px;
}
.text-address {
    font-size: 14px;
    margin: 0 0 10px;
    line-height: 1.3;
    padding-bottom: 10px;
    border-bottom: 1px solid #ddd;
}
.text-address .-ico::before {
    content:'';
	display: block;
    width: 15px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M480-480q33%200%2056.5-23.5T560-560q0-33-23.5-56.5T480-640q-33%200-56.5%2023.5T400-560q0%2033%2023.5%2056.5T480-480Zm0%20400Q319-217%20239.5-334.5T160-552q0-150%2096.5-239T480-880q127%200%20223.5%2089T800-552q0%20100-79.5%20217.5T480-80Z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;
    position: absolute;
    left: 5px;
    top: 2px;
    z-index: 5;
}
.text-address .-ico::after {
    content: '';
    display: block;
    width: 25px;
    height: 25px;
    background: #004E97;
    border-radius: 50%;
    position: absolute;
    top: -3px;
    left: 0;    
    z-index: 1;
}
.text-tel {
    font-size: 18px;
    margin: 15px 0 20px;
    padding-bottom: 10px;
    border-bottom: 1px solid #ddd;
}
.text-tel .-ico::before {
    content:'';
	display: block;
    width: 15px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M798.48-111.87q-126.44%200-249.87-55.1-123.44-55.1-224.87-156.29Q222.3-424.7%20167.21-548.25q-55.1-123.55-55.1-249.99%200-21.35%2014.15-35.62%2014.15-14.27%2035.5-14.27h161.76q19.5%200%2033.37%2011.53%2013.87%2011.53%2017.31%2029.56l25.76%20134.97q2.95%2019.59-.88%2033.22-3.84%2013.63-14.71%2023.78l-98.44%2096.09q19.05%2034.37%2045.11%2066.96%2026.07%2032.59%2058.11%2063.63%2029.81%2029.8%2061.42%2054.63%2031.6%2024.83%2066.26%2044.91l95.67-94.95q11.63-11.4%2028.52-16.37%2016.89-4.98%2034.48-2.03l131.54%2027.29q19.03%205.43%2030.06%2018.44%2011.03%2013.01%2011.03%2031.04v163.67q0%2021.35-14.27%2035.62-14.27%2014.27-35.38%2014.27Z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;
    position: absolute;
    left: 5px;
    top: 1px;
    z-index: 5;
}
.text-tel .-ico::after {
    content: '';
    display: block;
    width: 25px;
    height: 25px;
    background: #004E97;
    border-radius: 50%;
    position: absolute;
    top: -4px;
    left: 0;    
    z-index: 1;
}
.text-tel a {
    color: #004E97;
    font-weight: bold;
    pointer-events: none;
}
@media(max-width: 800px) {
    .text-tel a {
        pointer-events: initial;
    }
}

.table-near_spot {
    font-size: 13px;
    margin-bottom: 5px;
    display: flex;
}
.table-near_spot *+td {
    padding: 0 0 5px 5px;
}
.table-near_spot .-label {
    line-height: 1;
    display: inline-flex;
    width: 100px;
    height: 100%;
    justify-content: center;
    align-items: center;
    padding: 5px 8px 4px;
    background: #f81000;
    color: #fff;
    font-size: 11px;
    white-space: nowrap;
}
.table-near_spot .-place {
    font-size: 14px;
    padding-left: 12px;
    padding-right: 12px;
    line-height: 1.4;
}
.table-near_spot .-time {
    margin-left: auto;
    line-height: 1.4;
}
.table-near_spot .-time .-ico {
    padding-left:22px;
}
.table-near_spot .-ico::before {
	
    content:'';
	display: block;
    width: 15px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23333%22%3E%3Cpath%20d%3D%22M360-840v-80h240v80H360Zm80%20440h80v-240h-80v240Zm40%20320q-74%200-139.5-28.5T226-186q-49-49-77.5-114.5T120-440q0-74%2028.5-139.5T226-694q49-49%20114.5-77.5T480-800q62%200%20119%2020t107%2058l56-56%2056%2056-56%2056q38%2050%2058%20107t20%20119q0%2074-28.5%20139.5T734-186q-49%2049-114.5%2077.5T480-80Zm0-80q116%200%20198-82t82-198q0-116-82-198t-198-82q-116%200-198%2082t-82%20198q0%20116%2082%20198t198%2082Zm0-280Z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;
    position: absolute;
    left: 2px;
    top: 1px;
}
.table-near_spot b {
    padding-right: 15px;
    font-size: 14px;
    white-space: nowrap;
}
@media(max-width:640px) {
    .table-near_spot {
        flex-wrap: wrap;
    }
    .table-near_spot li:first-of-type {
        width: 100%;
        margin-bottom: 5px;
    }
    *+.table-near_spot {
        margin-top:10px;
    }    
    .table-near_spot li:first-of-type span {
        width: 100%;
        text-align: left;
    }
    .table-near_spot .-place {
        padding-left:0;
    }
    
    
}

.l-section {
    margin: 0 15px 10px;
    padding: 20px 4% 20px;
    background: #eee;
    border-top: 1px solid rgba(0,0,0,.02); 
    border-left: 1px solid rgba(0,0,0,.02); 
    position: relative;
}
@media(min-width:641px) {
    .l-section {
        margin: 0 auto 30px;
        width: 90%;
        max-width: 710px;
    }    
}
.l-section::before {
    content: '';
    width: 0;
    height: 0;
    border-style: solid;
    border-width: 30px 30px 0 0;
    border-color: #004e97 transparent transparent transparent;
    position: absolute;
    left: 0;
    top: 0;
}

.hl-mid_map {
    font-size: 16px;
    color: #004E97;
    padding: 10px 0 15px;
    text-align: center;
}
.hl-mid_map::after {
    content: '';
    display:block;
    background: #333;
    width: 30px;
    height: 1px;
    margin: 15px auto 0;
}
.box-map.-ga_map {
    position: relative;
    width: 100%;
    padding-top: 120%;
    margin-bottom: 20px;
    border: 3px solid #fff;
}
@media(min-width:641px) {
    .box-map.-ga_map {
        padding-top: 70%;
    }
    
}
.box-map iframe {
    width: 100%;
    height: 100%;
    position: absolute;
    left: 0;
    top: 0;
}
.text-access {
    font-size: 14px;
    line-height: 1.6;
    display: none;
}
.text-access + .text-access {}

.box-map.-img {
    position: relative;
    width: 100%;
    margin-bottom: 10px;
    border: 3px solid #fff;
}
.box-map.-img img {
    display: block;
    width: 100%;
    height: auto;
}
.text-right {
    font-size: 14px;
    text-align: right;
    margin-bottom: 20px;
}
.text-right a {
    color: #004e97;
    text-decoration: underline;
    position: relative;
}
.text-right a[target*=_blank]::before {
    content:'';
	display: block;
    width: 20px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2236%22%20height%3D%2236%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22none%22%20stroke%3D%22%23004e97%22%20stroke-width%3D%222%22%20stroke-linecap%3D%22round%22%20stroke-linejoin%3D%22round%22%20class%3D%22ai%20ai-ZoomIn%22%3E%3Cpath%20d%3D%22M21%2021l-4.486-4.494M19%2010.5a8.5%208.5%200%201%201-17%200%208.5%208.5%200%200%201%2017%200z%22%2F%3E%3Cpath%20d%3D%22M10.5%207v3.5m0%200V14m0-3.5H14m-3.5%200H7%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;
    position: absolute;
    left: -24px;
    top: 0;
}
.hl-low_map {
    font-size: 16px;
    font-weight: bold;
    padding-bottom: 10px;
    border-bottom: 1px solid #aaa;
    margin-bottom: 15px;
    position: relative;
}
.hl-low_map::after {
    content: '';
    display: block;
    background: #f81500;
    width: 32px;
    height: 2px;
    position: absolute;
    bottom: -1px;
    z-index: 10;
}

.p-list_number {
    font-size: 14px;
    counter-reset: number 0; 
}
.p-list_number li {
    position: relative;
    padding-left: 25px;
    margin-bottom: 10px;
    line-height: 1.2;
}
.p-list_number li:before {
    content: counter(number);
    counter-increment: number;
    background-color: #333;
    border-radius: 50%;
    box-sizing: border-box;
    display: flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    height: 18px;
    width: 18px;
    color: #fff;
    font-size: 70%;
    line-height: 1;
    position: absolute;
    top: -1px;
    left: 0;
}

.p-list_btn {
    width: 80%;
    max-width: 500px;
    margin: 30px auto;
}
.p-list_btn li{
    margin-bottom: 5px;
}
.p-btn {
    display: block;
    padding: 15px 10px;
    text-align: center;
    color: #fff;
    background: #000;
    font-size: 16px;
    border-radius:50px;
    border-bottom: 2px solid #999;
}
.p-btn.-print {
    background: #f81500;
}
.p-btn.-copy {
    background: #004e97;
}
.p-btn.-print .-ico,
.p-btn.-copy .-ico,
.p-close .-ico{
    padding-left: 25px;
}
.p-btn.-print .-ico::before {
    content:'';
	display: block;
    width: 20px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M720-680H240v-160h480v160Zm0%20220q17%200%2028.5-11.5T760-500q0-17-11.5-28.5T720-540q-17%200-28.5%2011.5T680-500q0%2017%2011.5%2028.5T720-460Zm-80%20260v-160H320v160h320Zm80%2080H240v-160H80v-240q0-51%2035-85.5t85-34.5h560q51%200%2085.5%2034.5T880-520v240H720v160Z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;

    position: absolute;
    left: -2px;
    top: -2px;
}
.p-btn.-copy .-ico::before {
    content:'';
	display: block;
    width: 20px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20height%3D%2224px%22%20viewBox%3D%220%20-960%20960%20960%22%20width%3D%2224px%22%20fill%3D%22%23fff%22%3E%3Cpath%20d%3D%22M330-240q-104%200-177-73T80-490q0-104%2073-177t177-73h370q75%200%20127.5%2052.5T880-560q0%2075-52.5%20127.5T700-380H350q-46%200-78-32t-32-78q0-46%2032-78t78-32h370v80H350q-13%200-21.5%208.5T320-490q0%2013%208.5%2021.5T350-460h350q42-1%2071-29.5t29-70.5q0-42-29-71t-71-29H330q-71-1-120.5%2049T160-490q0%2070%2049.5%20119T330-320h390v80H330Z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;

	position: absolute;
    left: -2px;
    top: -2px;
}

.p-close {
    display: block;
    text-align: center;
    margin-top: 30px;
    font-size: 14px;
    color: #333;
}
.p-close .-ico {
    text-decoration: underline;
}
.p-close .-ico::before {
    content:'';
	display: block;
    width: 20px;
	aspect-ratio: 1/1;
	background: url('data:image/svg+xml;charset=utf8,%3Csvg%20xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22%20width%3D%2236%22%20height%3D%2236%22%20viewBox%3D%220%200%2024%2024%22%20fill%3D%22currentColor%22%20stroke-width%3D%222%22%20class%3D%22ai%20ai-CircleXFill%22%3E%3Cpath%20fill-rule%3D%22evenodd%22%20clip-rule%3D%22evenodd%22%20d%3D%22M12%201C5.925%201%201%205.925%201%2012s4.925%2011%2011%2011%2011-4.925%2011-11S18.075%201%2012%201zm3.707%208.707a1%201%200%200%200-1.414-1.414L12%2010.586%209.707%208.293a1%201%200%201%200-1.414%201.414L10.586%2012l-2.293%202.293a1%201%200%201%200%201.414%201.414L12%2013.414l2.293%202.293a1%201%200%200%200%201.414-1.414L13.414%2012l2.293-2.293z%22%2F%3E%3C%2Fsvg%3E') 50% 50% no-repeat;
	background-size: contain;
    
	position: absolute;
    left: 0;
    top: -3px;
}

footer {
    background: #004e97;
    text-align: center;
    padding: 10px;
}
footer small {
    color: #fff;
}


a {
	text-decoration:none;
	}
a:hover{
	text-decoration:none;
	}
