@charset "UTF-8";

/*********************************************************************************************

	MODAL

**********************************************************************************************/
body.page { background-color: #fff; }

.modal_bg {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 6666;
  display: none;
  width: 100%;
  height: 120%;
  background-color: rgba(0, 0, 0, 0.7);
  display: block;
}

.modal {
  position: fixed;
  z-index: 7777;
  display: none;
  height: calc(100vh - 200px);
  min-height: 360px;
  max-width: 1000px;
  width: 100%;
  border-radius: 16px;
  -webkit-box-shadow: 0px 2px 8px 0 rgba(0, 0, 0, 0.1);
          box-shadow: 0px 2px 8px 0 rgba(0, 0, 0, 0.1);
  background: #fff;
  /*
  padding: 50px 10px 0px 50px;
  */
  padding: 10px;
}
.is-step {
  padding: 30px 10px 20px 30px;
}

@media screen and (max-width: 767px) {
  .modal {
    padding: 20px 10px 0px 20px;
    height: calc(100vh - 33%);
    min-height: 360px;
    max-width: 90%;
  }
}


/* 閉じる */
.btn-close a {
  display: block;
  background-color: #DF6035;
  border: 1px solid #fff;
  border-radius: 20px;
  width: 120px;
  height:36px;
  font-size:1.8rem;
  font-weight: 500;
  line-height:34px;
  color:#fff;
  text-align: center;
  float:right;
}
.btn-close a span {
  position: relative;
  padding-left:20px;
}
.btn-close a span::before {
  content:"";
  width: 14px;
  height:14px;
  background: url(../../img/plusmember/b-close.png) 0 0 no-repeat;
  background-size: 100%;
  position: absolute; top:7px; left:0;
}

@media screen and (min-width: 770px) {
  .btn-close {
    position: absolute;
    top: -60px; right: 0px;
  }
}

@media (max-width: 769px) {
  .btn-close { margin: 40px 0 0 0; }
  .btn-close a {
    border-radius: 12px;
    width: 25%;
    height:26px;
    font-size:1.4rem;
    line-height:24px;
    float:none;
    margin:0 auto;
  }
  .btn-close a span { padding-left:15px; }
  .btn-close a span::before {
    width: 10px;
    height:10px;
    top:5px;
  }
}



/* モーダル箱 */
.modal_inner {
  height: 100%;
  overflow-y: scroll;
}

.mo-wrap {
  background-color: #fff;
  overflow: hidden;
  padding: 40px;
}
#modal_step .mo-wrap { padding: 40px 50px 0px 40px; }

.is-step .mo-wrap { padding-right: 20px; }
.is-step .step-ttl { margin-top:0; }

#modal_coupon .mo-wrap { padding: 40px 50px 0px 40px; }

.is-coupon .mo-wrap { padding-right: 20px; }
.is-coupon .coupon-ttl { margin-top:0; }

.mo-wrap_inner {
  background-color: #F5F5F5;
  border-radius: 8px;
  min-height:80vh
}
.modal_inner::-webkit-scrollbar {
  background: #fff;
  width: 8px;
}
.modal_inner::-webkit-scrollbar-thumb {
  background-color: #F5A200;
  border-radius: 5px;
}


  
.mo-wrap_inner p.t-note,
.l-note li {
  font-size: 1.4rem;
  line-height: 1.4;
  font-weight: 400;
  letter-spacing: 0.06em;
  color: #8C8C8C;
  margin: 1em 0 0 0;
  padding:0 0 0 1em;
  text-indent: -1em;
}
.l-note li { margin:0 0 5px; }

.mo-ttl {
  border-radius: 8px 8px 0 0;
  padding: 20px 0;
  position: relative;
  margin-bottom:55px;

  font-size:3.2rem;
  font-weight: 700;
  text-align: center;
  color:#fff;
}

.mo-ttl::before,
.mo-ttl::after {
  content:"";
  width: 56px;
  height:56px;
  background: url(../../img/plusmember/member_3.png) 0 0 no-repeat;
  background-size: 100%;
  position: absolute; top:50%;
  -webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}
.mo-ttl::before { left: 12px; }
.mo-ttl::after  { right:12px; }

.mo-ttl.rank-2::before,
.mo-ttl.rank-2::after { background: url(../../img/plusmember/member_2.png) 0 0 no-repeat; background-size: 100%; }

.mo-ttl.rank-3::before,
.mo-ttl.rank-3::after { background: url(../../img/plusmember/member_1.png) 0 0 no-repeat; background-size: 100%; }


@media (max-width: 769px) {
  .mo-wrap { padding: 10px; }  
  #modal_step .mo-wrap { padding: 10px 15px 10px 5px; }

  #modal_coupon .mo-wrap { padding: 10px 15px 10px 5px; }

  .mo-wrap_inner p.t-note,
  .l-note li {
    font-size: 1.2rem;
    line-height: 1.4;
  }
  .mo-ttl {
    padding: 8px 0;
    margin-bottom:25px;
    font-size:1.6rem;
    line-height:1.4;
  }
  .mo-ttl::before,
  .mo-ttl::after {
    width: 28px;
    height:28px;
  }
  .mo-ttl::before { left: 8px; }
  .mo-ttl::after  { right:8px; }
}



.mo-inner {
  margin:0 50px;
  padding-bottom:30px;
}

.mo-kikan { margin-bottom:24px; }
.mo-kikan_ttl {
  background-color: #8C8C8C;
  text-align: center;
  font-size: 2.8rem;
  font-weight: 700;
  color:#fff;
  padding: 10px 0;
  width: 200px;
}

.mo-kikan_day {
  background-color: #fff;
  text-align: center;
  font-size: 2.8rem;
  font-weight: 500;
  width: calc(100% - 200px);
  padding-top:8px;
}

@media (max-width: 769px) {
  .mo-inner { margin:0 20px; }
  .mo-kikan { margin-bottom:15px; }
  .mo-kikan_ttl {
    font-size: 1.5rem;
    padding: 7px 0;
    width: 100%;
  }
  .mo-kikan_day {
    font-size: 1.5rem;
    width: 100%;
    padding:8px 0;
  }
}



/* 各支アンカー */
.branch-menu { margin: 35px 0 70px 0; }
.branch-menu_box { width: calc(50% - 3px); }

.branch-list li {
  width: calc(50% - 3px);
  margin:0 0 6px;
}
.branch-list a {
  display: block;
  background-color: #fff;
  text-align: left;
  padding: 10px 10px;
  font-size: 1.3rem;
  font-weight:500;
  position: relative;
}
.branch-list a:hover { background-color: #feefe8; }
.a-nonowa a:hover { background-color: #f5fcf1; }

.branch-list a::after {
  content:"";
  width: 12px;
  height:12px;
  background: url(../../img/plusmember/i-arw_a.png) 0 0 no-repeat;
  background-size: 100%;
  position: absolute; top:50%; right: 10px;
  -webkit-transform: translateY(-50%);
	transform: translateY(-50%);
}

.a-nonowa a::after {
  background: url(../../img/plusmember/i-arw_b.png) 0 0 no-repeat;
  background-size: 100%;
}

.area-menu .box-grid::after {
  content:"";
  display: block;
  width: calc(33.3333% - 3px);
}
.area-menu li { width: calc(33.3333% - 3px); }
.area-menu a:hover { background-color: #eee; }
.area-menu a::after {
  background: url(../../img/plusmember/i-arw_c.png) 0 0 no-repeat;
  background-size: 100%;
}


@media (max-width: 769px) {
  .branch-menu { margin: 30px 0 35px 0; }
  .branch-menu_box { width: calc(50% - 3px); }

  .branch-list li {
    width: 100%;
    margin:0 0 6px;
  }
  .branch-list a {
    padding: 10px 10px;
    font-size: 1.1rem;
  }
  .area-menu li { width: calc(50% - 3px); }
}


/* 各支店 */
.branch-box { margin-bottom: 50px; }
.branch-box .th2 { border-radius: 8px; margin-bottom: 40px; }
.branch-box .th2.is-nonowa { background-color: #55B441; }

#nonowa-5,
#nonowa-25,
#nonowa-35 { margin-bottom: 30px; }


.branch_shop::after {
  content:"";
  display: block;
  width: calc(33.3333% - 8px);
}
.branch_shop li {
  background-color: #fff;
  width: calc(33.3333% - 8px);
  position: relative;
  padding:15px 15px 25px 15px;
  border: 1px solid #F5A200;
  margin-bottom:30px;
}

.i-floor {
  width: 40px;
  height:40px;
  border-radius:50%;
  background: #F5A200;
  
  display:flex;
  align-items:center;
  justify-content:center;

  position: absolute;
  top: -8px; left: -8px;
  z-index:5;
}

.i-floor p {
  font-size:1.6rem;
  font-weight:700;
  color:#fff;
}

.shop-photo {
  border:1px solid #ddd;
  text-align: center;
}

.shop-name {
  font-size:1.6rem;
  font-weight:500;
  line-height:1.4;
  margin: 20px 0 10px;
}

.shop-text {
  font-size:1.4rem;
  line-height:1.6;
  margin:0 0 0;
}

.shop-text2 {
  font-size:1.4rem;
  line-height:1.5;
  margin:0 0 0;
  padding:0 0 0 1em;
  text-indent: -1em;
}

.shop-text3 {
  font-size:1.3rem;
  line-height:1.6;
  margin:0 0 0;
  padding:0 0 0 1em;
  text-indent: -1em;
}

.shop-text a {
  color:#DF6035;
  text-decoration: underline;
}
.shop-text a:hover { text-decoration: none; }

.branch_shop li.tok-member { border-color: #DF6035; }
.branch_shop li.tok-member .i-floor,
.branch_shop li.tok-member .i-coupon { background-color: #DF6035; }
.area-box_shop li .i-coupon { margin-top:16px; }

@media (max-width: 769px) {

  .branch-box { margin-bottom: 25px; }
  .branch-box .th2 {
    border-radius: 8px;
    margin-bottom: 20px;
    font-size: 1.5rem;
    height: 36px;
    line-height: 36px;
  }
  
  .branch_shop li {
    width: 100%;
    padding:15px 15px 25px 15px;
    margin-bottom:30px;
  }
  
  .i-floor {
    width: 36px;
    height:36px;
    top: -8px; left: -8px;
  }
  .i-floor p { font-size:1.5rem; }
}

/* エリア */
.area-box .th2 { background-color: #8C8C8C; }

.area-box_shop::after {
  content:"";
  display: block;
  width: calc(33.3333% - 8px);
}
.area-box_shop li {
  background-color: #fff;
  width: calc(33.3333% - 8px);
  position: relative;
  padding:15px 0px 0 0px;
  border: 1px solid #F5A200;
  margin-bottom:30px;
  display: flex;
  flex-direction: column;
}

.area-photo {
  border:1px solid #ddd;
  margin:0 15px 15px 15px;
  text-align: center;
}

.area-info {
  margin:0 15px;
  padding-bottom:20px;
  flex-grow: 1;
}

.t-kikan {
  margin: 15px 0;
}
.t-kikan h5 {
  color:#DF6035;
  font-size:1.4rem;
  margin-bottom:6px;
}

.t-day {
  background-color: #F5F5F5;
  padding:12px;
}
.t-day p { font-size: 1.4rem; line-height:1.6; }

.t-com {
  font-size:1.1rem;
  color:#8C8C8C;
}

.area-more {
  display: block;
  background-color: #F5A200;
  font-size:1.2rem;
  color:#fff;
  text-align: center;
  padding: 8px 0;
}

@media (max-width: 769px) {

  .area-box { margin-bottom: 25px; }
  .area-box .th2 {
    border-radius: 8px;
    margin-bottom: 20px;
    font-size: 1.5rem;
    height: 36px;
    line-height: 36px;
  }
  
  .area-box_shop li {
    width: 100%;
    padding:15px 15px 25px 15px;
    margin-bottom:30px;
  }
}


.iframeWrap {
  position: relative;
  height: 98%;
  overflow: hidden;
}

iframe {
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.smaple { border: 5px solid #55B441; }


.smaple::-webkit-scrollbar {
  background: #fff;
  width: 8px;
}
.smaple::-webkit-scrollbar-thumb {
  background-color: #F5A200;
  border-radius: 5px;
}


.t-tokuten_mo {
  font-size:2.4rem;
  font-weight:700;
  line-height:1.6;
  text-align: center;
}
@media (max-width: 769px) {
  .t-tokuten_mo { font-size:1.8rem; }
}

/*==========================================================================
期間外、エラー画面
==========================================================================*/

:root{
  --teal:#1b6172; --cream:#fff6ea; --cream-bd:#f8f6df; --ink:#222; --muted:#6b7280;
  --cta-a:#e27886; --cta-b:#8b5bb2;

  --footer-h: 300px;
}

/* body はレイアウト側で定義がある前提ですが、ここでも安全に指定 */
html,body{margin:0;color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Noto Sans JP",Meiryo,Arial,sans-serif}

main#sub-contents{
  padding-top: 60px;
  min-height: calc(100dvh - var(--footer-h));
  background:--cream-bd;
}

.container{
  max-width:980px;
  margin:0 auto;
  padding:16px 16px;
  min-height: calc(100dvh - var(--footer-h) - 48px); 
  display:flex;
  align-items:center;   
  justify-content:center; 
}

.pm-card{
  max-width:760px;
  width:100%;
  margin:0 auto;
  background:#fff;
  border-radius:18px;
  padding:24px 22px 26px;
  box-shadow:inset 0 1px 0 #fff
}
.pm-card p{margin:0 0 14px;line-height:1.8}
.pm-card .lead{font-weight:700;text-align:center}

.ctaWrap{display:flex;justify-content:center;margin-top:18px}
.season1{
  display:inline-flex;align-items:center;gap:8px;border:none;border-radius:8px;
  padding:14px 18px 14px 20px;
  background:linear-gradient(to right,#DA8487 20%,#A65695 80%);
  color:#fff;font-weight:700;text-decoration:none;
  letter-spacing:.02em;box-shadow:0 6px 14px rgba(139,91,178,.25);
  transition:transform .06s ease,filter .2s ease
}
.season2{
  display:inline-flex;align-items:center;gap:8px;border:none;border-radius:8px;
  padding:14px 18px 14px 20px;
  background:linear-gradient(to right, #78A591 20%, #578596);
  color:#fff;font-weight:700;text-decoration:none;
  letter-spacing:.02em;box-shadow:0 6px 14px rgba(139,91,178,.25);
  transition:transform .06s ease,filter .2s ease
}

.season1:hover, .season2:hover{filter:brightness(1.03)}
.season1:active, .season2:active{transform:translateY(1px)}
.season1 svg, .season2 svg{width:18px;height:18px}

.ctaBtn{
  display:flex; align-items:center; gap:10px;
}
.ctaBtn .ctaText{
  flex:1;                 /* アイコンを右に寄せつつ中央寄せ */
  text-align:center;
  line-height:1.4;
  display:block;
}

.br-sp{display:none}
@media (max-width:795px){
    .pm-card{padding:18px}
    .br-sp{display:inline}
}
