@charset "utf-8";
@import url(style.css) screen and (min-width: 769px); /* 769以上 */
@import url(tablet.css) screen and (max-width: 768px); /* 768以下 */
@import url(smart.css) screen and (max-width: 420px); /* 420以下 */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
a {
  color: #006bc4;
  text-decoration: underline;
  text-decoration-thickness: 1px; /*a-link アンダーラインの太さ*/
  text-underline-offset: 5px; /*a-link アンダーラインの距離*/
}
a:hover {
  color: #005ba6;
  text-decoration: none;
}
a.arrow::before { /*a-link 先頭三角マーク付き*/
  content: url(/common/imgs/bg_linkarrow.gif);
  vertical-align: 15%;
  padding-right: 5px;
}
a img {
  text-decoration: none;
}
ul, ul li {
  list-style: none;
}
span.arrow_span { /*span 先頭三角マーク付き*/
  background: url(/common/imgs/bg_linkarrow.gif) no-repeat 0 center;
  padding-left:10px;
}
.red { /*赤文字対応用*/
  color: #d00101;
}
.close { /*s終了文言用*/
	color: #d00101;
	font-weight: 600;
	padding-left: 1em;
}
/* clearfix-clear */
.clearfix:after {
  content: "."; 
  display: block;
  clear: both;
  height: 0;
  visibility: hidden;
}
.clearfix {
  min-height: 1px;
}
* html .clearfix {
  height: 1px;
  /*\*//*/
  height: auto;
  overflow: hidden;
  /**/
}
.clear {
	clear: both
}
/* body-wrapper-footer */
body {
  color: #30405e;
  background-color: #d4eeff;
  line-height: 1.6;
}
/*body a { /*a-link アンダーライン設定用
    text-decoration-thickness: 1px; /*a-link アンダーラインの太さ
    text-underline-offset: 3px; /*a-link アンダーラインの距離
}*/
/* table */
table.table01 th,
table.table01 td {
  padding: 10px 30px;
}
table.table02 th,
table.table02 td {
  width: 50%;
  padding: 20px 30px;
}
table.table01 th {
  width: 15%;
  color: #fff;
  background-color: #6093be;
  letter-spacing: 2px;
}
table.table02 th {
  border: 1px solid #fff;
}
table.table01 td {
  /*border-top: 2px solid #333;*/
  background-color: rgba(255,255,255,.9);
}
table.table01 td strong {
  display: inline-block;
  font-weight: 400;
  font-size: 110%;
  padding-bottom: .3em;
}
table.table02 td {
  border: 1px solid #e3e0dc;
}

/* nav */
nav ul {
  display: flex;
  flex-wrap: wrap;
  list-style: none;
}
nav ul li {
  background-color: #6093be;
  text-align: center;
}
nav ul li a {
  display: block;
  color: #fff;
  width: 100%;
  text-decoration: none;
  line-height: 1.2;
}
nav ul li a:hover {
  display: block;
  color: #fff !important;
  text-shadow: 2px 2px 2px #006bc4;
  width: 100%;
  text-decoration: none;
}
#wrapper {
  background-color: #fff;
  font-family: "Helvetica Neue", Arial, "Hiragino Kaku Gothic ProN", "Hiragino Sans", "BIZ UDPGothic", Meiryo, sans-serif;
}
/* table */
table.table01, table.table01 tr, table.table01 th, table.table01 td, table.table02, table.table02 tr, table.table02 th, table.table02 td {
  border-collapse: collapse;
}
table.table01 td strong {
  color: #005ead;
}
/**/
#main_contents section#general,
#main_contents section#external,
#main_contents section#information,
#main_contents section#inquiry {
  background-color: #eaf0f4;
}

/* tab_panel */
.tab_wrap {
  width: 100%;
  margin: 1em auto 0;
}
input[type="radio"] {
  display: none;
}
.tab_area {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  /*align-items: stretch;*/
  align-items: center;
  font-size: 0;
  margin: 0;
}
.tab_area label {
  align-self: stretch;
  width: 30%;
  margin: 0;
  display: inline-block;
  padding: 0;
  color: #fff;
  text-align: center;
  cursor: pointer;
  transition: ease 0.2s opacity;
  background-color: #006bc4;
}
.tab_area label:hover {
  opacity: 0.8;
}
.tab_area label p span {
  display: block;
  margin-top: .5em;
  font-size: 16px;
  line-height: 1.3;
  background-color: #479ce3;
  padding: 10px 15px;
}
.panel_area {
  margin: 1.6em 0 1em;
}
.tab_panel {
  box-sizing: border-box;
  width: 100%;
  display: none;
}
#tab1:checked ~ .tab_area .tab1_label,
#tab2:checked ~ .tab_area .tab2_label,
#tab3:checked ~ .tab_area .tab3_label {
  color: #fff000;
}
#tab1:checked ~ .panel_area #panel1,
#tab2:checked ~ .panel_area #panel2,
#tab3:checked ~ .panel_area #panel3 {
  display: block;
}

/* id="bnr" */
#information #bnr {
  display: block;
  text-indent: -10px;
}
/**/
#footer {
  position: relative;
}
#footer .footer_in {
  background-color: #fff;
}
#footer .footer_in .cr{
  position: absolute;
  right: 1rem;
  color: #333;
  font-size: 0.85rem;
  line-height: 1.2
}
#footer .totop a {
  display: block;
  position: absolute;
  top: -35px;
  right: 15px;
  width: 115px;
  height: 0;
  background-image: url(../images/btn_totop-BK.svg);
  background-color: #fff;
  background-repeat: no-repeat;
  background-size: 85%;
  padding: 40px 10px 0 10px;
  background-position: 10px 10px;
  border-top-left-radius: 10px;
  border-top-right-radius: 10px;
  overflow: hidden;
}
#footer .footer_in a#kahakutop_footer,
#footer .footer_in a#the-Cabinet,
#footer .footer_in a#metropolis {
  display: block;
  height: 0;
  font-size: 10px;
  background-repeat: no-repeat;
  background-size: contain;
  overflow: hidden;
}
/**/
.sub_title h2,
#flyer h2 {
  color: #006bc4;
}
#flyer .inner_box p {
  text-align: center;
  margin-top: .5em;
}
/**/
#inquiry ul li::before {
  content: "○ ";
}

/* #event */
#event ul#legend {
  display: flex;
  align-items: center;
}
#event ul#legend li {
  color: #fff;
  text-align: center;
  padding: 6px 5px;
  line-height: 1.2;
}
#event ul#legend li.order-pre {
  background-color: #5f93bd;
}
#event ul#legend li.order-now {
  background-color: #ff6c00;
}
#event ul#legend li.order-closed {
  background-color: #4c5054;
}
#event ul#legend li.status {
  color: #30405e !important;
  background: #dcdcdc;
}