@charset "UTF-8";
/* CSS Document */
@import url(https://fonts.googleapis.com/earlyaccess/notosansjp.css);
/* ////////////////////////////////// */
/* body html */
/* ////////////////////////////////// */
:root {
  --inv-black: #000000;
  --black75: #262626;
  --dk-blue: #004d80;
  --csd-blue: #00516D;
  --csd-blue90: #1A627C;
  --csd-blue80: #33748A;
  --light-blue: #E7F7FE;
  --light-glay: #E3E3E3;
  --light-glay: #cccccc;
  --red: #e60000;
  --csd-red: #D7000F;
  --sm-orange: #ff7a1f;
  --cont-gap: 60px;
  --cont-padd: 56px;
}

html {
  box-sizing: border-box;
  scroll-behavior: smooth;
}

ol,
ul,
li {
  margin: 0;
  padding: 0;
  list-style: none;
}

a {
  text-decoration: none;
}

a:hover {
  opacity: 0.8;
}

.fa-soli::before {
  font-weight: 900;
}

.pc {
  display: visible;
}

.sp {
  display: none;
}

.pc_inline {
  display: inline;
}

.sp_inline {
  display: none;
}

/* ////////////////////////////////// */
/* common */
/* ////////////////////////////////// */
p {
  margin: 1em 0 1em 0;
  padding: 0;
  text-align: start;
  text-justify: inter-ideograph;
  line-height: 160%;
}

h2, h3, h4 {
  font-weight: 700;
}

.content_border {
  margin: 0 auto 0 auto;
  padding: 0;
  width: 100%;
  max-width: 1080px;
  height: auto;
  border: 1px;
}

.content_inner {
  width: 100%;
  margin: 0 auto;
  padding: 0;
}

.indent {
  padding-left: 1em !important;
  text-indent: -1em;
}

.head {
  margin: 0 auto 2em auto;
  padding: 0;
  width: 100%;
  height: auto;
}

.head_b {
  margin: 2em auto 2em auto;
  padding: 0;
  width: 100%;
  height: auto;
}

.t_left {
  text-align: left;
}

.t_center {
  text-align: center;
}

.t_right {
  text-align: right;
}

.bold {
  font-weight: bold;
}

.tx_min {
  font-size: 0.8em;
}

.tx_15em {
  font-size: 1.3em;
}

.red {
  color: var(--red);
}

.tx_50par {
  font-size: 0.5em;
  line-height: 160%;
}

.tx_80par {
  font-size: 0.8em;
  line-height: 160%;
}

.tx_150par {
  font-size: 1.5em;
  line-height: 160%;
}

.tx_3em {
  font-size: 3em;
  line-height: 160%;
}

.mar_top_off {
  margin-top: 0 !important;
}

.mar_top_1em {
  margin-top: 1em !important;
}

.mar_top_3em {
  margin-top: 3em !important;
}

.mar_btm_off {
  margin-bottom: 0 !important;
}

.mar_btm_1em {
  margin-bottom: 1em !important;
}

.mar_btm_2em {
  margin-bottom: 2em !important;
}

.mar_10em {
  margin: 10em 0 !important;
}

.pad_1em {
  padding: 1em;
  box-sizing: border-box;
}

.pad_lf_1em {
  padding: 0 1em 0 1em;
  box-sizing: border-box;
}

.lineheight_100 {
  line-height: 100%;
}

.w95 {
  width: 95% !important;
  margin: 0 auto;
}

.tx_border {
  border: 1px;
  border-style: none none solid none;
  border-color: #ffffff;
}

.em_bd02 {
  background: linear-gradient(transparent 70%, #ffee66 0%);
}

.box_border {
  margin: 0;
  padding: 1em;
  width: 100%;
  height: auto;
  border: 3px;
  border-style: solid;
  border-color: #ffffff;
  border-radius: 20px;
  box-sizing: border-box;
}

hr.border {
  margin: 2em 0 2em 0;
  padding: 0;
  width: 100%;
  height: 0;
  border: 1px;
  border-style: none none solid none;
  border-color: #cccccc;
}

hr.border_white {
  margin: 2em 0 2em 0;
  padding: 0;
  width: 100%;
  height: 0;
  border: 1px;
  border-style: none none solid none;
  border-color: #ffffff;
}

hr.dot_white {
  margin: 2em auto 2em auto;
  padding: 0;
  width: 80%;
  height: 0;
  border: 1px;
  border-style: none none dashed none;
  border-color: #ffffff;
}

.space_03 {
  margin: 0 0 3em 0;
  padding: 0;
  width: 100%;
  height: 0;
}

.cl2_lf {
  position: relative;
  margin: 1em 0 1em 0;
  padding: 0;
  width: 48%;
  height: auto;
  float: left;
}

.cl2_rt {
  position: relative;
  margin: 1em 0 1em 0;
  padding: 0;
  width: 48%;
  height: auto;
  float: right;
}

.cl3_lf {
  position: relative;
  margin: 1em 0.5% 1em 0;
  padding: 0;
  width: 32%;
  height: auto;
  float: left;
}

.cl3_cn {
  position: relative;
  margin: 1em 1.5% 1em 1.5%;
  padding: 0;
  width: 32%;
  height: auto;
  float: left;
}

.cl3_rt {
  position: relative;
  margin: 1em 0 1em 0.5%;
  padding: 0;
  width: 32%;
  height: auto;
  float: left;
}

.fit100 {
  width: 100%;
  height: auto;
}

.back_btn {
  position: fixed;
  bottom: 40px;
  right: 0;
  margin: 0;
  padding: 0;
  width: 180px;
  height: auto;
  z-index: 2;
}

.row_item {
  flex-grow: 1;
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  width: 100%;
  gap: 1em;
}

.row_item img {
  display: block;
  width: auto;
  margin: 0 auto;
  padding: 1rem 0;
}

.row_item_sp {
  display: none;
}

/* ////////////////////////////////// */
/* contents */
/* ////////////////////////////////// */
/*アンカーリンク画面ギリギリ回避*/
#keihin_map,
#keihin,
#score,
#course4,
#course6,
#course8,
#course10,
#course12,
#course16 {
  margin-top: -20px;
  padding-top: 20px;
}

.head_black {
  display: flex;
  flex-flow: row wrap;
  align-items: center;
  justify-content: center;
  gap: 8px 1em;
  padding: 30px 5% 10px 5%;
  text-align: center;
  background-color: var(--inv-black);
  border-bottom: solid 1px #ccc;
}
.head_black img {
  max-width: 50%;
}
.head_black p {
  margin: 0 0;
  font-weight: bold !important;
  font-size: 2.1vmin;
  color: #fff;
}

.cp_rogo {
  width: 25%;
  margin: 0 auto;
}

.contents01 {
  position: relative;
  padding: var(--cont-gap) 0 0 0;
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  z-index: 0;
  background: #e60000;
  background: repeating-linear-gradient(90deg, var(--red), var(--red) 9.1%, var(--inv-black) 9.1%, var(--inv-black) 18.2%);
}

.contents01 a {
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
  align-items: center;
  position: relative;
  margin: 0 auto;
}

.contents01 a img {
  height: 100%;
}

.contents01 a p {
  font-size: 1.4em;
  margin: 0 auto;
  padding: 10px 0;
  color: rgb(255, 255, 255) !important;
}

.contents01 > .em_08 {
  font-size: 1em;
  text-align: center;
}

.contents01 p {
  color: #FFFFFF !important;
  font-weight: 600;
  width: 100%;
  margin: 0 auto;
}

.contents01 .period {
  width: 100%;
  margin: 0 0;
  text-align: right;
  text-shadow: 2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, 0px 2px 0 #000, 0 -2px 0 #000, -2px 0 0 #000, 2px 0 0 #000;
}

.contents01 h1 {
  width: 100%;
  margin: 0 auto;
  padding: 0 var(--cont-padd) 0px;
}
.contents01 h1 img {
  margin: 0 auto;
}

.contents01 h1 p {
  font-size: 1.1rem;
  padding-bottom: 1em;
}

.fair_date_wrap {
  grid-area: date;
  width: 100%;
  margin: 0 0;
  padding: 2em 0 0 0;
}

.fair_date_container {
  display: flex;
  flex-flow: column;
  width: 50%;
  margin: 0 0 0 auto;
  padding: 1px 1em 2px 1px;
}

.fair_date {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  text-shadow: rgb(51, 51, 51) 3px 0px 0px, rgb(51, 51, 51) 2.83487px 0.981584px 0px, rgb(51, 51, 51) 2.35766px 1.85511px 0px, rgb(51, 51, 51) 1.62091px 2.52441px 0px, rgb(51, 51, 51) 0.705713px 2.91581px 0px, rgb(51, 51, 51) -0.287171px 2.98622px 0px, rgb(51, 51, 51) -1.24844px 2.72789px 0px, rgb(51, 51, 51) -2.07227px 2.16926px 0px, rgb(51, 51, 51) -2.66798px 1.37182px 0px, rgb(51, 51, 51) -2.96998px 0.42336px 0px, rgb(51, 51, 51) -2.94502px -0.571704px 0px, rgb(51, 51, 51) -2.59586px -1.50383px 0px, rgb(51, 51, 51) -1.96093px -2.27041px 0px, rgb(51, 51, 51) -1.11013px -2.78704px 0px, rgb(51, 51, 51) -0.137119px -2.99686px 0px, rgb(51, 51, 51) 0.850987px -2.87677px 0px, rgb(51, 51, 51) 1.74541px -2.43999px 0px, rgb(51, 51, 51) 2.44769px -1.73459px 0px, rgb(51, 51, 51) 2.88051px -0.838247px 0px;
  position: relative;
}
.fair_date h3 {
  color: #fafafa;
  font-size: clamp(0.813rem, 0.734rem + 0.39vw, 1rem);
  margin: 0 0;
  padding: 0.3em 0.6em 0.3em 0;
  white-space: nowrap;
  font-weight: 700;
}
.fair_date P {
  color: #fafafa !important;
  font-size: clamp(0.813rem, 0.734rem + 0.39vw, 1rem);
  width: inherit;
  margin: inherit;
  padding: 0.3em 0;
  font-weight: 700;
  white-space: nowrap;
  letter-spacing: 0.05em;
}
.fair_date P span {
  font-size: 160%;
  letter-spacing: 0.05em;
  color: inherit;
}

.dotted01 {
  width: 100%;
  height: 1px;
  background-image: linear-gradient(to right, #fff 4px, transparent 4px);
  background-size: 10px 1px;
  background-repeat: repeat-x;
  background-position: left bottom;
}

/* .contents01 span {
	position: absolute;
	bottom: 10px;
	right: 25px;
	width: 100%;

} */
.contents01_in {
  position: relative;
  width: 100%;
  padding: 0 var(--cont-padd);
  display: grid;
  grid-template-columns: 1fr 1fr;
  /*grid-template-rows: 60% 40%;*/
  grid-template-areas: "date date" "in01 in02" "in01 in05" "in03 in03" "in04 in04";
  /*align-items: end;*/
}

.contents01_in02 {
  grid-area: in02;
  align-self: end;
}

.contents01_in03 {
  grid-area: in03;
}

.contents01_in04 {
  grid-area: in04;
}

.contents01_in05 {
  grid-area: in05;
}

.contents01_in picture img {
  max-width: 400px;
  object-fit: cover;
  padding-right: 3%;
}

.contents01_in01 {
  grid-area: in01;
}

.contents01_in02 {
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
}

.contents01_in02_contenr {
  display: flex;
  flex-flow: column wrap;
  gap: 1em;
  background-color: #333;
}

.contents01_in02 > .pc {
  position: relative;
  width: 90%;
  /*height: 330px;*/
  margin: 36px auto 0 auto;
  padding: 0.5em;
}

.contents01_in05 .contents01_in02_contenr {
  padding-bottom: 2em;
}

.contents01_in04 {
  display: flex;
  flex-flow: row wrap;
  justify-content: space-around;
  gap: 12px;
  background-color: #333;
  background-color: rgba(43, 43, 43, 0.7);
  width: 100vw;
  height: calc(100% + 1px);
  max-width: 1080px;
  margin: 0 -56px;
  padding: var(--cont-gap) 2em;
}

@media only screen and (max-width: 1080px) {
  .contents01_in04 {
    min-width: 1080px;
  }
}
.contents01_in04 h3 {
  font-size: 1.6em;
  padding-bottom: 16px;
  color: #fff;
  text-shadow: 2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, 0px 2px 0 #000, 0 -2px 0 #000, -2px 0 0 #000, 2px 0 0 #000;
}

.contents01_in04 .slide {
  position: relative;
  line-height: inherit;
  max-width: 1200px;
  width: 60%;
}

.contents01_in04 .movie {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-flow: row nowrap;
  gap: 12px;
  margin: 1em 1em;
}

.illust {
  display: flex;
  flex-flow: row nowrap;
  gap: 12px;
  margin: 1em 1em;
  /*padding: 1em 4px;*/
  /*background-color: #fff;*/
}

/*
.illust figure {
	object-fit: cover;

	& figcaption {
		color: var(--dk-blue);
		font-weight: bold;
		text-align: center;
		background-color: #eee;
		border-radius: 2em;
		padding: 0.6em 4px;
		margin: 0 auto;
		margin-bottom: 0.6em;

	}

	& img {
		object-fit: cover;
		width: 100%;

	}
} */
.contents01_in02 p,
.contents01_in05 p {
  margin: 0 auto;
  color: #ffffff;
  text-align: center;
  font-size: 2vmin;
}

.contents01_in02 span,
.contents01_in05 span {
  color: orange !important;
  font-weight: 600;
  letter-spacing: 0.1em;
  padding: 0 0 0 0.1em;
}

.contents01_in03 {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  gap: 1.4em;
  width: 100%;
  padding: var(--cont-gap) 2em;
}

.contents01_in03 a {
  padding: 0;
  width: 100%;
  max-width: 374px;
  margin: 0 0;
}
.contents01_in03 a.entry {
  font-size: 1.8em;
  background: #ff7a1f;
  background: linear-gradient(to bottom, #fab75a, #ff7a1f);
}
.contents01_in03 a.BUTTON_ZLL_BKbl {
  font-size: 1.2em;
}

.speechBubble {
  position: relative;
  display: inline-block;
  margin-bottom: 20px;
  padding: 16px;
  border: 2px solid #003b6b;
  border-radius: 8px;
  background-color: #ffffff;
  text-align: left;
  font-size: 16px;
  font-weight: 400;
  line-height: 1.5;
  color: #000000;
}

.speechBubble::before {
  content: "";
  position: absolute;
  bottom: 0;
  left: 25%;
  border-style: solid;
  border-width: 20px 20px 0 0;
  border-color: #003b6b transparent transparent;
  translate: -50% 100%;
}

.speechBubble::after {
  content: "";
  position: absolute;
  bottom: 0;
  left: 25%;
  border-style: solid;
  border-width: 15.2px 15.2px 0 0;
  border-color: #ffffff transparent transparent;
  translate: calc(-50% - 0.4px) 100%;
}

.contents04,
.contents05 {
  display: flex;
  flex-direction: column;
  color: #ffffff;
  width: 100%;
  text-align: center;
  padding: var(--cont-gap) var(--cont-padd);
  background-color: var(--csd-red);
}

.contents04 {
  /*background: url(../images/contents04-back_pc.webp) no-repeat bottom/cover #a6111b;*/
  background: #a6111b;
}

.contents04 > .column {
  display: flex;
  margin: 2em auto;
}

.contents04 > .column > .column_1 {
  flex: 3;
  margin: auto;
}

.contents04 > .column > .column_1 > p {
  color: #004098;
  padding: 5% 5%;
  text-align: center;
  border-radius: 10px;
  background-color: #ffffff;
  border: 3px solid #004098;
}

.contents04 > .column > .column_2 {
  flex: 7;
  margin: 0 auto;
  padding: 0 1em;
}

.contents04 > .column > .column_2 > p {
  font-weight: bold;
  font-size: 1.2em;
  text-align: left;
  line-height: 1.5em;
}

.contents04 li {
  padding-left: 1em;
  text-indent: -1em;
  font-weight: bold;
  text-align: left;
  font-size: 1em;
  padding-bottom: 0.5em;
}

.contents05 {
  background-color: var(--csd-blue);
}

.column_3 {
  display: flex;
  flex-wrap: wrap;
}

.column_3 div {
  flex: 3;
  margin: 0 auto;
  padding: 0 1em;
}

.fit100 {
  width: 100%;
}

.back_radius {
  background: var(--ft-blue);
  border-radius: 15px;
  padding: 1em 1em;
}

.back_g_1 {
  background-color: #E87D07;
  padding: 1em 1em;
}

.back_g_2 {
  background-color: var(#262626);
  /* padding: 1em 1em; */
}

.note {
  display: flex;
  flex-direction: column;
  width: 100%;
  margin: 1em auto;
  padding: 2em 1em;
  color: #333333;
}

.note > .bg_head {
  background: #843C0C;
  width: 100%;
  /* padding: 1em 1em; */
}

.note > .bg_head_3 {
  background: #ffffff;
  padding: 2em;
  font-size: 1.1em;
}

.note > .bg_head_3 h4 {
  text-align: left;
  line-height: 1.2em;
  margin: 1em auto;
  color: #d7000f;
  font-size: 1.2em;
}

.note > .bg_head_3 > .column {
  display: flex;
  flex-wrap: nowrap;
  align-items: center;
  width: 100%;
}

.note > .bg_head_3 > .column > .columns {
  padding-right: 5px;
  margin: 2em;
  width: 20%;
}

.note > .bg_head_3 > .column > .column_1 {
  width: 50%;
}

.note > .bg_head_3 > .column > .column_2 {
  width: 50%;
}

.note ul {
  padding: 0 0 1em 0;
}

.note ul li {
  padding-left: 1em;
  text-indent: -1em;
  margin: 0 auto;
  padding: 0 0 0.5em 1em;
  line-height: 1.5;
  text-align: left;
}

.note ul li span {
  color: red;
}

.mar_2em {
  margin: 0 2em;
}

.BUTTON_ZLL {
  position: relative;
  background: #ff7a1f;
  background: linear-gradient(to bottom, #fab75a, #ff7a1f);
  border: solid #FFF 3px;
  border-radius: 10px;
  color: #FFFFFF !important;
  /* font-family: Brush Script MT; */
  font-size: 26px;
  font-size: 1.4em;
  font-weight: bold;
  letter-spacing: 0.1em;
  min-width: 364px;
  padding: 20px !important;
  text-decoration: none;
  display: flex;
  flex-flow: column wrap;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  text-align: center;
  box-shadow: 10px 10px 15px -10px hsla(0, 0%, 0%, 0.5);
}

.BUTTON_ZLL_caption, .BUTTON_ZLL.undefind p, .BUTTON_ZLL_BKbl p {
  position: absolute;
  top: calc(100% + 0.5em);
  letter-spacing: auto;
  margin: 0 auto !important;
  padding: 0 0 !important;
  font-size: 1em !important;
  text-align: center;
  color: #FFFFFF !important;
  text-shadow: 2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, 0px 2px 0 #000, 0 -2px 0 #000, -2px 0 0 #000, 2px 0 0 #000;
}

.BUTTON_ZLL_BKbl {
  background: var(--csd-blue80);
}
.BUTTON_ZLL::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  position: absolute;
  right: 20px;
  top: calc(50% - 2px);
  border-top: solid 2px;
  border-right: solid 2px;
  transform: rotate(45deg) translateY(-50%);
  color: inherit;
}

.BUTTON_ZLL.undefind {
  pointer-events: none;
  color: var(--light-glay);
  border-color: var(--light-glay);
  background: #555;
}
.btn_01 {
  border-radius: 20px;
  color: #FFFFFF !important;
  font-size: 21px;
  font-weight: 100;
  background-color: #6f3f01;
  border: solid #FFFFFF 3px;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  text-align: center;
}

.f-end {
  justify-content: flex-end !important;
}

.contents02 {
  padding: var(--cont-gap) var(--cont-padd);
  display: flex;
  flex-flow: row wrap;
  justify-content: space-around;
  gap: 1em;
  background-color: var(--light-glay);
  background-color: #333;
}

.button-junp {
  width: 13em;
  /* padding: 5px 10px; */
  padding: 10px;
  background-color: #FFFFFF;
  position: relative;
  border-radius: 12px;
  border: solid 1px var(--dk-blue);
  color: var(--dk-blue) !important;
  font-size: 16px;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  text-align: center;
}

.button-junp::after {
  content: "";
  display: block;
  width: 8px;
  height: 8px;
  position: absolute;
  right: 20px;
  top: calc(50% - 2px);
  border-top: solid 2px;
  border-right: solid 2px;
  transform: rotate(135deg) translateY(50%);
  color: inherit;
}

.contents02 img {
  width: 100%;
}

.contents03 {
  padding: var(--cont-gap) var(--cont-padd);
  background: var(--light-glay);
}

.contents03 > .note {
  width: 80%;
}

.contents03 > .note > .bg_head_3 > .apply {
  width: calc(80% + 4em);
  margin: 0 auto;
}

.contents03 .apply p {
  padding-left: 1em;
  text-indent: -1em;
  padding-bottom: 0.3em;
  margin: 0 auto;
  font-size: 1.2em;
  line-height: 140%;
}

.contents03 p.tx_min {
  padding-left: 2em;
  text-indent: -1em;
  font-weight: normal;
  font-size: 1em;
  line-height: 160%;
}

h2 {
  width: 40%;
  margin: 0 auto;
  padding: 0.4em 0;
  text-align: center;
  background-color: var(--dk-blue);
  color: #FFF;
  border: solid 1px #FFF;
  font-size: 1.8em;
  letter-spacing: 0.1em;
}

.entry {
  display: flex;
  justify-content: center;
}

#keihin h3 {
  text-align: center;
  font-size: 1.8em;
  color: #6f3f01;
  padding: 0.8em 0;
}

.course_Anchor ul {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 1em 1em;
}

.course_Anchor li {
  width: 25%;
  text-align: center;
}

.course_Anchor li a {
  scroll-behavior: smooth;
  display: block;
  padding: 1em;
  border-radius: 10px;
  background-color: #6d3f01;
  color: #fdf300;
}

.course_Anchor li:hover {
  opacity: 0.8;
  color: #fdf300;
}

.course_Anchor li a:hover {
  opacity: 0.8;
  color: #fdf300;
}

.course_Anchor a:visited {
  color: #fdf300;
}

.course_container {
  width: 90%;
  margin: 0 auto;
}

.course_container h3 {
  margin: 1em auto;
  padding: 0.3em 0.5em;
  font-size: 2em;
  color: #6d3f01;
  border-bottom: 3px solid #6d3f01;
}

.item_container {
  display: flex;
  flex-flow: column nowrap;
  gap: 1em 0;
  /*padding-bottom: 3em;*/
}

.item {
  position: relative;
  display: flex;
  flex-flow: row nowrap;
  align-items: flex-start;
  width: 100%;
  gap: 0 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #b3b3b3;
}

.item figure {
  position: relative;
  margin: 0;
  width: 50%;
  height: auto;
}

.item img {
  width: 100%;
  height: auto;
}

.item p {
  width: 50%;
  box-sizing: border-box;
}

.hk_map {
  position: relative;
}

.hk_map .top-right {
  position: absolute;
  top: 0;
  right: 5%;
  width: 25%;
}

.top-right img {
  width: 100%;
}

.top-right p {
  width: 100%;
  font-size: 80%;
  white-space: nowrap;
}

.hk_map .btm-right {
  position: absolute;
  display: inline-block;
  bottom: 10px;
  right: 25px;
  width: 52%;
}

.hk_map .top-left {
  position: absolute;
  top: 7%;
  left: 2%;
  width: 240px;
  height: 116px;
}

.hk_map .top-left img {
  width: 100%;
}

.hk_map .top-left:after {
  position: absolute;
  display: inline-block;
  content: "";
  background-image: url(../images/point.png);
  background-size: contain;
  vertical-align: middle;
  width: 54px;
  height: 54px;
  top: 25%;
  left: 95%;
  transform: rotate(30deg);
}

.map_drink {
  position: absolute;
  display: flex;
  flex-flow: column wrap;
  bottom: 10px;
  right: 25px;
  width: 52%;
  background-color: rgba(255, 255, 255, 0.6);
  border: solid 1px #a88c66;
  border-radius: 1em;
}

.map_drink img {
  width: 100%;
}

.map_drink p {
  width: 100%;
  font-size: 80%;
  text-align: right;
  padding-bottom: 0.8em;
}

#keihin h2 img {
  width: 100%;
}

.list-container {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
  gap: 1em 1em;
  padding: 20px 0;
  background-color: #f4efe9;
}

.list-container h2 {
  width: 95%;
  margin: auto 0;
  padding: 0.8em 0 0 0;
}

.list-container .caption {
  width: 90%;
  margin: auto 0;
  padding: 3px 0;
  border: 2px solid;
  color: #ffffff;
  text-align: center;
  font-size: 1.5em;
  font-weight: bold;
  background-color: #4472C4;
}

.list-item {
  display: flex;
  flex-flow: column wrap;
  width: calc(33.3333333333% - 2em);
  background-color: #FFF;
  border: solid 1px #a88c66;
  border-radius: 1em;
}

.list-container::after {
  /* 奇数の場合最後のボックスを左寄せ*/
  content: "";
  display: block;
  width: calc(33.3333333333% - 2em);
  height: auto;
}

.list-container::before {
  /* 奇数の場合最後のボックスを左寄せ*/
  content: "";
  display: block;
  order: 1;
  width: calc(33.3333333333% - 2em);
  height: auto;
}

.list-item img {
  order: 3;
  width: 100%;
  overflow: hidden;
  border-radius: 1em;
}

.list-item p {
  order: 2;
  width: 100%;
  padding: 1% 2.5% 1% 2.5%;
}

.list-item h3 {
  order: 1;
  color: #6d3f00;
  padding: 4% 2.5% 1% 2.5%;
}

.itemset {
  position: relative;
  display: grid;
  grid-template-columns: 16% auto 8% 50%;
  grid-template-rows: auto auto auto;
  grid-auto-flow: row;
  align-self: center;
  justify-self: center;
  grid-template-areas: "item-images item-images item-images item-p" "course name auto item-p" "area name number item-p";
  gap: 0 10px;
  padding-bottom: 1em;
  border-bottom: 1px solid #b3b3b3;
  box-sizing: border-box;
}

.no-border-bottom {
  border-bottom: none;
}

.itemset .images {
  grid-area: item-images;
}

.itemset figure {
  position: relative;
  margin: 0;
}

.itemset i {
  box-sizing: border-box;
  position: absolute;
  width: 80px;
  display: inline-block;
  top: 0;
  left: 0;
  z-index: 1;
}

.score4 {
  content: url(../images/score04.png);
}

.score6 {
  content: url(../images/score06.png);
}

.score8 {
  content: url(../images/score08.png);
}

.score10 {
  content: url(../images/score10.png);
}

.score12 {
  content: url(../images/score12.png);
}

.score16 {
  content: url(../images/score16.png);
}

.itemset img {
  width: 100%;
  height: auto;
}

.itemset .coment {
  grid-area: item-p;
  display: flex;
  flex-flow: column wrap;
  padding: 0;
  line-height: 1.8em;
}

.itemset .caption {
  /*grid-area: coment;*/
  margin: 1em 0 1em 0;
}

.itemset .capa {
  /*grid-area: capa;*/
  margin: 1em 0 1em 0;
}

.itemset .keep {
  /*grid-area: keep;*/
  margin: 1em 0 1em 0;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.itemset .keep i {
  position: relative;
  width: 40px;
  height: 40px;
}

.itemset .course {
  grid-area: course;
  display: flex;
  align-items: center;
  margin: 0 auto;
  padding: 0.5em;
  background-color: #e6d6bf;
  width: 100%;
  font-size: 1.6em;
  font-weight: 600;
  box-sizing: border-box;
}

.itemset .course:before {
  content: "コース番号 ";
  font-size: 0.5em;
  padding-right: 0.5em;
}

.itemset .name {
  grid-area: name;
  width: 100%;
  padding: 0.3em 0;
  font-size: 1.4em;
  box-sizing: border-box;
}

.itemset .area {
  grid-area: area;
  margin: 0 auto;
  padding: 0.3em 0;
  width: 100%;
  font-size: 2.3vmin;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-align: center;
  background-color: #b7dc95;
  box-sizing: border-box;
}

.itemset .number {
  grid-area: number;
  align-self: end;
  display: flex;
  justify-content: center;
  align-items: flex-end;
  border-top-left-radius: 20px;
  background-color: #6d3f00;
  color: #FFF;
  padding: 8px 0 6px 0;
  font-size: 1.8em;
  font-weight: 600;
  box-sizing: border-box;
  vertical-align: bottom;
}

.itemset .number:after {
  font-size: 0.5em;
  content: " 名様";
  padding: 0 0 3px 2px;
}

.areaback {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 80%;
  margin: 1em auto;
}

.areaback p {
  padding: 1em 1em;
  color: #6d3f00;
  /*border: solid 1px #a88c66;
  border-radius: 1em;*/
}

.areaback:before,
.areaback:after {
  content: "";
  height: 2px;
  flex-grow: 1;
  background-color: #a88c66;
}

.areaback:before {
  /* margin-right: ; */
}

.areaback:after {
  /* margin-left: ; */
}

.caption_box {
  position: relative;
  margin-top: 7em;
  padding: 1em 1em;
  border-top: 1px solid black;
}

.caption_box .caption {
  position: absolute;
  top: -20%;
  left: -2em;
  font-size: 1em;
  color: white;
  padding: 0 2em 0 0.5em;
  margin: 11px;
  border-radius: 60% 0% 100% 0%/90% 100% 0% 62%;
  width: 200px;
  height: 40px;
  background-color: #db0f2f;
  transform: translateY(-115%) translateX(1em);
}

.cg_color {
  background-color: #1c85d8 !important;
}

.caption_box .text {
  position: absolute;
  top: -50%;
  left: 50%;
  width: 200px;
  font-size: 2em;
  font-weight: bold;
  color: white;
  text-align: center;
  /* padding: 0.1em 0.5em 0.2em 0em; */
  margin: 1em 0em 1em 0;
  transform: translateX(-50%);
  -webkit-transform: translateX(-50%);
  -ms-transform: translateX(-50%);
  /* text-align: center; */
}

.item_container h3 {
  border-radius: 1.25em;
  margin: 2em 0 1em 0;
  padding: 0.5em;
  border-bottom: none;
  color: white;
  font-size: 1.7em;
}

.item_container h3:before {
  content: "●";
  color: #fff;
  margin-right: 0.3em;
}

.h_area {
  background-color: #db0f2f;
}

.h_score {
  background-color: #1c85d8 !important;
}

.s_01 .accordion_one {
  max-width: 1024px;
  margin: 0 auto;
}

.s_01 .accordion_one .accordion_header {
  background-color: #ffffff;
  color: #013E97;
  font-size: 1.5em;
  font-weight: bold;
  padding: 20px 11%;
  text-align: center;
  position: relative;
  z-index: 1;
  cursor: pointer;
  transition-duration: 0.2s;
  border: solid 2px #013E97;
}

.s_01 .accordion_one .accordion_header .bg_grn {
  background-color: #1cf54b;
  color: #fff;
  font-size: 1.5em;
  font-weight: bold;
  padding: 20px 11%;
  text-align: center;
  position: relative;
  z-index: 1;
  cursor: pointer;
  transition-duration: 0.2s;
}

.s_01 .accordion_one:nth-of-type(2) .accordion_header {
  background-color: #ff9a05;
}

.s_01 .accordion_one:nth-of-type(3) .accordion_header {
  background-color: #1c85d8;
}

.s_01 .accordion_one .accordion_header:hover {
  opacity: 0.8;
}

.s_01 .accordion_one .accordion_header .i_box {
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  top: 50%;
  right: 5%;
  width: 40px;
  height: 40px;
  border: 1px solid #E87D07;
  margin-top: -20px;
  box-sizing: border-box;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
}

.s_01 .accordion_one .accordion_header.stay .i_box {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.s_01 .accordion_one .accordion_header .i_box .one_i {
  display: block;
  width: 18px;
  height: 18px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  transform-origin: center center;
  transition-duration: 0.2s;
  position: relative;
}

.s_01 .accordion_one .accordion_header.stay .i_box .one_i {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.s_01 .accordion_one .accordion_header.stay.open .i_box .one_i {
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.s_01 .accordion_one .accordion_header.open .i_box {
  -webkit-transform: rotate(-360deg);
  transform: rotate(-360deg);
}

.s_01 .accordion_one .accordion_header.stay.open .i_box {
  -webkit-transform: rotate(315eg);
  transform: rotate(315deg);
}

.s_01 .accordion_one .accordion_header .i_box .one_i:before,
.s_01 .accordion_one .accordion_header .i_box .one_i:after {
  display: flex;
  content: "";
  background-color: #E87D07;
  border-radius: 10px;
  width: 18px;
  height: 4px;
  position: absolute;
  top: 7px;
  left: 0;
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
  transform-origin: center center;
}

.s_01 .accordion_one .accordion_header .i_box .one_i:before {
  width: 4px;
  height: 18px;
  top: 0;
  left: 7px;
}

.s_01 .accordion_one .accordion_header.stay .i_box .one_i:before {
  content: none;
}

.s_01 .accordion_one .accordion_header.open .i_box .one_i:before {
  content: none;
}

.s_01 .accordion_one .accordion_header.stay.open .i_box .one_i:before {
  content: "";
}

.s_01 .accordion_one .accordion_header.open .i_box .one_i:after {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.s_01 .accordion_one .accordion_header.stay.open .i_box .one_i:after {
  -webkit-transform: rotate(0deg);
  transform: rotate(0deg);
}

.s_01 .accordion_one .tast_accordion_inner {
  display: none;
  padding: 0px;
  border-left: 2px solid #013E97;
  border-right: 2px solid #013E97;
  border-bottom: 2px solid #013E97;
  box-sizing: border-box;
}

.s_01 .accordion_one .tast_accordion_inner.stay {
  display: block;
}

.s_01 .accordion_one:nth-of-type(2) .tast_accordion_inner {
  border-left: 2px solid #ff9a05;
  border-right: 2px solid #ff9a05;
  border-bottom: 2px solid #ff9a05;
}

.s_01 .accordion_one:nth-of-type(3) .tast_accordion_inner {
  border-left: 2px solid #1c85d8;
  border-right: 2px solid #1c85d8;
  border-bottom: 2px solid #1c85d8;
}

.s_01 .accordion_one .tast_accordion_inner .box_one {
  height: auto;
  padding: auto;
}

.s_01 .accordion_one .tast_accordion_inner .box_one .caption {
  width: 95%;
  margin: 1em auto;
  padding: 3px 0;
  border: 2px solid;
  color: #ffffff;
  text-align: center;
  font-size: 1.5em;
  font-weight: bold;
  background-color: #4472C4;
}

.s_01 .accordion_one .tast_accordion_inner .box_one .head {
  padding: 0 0 0 2.5vw;
  color: #000000;
  text-align: left;
  font-size: 1.5em;
  font-weight: bold;
}

.s_01 .accordion_one .tast_accordion_inner .box_one ul {
  display: flex;
  list-style-type: none;
  padding: 0;
  flex-wrap: wrap;
  width: 100%;
}

.s_01 .accordion_one .tast_accordion_inner .box_one ul li {
  /* display: inline-flex; */
  align-self: auto;
  /* flex: 1; */
  border-right: 1px solid #fff;
  width: 12.5%;
  font-size: 1.2em;
  font-weight: bold;
  /* margin: 0 auto; */
  text-align: center;
  padding-bottom: 10px;
}

.s_01 .accordion_one .tast_accordion_inner .box_one ul::before::after {
  content: "after";
  width: 12.5%;
}

.s_01 .accordion_one .tast_accordion_inner p.txt_a_ac {
  margin: 0;
}

area {
  border: none;
  outline: none;
}

nav {
  display: none;
}

.nav-open {
  padding: 5px;
  color: #fff;
  font-size: 20px;
  background: #6EB92B;
  position: relative;
  margin: 0;
  text-align: center;
}

.nav-open::before {
  /* 開いている時 */
  content: "－";
  position: absolute;
  right: 20px;
}

.nav-open.active::before {
  /* 閉じている時 */
  content: "＋";
}

.cardlayout-wrap {
  /* position: relative; */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  margin: 0 auto;
  /* max-width: 1280px; */
  width: 100%;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between;
}

.cardlayout-wrap img {
  /* display: block; */
  max-width: 100%;
  height: auto;
}

.card-list {
  width: 16.6666666667%;
  text-align: center;
  margin: 1em;
}

.card-title {
  margin-top: auto;
  text-align: center;
  font-weight: bold;
}

.card-list img {
  width: 100%;
}

.list_az {
  display: flex;
  flex-direction: column;
  margin: 2em auto;
  width: 26.6666666667%;
  text-align: center;
}

.list_az img {
  width: 100%;
}

.list2 {
  width: 40%;
}

.list3 {
  width: calc((100% - 1em) / 3);
  flex-wrap: wrap;
}

.list4 {
  width: 20%;
}

/*景品グリッド*/
.prize_containers {
  display: grid;
  grid-auto-columns: auto;
  grid-auto-rows: auto;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: minmax(250px) 250px 250px;
  grid-template-areas: "div1 div1" "div2 div2" "div3 div4" "div3 div5";
  justify-items: center;
  align-items: center;
  align-items: stretch;
  margin: 0 auto;
  gap: 1em 1em;
  display: -ms-grid-columns;
  -ms-grid-columns: 1fr 1fr 1fr;
  -ms-grid-rows: auto auto;
}

.prize_containers > div p, p.em_gift {
  font-family: "Noto Sans JP", sans-serif;
  /* word-break: keep-all;
  	overflow-wrap: anywhere; */
  width: 100%;
  color: #000;
  font-size: 1em;
  line-height: 1.2;
  margin: 0;
  padding: 1% 1.5% 2% 1.5%;
  align-self: flex-end;
}

.prize_containers h3 {
  font-family: "Noto Sans JP", sans-serif;
  word-break: keep-all;
  overflow-wrap: anywhere;
  text-align: left;
  font-size: clamp(1.5rem, 1.364rem + 0.68vw, 1.875rem);
  line-height: 1.4;
  font-feature-settings: "palt";
  color: #000;
  padding: 1% 0 2% 2%;
  width: 100%;
}
.prize_containers h3 span {
  display: inline-block;
  font-size: 75%;
}

.prize_containers > div {
  width: 100%;
  position: relative;
  background: #FFF;
  border: solid var(--csd-blue) 2px;
  border-radius: 1em;
  display: flex;
  flex-flow: wrap;
  align-items: flex-start;
}

.prize_containers > div .containers {
  display: flex;
  position: relative;
  flex-flow: wrap;
  margin: 0 auto;
}

.div1 {
  grid-area: div1;
}
.div1 .containers {
  width: 80%;
}
.div1 h3 {
  padding: 1% 3% 2% 3%;
  line-height: 1.6;
}
.div1 p {
  padding: 1% 2% 2% 2%;
}
.div1 .t_center {
  display: flex;
  justify-content: center;
  width: 100%;
  margin-bottom: 1em;
}
.div1 .t_center a {
  background-color: #d4e8f2;
  width: 15em;
}

.div1_01 {
  position: relative;
  margin: 0 auto;
}

.div1_02 {
  width: 65%;
}

.div1_03 {
  width: 35%;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.div1_03::after {
  clear: both;
}

.div2 {
  grid-area: div2;
}

.div3 {
  grid-area: div3;
}

.div4 {
  grid-area: div4;
}

.div5 {
  grid-area: div5;
}

.div6 {
  grid-area: div6;
}

.div7 {
  grid-area: div7;
}

.div8 {
  grid-area: div8;
}

.div1 span.icon {
  position: absolute;
  width: 280px;
  top: -36px;
  left: auto;
  right: 34px;
}
.div1 span.icon img {
  width: 100%;
}

.gift_a-cast {
  display: flex;
  flex-direction: row;
  padding: 1% 4% 0 4%;
  gap: 2%;
}
.gift_a-cast figure {
  position: relative;
  margin: 0 0;
}
.gift_a-cast figure img {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  object-fit: cover;
}
.gift_a-cast figcaption {
  line-height: 20px;
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  top: auto;
  bottom: -1%;
  display: flex;
  justify-content: center;
  align-items: baseline;
  width: 90%;
  margin: 0 auto;
  padding: 8px 0;
  background-color: #d7000f;
  border-radius: 30px;
  line-height: 1;
  z-index: 1;
}
.gift_a-cast figcaption span {
  font-size: 80%;
  position: relative;
  vertical-align: baseline;
  width: auto;
  top: inherit;
  right: inherit;
}

div.div2 .containers {
  display: grid;
  width: 80%;
}
div.div2 .containers .div2_01 {
  grid-column: 1/2;
  grid-row: 1/2;
}
div.div2 .containers .div2_02 {
  align-self: center;
  grid-column: 2/3;
  grid-row: 1/4;
  height: auto;
  max-height: 250px;
}
div.div2 .containers h3 {
  grid-column: 1/2;
  grid-row: 2/3;
}
div.div2 .containers p {
  grid-column: 1/2;
  grid-row: 3/4;
}

.div3 {
  gap: 0 0;
}

.div3 > .gift_c_02 {
  text-align: right;
  margin: 0 0 0 auto;
  padding: 2% 3% 2% 1%;
  display: flex;
  flex-flow: row-reverse nowrap;
  align-items: stretch;
}
.div3 > .gift_c_02 img {
  width: 40%;
}
.div3 > .gift_c_02 .gift_c_02_text {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  width: 60%;
  padding: 1% 1.5% 2% 1.5%;
}
.div3 > .gift_c_02 p.caption {
  font-size: 1.18em;
}

.div5 img {
  width: 80%;
  margin: 0 auto;
}

/*対象商品 */
#applitem > .prize_containers {
  width: 85%;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-areas: "div1 div2 div3" "p p p";
}
#applitem > .prize_containers div {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  padding: 0.5em;
}
#applitem > .prize_containers h4 {
  width: 90%;
  margin: 0 auto;
}
#applitem > .prize_containers img {
  width: 100%;
  height: auto;
}
#applitem > .prize_containers p {
  font-size: 1.18em;
}
#applitem > .prize_containers .txt {
  grid-area: p;
  width: 100%;
  margin: 0 0;
}

.sm-wrap {
  /* position: relative; */
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  margin: 0 auto;
  /* max-width: 1280px; */
  width: 100%;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-pack: justify;
  justify-content: space-between;
}

.sm-wrap img {
  /* display: block; */
  max-width: 100%;
  height: auto;
}

#prize_details.contents03 {
  background: #a6111b;
  padding: var(--cont-gap) 0;
}
#prize_details.contents03 .note {
  margin: 0 auto;
  padding: 0 1em;
}
#prize_details.contents03 dl {
  display: flex;
  flex-flow: row wrap;
  width: 100%;
  font-size: 1.2em;
  line-height: 1.6;
}
#prize_details.contents03 dt {
  flex: 0 0 20%;
  padding: 8px 8px 8px 1.5em;
  background-color: #DADADA;
  text-align: left;
  border-bottom: solid 1px #ccc;
  margin: 0 0;
}
#prize_details.contents03 dd {
  flex: 0 0 80%;
  padding: 8px 8px 8px 1em;
  background-color: #f8f8f8;
  text-align: left;
  border-bottom: solid 1px #ccc;
  margin: 0 0;
}

.fotter_button {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  gap: 2em;
  width: 80%;
  margin: 0 auto;
  padding: 5em 2em 0 2em;
}
.fotter_button a {
  width: 100%;
  width: 100%;
  max-width: 410px;
  font-size: 1.2em;
}

/* color */
.white {
  color: #ffffff !important;
}

/* ページ一番上に戻るボタン */
#topBtn {
  height: 50px;
  position: absolute;
  bottom: 636px;
  right: calc((100vw - 1200px) / 2);
  right: 10px;
  z-index: 2;
  display: none;
  color: #FF9900;
  opacity: 0.7;
}

#topBtn:hover {
  opacity: 1 !important;
}

#topBtn.is-fixed {
  position: fixed;
  bottom: 4px;
}

#topBtn a::before {
  display: inline-block;
  content: url("../images/top_back.svg");
  line-height: 50px;
  width: 50px;
  height: 50px;
}

.topBtn_box {
  display: inline-block;
  height: 20px;
}

#footer {
  display: block;
}

.clear {
  content: " ";
  clear: both;
  height: 0;
}

.apply_inner01 {
  display: flex;
  justify-content: center;
  align-items: center;
}

.apply p {
  font-size: 1.2em;
  margin: 0 0 0 0;
  padding-left: 1em;
  text-indent: -1em;
}

.apply h3 {
  width: 100%;
  margin: 0 auto;
  padding: 0.8em 0;
  font-size: 2.3vmin;
  font-weight: 400;
  line-height: 1.4;
  padding-left: 1.2em;
  text-indent: -1em;
  /* text-align: center;
  color: #E8380D; */
}
.apply h3 i {
  font-style: normal;
  margin-left: -0.2em;
  padding-right: 0.2em;
}

.apply h5 {
  width: fit-content;
  min-width: 100%;
  margin: 1.8em auto 0 auto;
  padding: 0.8em 2em;
  text-align: center;
  color: #003B6B;
  background: #d0dee5;
}

.apply h5 + p {
  width: 100%;
  margin: 0 auto;
  padding: 0.8em 0 0 0;
  text-align: center;
  color: #a6111b;
  font-size: 1.4em !important;
  font-weight: 600 !important;
}

.contents03 hr {
  margin: 2em 0;
  border: 1px dashed;
}

.apply_inner01 h4 {
  width: 20%;
  min-width: inherit;
  text-align: center;
  display: flex;
  flex-flow: column;
  margin: 0 0 !important;
  padding: 0 0;
  padding-right: 1em;
  background: none;
}

.apply_inner01 h4 img {
  max-width: 128px;
}

.apply_inner01 h4 + p {
  width: 80%;
  font-size: 1em !important;
  text-indent: inherit;
  font-weight: 700;
  display: inline-block;
  color: #111 !important;
  text-align: left;
}

.apply_inner01 p span {
  color: #E50718;
}

.apply_box1 {
  border: solid 2px var(--light-glay);
  border-radius: 6px;
  padding: 1em;
  margin: 1em 0;
}

.button-notes {
  width: 13em;
  /* padding: 5px 10px; */
  padding: 10px;
  background-color: #FFFFFF;
  position: relative;
  border-radius: 12px;
  border: solid 1px var(--dk-blue);
  color: var(--dk-blue) !important;
  font-size: 16px;
  font-weight: 100;
  letter-spacing: 0.1em;
  text-decoration: none;
  display: inline-block;
  cursor: pointer;
  text-align: center;
  display: inline;
  background: var(--light-blue);
  box-sizing: border-box;
  margin: 1px 5px;
  padding: 4px 10px;
  font-size: 0.8em;
  font-weight: 400;
  white-space: nowrap;
  line-height: 28px;
}

/*//// モーダル ////*/
/* モーダルの背景 */
dialog {
  all: unset;
  display: revert;
}

.modal {
  position: fixed;
  /* 画面に固定 */
  z-index: 999;
  /* 他の要素の上に表示 */
  left: 0;
  top: 0;
  width: 100%;
  /* 全幅 */
  height: 100%;
  /* 全高さ */
  overflow: auto;
  /* スクロール可能 */
  background-color: rgb(0, 0, 0);
  /* 背景色 */
  background-color: rgba(0, 0, 0, 0.4);
  /* 透過 */
}

dialog::backdrop {
  background: rgba(94, 94, 94, 0.5);
  backdrop-filter: blur(4px);
}

body.is-modal {
  /* 追加 */
  overflow: hidden;
}

dialog::backdrop {
  background: rgba(94, 94, 94, 0.5);
  backdrop-filter: blur(4px);
}

body.is-modal {
  overflow: hidden;
}

dialog {
  /* 追加 */
  padding: 0;
}

.dialog_inner {
  /* 追加 */
  padding: 16px;
}

/* モーダルコンテンツ */
.modal-Wrap {
  display: flex;
  height: 100%;
  justify-content: center;
  align-items: center;
}

.modal-content {
  display: flex;
  flex-flow: column wrap;
  background-color: #fefefe;
  margin: 1em;
  padding: 3em 3em;
  border: 1px solid #888;
  width: fit-content;
  /* 幅 */
  max-width: 760px;
  height: fit-content;
  border-radius: 6px;
  z-index: 2;
  /* 他の要素の上に表示 */
  position: relative;
}
.modal-content h1 {
  font-size: var(--font-size-L);
}
.modal-content h2 {
  font-size: var(--font-size-L);
  color: var(--main-colorAA);
  padding: 1rem 0;
}
.modal-content h3 {
  width: 100%;
  text-align: left;
  font-size: var(--font-size-L);
}

.modal-content__inner {
  /*overflow-y: scroll;*/
  position: relative;
  background-color: #fff;
}

.js_modalClose {
  position: absolute;
  top: 20px;
  bottom: auto;
  left: auto;
  right: 20px;
  width: 26px;
  height: 26px;
  font-size: large;
  cursor: pointer;
  z-index: 1001;
}

:root {
  --icon-width: 3px;
  --icon-color: black;
}

.js_modalClose:before,
.js_modalClose:after {
  content: "";
  position: absolute;
  top: 4px;
  width: 24px;
  height: var(--icon-width);
  background-color: currentColor;
  border-radius: 10px;
}

.js_modalClose:before {
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.js_modalClose:after {
  left: 1px;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}

.modal-content .in_cart {
  max-width: 600px;
  margin: 0 auto;
}

/* グレーアウト */
.overlay_button {
  position: relative;
  pointer-events: none;
}

.overlay_button::before {
  content: "本キャンペーンは終了いたしました。";
  position: absolute;
  top: -10%;
  left: -4%;
  width: 108%;
  height: 120%;
  background-color: rgba(61, 61, 61, 0.8);
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  text-shadow: 2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, 0px 2px 0 #000, 0 -2px 0 #000, -2px 0 0 #000, 2px 0 0 #000;
}

.overlay_section {
  position: relative;
  pointer-events: none;
}

.overlay_section::before {
  content: "本キャンペーンは終了いたしました。";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(61, 61, 61, 0.8);
  z-index: 9999;
  display: flex;
  justify-content: center;
  align-items: center;
  color: #FFFFFF !important;
  font-size: clamp(1rem, 0.947rem + 0.26vw, 1.125rem);
  font-weight: 700;
  text-shadow: 2px 2px 0 #000, -2px -2px 0 #000, -2px 2px 0 #000, 2px -2px 0 #000, 0px 2px 0 #000, 0 -2px 0 #000, -2px 0 0 #000, 2px 0 0 #000;
}/*# sourceMappingURL=consadole_cp-event.css.map */