@charset "UTF-8";
/* charset */
/*
font-family: "Noto Serif JP", serif;
font-family: 'Noto Sans JP', sans-serif;
*/

* {
	box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
:root {
	--header: 120px;
	--SiteColor: #00017e;
	--AkaColor: #620011;
	--AoColor: #0a9fe7;
	scroll-padding: var(--header);
}
html {
	scroll-behavior: smooth;
}
img {
	max-width: 100%;
	height: auto;
	vertical-align: bottom;
}

body {
	margin: 0;
	padding: 0;
	line-height: 1.6em;
	color: #111;
	background: #efefef;
	font-size: 16px;
	font-family: "Noto Serif JP", serif;
	font-weight: 400;
	letter-spacing: 0.05em;
	letter-spacing: 1px\9;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: auto;
}

h1, h2, h3, h4, h5, h6, h7, .blr,
ul, ol, li, dl, dt, dd,
article, section,
div, figure, p, form, img,
legend, i, em, strong, address {
	margin: 0;
	padding: 0;
	border: 0;
	font-size: 1em;
	list-style: none;
	font-style: normal;
	font-weight: normal;
}
p {
	font-family: 'Noto Sans JP', sans-serif;
}
button {
	margin: 0;
	padding: 0;
	border: 0;
	background: transparent;
}

a ,
img ,
button ,
span {
	-webkit-transition: all 0.4s ease;
	-moz-transition: all 0.4s ease;
	-o-transition: all 0.4s ease;
	transition: all  0.4s ease;
	text-decoration: none!important;
}
a {
	text-decoration: underline!important;
}
a:link {color: var(--AoColor);}
a:visited {color: var(--AoColor);}
a:active {color: var(--AoColor);}

a:hover {
	opacity: .60;
	filter: alpha(opacity=60);
	-ms-filter: "alpha(opacity=60)";
	-khtml-opacity: .60;
	-moz-opacity: .60;
	text-decoration: none!important;
}

a:hover img ,
button:hover img {
	opacity: .75;
	filter: alpha(opacity=75);
	-ms-filter: "alpha(opacity=75)";
	-khtml-opacity: .75;
	-moz-opacity: .75;
}
a:focus,
*:focus {
	outline: none;
}
.error {
	color: #c00;
}
.error span {
	display: block;
}
.error span:before {
	content: "\f071";
	margin-right: 3px;
	color: #c00;
	font-size: 15px;
	font-family: "FontAwesome";
}

.hide {
	display: none!important;
}

.spi {
	display: none!important;
}
.spb {
	display: none!important;
}

.pci {
	display: inline!important;
}
.pcb {
	display: block!important;
}
.eupfade {
	opacity : 0;
	transform : translate(0, 30px);
	transition : all 1s ease-in-out;
}
.eupfade.escroll {
	opacity : 1;
	transform : translate(0, 0);
	transition-delay: 0.2s;
}

#wrapper {
	position: relative;
	z-index: 1;
}
.inner {
	margin: 0 auto;
	width: 90%;
	max-width: 1000px;
	position: relative;
}
.btn {
	margin: 50px auto;
	text-align: center;
}
.btn p + a {
	margin-top: 1em;
}
.btn a {
	display: inline-block;
	padding: 1.25em 2.75em;
	line-height: 1em;
	color: #fff;
	font-size: 20px;
	font-family: 'Noto Sans JP', sans-serif;
	text-decoration: none!important;
	position: relative;
	z-index: 1;
}
.btn a::before {
	content: "";
	border-radius: 0.25em;
	width: 100%;
	height: 100%;
	background: var(--SiteColor);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.5);
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
	transition: all  0.4s ease;
}
.btn a:hover {
	color: #fff!important;
	opacity: 1!important;
}
.btn a:hover::before {
	background: var(--AoColor);
	box-shadow: none;
}
.btn a span {
}
.btns {
}
.btns a {
	display: block;
	margin: 0 auto;
	border-radius: 10px;
	padding: 0.5em 0;
	width: 70%;
	line-height: 1.25em;
	font-size: 30px;
	font-weight: 400;
	font-style: italic;
	font-family: 'Anton','Noto Sans JP', sans-serif;
	text-align: center;
	color: #fff;
	background: var(--SiteColor);
	box-shadow: 5px 5px 0 rgba(0,0,0,0.75);
}
.btns a i {
	display: inline-block;
	margin: 0 2px 0 10px;
	line-height: 1em;
	font-weight: 900;
	font-style: italic;
	position: relative;
	top: -2px;
}
.btns a span {
}
a.more {
	display: inline-block;
	border-radius: 100em;
	padding: 1em 0;
	width: 330px;
	color: #fff;
	background: #000;
	font-size: 21px;
	text-align: center;
	position: relative;
	z-index: 1;
}

.ttl {
	display: flex;
	justify-content: space-between;
	align-items: center;
	margin: 1.75em auto;
	padding: 0.75em;
	line-height: 1.5em;
	font-size: 2.1em;
	color: #fff;
	background:  var(--AoColor);
	position: relative;
}
.ttl:before {
	content: "";
	border: none;
	border-bottom: solid 15px transparent;
	border-right: solid 20px rgb(149, 158, 155);
	position: absolute;
	top: 100%;
	left: 0;
}
.ttl b {
}
.ttl span {
	font-size: 0.65em;
}
.ttl span:before ,
.ttl span:after {
	content: "─";
	margin: 0 0.5em;
}

.sttl {
	margin: 1.5em auto;
	border-bottom: solid 3px var(--AoColor);
	padding: 0.75em 0.75em 0.5em;
	line-height: 1.5em;
	font-size: 2em;
	color: var(--SiteColor);
	position: relative;
}

.sttl:after {
	content: "";
	width: 6.5em;
	height: 10px;
	background: var(--SiteColor);
	position: absolute;
	left: 0;
	bottom: -10px;
}
.sttl b {
	margin-right: 1em;
}
.sttl span {
	font-size: 20px;
}
.sttl span:before ,
.sttl span:after {
	content: "─";
	margin: 0 0.5em;
}


header {
	display: flex;
	flex-flow: column;
	justify-content: space-between;
	height: var(--header);
	background: #fff;
	box-shadow: 0 0 10px #000;
	position: sticky;
	top: 0;
	left: 0;
	z-index: 100;
}
header .inner {
	display: flex;
	flex-flow: wrap;
	justify-content: space-between;
	align-items: center;
	align-content: center;
	padding: 10px 0;
	width: 98%;
	max-width: 1200px;
}
header .toptxt {
	margin: 0 auto;
	padding: 0.25em 0 0;
	width: 98%;
	max-width: 1200px;
	line-height: 1em;
	font-size: 13px;
}
header .logo {
	width: clamp(7.5rem, -7.578rem + 25.1vw, 11.25rem);
}
header .sptxt {
	display: none;
}
header .topnav {
	display: flex;
	justify-content: space-between;
	align-items: center;
	min-width: 700px;
	width: 80%;
}
header .topnav ul {
	display: flex;
	justify-content: end;
}
header .topnav ul li {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 1em;
}
header .topnav ul li a {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0.25em 0 0.075em;
	text-decoration: none !important;
}
header .topnav ul li a span {
	font-size: clamp(0.813rem, -0.444rem + 2.09vw, 1.125rem);
	font-weight: 700;
	color: #000;
	letter-spacing: 0.075em;
	white-space: nowrap;
}
header .topnav ul li a:hover ,
header .topnav ul li a span:hover {
	opacity: 1;
	color: var(--AoColor);
}
header .topnav dl {
	display: flex;
	flex-flow: column;
	font-size: 12px;
}
header .topnav dl dt {
	display: none;
}
header .topnav dl dd {
	display: flex;
	flex-flow: column;
	border-radius: 4px;
	padding: 0.5em 1em;
	line-height: 1.5em;
	color: #ffffff;
	background: #0a9fe7;
	white-space: nowrap;
}
header .topnav dl dd span {
}
header .dcd {
}
header .dcd a {
}
header .dcd a i {
	display: flex;
	border-radius: 100em;
	padding: 0 8px;
	width: 46px;
	height: 46px;
	background: #5865F1;
}
header .dcd a i img {
	object-fit: contain;
}
header .navbtn {
	display: none;
}

.main section:nth-child(2n+1) {
	background-color: #f2f2f2;
	overflow: hidden;
}

.fv {
}
.fv figure {
	display: flex;
	justify-content: center;
	align-items: center;
	position: relative;
}
.fv figure:before {
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.25);
	position: absolute;
	top: 0;
	left: 0;
}
.fv figure figcaption {
	font-size: 40px;
	font-weight: 700;
	line-height: 1.5em;
	width: 100%;
	text-align: center;
	color: #fff;
	text-shadow: 0 0 10px #000, 0 0 10px #000;
	position: absolute;
	top: 50%;
	left: 50%;
	z-index: 3;
	transform: translate(-50%, -50%);
}
.about {
}
.about p {
	padding: 50px 0;
	line-height: 1.75em;
	font-size: 30px;
	text-align: center;
}
.txt {
	margin-bottom: 50px;
}
.txt a {
	font-weight: 700;
	color: var(--SiteColor)!important;
	position: relative;
}
.txt a:hover {
	color: var(--SiteColor)!important;
}
.txt a:before {
	content: "";
	width: 0;
	height: 1px;
	background: var(--SiteColor);
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	transition: all 0.5s;
}
.txt a:hover:before {
	width: 100%;
}
.index .sec01 .box {
	margin: 50px 0;
}
.map {
	padding-top: 350px;
	position: relative;
}
.access .map {
	padding-top: 400px;
}
.map iframe {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	transition: all 0.4s ease;
}
.access .map iframe {
	filter: grayscale(100%);
	-webkit-filter: grayscale(100%);
}
.access .map iframe:hover {
	filter: none;
	-webkit-filter: none;
}
.news {
	padding-bottom: 100px;
	background: #f2f2f2;
	overflow: hidden;
}
.newslist {
}
.newslist ul {
	display: flex;
	flex-flow: column;
}
.newslist ul li {
	display: flex;
	flex-flow: column;
	margin: 30px auto 0;
	padding: 2.5em 2.5em 1.5em;
	width: 90%;
	position: relative;
}
/*
.newslist ul li:nth-child(2n) {
	margin-right: none;
	margin-left: auto;
}
*/
.newslist ul li:before {
	content: "";
	border: 1px solid #efefef;
	width: 100%;
	height: 100%;
	background: #fff;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
}
.newslist ul li:after {
	content: "";
	margin-left: 90%;
	width: 100vw;
	height: 30px;
	background: #e8e8e8;
	position: absolute;
	bottom: 0;
	left: 0;
	transform: translateY(50%);
}
.newslist ul li + li {
	margin-top: 60px;
}
.newslist ul li b {
	padding: 0.5em 1em;
	color: var(--SiteColor);
	position: absolute;
	top: 0;
	left: 0;
	transform: translate(-2.5%,-50%);
	z-index: 2;
}
.newslist ul li b:before {
	content: "";
	width: 100vw;
	height: 100%;
	background: #cfe0e9;
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
}
.newslist ul li b time {
	margin-right: 1em;
}
.newslist ul li b span {
}
.newslist ul li p {
	position: relative;
	z-index: 2;
}
.newslist ul li a.more {
	margin-left: auto;
	border-radius: 100em;
	padding: 0.5em 2em;
	width: auto;
	font-size: 18px;
	background: var(--SiteColor);
	position: absolute;
	bottom: 0;
	right: 0;
	transform: translate(5%, 50%);
}
.newslist ul li a.more span {
	display: flex;
	align-items: baseline;
	line-height: 1em;
}
.newslist ul li a.more[target="_blank"] span:after {
	content: "\f08e";
	margin-left: 5px;
	color: #fff;
	font-size: 16px;
	font-family: "FontAwesome";
}
.newslist ul li .btn a:before {
	transform: skewX(0);
	box-shadow: none;
}
.privacy {
}
.privacy ul li {
	padding: 0.5em 1em 0 1em;
	list-style: square inside;
}
.company ,
.history {
}
.company dl ,
.history dl ,
.contact dl {
	display: flex;
	flex-flow: wrap;
	position: relative;
}
.company dl dt ,
.history dl dt ,
.contact dl dt {
	padding: 0.5em;
	width: 27%;
	color: #fff;
	background: var(--SiteColor);
	text-align: center;
	position: absolute;
	top: 1em;
	left: 0;
}
.company dl dd ,
.history dl dd ,
.contact dl dd {
	border-top: 1px solid #ccc;
	padding: 1.5em 0.5em 1.5em 30%;
	width: 100%;
}
.company dl:last-child dd ,
.history dl:last-child dd ,
.contact dl:last-child dd {
	border-bottom: 1px solid #ccc;
}
.company dl:last-child dd + dd ,
.history dl:last-child dd + dd ,
.contact dl:last-child dd + dd {
	border-top: 0;
	text-align: right;
}
.policy {
}
.policy p {
	padding: 0 0 2em;
}
.policy ol {
	display: flex;
	flex-flow: column;
	margin: 0 auto 2em;
	border: 1px solid #ccc;
	padding: 30px 30px calc(30px - 1em);
	width: fit-content;
	background: #fff;
	text-align: left;
}
.policy ol li {
	margin: 0 0 1em;
	padding-left: 1.25em;
	position: relative;
}
.policy ol li i {
	margin: 0;
	position: absolute;
	top: 0;
	left: 0;
}
.policy figure {
	margin: 0 auto;
	width: 50%;
}
.policy figure img {
	width: 100%;
	max-width: 100%;
	height: auto;
}
.metal {
}
.metal dl dd .btn + figure {
	margin: 50px auto 0;
	width: 50%;
}
.metal ul.license {
	display: flex;
	flex-flow: column;
	margin: 0 auto;
	width: 90%;
	max-width: 900px;
	font-family: 'Noto Sans JP', sans-serif;
}
.metal ul.license li {
	display: flex;
	flex-flow: wrap;
	align-items: center;
	padding: 1.5em 0;
	border-bottom: 1px solid #ccc;
}
.metal ul.license li b {
	display: flex;
	justify-content: center;
	padding: 0.75em 0.5em 0.8em;
	width: 45%;
	line-height: 1em;
	color: #fff;
	background: var(--SiteColor);
}
.metal ul.license li p {
	display: flex;
	padding: 0.35em 1em;
	font-size: 0.85em;
	width: 55%;
}
.metal ul.license li.list {
	display: block;
	padding: 1.5em 0;
	line-height: 2em;
	border-bottom: 1px solid #ccc;
}
.metal ul.license li.list b {
	display: inline;
	color: var(--SiteColor);
	background: none;
	width: auto;
}
.metal ul.license li.list p {
	display: inline;
	width: auto;
	font-size: 1em;
}
.metal ul.license + figure {
	display: flex;
	flex-flow: wrap;
	justify-content: center;
	align-items: center;
	margin: 50px auto 0;
	width: 90%;
}
.metal ul.license + figure img {
	width: 25%;
}
.metal dl dd.work {
	display: flex;
}
.metal dl dd.work ul {
	display: flex;
	flex-flow: wrap;
	align-content: baseline;
	width: 55%;
}
.metal dl dd.work ul li {
	margin: 0 0.5em 1em;
	height: fit-content;
	white-space: nowrap;
	background: #ffffff;
	padding: 0.5em 1em;
}
.metal dl dd.work figure {
	width: 45%;
	display: flex;
	align-items: baseline;
}
.metal dl dd.work figure img {
	width: 50%;
	height: auto;
}
.metal dl dd ul.partner {
	display: flex;
	flex-flow: wrap;
	justify-content: center;
}
.metal dl dd ul.partner li {
	margin: 0 0.5em 1em;
	padding: 0.5em 1em;
	height: fit-content;
	background: #fff;
	font-size: 1.1em;
	white-space: nowrap;
}
.metal dl dd ul.partner li span:after {
	content: "様";
	margin-left: 0.25em;
}
.metal dl dd table.fleetlist {
	margin: 0 auto;
	border-top: 1px solid #ccc;
	border-left: 1px solid #ccc;
	border-collapse: separate;
	border-spacing: 0;
	width: 80%;
	font-family: 'Noto Sans JP', sans-serif;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}
.metal dl dd table.fleetlist tbody tr:nth-child(2n+1) {
	background: rgba(255, 255, 255, 0.25);
}
.metal dl dd table.fleetlist thead th {
	border-bottom: 1px solid #ddd;
	border-right: 1px solid #ddd;
	padding: 0.5em;
	font-size: 1.25em;
	color: #fff;
	background: var(--AoColor);
	text-align: center;
}
.metal dl dd table.fleetlist tbody tr th ,
.metal dl dd table.fleetlist tbody tr td {
	border-bottom: 1px solid #ccc;
	border-right: 1px solid #ccc;
	padding: 0.5em 1em;
	line-height: 1.5em;
}
.metal dl dd table.fleetlist tbody tr th {
	text-align: left;
	font-size: 1.25em;
}
.metal dl dd table.fleetlist tbody tr td {
	text-align: center;
	font-weight: 900;
	font-size: 1.5em;
}
.metal dl dd.permisson {
}
.metal dl dd.permission + dd.permission {
	margin-top: 50px;
}
.metal dl dd table.fleetlist th ul {
	display: flex;
	flex-flow: wrap;
	justify-content: center;
	width: 100%;
}
.metal dl dd table.fleetlist th ul li {
	display: flex;
	margin: 0 0.25em;
	height: fit-content;
}
.metal dl dd table.fleetlist th p + ul li {
	margin: 0.5em 0.25em 0;
}
.metal dl dd table.fleetlist th ul li span {
	display: flex;
	padding: 0.5em;
	line-height: 1em;
	font-size: 0.665em;
	color: #000;
	background: #ffffff;
	white-space: nowrap;
}
.metal dl.vehicle {
}
.metal dl.vehicle dd {
}
.metal dl.vehicle dd ul {
	display: flex;
	justify-content: space-between;
	align-self: stretch;
	margin: 0 auto 3%;
	width: 80%;
}
.metal dl.vehicle dd ul li {
	display: flex;
	flex-flow: column;
	align-items: center;
	border: 1px solid #222;
	width: 48%;
	background: #fff;
}
.metal dl.vehicle dd ul li b ,
.metal dl.vehicle dd figure figcaption {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0.5em;
	width: 100%;
	font-size: 1.25em;
	font-weight: 700;
	font-family: 'Noto Sans JP', sans-serif;
	color: #fff;
	background: #222;
	text-align: center;
}
.metal dl.vehicle dd figure figcaption {
	order: 1;
}
.metal dl.vehicle dd ul li p {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 5%;
	height: 100%;
	line-height: 1.25em;
	text-align: justify;
	font-size: 1.5em;
}
.metal dl.vehicle dd figure {
	display: flex;
	flex-flow: wrap;
	margin: 0 auto;
	border: 1px solid #222;
	width: 80%;
}
.metal dl.vehicle dd figure div + figcaption:after {
	content: "※画像をクリックで拡大";
	margin-left: 1em;
	font-size: 0.75em;l
}
.metal dl.vehicle dd figure div ,
.metal dl.vehicle dd figure p {
	display: flex;
	flex-flow: wrap;
	order: 2;
	padding: 1em;
	background: #fff;
}
.metal dl.vehicle dd figure p {
	justify-content: center;
	width: 100%;
}
.metal dl.vehicle dd figure div a {
	width: 25%;
}
.metal dl.vehicle dd figure p span {
	display: flex;
	flex-flow: column;
}
.metal dl.vehicle dd figure div a img ,
.metal dl.vehicle dd figure p img {
	max-width: 100%;
	height: auto;
}
.metal dl.vehicle dd figure p img {
	max-width: 100%;
	height: auto;
}
.metal dl.vehicle dd figure p span + img {
	object-fit: cover;
	height: 514px;
}
.metal dl.vehicle dd figure > img {
	display: flex;
	order: 2;
}
.metal dl.vehicle dd figure > img {
	display: flex;
	order: 2;
}
.metal .toptxt ,
.solar .toptxt {
	margin: 0 auto;
	line-height: 1.5em;
	font-size: 1.25em;
	text-align: center;
}
.metal nav.tab {
	padding: 50px 0 0;
}
.metal nav.tab {
	display: flex;
	justify-content: center;
}
.metal nav.tab span {
	display: flex;
	margin: 0 0.5em;
	border-radius: 100em;
	border: 1px solid #ccc;
	padding: 0.5em 1.5em 0.65em;
	color: #222;
	background: #ccc;
	font-size: 1.25em;
	font-weight: 700;
}
.metal nav.tab span:hover {
	border: 1px solid var(--AoColor);
	background: #fff;
	cursor: pointer;
}
.metal nav.tab span.on {
	border: 1px solid var(--AoColor);
	color: var(--AoColor);
	background: #fff;
}
.metal ol.reclist {
	display: flex;
	flex-flow: column;
	margin: 0 auto;
	width: 90%;
	max-width: 900px;
	font-family: 'Noto Sans JP', sans-serif;
}
.metal ol.reclist li {
	display: flex;
	flex-flow: wrap;
	align-items: center;
	padding: 1.5em 0;
	border-bottom: 1px solid #ccc;
}
.metal ol.reclist li time {
	display: flex;
	justify-content: center;
	padding: 0.5em 0.5em 0.6em;
	width: 10%;
	line-height: 1em;
	font-size: 0.85em;
	color: #fff;
	background: var(--SiteColor);
}
.metal ol.reclist li p {
	display: flex;
	padding: 0.35em 1em;
	width: 60%;
}
.metal ol.reclist li span {
	display: flex;
	padding: 0.5em 1em;
	width: 30%;
}
.metal .block {
	display: none;
	transition: all  0.4s ease;
}
.metal .block.on {
	display: block;
	animation: panel-show .9s ease-in-out forwards;
}
@keyframes panel-show {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

.solar {
}
.solar .btn + p {
	padding: 0 0 50px;
	text-align: center;
}
.solar figure {
	display: flex;
	flex-flow: column;
	align-items: center;
	margin: 0 auto;
	width: 70%;
}
.solar figure + figure {
	margin: 30px auto 0;
}
.solar figure img {
	max-width: 100%;
	height: auto;
}
.info {
}
.info p {
	margin: 0 auto;
	width: 90%;
	line-height: 1.5em;
	font-size: 1.25em;
}
.info p + p {
	margin-top: 2em;
}
.info figure {
	padding: 4em 0;
}
.info .adrs {
	display: flex;
	margin: 2em 0;
	border: 1px solid #ccc;
	padding: 1em;
	width: fit-content;
	background: #fff;
}
.access {
}
.access dl {
	display: flex;
	flex-flow: column;
	padding: 100px 0 50px;
}
.access dl dt {
	display: flex;
	justify-content: center;
	margin: 0 0 0.5em;
	line-height: 1.5em;
	color: var(--SiteColor);
	font-size: 40px;
}
.access dl dd {
}
.access dl dd ul {
	display: flex;
	justify-content: space-between;
}
.access dl dd ul li {
	display: flex;
	flex-flow: column;
	width: 30.333%;
	background: #fff;
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}
.access dl dd ul li b {
	display: flex;
	flex-flow: wrap;
	justify-content: center;
	align-items: center;
	align-content: center;
	padding: 0 0.5em;
	min-height: 80px;
	color: #fff;
	background: var(--SiteColor);
	font-size: 20px;
}
.access dl dd ul li b a {
	color: #fff!important;
}
.access dl dd ul li address {
	display: flex;
	flex-flow: column;
	justify-content: center;
	margin: 0 auto;
	padding: 1.5em 0.5em;
	width: fit-content;
	height: 100%;
}
.access dl dd ul li address span a {
	color: inherit;
	text-decoration: none!important;
	pointer-events: none;
	
}
footer {
	margin-top: 80px;
	padding: 30px 0 0;
	color: #fff;
	background: #1e1e1e;
	overflow: hidden;
	position: relative;
}
.map + footer ,
.access + footer {
	margin-top: 0;
}
.index footer ,
.tournament footer {
	margin-top: 0;
}
footer .inner {
	display: flex;
	justify-content: space-between;
	align-items: center;
	z-index: 2;
}
/*
footer .inner:before {
	content: "";
	width: 593px;
	height: 424px;
	background: url(../img/footer_before.png) no-repeat;
	position: absolute;
	top: 32px;
	right: -136px;
	z-index: -1;
}
*/
footer .footlogo {
	width: 160px;
}
footer ul {
	display: flex;
	flex-flow: wrap;
	width: 70%;
}
footer ul li {
}
footer ul li a {
	margin: 0 1em;
	line-height: 2em;
	color: #fff!important;
	font-size: 18px;
	text-decoration: none!important;
	position: relative;
}
footer ul li a:before {
	content: "";
	width: 0;
	height: 1px;
	background: var(--AoColor);
	position: absolute;
	bottom: 0;
	left: 50%;
	transform: translateX(-50%);
	transition: all 0.5s;
}
footer ul li a:hover ,
footer ul li a:hover span {
	opacity: 1;
	color: var(--AoColor);
}
footer ul li a:hover:before {
	width: 100%;
}
footer ul li a span {
}
footer .copy {
	padding: 100px 0 50px;
	text-align: center;
	position: relative;
	z-index: 2;
}
footer .copy span {
	font-size: 16px;
	font-weight: 400;
}

.error404 {
}
.error404 .sec01 {
}
.error404 .sec01 .inner {
}
.error404 .sec01 .inner .txt {
	display: flex;
	flex-flow: column;
	justify-content: center;
	align-items: center;
	line-height: 1.5em;
	font-size: 20px;
	font-weight: 900;
	text-align: center;
}
.error404 .sec01 .inner .txt b {
	display: block;
	margin-bottom: 0.5em;
	line-height: 1.25em;
	color: var(--SiteColor);
	font-size: 30px;
	font-weight: 900;
}

.slide ul .slick-prev:before ,
.slide ul .slick-next:before {
	position: absolute;
	top: 50%;
	font-family: "FontAwesome";
	font-size: 50px;
	color: #fff;
	transform: translateY(-50%);
	text-shadow: 0 0 10px #000, 0 0 10px #000;
}
.slide ul .slick-prev:before {
	content: '\f053';
	right: 5px;
}
.slide ul .slick-next:before {
	content: '\f054';
	left: 5px;
}
.dots-wrap {
	display: flex;
	justify-content: center;
	padding: 15px 0 0;
}
.dots-wrap li {
	width: 10px;
	height: 10px;
	margin: 0 5px;
	background: #fff;
	border-radius: 50%;
	cursor: pointer;
}
.dots-wrap li:hover,
.dots-wrap li.slick-active {
	background: #008cff;
}
.dots-wrap li button {
	display: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	outline: none;
	padding: 0;
	border: none;
	background-color: transparent;
}

@media print {
	body {
		zoom: 0.6;
		background: #efefef;
		-webkit-print-color-adjust: exact;
		print-color-adjust: exact;
	}
	.map iframe {
		background: url(/keihin/new/img/bg_mapprint.png) no-repeat center top;
		background-size: cover;
	}
}