/* ===== Base & Theme ===== */
:root{
  --mcf-primary:#0ea5e9;        /* 既存メイン（青） */
  --accent:#38abc4;             /* 指定ティール */
  --accent-warm:#ff7043;        /* 指定オレンジ */
  --mcf-ink:#0f172a;
  --mcf-muted:#64748b;
  --mcf-card:#f8fafc;
  --page-max:1440px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI",Roboto,"Hiragino Kaku Gothic ProN","Yu Gothic","Meiryo",sans-serif;
  color:var(--mcf-ink); line-height:1.8; overflow-x:hidden;
}
img,svg,video,canvas{max-width:100%;height:auto}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:56px 0}
.section--tint{background:#f8fbff}
.section--soft{background:#fcfdfd}
.grid{display:grid;gap:20px}
.grid--2{grid-template-columns:1fr}
.grid--3{grid-template-columns:1fr}
@media(min-width:768px){
  .grid--2{grid-template-columns:repeat(2,1fr)}
  .grid--3{grid-template-columns:repeat(3,1fr)}
}
.muted{color:var(--mcf-muted)}
.h1,.h2,.h3{font-family:Montserrat,"Noto Sans JP",sans-serif;letter-spacing:.02em}
.h1{font-weight:800;font-size:clamp(28px,7.8vw,89px);margin:0 0 .25rem;color:#fff}
.h2{font-weight:800;font-size:clamp(22px,3.2vw,32px);margin:0 0 1rem}
.h3{font-weight:800;font-size:18px;margin:0 0 .25rem}

/* ===== Header ===== */
.site-head{
  position:sticky; top:0; z-index:1000; background:rgba(255,255,255,.86);
  backdrop-filter: blur(6px); border-bottom:1px solid #e5e7eb;
}
.site-head .inner{display:flex;align-items:center;justify-content:space-between;height:60px}
.brand{display:flex;align-items:center;gap:10px;font-weight:900;color:var(--mcf-ink);text-decoration:none}
.brand img{width: 100px;
    height: auto;}
.gnav{display:flex;gap:18px;align-items:center}
.gnav a{color:#0f172a;text-decoration:none;font-weight:700;font-size:.95rem}
.gnav a.btn{padding:8px 14px;border-radius:999px;border:2px solid var(--accent);color:var(--accent)}
.gnav a.btn--solid{background:var(--accent);color:#fff}
@media(max-width:840px){ .gnav{display:none} }

/* ===== Hero ===== */
.mcf-hero{
  position:relative;min-height:94vh;
  display:grid;place-items:center;overflow:hidden;
  /* background:#e7f7ff; */
  width:100vw;
  margin-left:calc(50% - 50vw)}


.mcf-hero picture,.mcf-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.85)}
.mcf-hero__inner{position:relative;z-index:1;text-align:center}
.hero-sub{font-weight:600;font-size:clamp(18px,3.6vw,36px);color:#fff;text-shadow:0 4px 20px rgba(0,0,0,.45);margin:.5rem 0}
.hero-lead{color:#fff;text-shadow:0 3px 16px rgba(0,0,0,.45)}
.wave-divider-head{position:absolute;bottom:0;left:0;width:100%;height:40px;background:url("/my-color-fiji/assets/img/wave-divider.svg") repeat-x bottom;background-size:auto 100%;z-index:1;pointer-events:none}

/* ===== Intro ===== */
.intro{margin:35px;background:#fff;position:relative}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:2rem;align-items:center}
@media(max-width:768px){.intro-grid{grid-template-columns:1fr}}
.intro-title-wrap{position:relative;display:inline-block}
.intro-title-wrap .fukidashi{position:absolute;bottom:-63px;left:0;width:100%}
.intro-text h2{font-size:1.7rem;font-weight:700;margin-bottom:2.5rem;position:relative}
.intro-text h2 .accent{background:linear-gradient(120deg,#ff7e5f,#feb47b);-webkit-background-clip:text;-webkit-text-fill-color:transparent}
.intro-img{position:relative}
.intro-img img{width:100%;border-radius:1rem;object-fit:cover}
.intro-img .tapa{position:absolute;top:-49px;left:-58px;width:28%;z-index:2;opacity:.35}


/* ===== Theme Section ===== */
.section--tint{text-align:center}
.section--tint-title-wrap{position:relative;display:inline-block}
.section--tint-title-wrap .fukidashi{position:absolute;bottom:-87px;left:50%;transform:translateX(-50%);width:min(720px,100%);max-width:720px}
.section--tint-text .lead{font-weight:800;font-size:22px;margin:5% 0 .25rem}
.section--tint-photo{margin-top:28px;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px rgba(0,0,0,.06)}
.section--tint-photo img{display:block;width:100%;height:270px;object-fit:cover;object-position:center}
@media(max-width:768px){ .section--tint-photo img{height:180px} }

/* ===== 3 Reasons ===== */
.special-reasons{background:#fff;clip-path:polygon(0 3vw,100% 0,100% 100%,0 100%);padding-top:2rem}
.title-banner{text-align:center;padding:1rem 0;margin-bottom:3rem}
.title-banner h2{font-size:1.7rem;font-weight:700;color:var(--accent);display:inline-block;background:#fff;padding:0 .75rem}
.cards{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
@media(max-width:900px){
  .cards{
  grid-template-columns:1fr;
  }
}
.card{
  /* position:relative;background:#fff; */
  border-radius:12px;box-shadow:0 4px 15px rgba(0,0,0,.1);overflow:hidden;display:flex;flex-direction:column}
.card img{width:100%;display:block}
.card h3{font-size:1.2rem;font-weight:700;color:var(--accent);margin:1rem}
.card p{font-size:.95rem;line-height:1.6;margin:0 1rem 1.5rem}
.card-number{display:block;font-weight:900;font-size:1.2rem;color:var(--accent);margin:0 1rem}
.wave-divider{position:absolute;bottom:-1px;left:0;width:100%;height:40px;background:url("/my-color-fiji/assets/img/wave-divider.svg") repeat-x bottom;background-size:auto 100%;z-index:2;pointer-events:none}

.card-img{
  position: relative;
}

/* ===== Itinerary ===== */
.section--soft {
  margin: 0 3%;
}
.section--soft .fukidashi{position:absolute;bottom:-43px;left:50%;transform:translateX(-50%);width:min(720px,100%);max-width:720px}
.tapa-2{position:absolute;top:-49px;left:-58px;width:43%!important;z-index:2;opacity:.35}
.itinerary{position:relative;background:#fcfdfd}
.itn-lead{color:#475569;margin:24px 0 24px;font-weight:600}
.itn-list{
  /* display:grid;grid-template-columns:repeat(2,minmax(0,1fr));
  gap:18px 20px; */
  width: 70%;
  min-width: 300px;
  list-style:none;
  margin:0 auto;
  padding:0;
 }

@media(max-width:900px){
  .itn-list{
    grid-template-columns:1fr;
    width: 100%;
  }
}
.itn-list>li{
  margin: 7px 0;
  position:relative;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:18px;box-shadow:0 6px 18px rgba(0,0,0,.04);overflow:hidden}
.itn-list>li::before{content:"";position:absolute;left:12px;top:18px;bottom:18px;width:2px;background:#e2e8f0;border-radius:2px}
.itn-list>li::after{content:"";position:absolute;left:8px;top:18px;width:10px;height:10px;border-radius:50%;background:var(--mcf-primary);box-shadow:0 0 0 4px #e8f6fd}
.itn-list .day{display:inline-block;background:#e8fbff;color:var(--accent);border:1px solid #9be2ef;font-weight:700;font-size:13px;border-radius:999px;padding:6px 12px;margin-left:24px}
.itn-list .body{margin:10px 0 0 24px}
.itn-list .body h3{font-size:16px;font-weight:800;margin:8px 0 6px;color:#0f172a}
.itn-list .body p{margin:0;color:#5b6776;line-height:1.75}

/* ===== h2（左帯） ===== */
.h2-alt{position:relative;display:inline-block;font-family:Montserrat,"Noto Sans JP",sans-serif;font-weight:800;font-size:clamp(22px,3.4vw,36px);color:#0f172a;margin:0 0 2rem;padding-left:1.2em;line-height:1.25}
.h2-alt .h2-deco{position:absolute;left:0;top:50%;transform:translateY(-50%) rotate(-12deg);width:12px;height:calc(100% - 2px);background:linear-gradient(180deg,var(--accent),#7fd3e3);border-radius:3px;content:"";display:inline-block}

/* ===== Before / After（Thick） ===== */
.before-after.v2{background:#fff}
.ba-intro{text-align:center;max-width:860px;margin:0 auto 2rem;color:#475569;line-height:1.9;font-size:1.05rem}
.ba-rows{display:grid;gap:32px}
.ba-row{display:grid;grid-template-columns:260px 1fr 1fr;gap:16px;align-items:start;background:#fff;border:1px solid #e5e7eb;border-radius:16px;padding:16px;box-shadow:0 6px 18px rgba(0,0,0,.05)}
.ba-photo img{width:100%;height:220px;object-fit:cover;border-radius:12px;box-shadow:0 4px 12px rgba(0,0,0,.06)}
.ba-col{display:flex;flex-direction:column;gap:10px}
.ba-tag{display:inline-block;align-self:flex-start;padding:6px 12px;border-radius:999px;font-weight:800;font-size:13px;border:1px solid}
.ba-tag--before{background:#fff3ec;color:var(--accent-warm);border-color:#ffc3ad}
.ba-tag--after{background:#e8fbff;color:var(--accent);border-color:#9be2ef}
.ba-box{background:#fff;border:1px solid #e2e8f0;border-radius:12px;padding:14px 16px;color:#334155;line-height:1.9;font-size:.98rem}
.ba-cta-note{margin-top:18px;text-align:center;color:#64748b;font-size:.9rem}
@media(max-width:1024px){.ba-row{grid-template-columns:220px 1fr 1fr}}
@media(max-width:820px){.ba-row{grid-template-columns:1fr;padding:14px;gap:12px}.ba-photo img{height:200px}}

/* ===== Staff ===== */
.staff-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:2rem}
@media(max-width:820px){.staff-grid{grid-template-columns:1fr}}
.staff-card img{width:100%;border-radius:12px;margin-bottom:1rem}
.staff-card h3{margin:.5rem 0;font-weight:700;color:var(--accent)}
.staff-role{font-weight:700;color:#64748b;margin:.25rem 0}
.staff-copy{color:#334155}

/* ===== Why Fiji ===== */
.why-intro{text-align:center;max-width:820px;margin:0 auto 2.5rem;font-size:1.05rem;color:#475569;line-height:1.8}
.why-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:2rem}
.why-item{background:#fff;border-radius:12px;padding:1.5rem;text-align:center;box-shadow:0 6px 18px rgba(0,0,0,.06);transition:transform .2s ease, box-shadow .2s ease}
.why-item:hover{transform:translateY(-4px);box-shadow:0 10px 24px rgba(56,171,196,.18)}
.why-item img.why-icon{width:100%;max-width:280px;border-radius:8px;margin-bottom:1rem;box-shadow:0 4px 12px rgba(0,0,0,.08);height:190px;object-fit:cover}
.why-item h3{font-weight:700;font-size:1.15rem;margin-bottom:.5rem;color:var(--accent)}
.why-item p{font-size:.95rem;line-height:1.7;color:#475569}

.why-icon{
  margin: 0 auto;
}

/* ===== Pricing ===== */
.plan-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:24px}
@media(max-width:980px){.plan-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.plan-grid{grid-template-columns:1fr}}
.plan-card{background:#fff;border:1px solid #e5e7eb;border-radius:16px;overflow:hidden;box-shadow:0 8px 20px rgba(0,0,0,.06);display:flex;flex-direction:column;transition:transform .15s ease, box-shadow .15s ease}
.plan-card:hover{transform:translateY(-4px);box-shadow:0 12px 28px rgba(0,0,0,.12)}
.plan-card--highlight{border-color:var(--accent);box-shadow:0 10px 28px rgba(56,171,196,.18);position:relative}
.plan-badge{position:absolute;top:12px;left:12px;background:var(--accent-warm);color:#fff;font-weight:800;font-size:12px;padding:6px 10px;border-radius:999px;z-index:2}
.plan-media img{width:100%;height:220px;object-fit:cover;display:block}
.plan-body{padding:16px 16px 18px}
.plan-title{margin:.25rem 0 0;font-weight:800;font-size:1rem;color:#0f172a}
.plan-type{margin:.15rem 0 .5rem;color:#64748b;font-weight:700;font-size:.92rem}
.plan-price{font-weight:900;font-size:1.7rem;color:var(--accent);margin:.25rem 0 .75rem;letter-spacing:.01em}
.plan-price .yen{font-size:1.1rem;margin-right:.15rem;opacity:.9}
.plan-points{margin:0;padding-left:1.1em;color:#475569;line-height:1.7}
.plan-includes{display:grid;gap:16px;margin-top:26px;grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:800px){.plan-includes{grid-template-columns:1fr}}
.inc-box{background:#fff;border:1px solid #e5e7eb;border-radius:12px;padding:16px 18px;box-shadow:0 6px 16px rgba(0,0,0,.05)}
.inc-box h4{margin:.25rem 0 .5rem;font-size:1rem;font-weight:800;color:var(--accent)}
.inc-box--exclude h4{color:var(--accent-warm)}
.inc-box ul{margin:0;padding-left:1.2em;color:#475569;line-height:1.8}
.plan-note{margin:10px;color:#94a3b8;font-size:.86rem;}

/* ===== FAQ ===== */
.faq-list details{border:1px solid #e5e7eb;border-radius:12px;background:#fff;padding:14px 16px;margin-bottom:12px;box-shadow:0 4px 10px rgba(0,0,0,.04)}
.faq-list summary{cursor:pointer;list-style:none;font-weight:800;color:var(--accent);display:flex;align-items:center;gap:8px}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";margin-left:auto;font-weight:800;color:var(--accent);transition:transform .2s ease}
.faq-list details[open] summary::after{content:"–"}
.faq-body{margin-top:10px;color:#475569;line-height:1.8}

/* ===== Footer ===== */
.site-foot{background:#0b1222;color:#cbd5e1;padding:36px 0 150px;}
.site-foot a{color:#e2e8f0;text-decoration:none}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:20px}
@media(max-width:820px){.foot-grid{grid-template-columns:1fr}}
.copyright{margin-top:12px;color:#94a3b8;font-size:.9rem}

/* ===== Sticky CTA ===== */
/* .sticky-cta{
  position:fixed; left:0; right:0; bottom:0; z-index:1000;
  background:rgba(255,255,255,.96); backdrop-filter: blur(6px);
  border-top:1px solid #e5e7eb; padding:10px 14px;
}
.sticky-cta .inner{max-width:1100px;margin:0 auto;display:flex;gap:10px;align-items:center;justify-content:space-around;}
.sticky-cta .copy{font-weight:800;color:#0f172a;font-size:.98rem;display:flex;gap:8px;align-items:center}
.cta-actions{display:flex;gap:10px;flex-wrap:wrap}
.btn{display:inline-block;font-weight:700;border-radius:999px;padding:12px 20px;text-decoration:none;transition:transform .06s ease}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--accent);color:#fff;border:2px solid var(--accent)}
.btn--outline{background:#fff;color:var(--accent);border:2px solid var(--accent)}
.btn--warm{background:var(--accent-warm);border:2px solid var(--accent-warm);color:#fff}
@media(max-width:560px){ .sticky-cta .copy{display:none} } */

/* ===== Sticky CTA ===== */
.sticky-cta {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 1000;
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(10px) saturate(180%);
  border-top: 1px solid rgba(255, 255, 255, 0.3);
  padding: 14px 18px;
  box-shadow: 0 -4px 12px rgba(0,0,0,0.1);
  transition: transform .3s ease;
}
.sticky-cta.show {
  transform: translateY(0);
}
.sticky-cta.hide {
  transform: translateY(100%);
}

.sticky-cta .inner {
  max-width: 1100px;
  margin: 0 auto;
  display: flex;
  gap: 12px;
  align-items: center;
  justify-content: space-between;
}

.cta-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: center;
  flex: 1;
}

.btn {
  display: inline-block;
  font-weight: 700;
  border-radius: 999px;
  padding: 12px 24px;
  text-decoration: none;
  transition: all 0.25s ease;
  box-shadow: 0 4px 10px rgba(0,0,0,0.1);
}

.btn--primary {
  background: var(--accent);
  color: #fff;
  border: 2px solid var(--accent);
}
.btn--primary:hover {
  background: #fff;
  color: var(--accent);
}

.btn--warm {
  background: var(--accent-warm);
  border: 2px solid var(--accent-warm);
  color: #fff;
}
.btn--warm:hover {
  background: #fff;
  color: var(--accent-warm);
}

.btn--outline {
  background: #fff;
  color: var(--accent);
  border: 2px solid var(--accent);
}
.btn--outline:hover {
  background: var(--accent);
  color: #fff;
}

/* @media (max-width: 560px) {
  .sticky-cta .inner {
    flex-direction: column;
    gap: 8px;
  }
  .cta-actions {
    flex-direction: column;
    width: 100%;
  }
  .btn {
    width: 100%;
    text-align: center;
  }
} */


@media (max-width: 625px) {

  .sticky-cta .inner {
    flex-direction: row; /* 横並び維持 */
    justify-content: center;
    gap: 6px;
  }

  .cta-actions {
    flex-direction: row; /* 横並び維持 */
    flex-wrap: nowrap;  /* 折り返し防止 */
    width: 100%;
    gap: 6px;
  }

  .btn {
    flex: 1;            /* ボタンを等幅に */
    padding: 10px 6px;  /* 横幅が狭い端末用に padding を軽く調整 */
    font-size: 13px;    /* 読める範囲で少し小さめに */
    text-align: center;
    white-space: nowrap;
  }
}


@media (max-width: 625px) {

  .sticky-cta .inner {
    justify-content: center;
  }

  .cta-actions {
    width: 100%;
    justify-content: center;
  }

  /* オレンジの説明会ボタンはフル幅 */
  .cta-actions .btn.btn--warm {
    flex: 1 1 100%;
    width: 100%;
    text-align: center;
    padding: 12px 10px;
    font-size: 14px;
    white-space: normal;
    line-height: 1.3;
  }

  /* アウトラインボタン（LINE／個別相談）はスマホでは非表示 */
  .cta-actions .btn.btn--outline {
    display: none;
  }
}


@media (max-width: 480px) {

  .cta-actions {
    flex-wrap: wrap;            /* 折り返し許可 */
    justify-content: center;
  }

  .btn {
    flex: 1 1 calc(50% - 6px);  /* 基本は2列並び */
    padding: 8px 4px;
    font-size: 12px;
    white-space: normal;        /* 必要なら改行OK */
    line-height: 1.2;
  }

  /* 1つ目（説明会ボタン）だけ上段フル幅 */
  .cta-actions .btn:first-child {
    flex-basis: 100%;
  }
}

/* Helpers */
.fullbleed{width:100vw;margin-left:calc(50% - 50vw)}



/* 共通レスポンシブ */
@media(max-width:1024px){
  h2{
    font-size:1.4rem!important;
    }
  .intro-title-wrap .fukidashi{
    bottom: -50px;
  }
  }
  @media(max-width:820px){
    .staff-card{
      width: 70%;
      margin: 0 auto;
    }
  }

@media(max-width:768px){
  .staff-card{
    width: 80%;
  }
}
  @media(max-width:480px){
  .sp-br{
      display: block;
  }
  .br-sp{
    display: none;
  }
  .intro{
    margin: 15px;
  }
  .intro-title-wrap .fukidashi {
        bottom: -13px;
    }
  .section--tint-title-wrap .fukidashi {
    bottom: -43px;
  }
  .section--tint-text .lead{
    font-size: 17px;
  }

.intro-img .tapa {
  top: -51px;
    left: -44px;
    width: 59%;
}
.cards {
  margin: 0 20px;
}

      }
    @media(min-width:480px){
    .sp-br{
        display: none;
        }
      }



      /* --- 揺れ止めの基本 --- */
      html { overflow-x: clip; }

      /* hero の全幅化による横スク/再レイアウト防止 */
      .mcf-hero{
        inline-size: 100vw;
        margin-left:  calc(50% - 50vw);
        margin-right: calc(50% - 50vw);
        min-height: min(94svh, 94dvh);
      }

      /* 画像のレイアウト先決め（CLS対策） */
      .plan-media img,
      .ba-photo img,
      .why-item img.why-icon{
        aspect-ratio: 16 / 9;
        object-fit: cover;
        display:block;
      }


      /* 絶対配置のデコ類がコンテナをはみ出さないように */
      .section--tint-title-wrap .fukidashi,
      .section--soft .fukidashi{
        max-width: 100%;
      }

      /* hoverでレイアウトを動かさない（影とtransformだけにする） */
      .plan-card:hover{
        transform: translateY(-4px);
        box-shadow:0 12px 28px rgba(0,0,0,.12);
      }



/* ヒーロー追加 */


/* ヒーローセクション全体 */
.mcf-hero {
  position: relative;
  overflow: hidden;
  height: 100vh;
  color: #fff;
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
}

/* スマホは少し低めに（例: 70vh） */
@media (max-width: 768px) {
  .mcf-hero {
    height: 80vh;
    min-height: 70vh;
  }
}

/* 背景スライド */
.mcf-hero__slides {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  z-index: -1;
}

.mcf-hero__slides .slide {
  position: absolute;
  top: 0; left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  animation: mcfFade 30s infinite; /* 30秒で1周 */
}

.mcf-hero__slides .slide:nth-child(1) { animation-delay: 0s; }
.mcf-hero__slides .slide:nth-child(2) { animation-delay: 6s; }
.mcf-hero__slides .slide:nth-child(3) { animation-delay: 12s; }
.mcf-hero__slides .slide:nth-child(4) { animation-delay: 18s; }
.mcf-hero__slides .slide:nth-child(5) { animation-delay: 24s; }


.mcf-hero__slides img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}



/* フェード切替アニメーション */
@keyframes mcfFade {
  0%   { opacity: 0; }
  8%   { opacity: 1; }
  25%  { opacity: 1; }
  33%  { opacity: 0; }
  100% { opacity: 0; }
}

/* テキスト配置 */
.mcf-hero__inner {
  position: relative;
  z-index: 1;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 1rem;
}

/* 開催時期追加 */
/* === Term Hero (目立つ開催時期帯) === */
.term-hero{
  position:relative; isolation:isolate;
  padding: clamp(36px, 8vw, 72px) 0;
  margin: 0 0 20px;
  color:#0b1222;
}
.term-hero__bg{
  position:absolute; inset:0; z-index:-1;
  background:
    radial-gradient(1200px 400px at 10% -10%, rgba(56,171,196,.22), transparent 55%),
    radial-gradient(900px 360px at 90% 0%, rgba(255,112,67,.18), transparent 60%),
    linear-gradient(180deg, #fff, #f5fdff);
  mask-image: linear-gradient(180deg, rgba(0,0,0,.96), rgba(0,0,0,.96));
  border-block: 1px solid #e5e7eb;
}
.term-hero__inner{
  display:grid; gap:16px; text-align:center;
}
.term-hero__label{
  display:inline-block; align-self:center; justify-self:center;
  padding:6px 12px; border-radius:999px;
  background: var(--mcf-card, #f8fafc);
  color: var(--accent); border:1px solid #9be2ef;
  font-weight:800; font-size:13px; letter-spacing:.04em;
}
.term-hero__title{
  font-family: Montserrat, "Noto Sans JP", sans-serif;
  font-weight:800; letter-spacing:.02em; line-height:1.2;
  font-size: clamp(22px, 4.5vw, 40px);
  margin: 4px 0 0;
}
.term-hero__title span{
  color: var(--accent);
  background: linear-gradient(120deg, var(--accent), #7fd3e3);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
}
.term-hero__note{
  margin: 6px auto 0; max-width: 900px;
  color:#334155; line-height:1.8; font-weight:600;
}
.term-hero__badges{
  display:flex; gap:8px; flex-wrap:wrap; justify-content:center;
  margin-top: 6px;
}
.term-hero .badge{
  display:inline-block; padding:6px 12px; border-radius:999px;
  background:#e8fbff; color:var(--accent);
  border:1px solid #9be2ef; font-weight:800; font-size:12px;
}
.term-hero__cta{
  display:flex; gap:10px; justify-content:center; flex-wrap:wrap;
  margin-top: 10px;
}

@media (max-width: 480px) {
  .term-hero__cta {
  display: block;
    align-items: stretch;        /* 横幅100%に伸ばす */
    gap: 8px;                    /* ボタン同士の隙間 */
  }

  .term-hero__cta .btn {
    width: 100%;                 /* フル幅 */
    text-align: center;
    padding: 12px 10px;          /* クリックしやすいサイズ */
    font-size: 14px;
    margin-bottom: 5px;
  }
}


.term-hero .btn{padding:12px 18px;}
.term-hero .btn--outline{background:#fff;color:var(--accent);border:2px solid var(--accent);}

/* 開催時期セクション */
.term-hero {
  position: relative;
  margin-top: -24px; /* 波と重なるように調整 */
  isolation: isolate; /* マスクの独立性を担保 */
  z-index: 1;
}

/* 背景のグラデーション＋マスク */
.term-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  background:
    radial-gradient(1200px 400px at 10% -10%, rgba(56,171,196,.22), transparent 55%),
    radial-gradient(900px 360px at 90% 0%, rgba(255,112,67,.18), transparent 60%),
    linear-gradient(180deg, #fff, #f5fdff);

  /* 上端をフェードさせるマスク */
  -webkit-mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0,       /* 完全透明: 上端 */
    rgba(0,0,0,.8) 32px,   /* 半透明ゾーン */
    rgba(0,0,0,1) 64px     /* 完全表示: 下部 */
  );
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-mode: match-source;

          mask-image: linear-gradient(
    to bottom,
    rgba(0,0,0,0) 0,
    rgba(0,0,0,.8) 32px,
    rgba(0,0,0,1) 64px
  );
  mask-repeat: no-repeat;
  mask-mode: match-source;
}
