/*
Theme Name: Linoe Pilates
Theme URI: https://example.com/
Author: Your Name
Description: Custom WordPress theme inspired by TCD demo site
Version: 1.0
License: GNU General Public License v2 or later
License URI: http://www.gnu.org/licenses/gpl-2.0.html
Text Domain: linoe-pilates
*/

/* =======================================
   0) Tokens / Variables
======================================= */
:root{
  /* Colors */
  --text:#333; --text-invert:#fff; --line:#eee;
  --overlay:rgba(0,0,0,.36); --backdrop:rgba(0,0,0,.32);
  --brand:#90B8E0;          /* ブランド色（無料体験など） */
  --line-green:#06C755;     /* LINE予約ボタン */
  --accent:#111;            /* セカンダリアクセント */

  /* Header */
  --header-h:64px; --header-h-small:44px;
  --header-gap:24px; --header-gap-small:14px;
  --logo-w:180px; --logo-w-small:80px;
  --logo-w-sp:100px; --logo-w-sp-small:90px;
  --nav-pad-y:10px; --nav-pad-y-small:6px;

  /* Layout */
  --max-w:1100px; --max-w-narrow:860px;
  --radius-lg:20px; --shadow-sm:0 6px 24px rgba(0,0,0,.06);
}

/* ユーザーの省モーション設定に追従 */
@media (prefers-reduced-motion: reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important;}
}

/* =======================================
   1) Base
======================================= */
*{box-sizing:border-box;}
html,body{margin:0;padding:0;overflow-x:hidden;}
html,body{
  font-family:"Noto Sans JP",system-ui,-apple-system,"Segoe UI","Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans CJK JP",Meiryo,sans-serif;
  font-weight:400;line-height:1.8;color:var(--text);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;height:auto;display:block;}
.container{max-width:var(--max-w);width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,24px);}
.container--narrow{max-width:var(--max-w-narrow);width:100%;margin-inline:auto;padding-inline:clamp(16px,4vw,24px);}
.container--wide{width:min(1100px,94vw);margin-inline:auto;padding-inline:clamp(8px,2vw,16px);}
.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* 改行ユーティリティ */
.pc-br{display:none;}
.sp-br{display:inline;}
@media (min-width:961px){.pc-br{display:inline;}.sp-br{display:none;}}

/* 表示切替ユーティリティ */
.pc-only{display:none;}
.sp-only{display:block;}
@media (min-width:961px){.pc-only{display:block;}.sp-only{display:none;}}

/* =======================================
   2) Header（PC=横並び / SP=オーバーレイ）
======================================= */
.site-header{
  position:fixed; inset:0 0 auto 0; width:100%;
  background:transparent; border-bottom:1px solid transparent;
  transition:background .3s, border-color .3s, box-shadow .3s, opacity .35s;
  z-index:1000; opacity:1; pointer-events:auto;
}
.header-inner{
  position:relative; display:flex; align-items:center; gap:var(--header-gap);
  min-height:var(--header-h); padding-block:12px;
  transition:min-height .28s, gap .28s, padding .28s;
}
.site-header.scrolled{
  background:#fff; border-bottom-color:var(--line); box-shadow:0 1px 8px rgba(0,0,0,.04);
}
.site-header.scrolled .header-inner{ padding-block:8px; }
body.no-scroll .site-header{ opacity:0; pointer-events:none; } /* スプラッシュ中は非表示 */

.site-header .logo{ display:flex; align-items:center; line-height:0; }
.site-header .logo a{
  display:flex; align-items:center; padding:4px 0; color:var(--text-invert); transition:color .25s;
}
.site-header.scrolled .logo a{ color:var(--text); }
.site-header .logo svg{
  width:var(--logo-w); height:auto; display:block; color:#fff;
  transition:width .28s ease, color .28s ease;
}
.site-header.scrolled .logo svg{ width:var(--logo-w-small); color:var(--brand); }

/* PCナビ */
#global-nav{ margin-left:auto; }
#global-nav .menu{ list-style:none; display:flex; gap:24px; margin:0; padding:0; }
#global-nav .menu>li>a{
  display:block; padding-block:var(--nav-pad-y); color:var(--text-invert);
  transition:padding .28s, color .25s, opacity .25s;
}
.site-header.scrolled #global-nav .menu>li>a{ color:var(--text); }
#global-nav .menu>li>a:hover{ opacity:.7; }

@media (min-width:961px){
  #global-nav{ display:flex !important; align-items:center !important; gap:16px !important; margin-left:auto; }
  #global-nav .menu{ display:flex !important; flex-direction:row !important; align-items:center !important; gap:24px !important; margin:0 !important; padding:0 !important; }
}

/* CTAボタン（共通ベース） */
.btn-cta{
  display:inline-flex; align-items:center; gap:8px;
  padding:10px 16px; border-radius:6px; border:1px solid transparent;
  font-weight:700; line-height:1; text-decoration:none;
  transition:transform .18s, opacity .18s, filter .18s, background .18s, color .18s, border-color .18s;
}
.btn-cta:hover{ transform:translateY(-1px); opacity:.96; }
.btn-cta:focus-visible{ outline:2px solid #000; outline-offset:2px; }

/* ── PC専用 nav-cta（右端の目立つボタン） ── */
.nav-cta{ display:none; }
@media (min-width:961px){
  .nav-cta{ display:flex; align-items:center; gap:12px; margin-left:10px; flex:0 0 auto; }
  /* 配色（PC） */
  #global-nav .nav-cta .btn-cta--trial{
    background:#CC7F91 !important; border-color:#CC7F91 !important; color:#fff !important;
  }
  #global-nav .nav-cta .btn-cta--line{
    background:#90B8E0 !important; border-color:#90B8E0 !important; color:#fff !important;
  }
  .nav-cta .btn-cta--trial:hover,
  .nav-cta .btn-cta--line:hover{ filter:brightness(.95); }
}

/* ── SP用：ドロワー内CTA ── */
.menu-cta-wrap{ display:none; }
@media (max-width:960px){
  .menu-cta-wrap{ display:flex; gap:12px; justify-content:center; flex-wrap:wrap; margin-top:16px; }
  /* 配色（SPドロワー） */
  #global-nav .menu-cta-wrap .btn-cta--brand{
    background:#CC7F91 !important; border-color:#CC7F91 !important; color:#fff !important;
  }
  #global-nav .menu-cta-wrap .btn-cta--line{
    background:#90B8E0 !important; border-color:#90B8E0 !important; color:#fff !important;
  }
}

/* SPメニューボタン（右上テキスト） */
.menu-btn.menu-btn--text{
  display:none; position:absolute; right:16px; top:10px; padding:8px 14px; background:transparent; border:0; cursor:pointer; z-index:1100;
  font-family:"Noto Serif JP",serif; font-style:italic; font-size:20px; font-weight:700; color:var(--text-invert); transition:color .25s;
}
.site-header.scrolled .menu-btn.menu-btn--text{ color:var(--text); }
.menu-btn__label{ position:relative; display:inline-block; padding-bottom:2px; }
.menu-btn__label::after{
  content:""; position:absolute; left:0; bottom:0; width:100%; height:1px;
  background:currentColor; transform:scaleX(1); transform-origin:left; transition:transform .25s;
}
.menu-btn.is-open .menu-btn__label::after{ transform:scaleX(0); }
.menu-btn__label::before{ content:attr(data-open); }
.menu-btn.is-open .menu-btn__label::before{ content:attr(data-close); }

/* ── SPドロワー本体 ── */
@media (max-width:960px){
  .menu-btn.menu-btn--text{ display:inline-block; }
  .site-header .logo svg{ width:var(--logo-w-sp); }
  .site-header.scrolled .logo svg{ width:var(--logo-w-sp-small); }

  #global-nav{
    position:fixed; inset:0; display:flex; flex-direction:column; justify-content:center; align-items:center;
    background:#fff; opacity:0; pointer-events:none; transform:scale(1.02);
    transition:opacity .32s, transform .32s; z-index:1090;
  }
  #global-nav.open{ opacity:1; pointer-events:auto; transform:none; }
  #global-nav .nav-backdrop{ position:fixed; inset:0; background:var(--backdrop); opacity:0; pointer-events:none; transition:opacity .28s; z-index:-1; }
  #global-nav.open .nav-backdrop{ opacity:1; pointer-events:auto; }

  #global-nav .menu{ flex-direction:column; gap:18px; width:min(92%,720px); }
  #global-nav .menu>li>a{
    color:var(--text) !important; border-bottom:1px solid transparent; padding:16px 20px; line-height:1.4;
  }
}

/* ── PC固定（ドロワー無効化） ── */
@media (min-width:961px){
  .menu-btn.menu-btn--text{ display:none !important; }
  #global-nav, #global-nav.open{
    position:static !important; inset:auto !important; transform:none !important; opacity:1 !important;
    pointer-events:auto !important; background:transparent !important; width:auto !important; border-left:0 !important; box-shadow:none !important;
  }
  #global-nav .nav-backdrop{ display:none !important; }
  #global-nav .menu{ flex-direction:row !important; gap:24px !important; margin:0 !important; padding:0 !important; }
  .site-header.scrolled #global-nav .menu>li>a{ padding-block:var(--nav-pad-y-small); }
}

/* ドロワーOPEN時の背景スクロール抑止 */
body.no-scroll, body.drawer-open{ overflow:hidden; touch-action:none; }
.site-header:not(.scrolled){
  background:transparent !important; border-bottom-color:transparent !important; box-shadow:none !important;
}

/* =======================================
   3) SP固定バー（LINE予約／無料体験）
======================================= */
.fixed-reserve{
  position:fixed; left:0; right:0; bottom:0; display:flex; align-items:stretch; height:clamp(52px,7.2vh,64px);
  z-index:1200; background:#fff; box-shadow:0 -6px 22px rgba(0,0,0,.08);
  padding-bottom:env(safe-area-inset-bottom,0); transition:transform .28s ease, opacity .28s ease, visibility .28s ease;
}
.drawer-open .fixed-reserve{ transform:translateY(100%); opacity:0; visibility:hidden; pointer-events:none; }
.fixed-btn{
  flex:0 0 50% !important; display:flex; align-items:center; justify-content:center; gap:10px;
  padding:0 clamp(12px,3vw,18px); font-weight:700; letter-spacing:.02em; font-size:15px; line-height:1;
  -webkit-tap-highlight-color:transparent; min-height:48px;
  border-radius:0; /* ← スマ下部はフラット */
}
.fixed-btn--primary{ background:#90B8E0; color:#fff; border:0; }
.fixed-btn--ghost  { background:#CC7F91; color:#fff; border:0; }
.fixed-btn::before{
  -webkit-mask:none !important; mask:none !important; content:""; width:1.15em; height:1.15em; display:inline-block; background-repeat:no-repeat; background-position:center; background-size:100% 100%;
}
.fixed-btn--primary::before{
  background-image:url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M2 3h20v14H7l-5 5V3z'/%3E%3C/svg%3E);
}
.fixed-btn--ghost::before{
  background-image:url(data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='%23fff' d='M12 17.27 18.18 21l-1.64-7.03L22 9.24l-7.19-.61L12 2 9.19 8.63 2 9.24l5.46 4.73L5.82 21z'/%3E%3C/svg%3E);
}
@media (min-width:961px){ .fixed-reserve{ display:none; } }



/* =======================================
   4) Hero / Swiper
======================================= */
.hero-swiper,.hero-swiper .swiper-wrapper,.hero-swiper .swiper-slide{width:100%;height:100dvh;}
.hero-swiper{position:relative;background:#000;overflow:hidden;}
.hero-swiper::after{content:"";position:absolute;inset:0;background:rgba(60,110,180,0.35);mix-blend-mode:multiply;pointer-events:none;z-index:1;}
.hero-swiper .swiper-slide img{width:100%;height:100%;object-fit:cover;will-change:transform,opacity;transform:translateZ(0);}
.hero-swiper.swiper-fade .swiper-slide{pointer-events:none;transition:opacity 1.4s ease !important;z-index:0;}
.hero-swiper.swiper-fade .swiper-slide-active{pointer-events:auto;}

/* ヒーロー縦書きコピー */
.hero-copy{position:absolute;inset:0;z-index:5;display:flex;justify-content:center;align-items:center;color:#fff;pointer-events:none;padding:0;}
.hero-title,.hero-subtitle{
  font-family:"Klee One","Noto Serif JP",serif;font-weight:600;writing-mode:vertical-rl;text-orientation:upright;letter-spacing:.15em;line-height:1.8;text-shadow:0 2px 14px rgba(0,0,0,.25);
}
.hero-title{font-size:clamp(20px,2.5vw,36px);}
.hero-subtitle{font-size:clamp(20px,3.4vw,56px);line-height:1.9;}
@media (max-width:960px){
  .hero-title{font-size:clamp(22px,6vw,28px);}
  .hero-subtitle{font-size:clamp(26px,8vw,34px);}
  .hero-swiper::after{background:rgba(60,110,180,0.44);}
}

/* ズームアニメーション */
@keyframes heroZoom{from{transform:scale(1);}to{transform:scale(1.06);}}
.hero-swiper .swiper-slide.swiper-slide-active img{animation:heroZoom 6.8s linear forwards;}

/* =======================================
   5) Splash
======================================= */
:root{
  --catch-delay:0s; --catch-dur:.7s; --hold-catch:2.2s;  /* テキスト短く */
  --wipe-delay:2.4s; --wipe-dur:.9s; --hold-wipe:.7s;    /* ピンク早め */
  --logo-delay:3.0s; --logo-dur:.8s; --hold-logo:1.2s;   /* ロゴも早め */
  --leave-extra:.5s;
}

#splash{position:fixed;inset:0;background:#fff;z-index:2000;display:grid;place-items:center;overflow:hidden;opacity:1;}
.splash-inner{position:relative;width:100vw;height:100dvh;display:grid;place-items:center;text-align:center;isolation:isolate;}
.splash-catch,.splash-logo{grid-area:1/1;position:relative;}

.splash-catch{
  z-index:1;margin:0;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;
  font-size:clamp(20px,2.1vw,34px);letter-spacing:.06em;color:#8696a4;opacity:0;transform:translateY(14px);
}
.splash-wipe{position:absolute;inset:-20px 0 -20px 0;background:#FDECEE;transform:translateY(-120%);z-index:5;pointer-events:none;}
.splash-logo{z-index:10;color:#90B8E0;opacity:0;transform:translateY(12px);}
.splash-logo svg{width:clamp(180px,30vw,380px);height:auto;fill:currentColor;}
@media (min-width:961px){.splash-logo svg{width:clamp(160px,20vw,300px);}}

/* 動き */
@keyframes splashCatchIn{from{opacity:0;transform:translateY(14px);}to{opacity:1;transform:translateY(0);}}
@keyframes wipeDownStraight{from{transform:translateY(-120%);}to{transform:translateY(0);}}
@keyframes logoIn{from{opacity:0;transform:translateY(12px);}to{opacity:1;transform:translateY(0);}}
@keyframes splashOut{to{opacity:0;}}
#splash.is-run .splash-catch{animation:splashCatchIn var(--catch-dur) ease var(--catch-delay) forwards;}
#splash.is-run .splash-wipe{animation:wipeDownStraight var(--wipe-dur) cubic-bezier(.25,.9,.3,1) var(--wipe-delay) forwards;}
#splash.is-run .splash-logo{animation:logoIn var(--logo-dur) cubic-bezier(.22,1,.36,1) var(--logo-delay) forwards;}
#splash.is-leave{animation:splashOut .7s ease forwards;}

/* =======================================
   6) Local nav
======================================= */
.page-localnav{border-bottom:1px solid #eee;}
.page-localnav .container{overflow-x:auto;}
.page-localnav__list{display:flex;gap:16px;padding:14px 0;margin:0;list-style:none;}
.page-localnav__link{
  display:inline-block;padding:8px 14px;border-radius:999px;background:#f7f7f8;color:#222;transition:background .2s,color .2s;white-space:nowrap;
}
.page-localnav__link:hover{background:#ececee;}
.page-localnav__link.is-current{background:#111;color:#fff;}

/* =======================================
   7) Content / Typography
======================================= */
.page-hero{
  position:relative;background:#f6f6f6;background-image:var(--hero, none);
  background-size:cover;background-position:center;color:#111;padding:clamp(64px,10vw,128px) 0;
}
.page-hero__overlay{position:absolute;inset:0;background:rgba(255,255,255,.5);pointer-events:none;}
.page-hero .container{position:relative;z-index:1;}
.page-hero__title{font-size:clamp(28px,4vw,44px);font-weight:700;letter-spacing:.02em;margin:0 0 .35em;}
.page-hero__subtitle{font-size:clamp(15px,1.5vw,18px);opacity:.85;}
.page-hero[style*="--hero:none"] .page-hero__overlay{display:none;}

.page-content{padding:clamp(36px,6vw,72px) 0;}
.prose :where(p,ul,ol){line-height:1.9;}
.prose h2{font-size:clamp(22px,3vw,28px);margin:1.8em 0 .6em;}
.prose h3{font-size:clamp(18px,2.3vw,22px);margin:1.6em 0 .5em;}
.prose img{max-width:100%;height:auto;border-radius:14px;}

.section{padding:clamp(48px,8vw,96px) 0;}
.section-title{font-size:clamp(22px,3vw,32px);font-weight:700;text-align:center;margin-bottom:1em;}
.section-lead{text-align:center;font-size:1.1rem;opacity:.85;}

.feature-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;list-style:none;padding:0;margin:0;text-align:center;}
.feature-list img{border-radius:12px;margin-bottom:12px;}
.visual-grid{display:grid;gap:40px;align-items:center;}
@media (min-width:960px){.visual-grid{grid-template-columns:1fr 1fr;}}
.visual-text p{line-height:1.9;}
.cta{background:#fafafa;text-align:center;}
.cta-buttons{margin-top:20px;display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.blog-list{display:grid;gap:24px;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}
.blog-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 4px 12px rgba(0,0,0,.06);}
.blog-card img{width:100%;height:auto;display:block;}
.blog-card h3{margin:12px;font-size:1rem;}
.access .map{margin-top:20px;border-radius:12px;overflow:hidden;}

/* 共通ボタン（再掲・他所でも利用） */
.btn,.btn-cta{
  display:inline-flex;align-items:center;gap:8px;padding:12px 22px;border-radius:9999px;border:1px solid currentColor;
  text-decoration:none;font-weight:700;letter-spacing:.02em;line-height:1;transition:transform .18s,opacity .18s,background .18s,color .18s,border-color .18s;
}
.btn:hover,.btn-cta:hover{transform:translateY(-1px);opacity:.95;}
.btn-cta .i-line{display:inline-block;vertical-align:-1px;}
.btn--primary{background:#111;color:#fff;border-color:#111;}
.btn-cta--brand{background:var(--brand);border-color:var(--brand);color:#fff;}
.btn-cta--line{background:var(--line-green);border-color:var(--line-green);color:#fff;}

/* Hero右側CTA（PCのみ） */
.hero-cta{position:absolute;right:clamp(16px,4vw,56px);top:50%;transform:translateY(-50%);display:grid;gap:12px;z-index:3;pointer-events:auto;}
@media (max-width:960px){.hero-cta{display:none;}}

/* =======================================
   Footer（Light / Clean）
======================================= */
.site-footer{
  background:#f8f9fb; /* 清潔感のある薄グレー */
  color:#333;
  padding:60px 0 40px;
  overflow:hidden;
  border-top:1px solid #e6e8eb;
}
.footer-inner{width:min(92%,1200px);margin:0 auto;}
.footer-heading{
  font-size:1.4rem;font-weight:700;letter-spacing:.06em;margin-bottom:24px;
  text-align:center;color:#2b3137;
}

/* layout */
.footer-access-body{display:grid;gap:24px;}
@media (min-width:961px){
  .footer-access-body{grid-template-columns:1.1fr .9fr;gap:40px;align-items:start;}
}

/* map card */
.card{
  background:#fff;border-radius:var(--radius,12px);
  box-shadow:var(--shadow-sm,0 8px 24px rgba(0,0,0,.06));
  overflow:hidden;
}
.footer-map{position:relative;width:100%;aspect-ratio:16/9;min-height:280px;}
@supports not (aspect-ratio:1/1){
  .footer-map{padding-top:56.25%;}
  .footer-map iframe{position:absolute;inset:0;}
}
.footer-map iframe{width:100%;height:100%;border:0;display:block;}

/* text & info */
.footer-access-text{font-size:.95rem;line-height:1.9;word-break:keep-all;}
.footer-address{margin:0 0 10px;}
.footer-hours{margin:0 0 10px;color:#4b5563;}
.footer-contacts{list-style:none;padding:0;margin:10px 0 18px;display:flex;flex-wrap:wrap;gap:14px;}
.footer-contacts a{color:#1f2937;text-decoration:underline;text-decoration-color:#cbd5e1;text-underline-offset:3px;}
.footer-contacts a:hover{opacity:.85}

/* CTAs */
.footer-ctas{display:flex;flex-wrap:wrap;gap:10px;margin:18px 0 10px;}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.45em;
  padding:.75em 1.05em;border-radius:999px;font-weight:700;font-size:.95rem;
  border:1px solid transparent;text-decoration:none;transition:.2s ease;
}
.btn.line{background:#06C755;color:#fff;}
.btn.line:hover{filter:brightness(.95);}
.btn.trial{background:#90B8E0;color:#fff;}
.btn.trial:hover{filter:brightness(.96);}
.btn.ghost{background:#fff;border-color:#d1d5db;color:#374151;}
.btn.ghost:hover{border-color:#c5cad3;background:#f9fafb}

/* social */
.footer-social{margin-top:10px;}
.footer-social .sns{
  display:inline-flex;align-items:center;gap:.5em;background:#fff;border:1px solid #e5e7eb;
  border-radius:999px;padding:.55em .9em;color:#111;text-decoration:none;
}
.footer-social .sns:hover{background:#f3f4f6;border-color:#d1d5db}
.footer-social .sns svg{display:block}

/* bottom */
.footer-bottom{text-align:center;margin-top:48px;font-size:.85rem;color:#4b5563;}
.footer-logo{font-weight:800;margin-bottom:10px;letter-spacing:.08em;color:#2b3137;}
.footer-legal ul{display:flex;gap:16px;justify-content:center;list-style:none;padding:0;margin:0 0 8px;}
.footer-legal a{color:#556070;text-decoration:underline;text-decoration-color:#cbd5e1;text-underline-offset:3px;}
.footer-legal a:hover{opacity:.85}
.copy{opacity:.9;}

/* =======================================
   9) Page Hero (TCD-ish) 共通
======================================= */
.page-hero.tcd-ish{
  position:relative;color:#111;background:#f5f5f5;
  padding:clamp(84px,14vw,220px) 0 clamp(34px,5vw,56px);
}
.page-hero.tcd-ish .page-hero__inner{
  position:relative;z-index:1;display:grid;grid-template-rows:1fr auto; /* 本文 + パンくず帯 */
  min-height:clamp(60vh,70vh,72vh);
}
.page-hero.tcd-ish .page-hero__container{
  align-self:center;justify-self:center;width:min(92vw,1000px);text-align:center;padding-inline:16px;
}
.page-hero.tcd-ish .page-hero__title{
  margin:0 0 .4em;font-size:clamp(28px,5.2vw,56px);font-weight:700;letter-spacing:.02em;text-shadow:0 2px 14px rgba(0,0,0,.3);color:currentColor;
}
.page-hero.tcd-ish .page-hero__subtitle{margin:0;font-size:clamp(14px,1.8vw,18px);opacity:.95;text-shadow:0 2px 10px rgba(0,0,0,.28);color:currentColor;}
.page-hero.tcd-ish .page-hero__crumbs{align-self:end;}
.page-hero.tcd-ish .page-hero__crumbs-inner{
  display:flex;align-items:center;min-height:46px;padding:10px clamp(16px,4vw,28px);
  background:rgba(0,0,0,.3);backdrop-filter:saturate(1.1) blur(2px);
}
.page-hero.tcd-ish:not(.has-image) .page-hero__crumbs-inner{background:rgba(0,0,0,.06);}
.page-hero.tcd-ish .breadcrumbs{width:100%;color:#fff;font-size:13px;white-space:nowrap;overflow:auto;}
.page-hero.tcd-ish:not(.has-image) .breadcrumbs{color:#333;}
.page-hero.tcd-ish .breadcrumbs a{color:inherit;opacity:.9;text-decoration:none;}
.page-hero.tcd-ish .breadcrumbs a:hover{opacity:1;text-decoration:underline;}
.page-hero.tcd-ish .breadcrumbs span{opacity:.75;}
.page-hero.tcd-ish.is-compact{padding:clamp(56px,9vw,120px) 0 clamp(26px,4vw,40px);}
.page-hero.tcd-ish.is-compact .page-hero__inner{min-height:42vh;}
@media (max-width:960px){.page-hero.tcd-ish .page-hero__inner{min-height:56vh;}}

/* 画像あり時のオーバーレイ */
.page-hero.tcd-ish.has-image{color:#fff;background-image:var(--hero);background-size:cover;background-position:center;}
.page-hero.tcd-ish .page-hero__overlay{
  position:absolute;inset:0;background:linear-gradient(to bottom, rgba(0,0,0,.20) 0%, rgba(0,0,0,.20) 35%, rgba(0,0,0,.35) 70%, rgba(0,0,0,.55) 100%);
  opacity:0;pointer-events:none;transition:opacity .35s ease;
}
.page-hero.tcd-ish.has-image .page-hero__overlay{opacity:1;}

/* =======================================
   10) Concept page（統一）
======================================= */
.concept .section-title,
.concept h3,
.concept-features__head .section-title{
  font-family:"Klee One","Noto Serif JP",serif;font-weight:600;color:var(--brand);letter-spacing:.05em;line-height:1.4;text-align:center;margin-bottom:1em;
}
.concept .section-title{font-size:clamp(22px,3vw,32px);}
.concept h3,.concept h3.section-title,.concept-features__head .section-title{font-size:clamp(22px,3.2vw,30px);}
.concept .section-lead{font-size:1.05rem;opacity:.9;}
.concept .visual-text p{margin:.5em 0;}
.concept .visual-image img{display:block;width:100%;height:auto;border-radius:12px;object-fit:cover;}
@media (min-width:960px){.visual-grid{grid-template-columns:1fr 1fr;align-items:center;gap:40px;}}

/* 3カード */
.feature-grid{display:grid;gap:16px;grid-template-columns:repeat(3,1fr);margin-top:18px;list-style:none;padding-left:0;margin-left:0;}
@media (max-width:960px){.feature-grid{grid-template-columns:repeat(2,1fr);} }
@media (max-width:560px){.feature-grid{grid-template-columns:1fr;} }
.feature-card{background:#fff;border-radius:12px;padding:16px;box-shadow:var(--shadow-sm);text-align:center;}
.feature-card img{border-radius:12px;margin-bottom:12px;}
.feature-card h4{margin:.6em 0 .3em;font-size:1.05rem;}

/* Method（3カラム） */
.concept-method .method-steps{display:grid;gap:14px;margin:24px 0 10px;}
@media (min-width:961px){.concept-method .method-steps{grid-template-columns:1fr 1fr 1fr;}}
.concept-method .method-step{
  background:#fff;border:1px solid #eee;border-radius:14px;padding:16px 16px 18px;box-shadow:var(--shadow-sm);
  display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;
}
.concept-method .method-num{
  font-weight:800;letter-spacing:.06em;width:44px;height:44px;border-radius:12px;display:grid;place-items:center;background:#111;color:#fff;line-height:1;
}
.concept-method .method-body h4{margin:.1em 0 .25em;font-size:1.05rem;}
.concept-method .method-visual{margin-top:18px;}
.concept-method .method-visual img{width:100%;height:auto;border-radius:14px;object-fit:cover;}

/* Concept ヒーローの色味をTOPに合わせる */
.page-hero.tcd-ish.has-image .page-hero__overlay{background:rgba(60,110,180,0.35);mix-blend-mode:multiply;opacity:1 !important;}

/* Reveal（CSSアニメ、JSで .js-ready / .is-revealed を付与） */
.reveal-on-scroll{will-change:transform,opacity;opacity:1;transform:none;}
:root.js-ready .reveal-on-scroll{visibility:hidden;opacity:0;transform:translateY(18px);}
:root.js-ready .reveal-on-scroll.is-revealed{visibility:visible;animation:revealFadeUp .6s ease forwards;}
@keyframes revealFadeUp{to{opacity:1;transform:none;}}
@media (prefers-reduced-motion: reduce){:root.js-ready .reveal-on-scroll.is-revealed{animation-duration:.6s !important;}}

/* 横長ビジュアル帯 */
.concept-visual-band{padding:clamp(16px,3vw,24px) 0;}
.concept-visual-band .band-figure{
  position:relative;width:100%;aspect-ratio:21/9;border-radius:14px;overflow:hidden;background:#eaeaea;box-shadow:0 6px 24px rgba(0,0,0,.06);
}
.concept-visual-band .band-figure img{display:block;width:100%;height:100%;object-fit:cover;transform:translateZ(0);}
@media (max-height:680px){.concept-visual-band .band-figure{max-height:46vh;}}
:root.js-ready .concept-visual-band{opacity:0;transform:translateY(18px);}
:root.js-ready .concept-visual-band.is-revealed{animation:revealFadeUp .6s ease forwards;}

/* =======================================
   11) MENU
======================================= */
.menu-strengths__grid{display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));list-style:none;padding:0;margin:0;}
.menu-card{
  position:relative;background:#fff;border:1px solid #eee;border-radius:12px;padding:16px;text-align:center;box-shadow:var(--shadow-sm);
}
.menu-card__num{
  position:absolute;left:12px;top:12px;width:38px;height:38px;border-radius:10px;display:grid;place-items:center;background:#111;color:#fff;font-weight:800;font-size:.95rem;letter-spacing:.06em;
}
.menu-card__thumb{margin:0 0 12px 0;}
.menu-card__thumb img{border-radius:10px;display:block;width:100%;height:auto;object-fit:cover;}
.menu-card__title{margin:.4em 0 .2em;font-size:1.05rem;font-weight:700;}
.menu-card__text{margin:0;font-size:.95rem;opacity:.92;}
.menu-details .visual-grid{gap:28px;}
.menu-detail__text h3{margin-top:0;}
.menu-detail__image img{width:100%;height:auto;border-radius:12px;object-fit:cover;}
@media (min-width:960px){
  .menu-details .visual-grid{grid-template-columns:1fr 1fr;align-items:center;}
  .menu-details .menu-detail__text:nth-of-type(2){order:2;}
}
.u-center{text-align:center;}
.u-strong{font-weight:700;}

/* =======================================
   12) PRICE
======================================= */
.price-kv{list-style:none;padding:0;margin:0;display:grid;gap:10px;}
.price-kv li{
  display:flex;justify-content:space-between;align-items:center;background:#fff;border:1px solid #eee;border-radius:12px;
  padding:12px 16px;box-shadow:var(--shadow-sm);
}
.price-kv li span{opacity:.9;}
.price-kv li strong{font-size:1.1rem;}

.price-grid{list-style:none;padding:0;margin:0;display:grid;gap:18px;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.price-card{background:#fff;border:1px solid #eee;border-radius:14px;box-shadow:var(--shadow-sm);padding:16px;text-align:center;position:relative;}
.price-card.is-popular{border-color:var(--brand);box-shadow:0 6px 24px rgba(0,0,0,.08);}
.price-card__head{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:8px;}
.price-card__head .tag{display:inline-block;font-weight:700;font-size:.85rem;letter-spacing:.02em;padding:4px 8px;border-radius:999px;background:#f4f6fb;color:#3a4c6b;}
.price-card__head .badge{display:inline-block;font-size:.78rem;padding:2px 6px;border-radius:6px;background:var(--brand);color:#fff;font-weight:700;}
.price-card__price span{display:inline-block;font-size:1.6rem;font-weight:800;letter-spacing:.02em;}
.price-card__note{margin:.3em 0 0;font-size:.9rem;opacity:.8;}

.combo-list{list-style:none;padding:0;margin:0;display:grid;gap:12px;}
.combo-item{display:flex;align-items:center;justify-content:space-between;gap:16px;background:#fff;border:1px solid #eee;border-radius:12px;padding:12px 16px;box-shadow:var(--shadow-sm);}
.combo-item__head{font-weight:600;}
.combo-item__price{font-weight:800;}

.notes{list-style:disc inside;padding:0;margin:0;display:grid;gap:.4em;font-size:.95rem;}
.notes li{opacity:.92;}

.price-group.section,.price-personal.section,.price-combo.section{
  padding-top:clamp(28px,4vw,44px);padding-bottom:clamp(28px,4vw,44px);
}

/* =======================================
   13) FAQ / Accordion
======================================= */
#faq.section{padding:clamp(36px,6vw,72px) 0;}
.faq .ttl{
  margin:0 0 .4em;text-align:center;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;color:var(--brand);
  font-size:clamp(22px,3vw,32px);letter-spacing:.05em;
}
.faq .ttl2{margin:0 0 1.2em;text-align:center;opacity:.9;font-size:clamp(15px,1.6vw,18px);}
.faq .box{margin:10px 0;}
.faq .box + .box{margin-top:12px;}
.faq .box dl{margin:0;}
.faq .box dt,.faq .box dd{margin:0;}

.faq .faq-toggle{
  display:flex;align-items:flex-start;gap:12px;width:100%;
  background:#fff;border:1px solid #eee;border-radius:12px;padding:14px 18px;text-align:left;cursor:pointer;
  font:inherit;color:inherit;box-shadow:var(--shadow-sm);
  transition:background .2s,border-color .2s,box-shadow .2s;
}
.faq .faq-toggle:hover{border-color:#ddd;box-shadow:0 8px 28px rgba(0,0,0,.08);}
.faq .faq-toggle:focus-visible{outline:2px solid transparent;box-shadow:0 0 0 3px color-mix(in oklab, var(--brand) 60%, #fff);border-color:var(--brand);}
.faq .faq-item.is-open .faq-toggle{border-color:var(--brand);}
.faq .faq-toggle>span:last-child{flex:1 1 auto;font-weight:700;line-height:1.7;}
.faq .faq-toggle::after{
  content:"";flex:0 0 auto;width:12px;height:12px;margin-left:10px;margin-top:4px;border-right:2px solid currentColor;border-bottom:2px solid currentColor;transform:rotate(45deg);transition:transform .2s ease;opacity:.8;
}
.faq .faq-item.is-open .faq-toggle::after{transform:rotate(-135deg);}
.faq .faq-panel{
  overflow:hidden;max-height:0;opacity:0;transition:max-height .28s ease,opacity .18s ease;
  background:#fff;border:1px solid #eee;border-top:0;border-radius:0 0 12px 12px;padding:0 18px;
}
.faq .faq-item.is-open .faq-panel{opacity:1;}
.faq .faq-panel-inner{display:flex;gap:12px;padding:14px 0 16px;}
.faq .faq-panel-inner span:last-child{line-height:1.9;}
.faq-ico{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;background:#111;color:#fff;font-weight:700;font-size:.8rem;margin-top:2px;}
.faq-ico--q::before{content:"Q";}
.faq-ico--a::before{content:"A";}
@media (prefers-reduced-motion: reduce){.faq .faq-toggle,.faq .faq-panel{transition-duration:.001ms !important;}}

/* =======================================
   14) Instructors
======================================= */
.instructors-about p + p{margin-top:.8em;}
.instructors-note{margin:.2em 0 1.6em;opacity:.9;}

.inst-name{
  margin:.1em 0 .4em;font-family:"Klee One","Noto Serif JP",serif;font-weight:600;
  font-size:clamp(20px,2.2vw,26px);color:var(--brand);
}
.inst-photo img{display:block;width:100%;height:auto;object-fit:cover;border-radius:12px;}

.inst-meta{list-style:none;padding:0;margin:0 0 .6em;display:flex;flex-wrap:wrap;gap:10px 16px;font-size:.95rem;}
.inst-meta li strong{font-weight:700;}

.inst-quals{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:.8em;}
.inst-qual{display:inline-block;padding:6px 10px;border-radius:999px;background:#f4f6fb;color:#3a4c6b;font-size:.85rem;font-weight:700;letter-spacing:.02em;}

.instructor-profile.visual-grid{gap:22px;align-items:start;}
@media (min-width:960px){
  .instructor-profile.visual-grid{grid-template-columns:1fr 1.2fr;}
  .instructor-profile.inst--reverse.visual-grid{grid-template-columns:1.2fr 1fr;}
  .instructor-profile.inst--reverse .visual-image{order:2;}
  .instructor-profile.inst--reverse .visual-text{order:1;}
}
.inst-bio p{margin:.5em 0;line-height:1.9;}


/* ===== Contact Form ===== */
.contact-form .wpcf7 form { margin: 0; }
.form-grid{
  display: grid; gap: 16px;
  grid-template-columns: 1fr 1fr;
}
.form-row{ display:flex; flex-direction:column; gap:8px; }
.form-row--full{ grid-column: 1 / -1; }

/* ラベル */
.form-row > label{
  font-weight:700; letter-spacing:.02em;
  display:flex; align-items:center; gap:8px;
}
.req{
  display:inline-block; font-size:.75rem; line-height:1;
  padding:2px 6px; border-radius:999px;
  background:#f4f6fb; color:#3a4c6b; font-weight:700;
}

/* 入力 */
.input-text,
.input-select,
.input-textarea,
input[type="text"], input[type="email"], input[type="tel"],
select, textarea{
  appearance:none; width:100%;
  border:1px solid #e5e7eb; border-radius:12px;
  padding:12px 14px; background:#fff; color:var(--text);
  transition:border-color .18s, box-shadow .18s, background .18s;
  font: inherit; line-height:1.6;
}
.input-textarea, textarea{ min-height: 160px; resize: vertical; }
.input-file{ display:block; }

/* フォーカス */
.input-text:focus, .input-select:focus, .input-textarea:focus,
input:focus, select:focus, textarea:focus{
  outline: 2px solid transparent;
  border-color: color-mix(in oklab, var(--brand) 55%, #ddd);
  box-shadow: 0 0 0 3px color-mix(in oklab, var(--brand) 35%, #fff);
}

/* エラー・メッセージ */
.wpcf7 form .wpcf7-not-valid{
  border-color:#e96363 !important;
  box-shadow: 0 0 0 3px rgba(233,99,99,.12);
}
.wpcf7 form .wpcf7-not-valid-tip{
  font-size:.85rem; color:#b42318; margin-top:6px;
}
.wpcf7 form .wpcf7-response-output{
  margin-top:12px; border-radius:12px; padding:12px 14px; border:1px solid #eee; background:#fff;
}

/* 送信ボタン（既存ボタンを流用） */
.form-actions .btn{ padding:14px 26px; }

/* SPレイアウト */
@media (max-width: 960px){
  .form-grid{ grid-template-columns: 1fr; }
}
/* Trial Flow */
.trial-flow .flow-step {
  margin-bottom:64px;
}
.trial-flow .flow-step h4 {
  font-family:"Klee One", serif;
  font-size:1.25rem;
  color:var(--brand);
  margin-bottom:.5em;
  display:flex;
  align-items:center;
  gap:.4em;
}
.trial-flow .step-num {
  display:inline-block;
  width:2em; height:2em;
  border-radius:50%;
  background:var(--brand);
  color:#fff; font-weight:700;
  line-height:2em; text-align:center;
  font-size:.9rem;
}
.trial-flow figure {
  margin-top:16px;
}
.trial-flow figure img {
  width:100%; height:auto;
  border-radius:12px; object-fit:cover;
}
					
					
/* =========================
   Home CONCEPT（寄せバランス）
========================= */
.home-concept{
  background:#fff;
  padding-block:80px;
}
@media (min-width:961px){ .home-concept{ padding-block:100px; } }

.home-concept__head{
  text-align:center;
  margin-bottom:28px;
}
.home-concept__label{
  display:block;
  font-size:.95rem;
  letter-spacing:.15em;
  color: var(--brand, #90B8E0);
  font-weight:600;
  margin-bottom:6px;
}
.home-concept__title{
  font-size:2rem;
  font-weight:700;
  letter-spacing:.12em;
  color: var(--brand, #90B8E0);
}
@media (min-width:961px){
  .home-concept__title{ font-size:2.4rem; }
}

/* リード文（スプラッシュフォントで太く） */
.home-concept__lead{
  text-align:center;
  font-family: var(--splash-font, "Klee One", "Noto Serif JP", serif);
  font-size:1.6rem;
  font-weight:600;   /* ← 太めに */
  line-height:1.55;  /* 詰めて力強く */
  color:#222;
  margin:22px auto 28px;
  max-width:42rem;
}
@media (min-width:961px){
  .home-concept__lead{
    font-size:1.9rem;
    line-height:1.55;
  }
}

/* 本文（ゆったり行間） */
.home-concept__body{
  max-width:46rem;
  margin:0 auto;
  color:#444;
  line-height:2;     /* ←広めにして読みやすさ重視 */
  font-size:1rem;
  text-align:center;
}

.home-concept__cta{
  text-align:center;
  margin-top:40px;
}
.btn.btn--brand-lg{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:1.2em 3.2em;
  border-radius:999px;
  font-weight:700;
  font-size:1.2rem;
  background: var(--brand, #90B8E0);
  color:#fff;
  border:1px solid transparent;
  text-decoration:none;
  transition:filter .2s ease, transform .08s ease;
}
.btn.btn--brand-lg:hover{ filter:brightness(.95); }
.btn.btn--brand-lg:active{ transform:translateY(1px); }


					
					
/* =========================
   Gate Split (MENU / PRICE)
========================= */
.home-visual-split{ margin:0; padding:0; }
.gate-split{
  display:grid; grid-template-columns:1fr 1fr; width:100%;
}
@media (max-width:960px){
  .gate-split{ grid-template-columns:1fr; }
}

.gate-split__card{
  position:relative; display:block; overflow:hidden;
  isolation:isolate; text-decoration:none; color:#fff;
  /* 高さバランス：画像が未ロードでも見栄えを維持 */
  aspect-ratio:16/9; /* 好みで16/10や3/2でもOK */
}
@supports not (aspect-ratio:1/1){
  .gate-split__card::before{ content:""; display:block; padding-top:56.25%; }
}

.gate-split__card img{
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; transform:scale(1.02);
  transition:transform .5s ease, filter .5s ease;
  filter:saturate(1) contrast(1.02);
}

/* 下部グラデーションで白文字をくっきり */
.gate-split__card::after{
  content:""; position:absolute; inset:auto 0 0 0; height:62%;
  background: linear-gradient(to top, rgba(0,0,0,.52), rgba(0,0,0,.22) 45%, transparent 70%);
  z-index:1; pointer-events:none;
}

/* オーバーレイ内側 */
.gate-split__overlay{
  position:absolute; inset:0; display:flex; align-items:flex-end;
  justify-content:space-between; padding:18px 16px; z-index:2;
}
@media (min-width:961px){
  .gate-split__overlay{ padding:22px 22px; }
}

.gate-split__text{ max-width:70%; }
.gate-split__label{
  display:inline-block; font-size:.85rem; letter-spacing:.14em;
  color:#e5e7eb; opacity:.95; margin-bottom:6px;
}
.gate-split__title{
  margin:0 0 6px; font-family: var(--heading-font, "Klee One", "Noto Sans JP", system-ui, -apple-system, sans-serif);
  font-weight:800; letter-spacing:.08em; font-size:2rem; line-height:1;
  text-shadow:0 2px 10px rgba(0,0,0,.25); color:#fff;
}
@media (min-width:961px){
  .gate-split__title{ font-size:2.2rem; }
}
.gate-split__desc{
  margin:0; font-size:.95rem; line-height:1.6; opacity:.95;
}

/* 矢印ボタン風 */
.gate-split__arrow{
  display:inline-flex; align-items:center; justify-content:center;
  width:44px; height:44px; border-radius:999px;
  background:rgba(255,255,255,.92); color: var(--brand, #90B8E0);
  box-shadow:0 6px 16px rgba(0,0,0,.18);
  transform:translate3d(0,0,0);
  transition:transform .18s ease, background .18s ease, color .18s ease, box-shadow .18s ease;
}

/* ホバー演出：自然なズーム＋矢印ちょいスライド */
.gate-split__card:hover img{ transform:scale(1.06); filter:saturate(1.05); }
.gate-split__card:hover .gate-split__arrow{ transform:translateX(2px); background:#fff; color:#1f293b; }

/* 省エネ＆タッチ端末配慮 */
@media (hover:none){
  .gate-split__card:hover img{ transform:scale(1.02); }
  .gate-split__card:hover .gate-split__arrow{ transform:none; }
}
@media (prefers-reduced-motion: reduce){
  .gate-split__card img{ transition:none; }
  .gate-split__card:hover img{ transform:none; }
  .gate-split__arrow{ transition:none; }
}
					
					/* =========================
   NEWS（お知らせ）
========================= */
.home-news{ padding-block:70px; background:#fff; }
@media (min-width:961px){ .home-news{ padding-block:90px; } }

.home-news__head{
  text-align:center; margin-bottom:26px;
}
.home-news__label,
.home-news__title{
  display:block; letter-spacing:.15em; color: var(--brand, #90B8E0); font-weight:600;
}
.home-news__label{ font-size:.95rem; margin-bottom:6px; }
.home-news__title{ font-size:2rem; }
@media (min-width:961px){ .home-news__title{ font-size:2.4rem; } }

/* grid */
.news-grid{
  display:grid; gap:16px;
}
@media (min-width:801px){
  .news-grid{ grid-template-columns:repeat(3, 1fr); gap:20px; }
}

/* card */
.news-card{
  background:#fff; border:1px solid #e6e8eb; border-radius:12px; overflow:hidden;
  transition: box-shadow .18s ease, transform .18s ease, border-color .18s ease;
}
.news-card:hover{
  box-shadow:0 10px 28px rgba(0,0,0,.08);
  transform: translateY(-2px);
  border-color:#d9dce1;
}
.news-card__link{ display:block; color:inherit; text-decoration:none; }

/* thumb with fixed ratio */
.news-card__thumb{ position:relative; aspect-ratio:16/9; background:#f3f4f6; overflow:hidden; }
@supports not (aspect-ratio:1/1){
  .news-card__thumb::before{ content:""; display:block; padding-top:56.25%; }
}
.news-card__thumb img{
  position:absolute; inset:0; width:100%; height:100%; object-fit:cover;
  transform: scale(1.02); transition: transform .5s ease;
}
.news-card:hover .news-card__thumb img{ transform: scale(1.06); }

/* body */
.news-card__body{ padding:12px 14px 14px; }
.news-card__title{
  font-size:1.02rem; line-height:1.5; color:#1f2937; margin:4px 0 8px; font-weight:700;
  display:-webkit-box; -webkit-line-clamp:2; -webkit-box-orient:vertical; overflow:hidden;
}
.news-card__meta{
  font-size:.85rem; color:#6b7280;
}
