/* =============================================================
   合同会社YHK — style.css
   Aesthetic: 「幕開け」 editorial luxury — teal × gold × cream
   -------------------------------------------------------------
   レスポンシブ ブレークポイント（max-width / モバイルファースト上書き）:
     1024 … タブレット横・サイドバー調整
      900 … 3カラム→1カラム、メッセージ等の段組み解除
      768 … 主要切替（PCサイドバー→SPハンバーガー、入力欄16px）
      680 … タイムライン/2カラムの縦積み
      600 … ニュースバー・年表の細かいグリッド調整
      560 … 会社概要/特商法テーブルの縦積み
      480 … ボタン全幅などの最小調整
   ※ 表記は「@media (max-width:...)」に統一すること
   ============================================================= */

/* ---------- Fonts ---------- */
/* Cormorant Garamond (EN display) / Shippori Mincho (JP serif) /
   Zen Kaku Gothic New (JP body) / Parisienne (script accent) */

/* ---------- Tokens ---------- */
:root{
  /* ロゴのターコイズを基調にした配色（ベース=ロゴカラー） */
  --turq:#2bd3c5;        /* ロゴそのままの明るいターコイズ（小さなアクセント用） */
  --teal:#0fa093;        /* アクセント・リンク・罫 */
  --teal-deep:#0c8a7f;   /* グラデ上部 */
  --teal-ink:#0a6e64;    /* ベース（フッター・CTA・Stats等の面） */
  --teal-mist:#e4f5f2;
  --gold:#c2a14d;
  --gold-light:#e3cf9c;
  --gold-soft:#d8c79a;
  --cream:#fdfcfa;
  --cream-2:#f4f2ec;
  --white:#ffffff;
  --ink:#1b2b2a;
  --muted:#5f6f6e;

  --ff-display:'Cormorant Garamond',serif;
  --ff-serif:'Zen Old Mincho','Shippori Mincho',serif;
  --ff-body:'Zen Kaku Gothic New',sans-serif;
  --ff-script:'Pinyon Script','Parisienne',cursive;

  --wrap:1240px;
  --gut:clamp(20px,5vw,72px);
  --ease:cubic-bezier(.22,1,.36,1);
  --header-h:84px;
  --side-w:188px;

  /* ハイビスカス（マーカー・アクセント共通） */
  --flower:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='%23d6362a'%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(72 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(144 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(216 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(288 50 52)'/%3E%3C/g%3E%3Ccircle cx='50' cy='53' r='9' fill='%23a83228'/%3E%3Cpath d='M50 53 Q 52 78 53 95' stroke='%23c2a14d' stroke-width='4.5' fill='none' stroke-linecap='round'/%3E%3Cg fill='%23e3cf9c'%3E%3Ccircle cx='53' cy='95' r='4'/%3E%3Ccircle cx='47' cy='92' r='2.6'/%3E%3Ccircle cx='59' cy='92' r='2.6'/%3E%3C/g%3E%3C/svg%3E");
  --flower-gold:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='%23c2a14d'%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(72 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(144 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(216 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(288 50 52)'/%3E%3C/g%3E%3Ccircle cx='50' cy='53' r='8' fill='%23a07a2c'/%3E%3C/svg%3E");
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--ff-body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.95;
  font-size:16.5px;
  letter-spacing:.03em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;height:auto}
/* 日本語の改行を自然に：見出しは行頭行末を均等化、本文は文節区切りで折り返し＆孤立行を抑制 */
:where(h1,h2,h3,h4,.sec-title,.concept,.lead,blockquote,.hero-title){text-wrap:balance}
:where(p,li,dd,td,figcaption,.ach-tt){text-wrap:pretty}
:where(p,li,.lead,blockquote,.concept,.sec-title,h1,h2,h3,td){word-break:auto-phrase}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
ul{list-style:none}

/* grain overlay */
body::after{
  content:"";position:fixed;inset:0;z-index:9998;pointer-events:none;opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  mix-blend-mode:multiply;
}

/* ---------- Layout helpers ---------- */
.wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:var(--gut)}
.section{padding:clamp(72px,11vw,150px) 0;position:relative}
.bleed{padding-inline:var(--gut)}

/* eyebrow / index / title */
.eyebrow{
  font-family:var(--ff-display);
  font-size:.82rem;letter-spacing:.42em;text-transform:uppercase;
  color:var(--teal);font-weight:600;display:inline-flex;align-items:center;gap:.9em;
}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold)}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold)}
.eyebrow.center{justify-content:center}

.script{font-family:var(--ff-script);color:var(--gold);font-weight:400;line-height:1}

.h-display{
  font-family:var(--ff-display);
  font-weight:500;line-height:1.06;letter-spacing:.01em;
  font-size:clamp(2.4rem,6vw,4.6rem);
}
.h-jp{font-family:var(--ff-serif);font-weight:600;line-height:1.4}

.sec-title{
  font-family:var(--ff-serif);font-weight:600;
  font-size:clamp(1.7rem,3.6vw,2.7rem);line-height:1.45;letter-spacing:.04em;
  color:var(--teal-ink);
}
.sec-lead{color:var(--muted);max-width:46ch;margin-top:1.2em;font-size:.98rem;line-height:2.1}

.idx{
  font-family:var(--ff-display);font-style:italic;font-size:1.2rem;
  color:var(--gold);letter-spacing:.08em;
}

/* 数字を読みやすく（ライニング数字・直立・等幅） */
.ach-row .ach-yr,.award-list .yr,.ln-date,.news-item .date,
.svc-card .num,.svc-row__media .num,.stat .n,.idx{
  font-style:normal;
  font-variant-numeric:lining-nums tabular-nums;
  font-feature-settings:"lnum" 1,"tnum" 1;
}

/* ---------- Buttons / links ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.8em;
  font-family:var(--ff-display);font-size:1.02rem;font-weight:600;letter-spacing:.16em;
  text-transform:uppercase;padding:1.05em 2.4em;position:relative;isolation:isolate;
  border:1px solid var(--gold);color:var(--teal-ink);overflow:hidden;
  transition:color .5s var(--ease);
}
.btn::before{
  content:"";position:absolute;inset:0;background:var(--gold);
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);z-index:-1;
}
.btn:hover{color:var(--teal-ink)}
.btn:hover::before{transform:scaleX(1)}
.btn.solid{background:var(--teal-ink);color:#fff;border-color:var(--teal-ink)}
.btn.solid::before{background:var(--gold)}
.btn.solid:hover{color:var(--teal-ink)}
.form .btn.solid:hover{color:#fff}
.btn.light{color:var(--cream);border-color:var(--gold-light)}
.btn.sm{padding:.95em 2em;font-family:var(--ff-body);font-weight:600;font-size:.92rem;letter-spacing:.1em;text-transform:none;margin-top:.5em}
.btn.sm:hover{color:var(--teal-ink)}
.btn .ar{transition:transform .4s var(--ease)}
.btn:hover .ar{transform:translateX(5px)}

.link-gold{
  font-family:var(--ff-display);font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  font-size:.92rem;color:var(--teal-ink);display:inline-flex;align-items:center;gap:.7em;position:relative;
}
.link-gold::after{content:"";position:absolute;left:0;bottom:-6px;height:1px;width:100%;
  background:var(--gold);transform:scaleX(.0);transform-origin:left;transition:transform .45s var(--ease)}
.link-gold:hover::after{transform:scaleX(1)}
.link-gold .ar{transition:transform .4s var(--ease)}
.link-gold:hover .ar{transform:translateX(5px)}

/* ============================================================
   Curtain (opening reveal)
   ============================================================ */
.curtain{position:fixed;inset:0;z-index:10000;display:flex;pointer-events:none}
.curtain__panel{flex:1;background:linear-gradient(180deg,var(--teal-deep),var(--teal-ink));position:relative;overflow:hidden}
.curtain__panel::before{ /* gold thread along inner edge */
  content:"";position:absolute;top:0;bottom:0;width:2px;background:linear-gradient(180deg,transparent,var(--gold),transparent)}
.curtain__panel.l::before{right:0}
.curtain__panel.r::before{left:0}
.curtain__panel::after{ /* subtle vertical drape lines */
  content:"";position:absolute;inset:0;opacity:.25;
  background:repeating-linear-gradient(90deg,rgba(0,0,0,.25) 0 2px,transparent 2px 26px);
}
.curtain__logo{
  position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:10001;
  display:flex;flex-direction:column;align-items:center;gap:18px;
  transition:opacity .6s ease;
}
.curtain__logo img{width:108px;filter:drop-shadow(0 8px 30px rgba(0,0,0,.3))}
.curtain__logo .script{font-size:1.5rem;color:var(--gold-light);letter-spacing:.04em}
.curtain.is-open .curtain__panel.l{transform:translateX(-100%);transition:transform 1.5s cubic-bezier(.76,0,.24,1) .15s}
.curtain.is-open .curtain__panel.r{transform:translateX(100%);transition:transform 1.5s cubic-bezier(.76,0,.24,1) .15s}
.curtain.is-open .curtain__logo{opacity:0;transition:opacity .5s ease}
.curtain.done{display:none}
body.curtain-active{overflow:hidden}

/* ============================================================
   Page curtain（ページ遷移カーテン・全ページ）
   ============================================================ */
.page-curtain{position:fixed;inset:0;z-index:10000;pointer-events:none;display:flex}
/* 初回以外（sessionStorage）は head のスクリプトで .curtain-seen を付与し非表示 */
html.curtain-seen .page-curtain{display:none}
.pc-panel{flex:1;height:100%;position:relative;transform:translateY(0);
  background:linear-gradient(180deg,var(--teal-deep),var(--teal-ink));
  animation:pcReveal .7s cubic-bezier(.76,0,.24,1) forwards}
.pc-panel::after{content:"";position:absolute;left:0;right:0;bottom:0;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent);opacity:.55}
.pc-panel:not(:last-of-type){border-right:1px solid rgba(6,46,45,.4)}
/* 入場：ロゴを見せたまま約3.3秒キープ → 中央16枚が外側へ波打って一気に上へ抜ける（全体 約4秒） */
.pc-panel:nth-of-type(8),.pc-panel:nth-of-type(9){animation-delay:3.300s}
.pc-panel:nth-of-type(7),.pc-panel:nth-of-type(10){animation-delay:3.335s}
.pc-panel:nth-of-type(6),.pc-panel:nth-of-type(11){animation-delay:3.370s}
.pc-panel:nth-of-type(5),.pc-panel:nth-of-type(12){animation-delay:3.405s}
.pc-panel:nth-of-type(4),.pc-panel:nth-of-type(13){animation-delay:3.440s}
.pc-panel:nth-of-type(3),.pc-panel:nth-of-type(14){animation-delay:3.475s}
.pc-panel:nth-of-type(2),.pc-panel:nth-of-type(15){animation-delay:3.510s}
.pc-panel:nth-of-type(1),.pc-panel:nth-of-type(16){animation-delay:3.545s}
@keyframes pcReveal{0%{transform:translateY(0)}100%{transform:translateY(-101%)}}

.page-curtain__logo{position:absolute;left:50%;top:50%;z-index:1;
  display:flex;flex-direction:column;align-items:center;gap:14px;opacity:0;
  animation:pcLogo 3.5s var(--ease) forwards}
.page-curtain__logo img{width:88px;filter:drop-shadow(0 8px 30px rgba(0,0,0,.3))}
.page-curtain__logo .script{font-family:var(--ff-script);color:var(--gold-light);font-size:1.8rem;line-height:1}
@keyframes pcLogo{0%{opacity:0;transform:translate(-50%,-44%)}10%{opacity:1;transform:translate(-50%,-50%)}
  88%{opacity:1;transform:translate(-50%,-50%)}97%{opacity:0;transform:translate(-50%,-56%)}100%{opacity:0;transform:translate(-50%,-56%)}}

/* 退場（遷移時・JS）：16枚が中央から外側へ波打って下から閉じる */
.page-curtain.is-covering .pc-panel{animation:pcCover .55s cubic-bezier(.76,0,.24,1) forwards}
.page-curtain.is-covering .pc-panel:nth-of-type(8),.page-curtain.is-covering .pc-panel:nth-of-type(9){animation-delay:0s}
.page-curtain.is-covering .pc-panel:nth-of-type(7),.page-curtain.is-covering .pc-panel:nth-of-type(10){animation-delay:.03s}
.page-curtain.is-covering .pc-panel:nth-of-type(6),.page-curtain.is-covering .pc-panel:nth-of-type(11){animation-delay:.06s}
.page-curtain.is-covering .pc-panel:nth-of-type(5),.page-curtain.is-covering .pc-panel:nth-of-type(12){animation-delay:.09s}
.page-curtain.is-covering .pc-panel:nth-of-type(4),.page-curtain.is-covering .pc-panel:nth-of-type(13){animation-delay:.12s}
.page-curtain.is-covering .pc-panel:nth-of-type(3),.page-curtain.is-covering .pc-panel:nth-of-type(14){animation-delay:.15s}
.page-curtain.is-covering .pc-panel:nth-of-type(2),.page-curtain.is-covering .pc-panel:nth-of-type(15){animation-delay:.18s}
.page-curtain.is-covering .pc-panel:nth-of-type(1),.page-curtain.is-covering .pc-panel:nth-of-type(16){animation-delay:.21s}
@keyframes pcCover{0%{transform:translateY(101%)}100%{transform:translateY(0)}}

/* ============================================================
   Sidebar navigation（縦書き・左固定）
   ============================================================ */
body{padding-left:var(--side-w)}
.site-sidebar{
  position:fixed;top:0;left:0;height:100vh;width:var(--side-w);z-index:9000;
  display:flex;flex-direction:column;align-items:flex-start;justify-content:space-between;
  padding:34px 28px;background:linear-gradient(180deg,#ffffff 0%,var(--cream) 58%,#f6f2e9 100%);
  border-right:none;
  box-shadow:7px 0 40px -28px rgba(6,64,63,.3);
  transition:background 2s var(--ease),box-shadow 2s var(--ease);
}
.brand,.side-nav,.side-foot,.hamburger{position:relative;z-index:1}
.brand{display:flex;align-items:center;justify-content:center;z-index:9100}
.brand-logo{width:clamp(104px,78%,124px);height:auto;transition:filter 2s var(--ease)}
.side-nav ul{display:flex;flex-direction:column;align-items:flex-start;gap:clamp(20px,3.2vh,36px)}
.side-nav a{
  writing-mode:horizontal-tb;font-family:var(--ff-body);font-size:.92rem;font-weight:500;letter-spacing:.12em;
  color:var(--teal-ink);position:relative;padding:3px 0;transition:color 2s var(--ease);white-space:nowrap
}
.side-nav a::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;
  background:linear-gradient(90deg,var(--gold),var(--gold-soft));
  transform:scaleX(0);transform-origin:right;transition:transform .45s var(--ease)}
.side-nav a:hover::after,.side-nav a.current::after{transform:scaleX(1);transform-origin:left}
.side-nav a:hover,.side-nav a.current{color:var(--gold)}
/* 事業内容のサブメニュー（ホバーで右に展開） */
.side-nav .has-sub{position:relative}
.side-nav .has-sub > a{padding-right:18px}
.side-nav .has-sub > a::before{content:"+";position:absolute;right:0;top:50%;transform:translateY(-50%);
  font-family:var(--ff-body);font-size:.9rem;color:var(--gold);opacity:.6;transition:opacity .3s,transform .35s var(--ease),color 2s var(--ease)}
.side-nav .has-sub:hover > a::before{opacity:1;transform:translateY(-50%) rotate(90deg);color:var(--gold)}
.sub-nav{position:absolute;left:calc(100% + 6px);top:50%;transform:translateY(-50%) translateX(-10px);
  width:268px;padding:8px 0;background:#fff;border:none;border-radius:0;align-items:stretch;
  box-shadow:0 32px 72px -34px rgba(6,64,63,.5),0 6px 16px -10px rgba(6,64,63,.22);
  opacity:0;visibility:hidden;pointer-events:none;z-index:30;
  transition:opacity .35s var(--ease),transform .35s var(--ease),visibility .35s,background .3s var(--ease);transition-delay:.16s}
/* .side-nav ul の align-items:flex-start を打ち消し、項目を端まで伸ばす */
.side-nav .sub-nav{align-items:stretch}
/* 透明ブリッジ：サイドバー右余白＋隙間を覆い、パネルまでマウスが途切れない */
.sub-nav::before{content:"";position:absolute;top:0;height:100%;left:-48px;width:54px}
.side-nav .has-sub:hover .sub-nav{opacity:1;visibility:visible;pointer-events:auto;
  transform:translateY(-50%) translateX(0);transition-delay:0s}
.sub-nav li{margin:0;opacity:0;transform:translateX(10px);transition:opacity .4s var(--ease),transform .4s var(--ease)}
.side-nav .has-sub:hover .sub-nav li{opacity:1;transform:none}
.side-nav .has-sub:hover .sub-nav li:nth-child(1){transition-delay:.06s}
.side-nav .has-sub:hover .sub-nav li:nth-child(2){transition-delay:.12s}
.side-nav .has-sub:hover .sub-nav li:nth-child(3){transition-delay:.18s}
.side-nav .has-sub:hover .sub-nav li:nth-child(4){transition-delay:.24s}
.sub-nav a{display:flex;align-items:center;justify-content:space-between;gap:14px;writing-mode:horizontal-tb;padding:14px 20px;font-size:.92rem;font-weight:600;
  width:100%;box-sizing:border-box;color:var(--teal-ink);letter-spacing:.04em;white-space:nowrap;border-radius:0;transition:background .3s,color .3s}
/* ホバーで右に矢印がスッと現れる（下線スタイルを打ち消す） */
.sub-nav a::after{content:"→";position:static;width:auto;height:auto;background:none;display:inline-block;
  color:#fff;opacity:0;transform:translateX(-8px);
  transition:opacity .3s var(--ease),transform .3s var(--ease);writing-mode:horizontal-tb}
.sub-nav a::before{display:none}
/* ホバーした項目（div全体）をターコイズ＋白文字に（パネルは白のまま） */
.sub-nav a:hover{background:var(--teal);color:#fff}
.sub-nav a:hover::after{opacity:1;transform:none}
.side-foot{display:flex;flex-direction:column;align-items:flex-start;gap:14px}
.side-foot .v-line{width:1px;height:34px;background:linear-gradient(180deg,var(--gold),transparent);transition:background 2s var(--ease)}
.side-sns{display:flex;flex-wrap:wrap;gap:14px 16px;align-items:center}
.side-sns a{display:inline-flex;color:var(--teal-ink);opacity:.7;transition:opacity .4s,color 2s var(--ease),transform .3s}
.side-sns a svg{width:20px;height:20px;display:block}
/* 公式LINE：テーマに合わせた角型ボタン（ティール×ゴールド） */
.side-line{display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:11px 16px;border-radius:2px;background:var(--teal-ink);color:var(--cream);
  border:1px solid var(--gold);
  font-family:var(--ff-body);font-weight:600;font-size:.8rem;letter-spacing:.08em;line-height:1;white-space:nowrap;
  box-shadow:0 14px 30px -16px rgba(6,64,63,.55);
  transition:background .4s var(--ease),color .4s var(--ease),border-color .4s,transform .3s var(--ease)}
.side-line svg{width:18px;height:18px;flex:none;color:var(--gold-light);transition:color .4s var(--ease)}
.side-line:hover{background:var(--gold);border-color:var(--gold);color:#fff;transform:translateY(-2px)}
.side-line:hover svg{color:#fff}
.side-sns a:hover{opacity:1;color:var(--gold);transform:translateY(-2px)}

/* 言語切替トグル（JA / EN） */
.lang-switch{display:flex;align-items:center;gap:8px;margin-top:20px;font-family:var(--ff-body);font-size:.82rem;font-weight:600;letter-spacing:.08em}
.lang-switch button{font:inherit;letter-spacing:.08em;color:var(--teal-ink);opacity:.75;padding:2px 4px;transition:color .3s,opacity .3s}
.lang-switch button.is-active{opacity:1;font-weight:600;color:var(--gold)}
.lang-switch button:hover{opacity:1;color:var(--gold)}
.lang-switch span{color:var(--gold-soft)}

/* サイドバー全体ホバーで白⇔ターコイズに色反転（デスクトップのみ） */
@media (hover:hover) and (min-width:769px){
  .site-sidebar:hover{background:linear-gradient(180deg,var(--teal),var(--teal-ink));
    box-shadow:7px 0 50px -26px rgba(6,64,63,.55)}
  .site-sidebar:hover .brand-logo{filter:brightness(0) invert(1)}
  .site-sidebar:hover .side-nav a{color:var(--cream)}
  .site-sidebar:hover .side-nav > ul > li > a::after{background:linear-gradient(90deg,var(--gold-light),var(--gold-soft))}
  .site-sidebar:hover .side-nav a:hover,
  .site-sidebar:hover .side-nav a.current{color:var(--gold-light)}
  /* サブメニュー：白パネル＋濃ティール文字、ホバーした項目だけターコイズ＋白文字 */
  .site-sidebar:hover .sub-nav a{color:var(--teal-ink)}
  .site-sidebar:hover .sub-nav a:hover{color:#fff}
  .site-sidebar:hover .has-sub > a::before{color:var(--cream)}
  .site-sidebar:hover .side-foot .v-line{background:linear-gradient(180deg,var(--gold-light),transparent)}
  .site-sidebar:hover .side-sns a{color:var(--cream)}
  .site-sidebar:hover .side-sns a:hover{color:var(--gold-light)}
  .site-sidebar:hover .lang-switch button{color:rgba(253,252,250,.6)}
  .site-sidebar:hover .lang-switch button.is-active,
  .site-sidebar:hover .lang-switch button:hover{color:var(--gold-light)}
}

/* hamburger（モバイルのみ） */
.hamburger{display:none;flex-direction:column;gap:6px;width:34px;height:34px;justify-content:center;align-items:center;z-index:9100}
.hamburger span{display:block;height:1.5px;width:26px;background:var(--teal-ink);transition:.4s var(--ease)}
.menu-open .hamburger span{background:var(--cream)}
.hamburger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.5px) rotate(45deg)}
.hamburger[aria-expanded="true"] span:nth-child(2){opacity:0}
.hamburger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.5px) rotate(-45deg)}

/* ============================================================
   Hero
   ============================================================ */
.hero{position:relative;height:100svh;min-height:620px;display:flex;align-items:center}
/* FIX: 動画は画面固定。コンテンツ(.scroll-cover)がこの上をスクロールして覆う */
.hero__media{position:fixed;inset:0;z-index:0;overflow:hidden;background:var(--teal-ink)}
.hero__v{position:absolute;inset:0;width:100%;height:100%}
.hero__v-blur{object-fit:cover;filter:blur(38px) brightness(.5) saturate(1.1);transform:scale(1.2)}
.hero__v-main{object-fit:contain;object-position:82% center}
.hero__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.hero__media::after{
  content:"";position:absolute;inset:0;
  background:
    linear-gradient(180deg,rgba(6,64,63,.5) 0%,rgba(6,64,63,.2) 30%,rgba(6,64,63,.35) 70%,rgba(6,64,63,.7) 100%),
    radial-gradient(120% 90% at 50% 45%,transparent 38%,rgba(6,64,63,.55) 100%);
}
.scroll-cover{position:relative;z-index:1;background:var(--cream)}
.hero__content{position:relative;z-index:2;width:100%;padding-inline:var(--gut);color:var(--cream)}
.hero__eyebrow{color:var(--gold-light);margin-bottom:24px}
.hero__eyebrow.eyebrow::before{background:var(--gold-light)}
.hero h1{
  font-family:var(--ff-serif);font-weight:600;color:var(--white);
  font-size:clamp(2rem,5.4vw,4.2rem);line-height:1.42;letter-spacing:.06em;
  text-shadow:0 4px 40px rgba(0,0,0,.35);
}
.hero h1 em{font-style:normal;color:var(--gold-light)}
.hero__script{font-family:var(--ff-script);font-size:clamp(1.6rem,4vw,2.6rem);color:var(--gold-light);margin-bottom:.2em;display:block}
/* ブランド名は筆記体をやめ、読みやすい上品なセリフ＋字間で */
.hero__wordmark{font-family:var(--ff-display);font-style:normal;font-weight:500;
  font-size:clamp(1.05rem,2.4vw,1.5rem);letter-spacing:.16em;text-transform:uppercase;margin-bottom:.5em}
.hero__sub{margin-top:30px;max-width:36em;font-size:1rem;color:rgba(253,252,250,.86);line-height:2.1}

/* hero title — 1文字ずつ表示 */
.hero-title{opacity:0;transition:opacity .3s ease}
.hero.ready .hero-title{opacity:1}
.hero-title .char{display:inline-block;opacity:0;transform:translateY(.55em) rotate(4deg);
  transition:opacity .95s var(--ease),transform 1.05s var(--ease)}
.hero-title .char.in{opacity:1;transform:none}
.hero__actions{margin-top:42px;display:flex;gap:18px;flex-wrap:wrap}

.hero__scroll{position:absolute;bottom:30px;left:50%;transform:translateX(-50%);z-index:3;
  display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--gold-light)}
.hero__scroll span{font-family:var(--ff-display);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase}
.hero__scroll i{width:1px;height:54px;background:linear-gradient(180deg,var(--gold-light),transparent);position:relative;overflow:hidden}
.hero__scroll i::after{content:"";position:absolute;top:-50%;left:0;width:1px;height:50%;background:var(--white);animation:scrolldot 2.2s var(--ease) infinite}
@keyframes scrolldot{0%{top:-50%}60%,100%{top:100%}}

/* hero staggered intro */
.hero__content [data-rise]{opacity:0;transform:translateY(32px)}
.hero.ready [data-rise]{opacity:1;transform:none;transition:opacity 1s var(--ease),transform 1s var(--ease)}
.hero.ready [data-rise="1"]{transition-delay:.1s}
.hero.ready [data-rise="2"]{transition-delay:.28s}
.hero.ready [data-rise="3"]{transition-delay:.46s}
.hero.ready [data-rise="4"]{transition-delay:.64s}
.hero.ready [data-rise="5"]{transition-delay:.82s}

/* ============================================================
   Reveal (scroll)
   ============================================================ */
.reveal{opacity:0;transform:translateY(38px);transition:opacity 1s var(--ease),transform 1s var(--ease)}
.reveal.is-visible{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.12s}
.reveal[data-d="2"]{transition-delay:.24s}
.reveal[data-d="3"]{transition-delay:.36s}
.reveal[data-d="4"]{transition-delay:.48s}
.reveal-img{overflow:hidden;position:relative}
.reveal-img img{transition:transform 1.6s var(--ease);transform:scale(1.08)}
.reveal-img.is-visible img{transform:scale(1)}

/* ============================================================
   Intro / concept
   ============================================================ */
.intro{background:var(--cream);position:relative}
.intro__grid{display:grid;grid-template-columns:1.25fr .75fr;gap:clamp(36px,5vw,78px);align-items:center}
.intro__copy .concept{
  font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);
  font-size:clamp(1.5rem,3vw,2.3rem);line-height:1.9;letter-spacing:.05em;margin:.6em 0 1em;
}
.intro__copy .concept .script{display:block;font-size:1.5em;margin-bottom:.1em}
.intro__copy p{color:var(--muted);line-height:2.15;margin-bottom:1.4em;max-width:none}
.intro__visual{position:relative}
.intro__visual .frame{aspect-ratio:4/5;box-shadow:0 40px 80px -40px rgba(6,64,63,.55)}
.intro__visual .frame img{width:100%;height:100%;object-fit:cover}
.intro__visual .tag{
  position:absolute;bottom:-26px;left:-26px;background:var(--teal-ink);color:var(--cream);
  padding:22px 28px;max-width:230px;border-top:2px solid var(--gold);
}
.intro__visual .tag b{font-family:var(--ff-display);font-size:2.4rem;color:var(--gold-light);display:block;line-height:1}
.intro__visual .tag span{font-size:.78rem;letter-spacing:.18em;color:rgba(253,252,250,.8)}

/* ============================================================
   Services
   ============================================================ */
.services{background:linear-gradient(180deg,var(--cream) 0%,var(--cream-2) 100%)}
.sec-head--split{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;flex-wrap:wrap;margin-bottom:clamp(40px,6vw,84px)}

.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,80px);align-items:center;margin-bottom:clamp(56px,8vw,120px)}
.svc-row:last-child{margin-bottom:0}
.svc-row:nth-child(even) .svc-row__media{order:2}
.svc-row__media{position:relative}
/* 数字がはみ出して切れないように（画像のクリップは .ph 側で担保） */
.svc-row__media.reveal-img{overflow:visible}
.svc-row__media .ph{position:relative;aspect-ratio:7/5;overflow:hidden}
.svc-row__media .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s var(--ease)}
/* アクセント色のオーバーレイ（ホバーで現れる） */
.svc-row__media .ph::after{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(180deg,transparent 40%,color-mix(in srgb,var(--accent,var(--teal-ink)) 62%,transparent));
  opacity:0;transition:opacity .55s var(--ease)}
.svc-row:hover .ph img{transform:scale(1.06)}
.svc-row:hover .ph::after{opacity:1}
.svc-row__media .num{
  position:absolute;top:-.72em;left:-16px;font-family:var(--ff-display);font-style:italic;font-weight:700;
  font-size:clamp(3.6rem,7.2vw,6.2rem);color:var(--accent,var(--gold));opacity:1;z-index:2;line-height:1;
  -webkit-text-stroke:5px var(--cream);text-stroke:5px var(--cream);paint-order:stroke fill;
  text-shadow:0 2px 3px rgba(6,64,63,.45)}
.svc-row:nth-child(even) .svc-row__media .num{left:auto;right:-14px}
.svc-row__body .kicker{font-family:var(--ff-script);color:var(--accent,var(--gold));font-size:1.6rem;line-height:1}
.svc-row__body h3{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);
  font-size:clamp(1.4rem,2.8vw,2rem);margin:.3em 0 .7em;letter-spacing:.04em;transition:color .4s var(--ease)}
.svc-row:hover .svc-row__body h3{color:var(--accent,var(--teal-ink))}
.svc-row__body p{color:var(--muted);line-height:2.1;margin-bottom:1.4em;max-width:44ch}
.svc-tags{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:1.6em}
.svc-tags li{font-size:.78rem;letter-spacing:.1em;color:var(--accent,var(--teal));border:1px solid color-mix(in srgb,var(--accent,var(--gold-soft)) 50%,transparent);
  padding:.5em 1.1em;border-radius:40px;background:color-mix(in srgb,var(--accent,#fff) 7%,#fff);transition:background .4s,color .4s,border-color .4s}
.svc-row:hover .svc-tags li{background:var(--accent,var(--teal));color:#fff;border-color:var(--accent,var(--teal))}
/* 「詳しく見る」ボタン：各事業のアクセント色で塗り、ホバー時は白文字 */
.svc-row .btn.sm{border-color:var(--accent,var(--gold));color:var(--accent,var(--teal-ink))}
.svc-row .btn.sm::before{background:var(--accent,var(--gold))}
.svc-row .btn.sm:hover{color:#fff}

/* services compact cards (used on home) */
.svc-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;background:transparent}
.svc-card{position:relative;overflow:hidden;isolation:isolate;min-height:430px;
  display:flex;flex-direction:column;justify-content:flex-end;padding:32px 28px;color:var(--cream);
  border:1px solid rgba(216,199,154,.22)}
.svc-card__bg{position:absolute;inset:0;z-index:-2;transform:scale(1.02);transition:transform 1.3s var(--ease)}
.svc-card__bg img{width:100%;height:100%;object-fit:cover}
.svc-card::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(180deg,rgba(0,0,0,.15) 0%,rgba(0,0,0,.5) 55%,rgba(0,0,0,.86) 100%);
  transition:background .6s var(--ease)}
.svc-card:hover .svc-card__bg{transform:scale(1.12)}
.svc-card:hover::after{background:linear-gradient(180deg,rgba(0,0,0,.28) 0%,rgba(0,0,0,.62) 55%,rgba(0,0,0,.92) 100%)}
.svc-card .num{position:absolute;top:26px;left:28px;font-family:var(--ff-display);font-style:italic;
  color:var(--gold-light);font-size:1.5rem;letter-spacing:.06em;text-shadow:0 2px 14px rgba(0,0,0,.4)}
.svc-card .num::after{content:"";display:block;width:26px;height:1px;background:var(--gold);margin-top:8px}
.svc-card h3{font-family:var(--ff-serif);font-weight:600;font-size:1.28rem;margin:0 0 .5em;color:var(--cream);letter-spacing:.04em;line-height:1.5}
.svc-card p{font-size:.86rem;color:rgba(253,252,250,.85);line-height:1.9}
.svc-card .en{font-family:var(--ff-display);letter-spacing:.2em;text-transform:uppercase;font-size:.72rem;
  color:var(--gold-light);margin-top:16px;display:flex;align-items:center;gap:8px}
.svc-card .en::before{content:"";width:18px;height:1px;background:var(--gold)}

/* ============================================================
   Stats
   ============================================================ */
.stats{background:var(--teal-ink);color:var(--cream);position:relative;overflow:hidden}
.stats__bg{position:absolute;inset:0;z-index:0;opacity:.24;overflow:hidden}
.stats__bg img{position:absolute;top:-13%;left:0;width:100%;height:126%;object-fit:cover}
.stats::before{content:"";position:absolute;inset:0;z-index:1;opacity:.5;background:
  radial-gradient(50% 70% at 20% 10%,var(--gold) 0,transparent 60%),
  radial-gradient(40% 60% at 90% 90%,var(--teal) 0,transparent 60%),
  linear-gradient(180deg,rgba(10,110,100,.55),rgba(6,64,63,.7))}
.stats > .wrap{position:relative;z-index:2}
.stats__head{text-align:center;margin-bottom:clamp(36px,5vw,60px);position:relative}
.stats__head .eyebrow{color:var(--gold-light)}
.stats__head .eyebrow::before{background:var(--gold-light)}
.stats__head h2{font-family:var(--ff-serif);font-weight:600;color:var(--cream);font-size:clamp(1.5rem,3vw,2.2rem);letter-spacing:.05em;margin-top:14px}
.stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(12px,1.5vw,20px);position:relative}
.stat{position:relative;text-align:center;padding:clamp(30px,3.4vw,50px) 16px;overflow:hidden;
  border:1px solid rgba(216,199,154,.26);background:rgba(253,252,250,.035);transition:.55s var(--ease)}
.stat::before{content:"";position:absolute;top:0;left:50%;transform:translateX(-50%);width:46px;height:2px;
  background:linear-gradient(90deg,transparent,var(--gold),transparent)}
.stat::after{content:"";position:absolute;inset:0;background:radial-gradient(80% 60% at 50% 0,rgba(216,199,154,.12),transparent 70%);opacity:0;transition:opacity .55s var(--ease)}
.stat:hover{transform:translateY(-6px);border-color:rgba(216,199,154,.55);background:rgba(216,199,154,.05)}
.stat:hover::after{opacity:1}
.stat .n{position:relative;font-family:var(--ff-display);font-weight:500;font-size:clamp(2.6rem,5.4vw,4.2rem);color:var(--gold-light);line-height:1}
.stat .n small{font-size:.4em;margin-left:.1em}
.stat .l{position:relative;margin-top:16px;font-size:.92rem;letter-spacing:.12em;color:rgba(253,252,250,.92);font-family:var(--ff-serif);font-weight:600}
.stat .l::before{content:"";display:block;width:24px;height:1px;background:var(--gold-soft);margin:0 auto 12px;opacity:.6}
.stat .jp{position:relative;font-size:.74rem;color:var(--gold-light);opacity:.7;margin-top:8px;letter-spacing:.18em;font-family:var(--ff-display);font-style:italic}

/* 実績（パネルが外から すっと フェードイン） */
.ach-list{max-width:940px;margin:0 auto;display:flex;flex-direction:column;gap:16px}
.ach-row{position:relative;display:grid;grid-template-columns:160px 1fr;gap:30px;align-items:center;
  padding:28px 34px;background:rgba(255,255,255,.045);border:1px solid rgba(216,199,154,.22);overflow:hidden;
  opacity:0;transform:translateX(220px) scale(.9);transform-origin:right center;
  transition:opacity .7s var(--ease),transform 1.05s cubic-bezier(.3,1.35,.4,1),background .4s var(--ease)}
.ach-row::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);
  transform:scaleY(0);transform-origin:top;transition:transform .8s var(--ease) .45s}
/* 右から左へ・大胆な時間差（上から順に） */
.ach-row:nth-child(2){transition-delay:.2s}
.ach-row:nth-child(3){transition-delay:.4s}
.ach-row:nth-child(4){transition-delay:.6s}
.ach-row.is-visible{opacity:1;transform:none}
.ach-row.is-visible::before{transform:scaleY(1)}
.ach-row .ach-yr{font-family:var(--ff-display);font-style:italic;font-size:clamp(1.7rem,3.2vw,2.5rem);
  color:var(--gold-light);line-height:1;letter-spacing:.04em;transition:color .45s var(--ease)}
.ach-row .ach-cat{display:block;font-family:var(--ff-display);font-size:.76rem;font-weight:600;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold-light);margin-top:10px;transition:color .45s var(--ease)}
.ach-row .ach-tt{font-family:var(--ff-serif);font-weight:600;color:var(--cream);
  font-size:clamp(1.02rem,1.9vw,1.3rem);line-height:1.7;letter-spacing:.03em;transition:color .45s var(--ease)}
/* ホバー：白背景に反転 */
.ach-row:hover{background:var(--cream);border-color:var(--gold)}
.ach-row:hover .ach-yr{color:var(--gold)}
.ach-row:hover .ach-cat{color:var(--teal)}
.ach-row:hover .ach-tt{color:var(--teal-ink)}
.ach-foot{text-align:center;margin-top:clamp(34px,5vw,52px)}
.ach-foot .link-gold{color:var(--cream)}
.ach-foot .link-gold::after{background:var(--gold-light)}
@media (max-width:680px){
  .ach-row{grid-template-columns:1fr;gap:8px;padding:22px 22px;transform:translateX(56px)}
}

/* ============================================================
   Profile band
   ============================================================ */
.profileband{background:var(--cream)}
.profileband__grid{display:grid;grid-template-columns:.72fr 1.28fr;gap:clamp(40px,5vw,72px);align-items:center}
.profileband__img{position:relative}
.profileband__img .frame{aspect-ratio:3/4;overflow:hidden;box-shadow:0 40px 90px -50px rgba(6,64,63,.6)}
.profileband__img .frame img{width:100%;height:100%;object-fit:cover}
.profileband__img .sig{position:absolute;right:-10px;bottom:24px;font-family:var(--ff-script);color:var(--gold);font-size:3rem;line-height:1;text-shadow:0 2px 20px rgba(253,252,250,.8)}
.profileband__body h2{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:clamp(1.6rem,3.4vw,2.4rem);line-height:1.5;margin:.4em 0 .2em;letter-spacing:.04em}
.profileband__body .role{font-family:var(--ff-display);letter-spacing:.2em;text-transform:uppercase;color:var(--gold);font-size:.86rem;font-weight:600}
.profileband__body p{color:var(--muted);line-height:2.2;margin:1.3em 0;max-width:none}
.award-list{position:relative;margin:2em 0;padding:0}
.award-list li{position:relative;display:grid;grid-template-columns:96px 1fr;column-gap:0;align-items:baseline;
  padding:21px 10px 21px 22px;border-bottom:1px solid rgba(194,161,77,.18);
  opacity:0;transform:translateX(-22px);transition:opacity .8s var(--ease),transform .8s var(--ease),background .45s var(--ease)}
.award-list li:last-child{border-bottom:none}
/* 丸ぽち廃止 → 左端に伸びるゴールドのアクセントバー */
.award-list li::before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);
  width:3px;height:0;border-radius:2px;background:linear-gradient(180deg,var(--gold),var(--gold-soft));
  transition:height .45s var(--ease)}
.award-list li:hover{transform:translateX(4px);background:linear-gradient(90deg,rgba(194,161,77,.08),transparent)}
.award-list li:hover::before{height:64%}
.award-list .yr{font-family:var(--ff-serif);font-weight:600;color:var(--gold);text-align:right;padding-right:26px;
  font-size:clamp(1.15rem,2vw,1.5rem);line-height:1.25;letter-spacing:.03em;white-space:nowrap;
  font-variant-numeric:lining-nums tabular-nums;font-feature-settings:"lnum" 1,"tnum" 1}
.award-list .tt{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);
  font-size:clamp(1rem,1.6vw,1.16rem);line-height:1.75;letter-spacing:.02em;
  padding-left:26px;border-left:1px solid rgba(194,161,77,.4);transition:color .4s,border-color .4s}
.award-list li:hover .tt{color:var(--teal);border-color:var(--gold)}
/* コンテナ表示時に時間差でスライドイン */
.reveal.is-visible .award-list li{opacity:1;transform:none}
.award-list li:nth-child(1){transition-delay:.04s}
.award-list li:nth-child(2){transition-delay:.1s}
.award-list li:nth-child(3){transition-delay:.16s}
.award-list li:nth-child(4){transition-delay:.22s}
.award-list li:nth-child(5){transition-delay:.28s}
.award-list li:nth-child(6){transition-delay:.34s}
.award-list li:nth-child(7){transition-delay:.4s}
.award-list li:nth-child(8){transition-delay:.46s}
.award-list li:nth-child(9){transition-delay:.52s}
.award-list li:nth-child(10){transition-delay:.58s}
@media (max-width:600px){
  .award-list li{grid-template-columns:1fr;row-gap:3px;padding:15px 10px 15px 16px}
  .award-list .yr{text-align:left;padding-right:0;font-size:1.05rem}
  .award-list .tt{padding-left:0;border-left:none;font-size:1rem;line-height:1.7}
}


/* ============================================================
   News
   ============================================================ */
.news{background:linear-gradient(180deg,var(--cream-2),var(--cream))}
.news-list{display:flex;flex-direction:column}
.news-item{position:relative;overflow:hidden;display:grid;grid-template-columns:170px 1fr auto;gap:30px;align-items:center;
  padding:30px 22px;border-top:1px solid rgba(194,161,77,.3);transition:padding-left .45s var(--ease)}
.news-item:last-child{border-bottom:1px solid rgba(194,161,77,.3)}
/* ホバー：グリーンが下から上へ満ちる */
.news-item::before{content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(180deg,var(--teal-deep),var(--teal-ink));
  transform:scaleY(0);transform-origin:bottom;transition:transform .95s var(--ease)}
.news-item:hover::before{transform:scaleY(1)}
.news-item:hover{padding-left:30px;transition:padding-left .8s var(--ease)}
.news-item > *{position:relative;z-index:1}
.news-item .meta{display:flex;flex-direction:column;gap:8px}
.news-item .date{font-family:var(--ff-serif);color:var(--gold);font-size:.98rem;letter-spacing:.04em;transition:color .8s var(--ease)}
.news-item .cat{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);
  border:1px solid var(--gold-soft);padding:.5em 1em;width:fit-content;transition:color .8s var(--ease),border-color .8s var(--ease)}
.news-item .ttl{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.08rem;line-height:1.7;letter-spacing:.03em;transition:color .8s var(--ease)}
.news-item .go{color:var(--gold);font-size:1.3rem;transition:transform .5s var(--ease),color .8s var(--ease)}
.news-item:hover .go{transform:translateX(6px);color:var(--gold-light)}
/* ホバー時の文字色 */
.news-item:hover .date{color:var(--gold-light)}
.news-item:hover .cat{color:var(--cream);border-color:rgba(216,199,154,.5)}
.news-item:hover .ttl{color:var(--cream)}

/* ============================================================
   CTA band
   ============================================================ */
.cta{position:relative;overflow:hidden;color:var(--cream);text-align:center;
  padding:clamp(80px,12vw,150px) 0;background:var(--teal-ink)}
.cta__bg{position:absolute;inset:0;z-index:0;opacity:.32;overflow:hidden}
.cta__bg img{position:absolute;top:-13%;left:0;width:100%;height:126%;object-fit:cover;will-change:transform}
/* — 背景画像を固定（FIX）表示：ヒーロー動画と同じくスクロールしても背景が動かない — */
.bg-fixed{background-attachment:fixed;background-position:center 32%;background-size:cover;background-repeat:no-repeat}
.bg-fixed img{display:none}
.cta::before{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(6,64,63,.8),rgba(10,92,90,.78))}
.cta .wrap{position:relative;z-index:2}
.cta h2{font-family:var(--ff-serif);font-weight:600;font-size:clamp(1.8rem,4vw,3rem);line-height:1.5;letter-spacing:.05em;margin:.4em 0 .2em}
.cta .script{font-size:clamp(1.8rem,4vw,2.6rem)}
.cta p{color:rgba(253,252,250,.8);max-width:40ch;margin:1.2em auto 2.4em;line-height:2.1}

/* ============================================================
   Footer
   ============================================================ */
.site-footer{background:linear-gradient(180deg,#1a1f1e,#0a0d0c);color:rgba(255,255,255,.92);padding-top:clamp(40px,5vw,60px)}
.footer-top{display:flex;flex-wrap:wrap;align-items:flex-start;gap:22px clamp(36px,6vw,80px);
  padding-bottom:clamp(24px,3vw,38px);border-bottom:1px solid rgba(216,199,154,.18)}
.footer-brand{flex:0 0 auto}
.footer-brand img{height:42px;margin-bottom:0}
.footer-col{flex:0 1 auto}
.footer-col h4{font-family:var(--ff-display);font-weight:600;letter-spacing:.22em;text-transform:uppercase;font-size:.8rem;color:var(--gold-light);margin-bottom:12px}
.footer-col ul{display:flex;flex-direction:row;flex-wrap:wrap;gap:8px 18px}
.footer-col a{font-size:.85rem;color:rgba(255,255,255,.95);transition:color .3s}
.footer-col a:hover{color:var(--gold-light)}
.sns-row{display:flex;flex-direction:row;align-items:center;gap:16px;margin-top:12px}
.sns-row a{display:inline-flex;align-items:center;color:rgba(255,255,255,.95);transition:color .3s,transform .3s}
.sns-row a:hover{color:var(--gold-light);transform:translateY(-2px)}
.sns-row a span{display:none}
.sns-row svg{width:23px;height:23px;color:var(--gold-light);flex:none;transition:color .3s}
.sns-row a:hover svg{color:var(--gold)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:20px 0}
.footer-bottom small{font-size:.8rem;letter-spacing:.08em;color:rgba(255,255,255,.8)}
.footer-bottom .pol{display:flex;gap:24px}
.footer-bottom .pol a{font-size:.8rem;color:rgba(255,255,255,.82);padding:4px 0}

/* ============================================================
   Sub-page hero
   ============================================================ */
.page-hero{position:relative;min-height:60vh;display:flex;align-items:flex-end;overflow:hidden;padding-bottom:clamp(40px,6vw,80px)}
.page-hero__bg{position:absolute;inset:0;z-index:0;overflow:hidden}
.page-hero__bg img{position:absolute;top:-13%;left:0;width:100%;height:126%;object-fit:cover;will-change:transform}
.page-hero__bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(6,64,63,.5),rgba(6,64,63,.82))}
.page-hero__inner{position:relative;z-index:2;color:var(--cream);width:100%}
.page-hero .eyebrow{color:var(--gold-light)}
.page-hero .eyebrow::before{background:var(--gold-light)}
.page-hero h1{font-family:var(--ff-serif);font-weight:600;font-size:clamp(2rem,5vw,3.4rem);line-height:1.4;letter-spacing:.06em;margin-top:18px;color:var(--white)}
.page-hero .en{font-family:var(--ff-display);font-style:italic;letter-spacing:.1em;color:var(--gold-light);font-size:1.2rem;margin-top:10px}

.breadcrumb{display:flex;gap:10px;align-items:center;font-size:.78rem;letter-spacing:.08em;color:var(--muted);padding:22px 0}
.breadcrumb a{color:var(--teal)}
.breadcrumb span{color:var(--gold)}

/* 下層ページの見出し（ヒーローバナーなし・コンパクト） */
.page-head{position:relative;background:var(--cream);padding:clamp(100px,15vh,184px) 0 0}
.page-head .breadcrumb{padding:0 0 22px}
.page-head .eyebrow{color:var(--teal)}
.page-head h1{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);
  font-size:clamp(2rem,4.6vw,3.1rem);line-height:1.4;letter-spacing:.06em;margin-top:14px}
.page-head::after{content:"";display:block;width:62px;height:2px;background:var(--gold);margin-top:28px}

/* ============================================================
   Contact
   ============================================================ */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.contact-aside h2{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:clamp(1.5rem,3vw,2.1rem);line-height:1.5;margin-bottom:.6em;letter-spacing:.04em}
.contact-aside p{color:var(--muted);line-height:2.1;margin-bottom:2em;max-width:42ch}
.contact-channels{display:flex;flex-direction:column;gap:16px;margin-bottom:2em}
.channel{display:flex;align-items:center;gap:20px;padding:22px 26px;border:1px solid var(--gold-soft);
  background:var(--white);position:relative;overflow:hidden;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s var(--ease)}
.channel::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);
  transform:scaleY(0);transform-origin:top;transition:transform .45s var(--ease)}
.channel:hover{transform:translateX(5px);box-shadow:0 28px 56px -38px rgba(6,64,63,.55);border-color:var(--gold)}
.channel:hover::before{transform:scaleY(1)}
.channel .ic{width:54px;height:54px;border-radius:50%;display:grid;place-items:center;flex:none;
  background:var(--teal-ink);transition:transform .45s var(--ease),background .4s var(--ease)}
.channel .ic svg{width:24px;height:24px;display:block;color:var(--gold-light);transition:color .4s var(--ease)}
.channel:hover .ic{transform:scale(1.06);background:var(--gold)}
.channel:hover .ic svg{color:#fff}
.channel .tx{flex:1;min-width:0}
.channel .tx b{display:block;font-family:var(--ff-display);letter-spacing:.16em;text-transform:uppercase;font-size:.92rem;color:var(--teal-ink)}
.channel .tx span{font-size:.88rem;color:var(--muted)}
.channel .ch-ar{color:var(--gold);font-size:1.3rem;flex:none;transition:transform .4s var(--ease)}
.channel:hover .ch-ar{transform:translateX(6px)}

/* form */
.form{display:flex;flex-direction:column;gap:22px;background:var(--white);padding:clamp(28px,4vw,44px);
  border-top:3px solid var(--gold);box-shadow:0 40px 80px -50px rgba(6,64,63,.5)}
.field{display:flex;flex-direction:column;gap:8px}
.field label{font-family:var(--ff-display);letter-spacing:.14em;text-transform:uppercase;font-size:.78rem;color:var(--teal-ink);font-weight:600}
.field label .req{color:var(--gold);margin-left:4px}
.field input,.field select,.field textarea{
  font-family:var(--ff-body);font-size:.95rem;color:var(--ink);
  border:1px solid #d9d2c4;background:var(--cream);padding:.9em 1em;transition:border .3s,box-shadow .3s;width:100%;
}
.field textarea{resize:vertical;min-height:130px}
/* SP: 入力欄は16px以上にしてiOSのフォーカス時自動ズームを防ぐ */
@media (max-width:768px){.field input,.field select,.field textarea{font-size:16px}}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 3px rgba(14,124,123,.12)}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.contact-status{font-size:.88rem;color:var(--teal);min-height:1.4em;letter-spacing:.02em}
.form .note{font-size:.74rem;color:var(--muted);line-height:1.8}

/* ============================================================
   About specifics
   ============================================================ */
.company-table{width:100%;border-collapse:collapse;margin-top:10px}
.company-table th,.company-table td{text-align:left;padding:24px 8px;border-bottom:1px solid rgba(194,161,77,.28);vertical-align:top;font-size:1rem}
.company-table th{font-family:var(--ff-serif);letter-spacing:.1em;font-size:.92rem;color:var(--gold);width:190px;font-weight:600}
.company-table td{color:var(--ink);line-height:2;overflow-wrap:anywhere}
/* SP: 会社概要/特商法テーブルは縦積みにして狭幅でのはみ出しを防ぐ */
@media (max-width:560px){
  .company-table tr{display:block;padding:14px 0;border-bottom:1px solid rgba(194,161,77,.28)}
  .company-table th,.company-table td{display:block;width:auto;padding:0;border:none}
  .company-table th{margin-bottom:4px}
  .company-table tr:last-child{border-bottom:none}
}

.message-block{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(36px,5vw,80px);align-items:center}
.message-block .frame{aspect-ratio:4/5;overflow:hidden;box-shadow:0 40px 80px -50px rgba(6,64,63,.55)}
.message-block .frame img{width:100%;height:100%;object-fit:cover}
.message-block blockquote{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:clamp(1.2rem,2.2vw,1.6rem);line-height:1.95;letter-spacing:.04em}
.message-block .from{margin-top:1.6em;font-family:var(--ff-display);letter-spacing:.1em;color:var(--muted)}
.message-block .from b{color:var(--teal-ink)}
.message-block .from .sig{font-family:var(--ff-script);color:var(--gold);font-size:2rem;display:block;margin-top:.2em}

/* ============================================================
   Gallery (profile)
   ============================================================ */
.gallery{columns:4;column-gap:12px}
.gallery .g-item{break-inside:avoid;margin-bottom:12px;overflow:hidden;position:relative;cursor:zoom-in}
.gallery .g-item img{width:100%;display:block;transition:transform 1.2s var(--ease)}
.gallery .g-item:hover img{transform:scale(1.07)}
.gallery .g-item::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(6,64,63,.45));opacity:0;transition:opacity .5s}
.gallery .g-item:hover::after{opacity:1}
.gallery .g-item::before{content:"";position:absolute;z-index:2;right:10px;bottom:10px;width:26px;height:26px;border-radius:50%;
  background:rgba(253,252,250,.92) url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230a6e64' stroke-width='2' stroke-linecap='round'%3E%3Ccircle cx='10.5' cy='10.5' r='6.5'/%3E%3Cpath d='M15.5 15.5 21 21M8 10.5h5M10.5 8v5'/%3E%3C/svg%3E") center/15px no-repeat;
  opacity:0;transform:scale(.7);transition:opacity .45s,transform .45s}
.gallery .g-item:hover::before{opacity:1;transform:scale(1)}

/* — Lightbox（モーダル拡大） — */
.lightbox{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center;
  background:rgba(6,40,38,.92);backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s;padding:clamp(20px,4vw,60px)}
.lightbox.is-open{opacity:1;visibility:visible}
.lightbox__img{max-width:92vw;max-height:86vh;box-shadow:0 40px 100px -30px rgba(0,0,0,.7);
  transform:scale(.94);transition:transform .45s var(--ease);object-fit:contain;background:#0a2826}
.lightbox.is-open .lightbox__img{transform:scale(1)}
.lightbox__close,.lightbox__nav{position:absolute;background:rgba(253,252,250,.12);border:1px solid rgba(253,252,250,.4);
  color:var(--cream);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s;backdrop-filter:blur(4px)}
.lightbox__close{top:clamp(16px,3vw,30px);right:clamp(16px,3vw,30px);width:48px;height:48px;border-radius:50%;font-size:1.5rem;line-height:1}
.lightbox__nav{top:50%;transform:translateY(-50%);width:52px;height:52px;border-radius:50%;font-size:1.6rem;line-height:1}
.lightbox__nav.prev{left:clamp(10px,2vw,28px)}
.lightbox__nav.next{right:clamp(10px,2vw,28px)}
.lightbox__close:hover,.lightbox__nav:hover{background:var(--gold);border-color:var(--gold);color:var(--teal-ink)}
.lightbox__count{position:absolute;bottom:clamp(16px,3vw,28px);left:50%;transform:translateX(-50%);
  color:rgba(253,252,250,.85);font-family:var(--ff-display);letter-spacing:.18em;font-size:.85rem}

/* News 読み込みスピナー */
.news-spinner{display:inline-block;width:22px;height:22px;vertical-align:-5px;margin-right:8px;
  border:2px solid rgba(194,161,77,.3);border-top-color:var(--gold);border-radius:50%;animation:newsSpin .8s linear infinite}
@keyframes newsSpin{to{transform:rotate(360deg)}}

/* tag list (services page details) */
.feature-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;margin-top:24px}
.feature{position:relative;padding:36px 30px 32px;background:linear-gradient(180deg,#fff,var(--cream));
  border:1px solid rgba(194,161,77,.2);overflow:hidden;
  transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s}
.feature::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--accent,var(--gold)),color-mix(in srgb,var(--accent,var(--gold)) 35%,transparent))}
.feature::after{content:"";position:absolute;right:-30px;top:-30px;width:88px;height:88px;border-radius:50%;
  border:1px solid color-mix(in srgb,var(--accent,var(--gold)) 22%,transparent);pointer-events:none}
.feature:hover{transform:translateY(-7px);box-shadow:0 36px 66px -42px rgba(6,64,63,.52);
  border-color:color-mix(in srgb,var(--accent,var(--gold)) 45%,transparent)}
.feature .fi{font-family:var(--ff-script);color:var(--accent,var(--gold));font-size:2.15rem;line-height:1}
.feature h4{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);margin:.35em 0 .55em;font-size:1.16rem;letter-spacing:.03em}
.feature p{font-size:.88rem;color:var(--muted);line-height:2}

/* こんな場面で（出演シーン・アイコンカード） */
.scene-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:16px;margin-top:24px}
.scene{position:relative;display:flex;flex-direction:column;align-items:center;text-align:center;gap:15px;
  padding:32px 14px 26px;background:linear-gradient(180deg,#fff,var(--cream));
  border:1px solid rgba(194,161,77,.24);border-radius:3px;overflow:hidden;
  transition:transform .5s var(--ease),box-shadow .5s var(--ease),border-color .5s}
.scene::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;
  background:linear-gradient(90deg,var(--gold-light),var(--gold),var(--gold-light));
  transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.scene:hover{transform:translateY(-6px);box-shadow:0 32px 60px -42px rgba(6,64,63,.5);border-color:rgba(194,161,77,.5)}
.scene:hover::before{transform:scaleX(1)}
.scene-ic{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;flex:none;
  border:1px solid var(--gold);color:#fff;background:var(--gold);
  transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease)}
.scene-ic svg{width:26px;height:26px;display:block}
.scene:hover .scene-ic{background:#fff;color:var(--gold);transform:scale(1.07)}
.scene-t{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:.96rem;letter-spacing:.03em;line-height:1.5}
@media (max-width:900px){.scene-grid{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.scene-grid{grid-template-columns:repeat(2,1fr);gap:12px}.scene{padding:26px 10px 22px;gap:12px}.scene-ic{width:50px;height:50px}.scene-t{font-size:.9rem}}

/* ショー：本番写真ギャラリー */
.show-gallery{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-top:24px}
.show-gallery .gitem{position:relative;display:block;overflow:hidden;border-radius:3px;aspect-ratio:3/4}
.show-gallery .gitem img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.show-gallery .gitem:hover img{transform:scale(1.07)}
.show-gallery .gitem::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(194,161,77,.28);pointer-events:none}
@media (max-width:900px){.show-gallery{grid-template-columns:repeat(3,1fr)}}
@media (max-width:560px){.show-gallery{grid-template-columns:repeat(2,1fr);gap:10px}}

/* ステージのスライドショー */
.stage-slider{position:relative;margin-top:24px;border-radius:8px;overflow:hidden;background:#06403f;box-shadow:0 34px 76px -44px rgba(6,64,63,.65)}
.stage-slides{position:relative;aspect-ratio:16/10}
.stage-slide{position:absolute;inset:0;margin:0;opacity:0;transition:opacity .9s var(--ease)}
.stage-slide.is-active{opacity:1}
.stage-slide img{width:100%;height:100%;object-fit:cover;display:block}
.stage-slider::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(194,161,77,.32);pointer-events:none;z-index:2}
.stage-nav{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:46px;height:46px;border:none;border-radius:50%;
  background:rgba(255,255,255,.85);color:var(--teal-ink);font-family:var(--ff-display);font-size:1.7rem;line-height:1;cursor:pointer;
  display:grid;place-items:center;box-shadow:0 6px 18px rgba(0,0,0,.22);transition:background .3s var(--ease),transform .3s var(--ease)}
.stage-nav:hover{background:#fff;transform:translateY(-50%) scale(1.07)}
.stage-nav.prev{left:16px}
.stage-nav.next{right:16px}
.stage-dots{position:absolute;left:0;right:0;bottom:16px;z-index:3;display:flex;justify-content:center;gap:9px}
.stage-dots button{width:9px;height:9px;padding:0;border:none;border-radius:50%;background:rgba(255,255,255,.55);cursor:pointer;transition:background .3s,transform .3s}
.stage-dots button.is-active{background:var(--gold);transform:scale(1.3)}
@media (max-width:600px){
  .stage-slides{aspect-ratio:4/3}
  .stage-nav{width:38px;height:38px;font-size:1.4rem}
  .stage-nav.prev{left:10px}.stage-nav.next{right:10px}
}

/* チームバンド（Manule'a：写真＋紹介） */
.team-band{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(26px,4vw,52px);align-items:center;margin-top:24px}
.team-band__media{position:relative;margin:0}
.team-band__media img{display:block;width:100%;aspect-ratio:3/2;object-fit:cover;border-radius:4px;
  box-shadow:0 40px 80px -44px rgba(6,64,63,.55),0 0 0 1px rgba(194,161,77,.25)}
.team-band__media figcaption{position:absolute;left:16px;bottom:13px;color:#fff;font-family:var(--ff-display);
  letter-spacing:.12em;font-size:1.15rem;text-shadow:0 2px 18px rgba(0,0,0,.65)}
.team-band__body p{color:var(--muted);line-height:2.2;margin-bottom:1.2em}
@media (max-width:680px){.team-band{grid-template-columns:1fr;gap:20px}}

/* 申込みの流れ（タイムライン） */
.flow{position:relative;list-style:none;margin:34px 0 0;padding:0;
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
/* ノード中心を貫く横レール */
.flow::before{content:"";position:absolute;top:25px;left:13%;right:13%;height:2px;z-index:0;
  background:linear-gradient(90deg,var(--gold-soft) 0%,var(--gold) 50%,var(--gold-soft) 100%)}
.flow__step{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;text-align:center}
.flow__step .n{display:flex;align-items:center;justify-content:center;width:52px;height:52px;flex:0 0 auto;
  font-family:var(--ff-display);font-size:1.5rem;line-height:1;color:var(--teal-ink);
  background:linear-gradient(180deg,#fff,var(--cream));border:1.5px solid var(--gold);border-radius:50%;
  margin-bottom:20px;box-shadow:0 0 0 6px var(--cream),0 8px 18px rgba(11,58,58,.1);transition:.4s}
.flow__step:hover .n{color:#fff;background:linear-gradient(180deg,var(--teal-ink),var(--teal-deep));
  border-color:var(--teal-ink);transform:translateY(-3px)}
.flow__cap{display:block;font-family:var(--ff-body);font-size:.62rem;font-weight:700;letter-spacing:.22em;
  text-transform:uppercase;color:var(--gold);margin-bottom:.6em}
.flow__step h4{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1rem;margin:0 0 .55em;line-height:1.5}
.flow__step p{font-size:.84rem;color:var(--muted);line-height:1.9;max-width:24ch}
@media (max-width:680px){
  /* スマホは縦タイムライン（上から下へ時系列） */
  .flow{grid-template-columns:1fr;gap:0;margin-top:26px;padding-left:6px}
  .flow::before{top:8px;bottom:24px;left:32px;right:auto;width:2px;height:auto;
    background:linear-gradient(180deg,var(--gold) 0%,var(--gold-soft) 100%)}
  .flow__step{flex-direction:row;align-items:flex-start;text-align:left;gap:20px;padding-bottom:30px}
  .flow__step:last-child{padding-bottom:0}
  .flow__step .n{width:52px;height:52px;font-size:1.4rem;margin-bottom:0;box-shadow:0 0 0 6px var(--cream),0 6px 14px rgba(11,58,58,.1)}
  .flow__step p{max-width:none}
  .flow__body{padding-top:6px}
}

/* 画像＋テキストの汎用2カラム（レイメイキング等） */
.media-text{display:grid;grid-template-columns:minmax(0,280px) 1fr;gap:clamp(24px,4vw,48px);align-items:center;margin-top:10px}
.media-text > img{width:100%;border-radius:4px;box-shadow:0 30px 64px -40px rgba(6,64,63,.5),0 0 0 1px rgba(194,161,77,.25)}
.media-text p{color:var(--muted);line-height:2.2;margin-bottom:1.2em}
@media (max-width:680px){.media-text{grid-template-columns:1fr;gap:20px;max-width:360px}}
/* 2枚組の写真（レッスン風景） */
.duo{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin:.7em 0 1.8em}
.duo img{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:3px;box-shadow:0 0 0 1px rgba(194,161,77,.22)}
.walk-intro{display:grid;grid-template-columns:1fr minmax(0,300px);gap:clamp(26px,4vw,52px);align-items:start;margin:.4em 0 .6em}
.walk-intro__text > p{max-width:none}
.walk-intro__photo{margin:0}
.walk-intro__photo img{width:100%;display:block;border-radius:4px;box-shadow:0 30px 64px -40px rgba(6,64,63,.5),0 0 0 1px rgba(194,161,77,.25)}
.walk-intro__photo figcaption{margin-top:.6em;font-size:.76rem;color:var(--muted);letter-spacing:.03em;text-align:center;line-height:1.5}
@media (max-width:760px){.walk-intro{grid-template-columns:1fr;gap:22px;max-width:420px}}
/* 認定バッジ（信頼の証） */
.cert-line{display:inline-flex;align-items:center;gap:14px;margin:.2em 0 1.6em;padding:9px 20px 9px 11px;
  background:linear-gradient(180deg,#fff,var(--cream));border:1px solid rgba(194,161,77,.32);border-radius:3px}
.cert-line img{width:52px;height:52px;object-fit:contain;flex:none}
.cert-line span{font-size:.86rem;color:var(--teal-ink);line-height:1.55}
.cert-line b{font-family:var(--ff-display);letter-spacing:.05em;font-size:.96rem}

/* レッスン詳細（クラス・スケジュール） */
.lesson-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:1.8em 0}
.lesson-card{position:relative;background:linear-gradient(180deg,#fff,var(--cream));border:1px solid rgba(194,161,77,.26);padding:34px 22px 30px;border-radius:3px;overflow:hidden;
  box-shadow:0 26px 56px -44px rgba(6,64,63,.5);transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s}
.lesson-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--gold-light),var(--gold),var(--gold-light))}
.lesson-card::after{content:"";position:absolute;right:-34px;top:-34px;width:92px;height:92px;border:1px solid rgba(194,161,77,.22);border-radius:50%;pointer-events:none}
.lesson-card:hover{transform:translateY(-6px);box-shadow:0 40px 70px -40px rgba(6,64,63,.55);border-color:rgba(194,161,77,.5)}
.lesson-card h4{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.22rem;letter-spacing:.04em}
.lesson-card .loc{display:inline-block;font-family:var(--ff-display);font-style:italic;font-size:.82rem;color:var(--gold-soft);letter-spacing:.08em;
  margin:.55em 0 1.2em;padding:3px 12px;border:1px solid rgba(194,161,77,.4);border-radius:20px;background:rgba(194,161,77,.06)}
.lesson-card ul{display:flex;flex-direction:column;gap:10px}
.lesson-card li{font-size:.82rem;color:var(--muted);line-height:1.7;padding-left:15px;position:relative}
.lesson-card li{padding-left:22px}
.lesson-card li::before{content:"";position:absolute;left:0;top:.36em;width:14px;height:14px;background:var(--flower) center/contain no-repeat}
.lesson-card li b{color:var(--teal-ink);font-weight:600}
.campus-head{display:flex;align-items:baseline;gap:.5em .85em;flex-wrap:wrap;margin:2em 0 1em;padding-bottom:.5em;border-bottom:1px solid rgba(194,161,77,.32)}
.campus-head:first-of-type{margin-top:.4em}
.campus-head .nm{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.5rem;letter-spacing:.05em}
.campus-head .sub{font-family:var(--ff-body);font-weight:500;color:var(--muted);font-size:.86rem;letter-spacing:.03em}
.campus-head .sub sup{color:var(--gold);font-weight:600}
.lesson-note{font-size:.82rem;color:var(--muted);line-height:1.85;margin:.9em 0 0;max-width:760px}
.lesson-note sup{color:var(--gold);font-weight:600}
@media (max-width:900px){.lesson-grid{grid-template-columns:1fr}}

/* ============================================================
   プロフィール：動画・リンク
   ============================================================ */
.media-links{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(28px,4vw,48px);align-items:center;margin-top:6px}
.yt-embed{position:relative;aspect-ratio:16/9;overflow:hidden;border:1px solid var(--gold-soft);
  box-shadow:0 32px 72px -46px rgba(6,64,63,.55)}
.yt-embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.yt-stack{display:flex;flex-direction:column;gap:16px}
.link-cards{display:flex;flex-direction:column;gap:12px}
.lk{display:flex;align-items:center;gap:14px;padding:16px 22px;border:1px solid var(--gold-soft);background:var(--white);
  position:relative;overflow:hidden;transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s var(--ease)}
.lk::before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px;background:var(--gold);transform:scaleY(0);transform-origin:top;transition:transform .4s var(--ease)}
.lk:hover{transform:translateX(4px);box-shadow:0 22px 46px -34px rgba(6,64,63,.5);border-color:var(--gold)}
.lk:hover::before{transform:scaleY(1)}
.lk .lk-ic{width:20px;height:20px;flex:none}
.lk b{flex:1;font-family:var(--ff-display);letter-spacing:.14em;text-transform:uppercase;font-size:.88rem;color:var(--teal-ink)}
.lk .lk-sub{font-size:.78rem;color:var(--muted);letter-spacing:.02em}
.lk .lk-ar{color:var(--gold);font-size:1.2rem;transition:transform .4s var(--ease)}
.lk:hover .lk-ar{transform:translateX(5px)}
@media (max-width:900px){.media-links{grid-template-columns:1fr}}

/* ============================================================
   FAQ（アコーディオン）
   ============================================================ */
.faq-list{max-width:840px;border-top:1px solid rgba(194,161,77,.3)}
.faq-item{border-bottom:1px solid rgba(194,161,77,.3)}
.faq-item summary{list-style:none;cursor:pointer;display:flex;justify-content:space-between;align-items:center;gap:20px;
  padding:26px 4px;font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.05rem;letter-spacing:.02em;transition:color .3s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary:hover{color:var(--teal)}
.faq-item summary .q{display:flex;gap:16px;align-items:baseline}
.faq-item summary .q::before{content:"Q";font-family:var(--ff-display);font-style:italic;color:var(--gold);font-size:1.3rem;line-height:1}
.faq-item summary .mark{flex:none;width:18px;height:18px;position:relative}
.faq-item summary .mark::before,.faq-item summary .mark::after{content:"";position:absolute;background:var(--teal);transition:.4s var(--ease)}
.faq-item summary .mark::before{left:0;top:8.25px;width:18px;height:1.5px}
.faq-item summary .mark::after{left:8.25px;top:0;width:1.5px;height:18px}
.faq-item[open] summary .mark::after{transform:rotate(90deg);opacity:0}
.faq-item .a{position:relative;padding:0 4px 28px 34px;color:var(--muted);line-height:2.05;font-size:.95rem}
.faq-item .a::before{content:"A";position:absolute;left:2px;top:0;font-family:var(--ff-display);font-style:italic;color:var(--teal);font-size:1.3rem;line-height:1.95rem}

/* ============================================================
   事業詳細ページ（料金・内容）
   ============================================================ */
.detail-hero{position:relative;aspect-ratio:16/7;overflow:hidden;margin-bottom:clamp(40px,6vw,72px);
  box-shadow:0 44px 96px -56px rgba(6,64,63,.55)}
.detail-hero img{width:100%;height:100%;object-fit:cover;transition:transform 7s var(--ease)}
.detail-hero:hover img{transform:scale(1.05)}
.detail-hero::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(216,199,154,.45);
  background:linear-gradient(115deg,color-mix(in srgb,var(--accent,var(--teal-ink)) 22%,transparent),transparent 42%)}
.detail-lead{max-width:800px;margin-bottom:clamp(20px,3vw,36px)}
.detail-lead .kicker{font-family:var(--ff-script);color:var(--accent,var(--gold));font-size:1.95rem;line-height:1}
.detail-lead h2{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:clamp(1.6rem,3.3vw,2.5rem);line-height:1.55;letter-spacing:.04em;margin:.18em 0 .6em}
.detail-lead p{color:var(--muted);line-height:2.25;font-size:1.02rem}
.detail-block{margin-top:clamp(44px,6vw,76px)}
.detail-block > .eyebrow{margin-bottom:.4em}
.detail-block h3.dt{position:relative;font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:clamp(1.35rem,2.6vw,1.85rem);letter-spacing:.04em;margin:.2em 0 1.1em;padding-bottom:.45em}
.detail-block h3.dt::after{content:"";position:absolute;left:0;bottom:0;width:44px;height:2px;background:var(--accent,var(--gold))}

/* 料金カード */
.price-cards{display:grid;grid-template-columns:1fr 1fr;gap:24px;margin:1.4em 0}
.price-card{position:relative;background:linear-gradient(180deg,#fff,var(--cream));border:1px solid rgba(194,161,77,.26);padding:38px 34px 32px;border-radius:3px;overflow:hidden;
  box-shadow:0 28px 60px -44px rgba(6,64,63,.5);transition:transform .55s var(--ease),box-shadow .55s var(--ease),border-color .55s}
.price-card::before{content:"";position:absolute;inset:0 0 auto 0;height:4px;background:linear-gradient(90deg,var(--gold-light),var(--gold),var(--gold-light))}
.price-card::after{content:"";position:absolute;right:-40px;top:-40px;width:110px;height:110px;border:1px solid rgba(194,161,77,.22);border-radius:50%;pointer-events:none}
.price-card:hover{transform:translateY(-6px);box-shadow:0 42px 74px -40px rgba(6,64,63,.55);border-color:rgba(194,161,77,.5)}
.price-card h4{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.3rem;letter-spacing:.04em}
.price-card h4::after{content:"";display:block;width:34px;height:2px;background:var(--gold);margin-top:.5em}
.price-card .sub{font-family:var(--ff-display);font-style:italic;color:var(--gold);font-size:.88rem;margin:.55em 0 1.2em;letter-spacing:.06em}
.price-row{display:flex;justify-content:space-between;gap:16px;padding:15px 0;border-bottom:1px solid rgba(194,161,77,.2);font-size:.92rem;align-items:baseline}
.price-row:last-child{border-bottom:none}
.price-row .nm{color:var(--ink);line-height:1.5}
.price-row .nm small{display:block;color:var(--muted);font-size:.78rem;margin-top:3px}
.price-row .pr{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);white-space:nowrap;font-size:1.18rem;letter-spacing:.02em}
.price-row .pr small{font-weight:400;color:var(--muted);font-size:.74rem}
.price-note{font-size:.8rem;color:var(--muted);line-height:1.9;margin-top:1em}
@media (max-width:900px){.price-cards{grid-template-columns:1fr}}

/* ============================================================
   Legal / prose
   ============================================================ */
.prose{max-width:760px}
.prose h2{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.3rem;letter-spacing:.04em;margin:2em 0 .8em;padding-bottom:.5em;border-bottom:1px solid rgba(194,161,77,.3)}
.prose h2:first-child{margin-top:0}
.prose p{color:var(--muted);line-height:2.1;margin-bottom:1.2em;font-size:.95rem}
.prose ul.dot{list-style:none;padding-left:0;margin:0 0 1.2em;color:var(--muted)}
.prose ul.dot li{line-height:2;margin-bottom:.5em;padding-left:24px;position:relative}
.prose ul.dot li::before{content:"";position:absolute;left:0;top:.5em;width:14px;height:14px;background:var(--flower) center/contain no-repeat}
.prose a{color:var(--teal);text-decoration:underline;text-underline-offset:3px}

/* ============================================================
   News detail（読み物）
   ============================================================ */
.page-head.news-head h1{font-size:clamp(1.5rem,3.2vw,2.1rem);line-height:1.55;letter-spacing:.04em}
.news-article{max-width:680px}
.news-article .article-head{display:flex;align-items:center;gap:14px;flex-wrap:wrap;margin:0 0 36px;padding-bottom:24px;border-bottom:1px solid rgba(194,161,77,.3)}
.news-article .article-date{font-family:var(--ff-serif);color:var(--gold);font-size:1.02rem;letter-spacing:.04em}
.news-article .article-cat{font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;color:var(--teal);border:1px solid var(--gold-soft);padding:.45em .95em}
.news-article .article-body{font-family:var(--ff-body);color:var(--ink);font-size:1rem;line-height:1.95;letter-spacing:.03em;font-weight:400;word-break:normal;line-break:strict;text-spacing-trim:trim-start;
  background:var(--cream-2);padding:clamp(28px,4.5vw,44px) clamp(22px,4.5vw,46px);border-radius:3px;border-left:3px solid var(--gold-soft);box-shadow:0 1px 2px rgba(27,43,42,.04)}
.news-article .article-body :where(p,li,blockquote,h2,h3){word-break:normal}
.news-article .article-body > *{margin:0 0 1.7em}
.news-article .article-body > *:last-child{margin-bottom:0}
.news-article .article-body p{text-indent:1em}
.news-article .article-body p:empty{margin:0;height:.9em;text-indent:0}
.news-article .article-body a{color:var(--teal);text-decoration:underline;text-underline-offset:3px}
.news-article .article-body strong{color:var(--teal-ink);font-weight:700}
.news-article .article-body img{max-width:100%;height:auto;margin:2em auto;display:block;border-radius:2px}
.news-article .article-body h2{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.3rem;letter-spacing:.04em;margin:2.2em 0 .9em;padding-bottom:.5em;border-bottom:1px solid rgba(194,161,77,.3);text-indent:0}
.news-article .article-body h3{font-family:var(--ff-serif);font-weight:600;color:var(--teal-ink);font-size:1.15rem;letter-spacing:.04em;margin:1.8em 0 .6em;text-indent:0}
.news-article .article-body ul,.news-article .article-body ol{padding-left:1.6em;margin:0 0 1.7em}
.news-article .article-body li{line-height:1.9;margin-bottom:.5em}
.news-article .article-body blockquote{margin:1.8em 0;padding:.8em 0 .8em 1.4em;border-left:3px solid var(--gold-soft);color:var(--muted)}
@media (max-width:680px){
  .news-article .article-body{font-size:.94rem;line-height:1.9;letter-spacing:.02em}
  .news-article .article-body > *{margin-bottom:1.5em}
  .news-article .article-body p{text-indent:1em}
}

/* ============================================================
   SP line break helper
   ============================================================ */
.br-sp{display:none}

/* ============================================================
   RICH ENHANCEMENTS
   ============================================================ */

/* — Hero: gold inset frame + vertical side label + corner ticks — */
.hero__frame{position:absolute;inset:20px;border:1px solid rgba(227,207,156,.32);z-index:1;pointer-events:none}
.hero__frame::before,.hero__frame::after{content:"";position:absolute;width:14px;height:14px;border:1px solid var(--gold-light)}
.hero__frame::before{top:-1px;left:-1px;border-right:0;border-bottom:0}
.hero__frame::after{bottom:-1px;right:-1px;border-left:0;border-top:0}
.hero__side{position:absolute;right:34px;top:50%;transform:translateY(-50%);writing-mode:vertical-rl;z-index:3;
  font-family:var(--ff-display);letter-spacing:.5em;text-transform:uppercase;font-size:.7rem;font-weight:600;color:var(--gold-light)}
.hero__side::before{content:"";display:block;width:1px;height:46px;background:var(--gold-light);margin:0 auto 18px}

/* — Marquee ticker — */
/* 最新のお知らせ（ヒーロー直下のバー・発光） */
.latest-news{position:relative;overflow:hidden;display:flex;align-items:center;gap:clamp(14px,2vw,24px);
  background:linear-gradient(180deg,var(--teal-deep),var(--teal-ink));
  border-block:1px solid rgba(216,199,154,.2);padding:17px var(--gut);
  color:#fff;transition:background .4s var(--ease)}
.latest-news:hover{background:linear-gradient(180deg,var(--teal),var(--teal-deep))}
/* 流れる光のシャイン */
.latest-news::after{content:"";position:absolute;top:0;left:-40%;width:35%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.16),transparent);transform:skewX(-20deg);
  animation:lnShine 5s ease-in-out infinite}
@keyframes lnShine{0%{left:-40%}40%,100%{left:140%}}
.latest-news > *{position:relative;z-index:1}
.ln-tag{flex:none;font-family:var(--ff-display);letter-spacing:.2em;text-transform:uppercase;font-size:.72rem;
  font-weight:600;color:var(--teal-ink);background:var(--gold-light);padding:.45em 1em;
  animation:lnPulse 2.4s ease-in-out infinite}
@keyframes lnPulse{0%,100%{box-shadow:0 0 0 0 rgba(227,207,156,0)}50%{box-shadow:0 0 16px 2px rgba(227,207,156,.7)}}
.ln-date{flex:none;font-family:var(--ff-serif);color:var(--cream);font-size:1rem;letter-spacing:.04em;white-space:nowrap}
.ln-ttl{flex:1;min-width:0;font-size:.94rem;color:rgba(255,255,255,.95);letter-spacing:.02em;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.ln-ar{flex:none;color:var(--gold-light);font-size:1.2rem;transition:transform .4s var(--ease)}
.latest-news:hover .ln-ar{transform:translateX(5px)}
@media (max-width:600px){
  .latest-news{flex-wrap:wrap;gap:8px 14px;padding:14px var(--gut)}
  .ln-ttl{flex-basis:100%;white-space:normal;font-size:.9rem;order:3}
  .ln-ar{margin-left:auto}
}

/* — Section ornament (eyebrow diamond / divider) — */
.orn-divider{display:flex;align-items:center;justify-content:center;gap:18px;margin:0 auto;width:100%;max-width:240px}
.orn-divider::before,.orn-divider::after{content:"";height:1px;flex:1;background:linear-gradient(90deg,transparent,var(--gold-soft))}
.orn-divider::after{background:linear-gradient(90deg,var(--gold-soft),transparent)}
.orn-divider i{width:30px;height:30px;flex:none;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 100 100'%3E%3Cg fill='%23d6362a'%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(72 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(144 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(216 50 52)'/%3E%3Cpath d='M50 52 C 30 42 27 16 41 9 C 46 6 48 13 50 13 C 52 13 54 6 59 9 C 73 16 70 42 50 52 Z' transform='rotate(288 50 52)'/%3E%3C/g%3E%3Ccircle cx='50' cy='53' r='9' fill='%23a83228'/%3E%3Cpath d='M50 53 Q 52 78 53 95' stroke='%23c2a14d' stroke-width='4.5' fill='none' stroke-linecap='round'/%3E%3Cg fill='%23e3cf9c'%3E%3Ccircle cx='53' cy='95' r='4'/%3E%3Ccircle cx='47' cy='92' r='2.6'/%3E%3Ccircle cx='59' cy='92' r='2.6'/%3E%3C/g%3E%3C/svg%3E") center/contain no-repeat}

/* — Service cards: image reveal on hover — */
.svc-card>:not(.svc-card__bg){position:relative}

/* — Showreel: auto-scrolling photo strip — */
.showreel{overflow:hidden;background:var(--cream-2);padding:clamp(40px,6vw,72px) 0;position:relative}
.showreel__track{display:flex;gap:16px;width:max-content;animation:reel 64s linear infinite;will-change:transform;padding-inline:16px}
.showreel:hover .showreel__track{animation-play-state:paused}
.showreel .shot{width:clamp(158px,16vw,212px);aspect-ratio:3/4;flex:none;overflow:hidden;position:relative;
  box-shadow:0 22px 44px -30px rgba(6,64,63,.55)}
.showreel .shot img{width:100%;height:100%;object-fit:cover;transition:transform 1s var(--ease)}
.showreel .shot::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(216,199,154,.3);
  background:linear-gradient(180deg,transparent 65%,rgba(6,64,63,.32))}
.showreel .shot:hover img{transform:scale(1.06)}
@keyframes reel{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* — Footer watermark — */
.site-footer{position:relative;overflow:hidden}
.footer-watermark{position:absolute;right:-1%;bottom:-6%;font-family:var(--ff-script);
  font-size:clamp(7rem,20vw,18rem);line-height:.8;color:rgba(216,199,154,.055);pointer-events:none;z-index:0;user-select:none}
.site-footer .wrap{position:relative;z-index:1}

/* — Page-hero gold baseline — */
.page-hero__inner::after{content:"";display:block;width:60px;height:2px;background:var(--gold);margin-top:26px}

/* — Refined eyebrow center ornament — */
.eyebrow.center.orn::after{content:"";width:34px;height:1px;background:var(--gold)}

/* — Intro visual: gold offset frame — */
.intro__visual .frame{position:relative}
.intro__visual::before{content:"";position:absolute;top:-18px;right:-18px;width:62%;height:62%;
  border:1px solid var(--gold-soft);z-index:-1}

/* — Buttons: subtle sheen — */
.btn.light{position:relative}

/* — Profile band image gold frame — */
.profileband__img::before{content:"";position:absolute;left:-18px;bottom:-18px;width:55%;height:55%;border:1px solid var(--gold-soft);z-index:0}

@media (max-width:768px){
  .hero__side{display:none}
  .hero__frame{inset:12px}
  .hero__v-blur{display:none}
  .hero__v-main{object-fit:cover;object-position:center}
  .marquee{padding:11px 0}
  .marquee__track span{padding:0 16px;letter-spacing:.34em}
  .intro__visual::before,.profileband__img::before{display:none}
  .footer-watermark{font-size:7rem;bottom:-2%}
}

/* ============================================================
   Responsive
   ============================================================ */
@media (max-width:1024px){
  .intro__grid,.profileband__grid,.contact-grid,.message-block{grid-template-columns:1fr}
  .svc-cards{grid-template-columns:repeat(2,1fr)}
  .stats__grid{grid-template-columns:1fr 1fr;gap:30px 20px}
  .stat .divider{display:none}
  .footer-top{grid-template-columns:1fr 1fr}
  .footer-brand{grid-column:1/-1}
  .gallery{columns:2}
  .feature-grid{grid-template-columns:1fr 1fr}
}

@media (max-width:768px){
  :root{--gut:22px}
  .br-sp{display:inline}
  body{font-size:16px}
  /* スマホ：日本語が変な位置で2行に折り返されないよう、文節単位の改行＋行バランス調整 */
  body{line-break:strict;word-break:auto-phrase}
  h1,h2,h3,h4,.h-jp,.dt,.eyebrow,.kicker,.hero__sub,.sec-lead,.cta h2,.page-hero h1,
  .detail-lead h2,.profileband h2,.message-block .lead,.lead{text-wrap:balance}
  p,li,.svc-card p,.feature p,.price-note,.footer-desc,.contact-aside p{text-wrap:pretty}
  .footer-col a{padding:7px 0;display:inline-block}
  .footer-col ul{gap:6px}
  /* サイドバー → 上部バー */
  body{padding-left:0}
  .site-sidebar{flex-direction:row;align-items:center;height:62px;width:100%;padding:0 20px;
    justify-content:space-between;border-right:none;border-bottom:1px solid rgba(194,161,77,.45);
    background:var(--cream);box-shadow:0 6px 24px -18px rgba(6,64,63,.35);backdrop-filter:none}
  /* iOS では background-attachment:fixed が不安定なため通常スクロールへ */
  .bg-fixed{background-attachment:scroll}
  .brand-logo{height:40px;width:auto}
  .side-foot{display:none}
  .lang-switch{margin-top:0;font-size:.8rem;order:2;margin-right:8px}
  .hamburger{order:3}
  .side-nav{
    position:fixed;inset:0;
    background:radial-gradient(125% 80% at 82% 4%,#11998b 0%,var(--teal-ink) 52%,#06433d 100%);
    display:flex;flex-direction:column;align-items:center;justify-content:center;
    transform:translateX(100%);transition:transform .55s var(--ease),visibility .55s;visibility:hidden;
    z-index:9050;overflow-y:auto;padding:clamp(74px,11vh,96px) 24px clamp(100px,15vh,128px)}
  .side-nav.is-open{transform:none;visibility:visible}
  /* 装飾：ハイビスカスの大きな透かし */
  .side-nav::before{content:"";position:absolute;right:-46px;top:-34px;width:248px;height:248px;
    background:var(--flower) center/contain no-repeat;opacity:.1;transform:rotate(16deg);pointer-events:none}
  .side-nav > ul{display:flex;flex-direction:column;gap:6px;text-align:center;width:100%;max-width:340px;margin:auto}
  .side-nav > ul > li{opacity:0;transform:translateY(18px);transition:opacity .55s var(--ease),transform .55s var(--ease)}
  .side-nav.is-open > ul > li{opacity:1;transform:none}
  .side-nav.is-open > ul > li:nth-child(1){transition-delay:.10s}
  .side-nav.is-open > ul > li:nth-child(2){transition-delay:.16s}
  .side-nav.is-open > ul > li:nth-child(3){transition-delay:.22s}
  .side-nav.is-open > ul > li:nth-child(4){transition-delay:.28s}
  .side-nav.is-open > ul > li:nth-child(5){transition-delay:.34s}
  .side-nav.is-open > ul > li:nth-child(6){transition-delay:.40s}
  .side-nav.is-open > ul > li:nth-child(7){transition-delay:.46s}
  .side-nav a{writing-mode:horizontal-tb;color:var(--cream)!important;font-family:var(--ff-serif);font-weight:500;
    font-size:clamp(1.02rem,4.4vw,1.2rem);letter-spacing:.08em;display:block;padding:11px 0;min-height:44px}
  .side-nav a::after{display:none}
  .side-nav > ul > li > a.current{color:var(--gold-light)!important}
  .side-nav .has-sub > a::before{display:none}
  /* サブメニュー：ゴールドの縦線でインデント表示 */
  .sub-nav{position:static;opacity:1;visibility:visible;pointer-events:auto;transform:none;
    background:none;border:none;box-shadow:none;min-width:0;display:flex;flex-direction:column;gap:0;
    padding:4px 0 12px;margin:2px auto 6px;width:max-content;border-left:1px solid rgba(227,207,156,.5)}
  .sub-nav::before{display:none}
  .sub-nav li{opacity:1;transform:none}
  .sub-nav a{color:rgba(253,252,250,.82)!important;font-family:var(--ff-body);font-weight:400;font-size:.88rem;
    justify-content:center;padding:10px 22px;letter-spacing:.05em}
  .sub-nav a::before{display:none}
  .sub-nav a:hover,.sub-nav a:active{background:none;padding-left:22px;color:var(--gold-light)!important}
  .hamburger{display:flex;z-index:9120}
  /* メニュー展開時：下部に SNS アイコン */
  body.menu-open .side-foot{display:flex;position:fixed;left:0;right:0;bottom:40px;z-index:9100;
    flex-direction:column;align-items:center;gap:0}
  body.menu-open .side-foot .v-line{display:none}
  body.menu-open .side-sns{gap:22px}
  body.menu-open .side-sns a{color:var(--cream);opacity:.92}
  body.menu-open .side-sns a:hover{color:var(--gold-light)}
  body.menu-open .side-sns a svg{width:24px;height:24px}
  /* メニュー展開時：言語トグルを上部中央（ロゴとXの間）に・ティール背景で見えるよう明色化 */
  body.menu-open .lang-switch{position:fixed;top:18px;left:50%;transform:translateX(-50%);z-index:9130;
    justify-content:center;margin:0;font-size:.95rem}
  body.menu-open .lang-switch button{color:rgba(253,252,250,.62)}
  body.menu-open .lang-switch button.is-active{color:var(--gold-light);opacity:1}
  body.menu-open .lang-switch span{color:rgba(253,252,250,.4)}

  .svc-row{grid-template-columns:1fr;gap:24px}
  .svc-row:nth-child(even) .svc-row__media{order:0}
  .svc-row__media .num,.svc-row:nth-child(even) .svc-row__media .num{left:8px;right:auto;top:6px;font-size:3.2rem;-webkit-text-stroke-width:3px}
  .svc-cards{grid-template-columns:1fr}
  .news-item{grid-template-columns:1fr;gap:12px;padding:24px 6px}
  .news-item .go{display:none}
  .stats__grid{grid-template-columns:1fr 1fr}
  .gallery{columns:1}
  .feature-grid{grid-template-columns:1fr}
  .form .row{grid-template-columns:1fr}
  .hero__sub{max-width:none}
  .company-table th{width:120px}

  /* コンパクトなスマホ用フッター */
  .site-footer{padding-top:46px}
  .footer-top{grid-template-columns:1fr 1fr;gap:28px 24px;padding-bottom:32px}
  .footer-brand{grid-column:1/-1}
  .footer-brand img{height:36px;margin-bottom:14px}
  .footer-brand .concept{font-size:1.2rem;margin-bottom:8px}
  .footer-brand .footer-desc{display:none}
  .footer-col h4{margin-bottom:14px}
  .footer-col a{padding:5px 0}
  .sns-row{flex-direction:row;flex-wrap:wrap;gap:16px;margin-top:14px}
  .sns-row a span{display:none}
  .sns-row svg{width:25px;height:25px}
  .footer-bottom{padding:18px 0;gap:8px}
  .footer-watermark{display:none}
}

@media (max-width:480px){
  .hero__actions{flex-direction:column;align-items:flex-start}
  .btn{width:100%;justify-content:center}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}

/* ============================================================
   モバイル/タブレット 可読性向上（小さめ文字の底上げ）
   1カラム表示になる幅なので、文字を大きくしてもレイアウトは崩れない
   ============================================================ */
@media (max-width:768px){
  body{font-size:16.5px}
  /* レッスンスケジュール */
  .lesson-card li{font-size:.95rem;line-height:1.9}
  .lesson-note{font-size:.92rem;line-height:1.95}
  .campus-head .nm{font-size:1.4rem}
  .campus-head .sub{font-size:.92rem}
  /* 料金カード */
  .price-row{font-size:1rem}
  .price-row .nm small{font-size:.86rem}
  .price-row .pr small{font-size:.82rem}
  .price-note{font-size:.92rem;line-height:1.95}
  /* タグ・特徴・フロー */
  .svc-tags li{font-size:.86rem}
  .feature p{font-size:.95rem;line-height:2}
  .flow__step p{font-size:.92rem;line-height:2}
  /* FAQ・パンくず・フッター・キャプション */
  .faq-item .a{font-size:1rem;line-height:2.1}
  .breadcrumb{font-size:.82rem}
  .footer-col a{font-size:.95rem}
  .walk-intro__photo figcaption{font-size:.84rem}
  .lk .lk-sub{font-size:.86rem}
  .form .note{font-size:.82rem}
}

/* ============================================================
   Reduced motion
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .reveal,.hero__content [data-rise]{opacity:1!important;transform:none!important}
  .reveal-img img{transform:none!important}
  .reveal-img::before{display:none}
  .curtain{display:none!important}
}

/* ============================================================
   SP フォントサイズ最適化（≤600px の見やすさ調整）
   ※ 既存ルールへ確実に上書きするため、ファイル末尾に配置
   ============================================================ */
@media (max-width:600px){
  .hero h1{font-size:1.85rem;line-height:1.42;letter-spacing:.05em}
  .hero__sub{font-size:.94rem;line-height:1.95;margin-top:22px}
  .hero__script{font-size:1.4rem}
  .hero__wordmark{font-size:1rem}
  .hero__actions{margin-top:30px;gap:12px}

  .sec-title{font-size:1.55rem;line-height:1.4;letter-spacing:.03em}
  .sec-lead{font-size:.95rem;line-height:1.95}
  .intro__copy .concept{font-size:1.32rem;line-height:1.75;margin:.5em 0 .8em}
  .intro__copy .concept .script{font-size:1.4em}

  .page-head h1{font-size:1.72rem;line-height:1.45}
  .page-head.news-head h1{font-size:1.3rem;line-height:1.55}
  .page-hero h1{font-size:1.85rem;line-height:1.42}
  .breadcrumb{font-size:.78rem}

  .svc-card{min-height:340px;padding:22px}
  .svc-card h3{font-size:1.15rem;line-height:1.5}
  .svc-card p{font-size:.94rem;line-height:1.85;color:rgba(253,252,250,.92)}
  .svc-card .num{font-size:.95rem;top:18px;left:20px}
  .svc-card .en{font-size:.66rem}

  .news-item .ttl{font-size:1rem;line-height:1.7}
  .news-item .date{font-size:.94rem}
  .news-item .cat{font-size:.7rem;padding:.45em .85em}

  .latest-news{padding:13px var(--gut);gap:6px 12px}
  .ln-tag{font-size:.66rem;padding:.4em .85em;letter-spacing:.18em}
  .ln-date{font-size:.94rem}
  .ln-ttl{font-size:.92rem;line-height:1.55}

  .lang-switch{font-size:.84rem}
  .lang-switch button{padding:.35em .6em;min-height:30px}

  .footer-col h4{font-size:.92rem;letter-spacing:.16em}
  .footer-col li,.footer-col a{font-size:.94rem}

  .btn,.btn.light{font-size:.95rem;padding:1em 1.6em}
  .btn.sm{font-size:.88rem;padding:.85em 1.4em}

  .news-article{max-width:none}
  .news-article .article-head{gap:10px;margin-bottom:24px;padding-bottom:16px}
  .news-article .article-date{font-size:.96rem}
  .news-article .article-cat{font-size:.7rem}
}
@media (max-width:380px){
  .hero h1{font-size:1.7rem}
  .sec-title{font-size:1.42rem}
  .page-head h1{font-size:1.55rem}
}

/* Top の Profile preview（横長画像）— PC のみ 2列、SP は既存の 1024px 以下ルールで自動 1列 */
@media (min-width:1025px){
  .profileband__grid--wide-img{grid-template-columns:1.05fr .95fr}
}
