@charset "UTF-8";
/* ==========================================================================
   KAGRA Medical Clinic — HOME (gate hero + full site, single scroll)
   ========================================================================== */
:root{
  --ink:#0c0b0a;--ink-2:#100e0c;--ink-3:#16130f;--ink-4:#1c1813;
  --paper:#f3ede2;--mute:#a99f8d;--mute-2:#7c7264;--mute-3:#5a5247;
  --gold:#c9a96a;--gold-2:#d8bd86;
  --line:rgba(201,169,106,.20);--line-2:rgba(243,237,226,.09);
  --serif-en:"Cormorant Garamond",serif;--serif-jp:"Shippori Mincho",serif;
  --ease:cubic-bezier(.4,0,.2,1);--fade:1500ms;--maxw:1240px;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--serif-jp);background:var(--ink);color:var(--paper);line-height:1.85;letter-spacing:.04em;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:rgba(201,169,106,.28);color:#fff}
body::after{content:"";position:fixed;inset:0;pointer-events:none;z-index:60;opacity:.035;mix-blend-mode:overlay;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='.85' numOctaves='2'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(24px,5vw,64px)}
.eyebrow{font-family:var(--serif-en);font-size:13px;letter-spacing:.42em;text-transform:uppercase;color:var(--gold);font-weight:500;display:inline-flex;align-items:center;gap:.9em}
.eyebrow::before{content:"";width:34px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center{justify-content:center}
.eyebrow.center::after{content:"";width:34px;height:1px;background:var(--gold);opacity:.7}

/* ───────────────────────────────────────────────
   改行ルール（どなたでも編集できます）
     <br class="br-pc">  … PC（幅880pxより上）でだけ改行
     <br class="br-sp">  … スマホ（幅880px以下）でだけ改行
     <br>                … PC・スマホ両方で改行
   行末の文字が美しく揃うよう text-wrap:pretty も併用しています。
   ─────────────────────────────────────────────── */
.statement .quote,.privacy-body h2,.member-cta .jp,.origin .meaning{text-wrap:pretty}
.br-sp{display:none}
@media (max-width:880px){
  .br-pc{display:none}
  .br-sp{display:inline}
}
.btn{display:inline-flex;align-items:center;gap:.85em;font-family:var(--serif-en);font-size:14px;letter-spacing:.22em;text-transform:uppercase;padding:16px 30px;border:1px solid var(--line);color:var(--paper);background:transparent;cursor:pointer;transition:border-color .5s var(--ease),color .5s var(--ease),background .5s var(--ease)}
.btn .arw{font-size:15px;transition:transform .5s var(--ease)}
.btn:hover{border-color:var(--gold);color:var(--gold-2)}
.btn:hover .arw{transform:translateX(5px)}
.btn-solid{background:var(--gold);color:#1a1409;border-color:var(--gold)}
.btn-solid:hover{background:var(--gold-2);color:#1a1409;border-color:var(--gold-2)}

/* ---- nav (hidden over hero, revealed on scroll) ---- */
.nav{position:fixed;top:0;left:0;right:0;z-index:50;display:flex;align-items:center;justify-content:space-between;padding:14px clamp(24px,5vw,64px);border-bottom:1px solid transparent;opacity:0;transform:translateY(-14px);pointer-events:none;transition:opacity .6s var(--ease),transform .6s var(--ease),background .6s var(--ease),border-color .6s var(--ease)}
.nav.reveal{opacity:1;transform:none;pointer-events:auto;background:rgba(10,9,8,.84);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--line-2)}
.brand{display:flex;flex-direction:column;line-height:1;gap:5px}
.brand .b1{font-family:var(--serif-en);font-size:23px;letter-spacing:.36em;color:var(--paper);font-weight:500}
.brand .b2{font-family:var(--serif-en);font-size:9.5px;letter-spacing:.5em;text-transform:uppercase;color:var(--gold);padding-left:.3em}
.nav-links{display:flex;align-items:center;gap:clamp(20px,2.4vw,40px)}
.nav-links a{font-size:14.5px;letter-spacing:.16em;color:var(--mute);transition:color .4s var(--ease)}
.nav-links a .en{display:block;font-family:var(--serif-en);font-size:9px;letter-spacing:.3em;text-transform:uppercase;color:var(--mute-3);margin-top:3px;transition:color .4s var(--ease)}
.nav-links a:hover{color:var(--paper)}
.nav-links a:hover .en{color:var(--gold)}
.nav-cta{font-family:var(--serif-en);font-size:12.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--paper);border:1px solid var(--line);padding:11px 22px;transition:border-color .45s var(--ease),color .45s var(--ease)}
.nav-cta:hover{border-color:var(--gold);color:var(--gold-2)}
.nav-burger{display:none;flex-direction:column;gap:6px;background:none;border:0;cursor:pointer;padding:6px}
.nav-burger span{width:26px;height:1px;background:var(--paper);transition:.4s var(--ease)}
.drawer{position:fixed;inset:0;z-index:49;background:rgba(8,7,6,.97);backdrop-filter:blur(8px);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:30px;opacity:0;visibility:hidden;transition:opacity .5s var(--ease),visibility .5s var(--ease)}
.drawer.open{opacity:1;visibility:visible}
.drawer a{font-size:22px;letter-spacing:.18em;color:var(--paper)}
.drawer a .en{display:block;text-align:center;font-family:var(--serif-en);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-top:6px}

.rv{opacity:0;transform:translateY(26px);transition:opacity 1.2s var(--ease),transform 1.2s var(--ease)}
.rv.in{opacity:1;transform:none}
.rv-d1{transition-delay:.12s}.rv-d2{transition-delay:.24s}.rv-d3{transition-delay:.36s}.rv-d4{transition-delay:.48s}
@media (prefers-reduced-motion:reduce){.rv{opacity:1;transform:none;transition:none}}

/* ==========================================================================
   GATE HERO  (morning / evening cross-fade + toggle + ENTER + scroll cue)
   ========================================================================== */
.hero{position:relative;min-height:100svh;display:flex;flex-direction:column;justify-content:flex-end;overflow:hidden;background:var(--ink)}
.stage{position:absolute;inset:0;overflow:hidden;z-index:0}
.layer{position:absolute;inset:0;background-repeat:no-repeat;background-size:cover;background-position:center;will-change:opacity}
.layer.morning{background-image:url("images/morning.jpg");opacity:1}
.layer.evening{background-image:url("images/evening.jpg");opacity:0;transition:opacity var(--fade) var(--ease)}
body.is-evening .layer.evening{opacity:1}
.hero .scrim{position:absolute;inset:0;pointer-events:none;z-index:1;background:linear-gradient(180deg,rgba(8,10,16,.35) 0%,rgba(8,10,16,0) 38%,rgba(6,7,12,.72) 100%)}

/* hero content */
.hero-inner{position:relative;z-index:2;flex:1 1 auto;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;width:100%;padding:clamp(96px,12vh,130px) clamp(24px,5vw,40px) 20px}
.hero h1{font-family:var(--serif-en);font-weight:400;font-size:clamp(54px,11vw,150px);line-height:.92;letter-spacing:.06em;color:var(--paper);margin:.16em 0 .12em}
.hero h1 .sub{display:block;font-size:clamp(14px,2.1vw,26px);letter-spacing:.58em;color:var(--gold);text-transform:uppercase;margin-top:.9em;padding-left:.58em}
.hero .lead{font-size:clamp(14.5px,1.7vw,19px);color:var(--paper);opacity:.86;max-width:30em;margin:0 auto;line-height:2.15;letter-spacing:.1em;text-shadow:0 1px 16px rgba(0,0,0,.4)}
.hero .opening{margin-top:clamp(24px,4vh,42px);font-family:var(--serif-en);font-size:13px;letter-spacing:.34em;text-transform:uppercase;color:var(--mute)}

/* hero foot: toggle + scroll cue (in normal flow, never overlaps content) */
.hero-foot{position:relative;z-index:4;flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:clamp(16px,2.4vh,26px);padding-bottom:clamp(30px,6vh,56px)}

/* 朝 / 夕方 toggle */
.hero-controls{display:flex;justify-content:center}
.toggle{position:relative;display:inline-flex;padding:5px;border-radius:999px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.28);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);box-shadow:0 8px 30px rgba(0,0,0,.25)}
.toggle .thumb{position:absolute;top:5px;left:5px;width:104px;height:calc(100% - 10px);border-radius:999px;background:rgba(255,255,255,.95);box-shadow:0 4px 14px rgba(0,0,0,.22);transition:transform var(--fade) var(--ease),background var(--fade) var(--ease)}
body.is-evening .toggle .thumb{transform:translateX(104px);background:var(--gold)}
.toggle button{position:relative;z-index:2;width:104px;height:42px;border:0;background:transparent;cursor:pointer;font-family:var(--serif-jp);font-size:16px;letter-spacing:.18em;color:rgba(255,255,255,.88);transition:color 400ms var(--ease)}
.toggle button .en{display:block;font-family:var(--serif-en);font-size:11px;letter-spacing:.24em;opacity:.6;margin-top:1px;text-transform:uppercase}
body:not(.is-evening) .toggle button[data-mode="morning"]{color:#1a1714}
body.is-evening .toggle button[data-mode="evening"]{color:#231708}

/* scroll cue */
.scrollcue{display:flex;flex-direction:column;align-items:center;gap:10px}
.scrollcue span{font-family:var(--serif-en);font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.scrollcue i{width:1px;height:30px;background:linear-gradient(var(--gold),transparent);display:block;animation:cueline 2.6s var(--ease) infinite}
@keyframes cueline{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

@media (max-aspect-ratio:3/2) and (min-width:881px){.layer{background-size:contain;background-position:center}}
@media (max-width:880px){
  .layer.morning{background-image:url("images/morning-sp.jpg") !important}
  .layer.evening{background-image:url("images/evening-sp.jpg") !important}
  .layer{background-size:contain !important;background-position:top center !important}
}
@media (max-width:560px){.toggle .thumb{width:92px}body.is-evening .toggle .thumb{transform:translateX(92px)}.toggle button{width:92px;height:40px;font-size:15px}.hero .lead br{display:none}}

/* ==========================================================================
   STATEMENT
   ========================================================================== */
.statement{padding:clamp(110px,16vh,180px) 0;position:relative;background:var(--ink)}
.statement .wrap{max-width:1000px}
.statement .quote{font-family:var(--serif-jp);font-weight:400;font-size:clamp(24px,4vw,52px);line-height:1.65;letter-spacing:.08em;text-wrap:pretty;color:var(--paper);margin-top:36px}
.statement .quote em{font-style:normal;color:var(--gold-2)}
.statement .body{margin-top:46px;display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,5vw,72px)}
.statement .body p{color:var(--mute);font-size:16px;line-height:2.25;letter-spacing:.06em}
.statement .body p+p{margin-top:1.4em}
.origin{margin-top:64px;padding-top:40px;border-top:1px solid var(--line-2);display:flex;flex-wrap:wrap;gap:18px 56px;align-items:baseline}
.origin .kanji{font-family:var(--serif-jp);font-size:clamp(40px,6vw,72px);color:var(--gold);letter-spacing:.1em}
.origin .meaning{color:var(--mute);font-size:15.5px;line-height:2.1;max-width:34em}

/* ==========================================================================
   PRACTICE (5 pillars)
   ========================================================================== */
.practice{padding:clamp(100px,14vh,170px) 0;background:var(--ink-2);position:relative}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap;margin-bottom:clamp(48px,7vw,86px)}
.sec-head h2{font-family:var(--serif-en);font-weight:400;font-size:clamp(34px,5vw,62px);line-height:1.04;letter-spacing:.04em}
.sec-head h2 .jp{display:block;font-family:var(--serif-jp);font-size:clamp(14px,1.6vw,18px);letter-spacing:.4em;color:var(--mute);margin-top:14px}
.sec-head .note{max-width:30em;color:var(--mute);font-size:15px;line-height:2.1}
.pillars{border-top:1px solid var(--line-2)}
.pillar{display:grid;grid-template-columns:88px 1fr 1.25fr auto;gap:clamp(20px,4vw,60px);align-items:start;padding:clamp(30px,4vw,48px) 0;border-bottom:1px solid var(--line-2);position:relative;transition:background .6s var(--ease)}
.pillar:hover{background:none}
.pillar .idx{font-family:var(--serif-en);font-size:17px;color:var(--gold);letter-spacing:.2em;padding-top:7px}
.pillar .name .jp{font-size:clamp(22px,2.6vw,30px);letter-spacing:.1em;color:var(--paper);line-height:1.4}
.pillar .name .en{display:block;font-family:var(--serif-en);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute-2);margin-top:9px}
.pillar .desc{color:var(--mute);font-size:15.5px;line-height:2.15;letter-spacing:.05em;max-width:34em}
.pillar .desc .tag{display:block;width:fit-content;font-family:var(--serif-en);font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);border:1px solid var(--line);padding:5px 13px;margin-top:18px}
.pillar .more{align-self:center;font-family:var(--serif-en);font-size:22px;color:var(--mute-3);transition:color .4s var(--ease),transform .4s var(--ease)}
.pillar:hover .more{color:var(--gold);transform:translateX(4px)}
.practice-extra{margin-top:clamp(40px,6vw,68px);display:grid;grid-template-columns:auto 1fr;gap:clamp(24px,5vw,60px);align-items:start;padding:clamp(30px,3.5vw,46px) clamp(30px,4vw,52px);border:1px solid var(--line);background:rgba(201,169,106,.04)}
.practice-extra .pe-label{display:flex;flex-direction:column;gap:7px;white-space:nowrap}
.practice-extra .pe-label .en{font-family:var(--serif-en);font-size:13px;letter-spacing:.28em;text-transform:uppercase;color:var(--gold)}
.practice-extra .pe-label .jp{font-size:12px;letter-spacing:.28em;color:var(--mute-2)}
.practice-extra .pe-body h3{font-size:clamp(19px,2.3vw,26px);letter-spacing:.08em;line-height:1.5;color:var(--paper)}
.practice-extra .pe-body h3 .en{display:inline-block;font-family:var(--serif-en);font-size:12px;letter-spacing:.28em;text-transform:uppercase;color:var(--mute-2);margin-left:14px}
.practice-extra .pe-body p{color:var(--mute);font-size:15px;line-height:2.15;letter-spacing:.05em;margin-top:14px;max-width:48em}

/* ==========================================================================
   SPACE — fragmentary interior triptych
   ========================================================================== */
.space{background:var(--ink)}
.space-head{padding:clamp(100px,14vh,170px) clamp(24px,5vw,64px) clamp(46px,7vh,72px)}
.space-head .sh-grid{display:flex;align-items:flex-end;justify-content:space-between;gap:30px;flex-wrap:wrap}
.space-head h2{font-family:var(--serif-en);font-weight:400;font-size:clamp(34px,5vw,62px);line-height:1.04;letter-spacing:.04em}
.space-head h2 .jp{display:block;font-family:var(--serif-jp);font-size:clamp(14px,1.6vw,18px);letter-spacing:.4em;color:var(--mute);margin-top:14px}
.space-head .note{max-width:28em;color:var(--mute);font-size:15px;line-height:2.1}
.space-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;background:var(--line-2)}
.space-cell{position:relative;aspect-ratio:3/3.6;overflow:hidden;background:repeating-linear-gradient(45deg,rgba(243,237,226,.02) 0 14px,transparent 14px 28px),var(--ink-3)}
.space-cell img{width:100%;height:100%;object-fit:cover;filter:saturate(.82) brightness(.66) contrast(1.03);transition:transform 1.4s var(--ease),filter 1.2s var(--ease)}
.space-cell:hover img{transform:scale(1.05);filter:saturate(.9) brightness(.76)}
.space-cell::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(8,7,6,.05) 40%,rgba(8,7,6,.78))}
.space-cell .cap{position:absolute;left:clamp(20px,2vw,30px);bottom:clamp(20px,2vw,28px);z-index:2}
.space-cell .cap .en{font-family:var(--serif-en);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold)}
.space-cell .cap .jp{font-size:clamp(16px,1.7vw,19px);letter-spacing:.12em;color:var(--paper);margin-top:7px}
.space-cell .ph-note{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;font-family:'Courier New',monospace;font-size:11px;letter-spacing:.12em;color:var(--mute-3);text-align:center;padding:20px}

/* ==========================================================================
   PRIVACY
   ========================================================================== */
.privacy{position:relative;background:var(--ink);overflow:hidden}
.privacy-grid{display:grid;grid-template-columns:1.05fr 1fr;min-height:88vh}
.privacy-media{position:relative;overflow:hidden;background:var(--ink-3)}
.privacy-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:saturate(.8) brightness(.66) contrast(1.03)}
.privacy-media::after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,rgba(8,7,6,.2),rgba(8,7,6,.85) 88%)}
.privacy-media .frame-label{position:absolute;left:30px;bottom:28px;z-index:2;font-family:var(--serif-en);font-size:11px;letter-spacing:.34em;text-transform:uppercase;color:var(--mute)}
.privacy-body{display:flex;flex-direction:column;justify-content:center;padding:clamp(70px,9vw,120px) clamp(30px,6vw,96px) clamp(70px,9vw,120px) clamp(20px,4vw,60px)}
.privacy-body h2{font-family:var(--serif-jp);font-weight:400;font-size:clamp(24px,3.3vw,40px);line-height:1.6;letter-spacing:.09em;margin:26px 0 10px;text-wrap:pretty}
.privacy-body h2 em{font-style:normal;color:var(--gold-2)}
.priv-list{margin-top:40px;border-top:1px solid var(--line-2)}
.priv-item{display:flex;gap:24px;align-items:baseline;padding:24px 0;border-bottom:1px solid var(--line-2)}
.priv-item .n{font-family:var(--serif-en);font-size:13px;color:var(--gold);letter-spacing:.18em;min-width:30px}
.priv-item .t{font-size:16.5px;color:var(--paper);letter-spacing:.06em;line-height:1.7}
.priv-item .t small{display:block;color:var(--mute-2);font-size:13.5px;letter-spacing:.04em;margin-top:5px;line-height:1.8}

/* ==========================================================================
   MEMBERSHIP CTA
   ========================================================================== */
.member-cta{padding:clamp(110px,16vh,190px) 0;text-align:center;position:relative;background:var(--ink-2)}
.member-cta::before{content:"";position:absolute;inset:0;background:radial-gradient(60% 80% at 50% 0%,rgba(201,169,106,.08),transparent 70%);pointer-events:none}
.member-cta .wrap{max-width:840px;position:relative}
.member-cta h2{font-family:var(--serif-en);font-weight:400;font-size:clamp(36px,6vw,76px);line-height:1.05;letter-spacing:.04em;margin:30px 0 8px}
.member-cta .jp{font-size:clamp(15px,1.8vw,19px);color:var(--mute);line-height:2.2;letter-spacing:.1em;max-width:30em;margin:24px auto 0}
.member-cta .cta-row{display:flex;gap:18px;justify-content:center;flex-wrap:wrap;margin-top:50px}
.member-cta .fine{margin-top:34px;font-size:13px;color:var(--mute-3);letter-spacing:.1em}
.member-cta .fine a{color:var(--gold);border-bottom:1px solid var(--line)}

/* ==========================================================================
   ACCESS
   ========================================================================== */
.access{padding:clamp(100px,14vh,170px) 0;background:var(--ink)}
.access-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:start}
.access-map{aspect-ratio:4/3.4;border:1px solid var(--line-2);position:relative;overflow:hidden;background:repeating-linear-gradient(45deg,rgba(243,237,226,.018) 0 12px,transparent 12px 24px),var(--ink-3)}
.access-map .pin{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);text-align:center}
.access-map .pin .dot{width:11px;height:11px;border-radius:50%;background:var(--gold);margin:0 auto 12px;box-shadow:0 0 0 6px rgba(201,169,106,.16),0 0 0 16px rgba(201,169,106,.07)}
.access-map .pin .lbl{font-family:var(--serif-en);font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--mute)}
.access-map .ph{position:absolute;left:18px;bottom:16px;font-family:var(--serif-en);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--mute-3)}
.access-info dl{display:grid;grid-template-columns:auto 1fr;gap:0;border-top:1px solid var(--line-2)}
.access-info dt{font-family:var(--serif-en);font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--gold);padding:22px 30px 22px 0;border-bottom:1px solid var(--line-2);white-space:nowrap}
.access-info dd{padding:22px 0;border-bottom:1px solid var(--line-2);color:var(--paper);font-size:15.5px;line-height:1.95;letter-spacing:.05em}
.access-info dd small{color:var(--mute-2);font-size:13px;display:block;margin-top:4px}
.access-info h2{font-family:var(--serif-en);font-weight:400;font-size:clamp(30px,4vw,52px);margin:18px 0 30px;letter-spacing:.04em}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.foot{background:var(--ink-2);border-top:1px solid var(--line-2);padding:clamp(70px,9vw,110px) 0 40px}
.foot-top{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:40px}
.foot .fb1{font-family:var(--serif-en);font-size:30px;letter-spacing:.34em;color:var(--paper)}
.foot .fb2{font-family:var(--serif-en);font-size:10px;letter-spacing:.46em;text-transform:uppercase;color:var(--gold);margin-top:8px}
.foot .ftag{color:var(--mute-2);font-size:14px;line-height:2.1;margin-top:24px;max-width:24em}
.foot h4{font-family:var(--serif-en);font-size:11px;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
.foot ul{list-style:none}
.foot ul li{margin-bottom:13px}
.foot ul a{color:var(--mute);font-size:14.5px;letter-spacing:.05em;transition:color .4s var(--ease)}
.foot ul a:hover{color:var(--paper)}
.foot-bottom{margin-top:clamp(50px,7vw,80px);padding-top:28px;border-top:1px solid var(--line-2);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px}
.foot-bottom small{color:var(--mute-3);font-size:12px;letter-spacing:.14em}
.foot-bottom .lang{display:flex;gap:14px}
.foot-bottom .lang a{font-family:var(--serif-en);font-size:11px;letter-spacing:.24em;color:var(--mute-2)}
.foot-bottom .lang a.on{color:var(--gold)}

@media (max-width:1080px){
  .pillar{grid-template-columns:64px 1fr;gap:18px 26px}
  .pillar .desc{grid-column:1/-1;padding-left:82px}
  .pillar .more{display:none}
  .practice-extra{grid-template-columns:1fr;gap:14px}
}
@media (max-width:880px){
  .nav-links,.nav-cta{display:none}
  .nav-burger{display:flex}
  .statement .body{grid-template-columns:1fr}
  .space-head{padding:clamp(70px,9vh,100px) clamp(24px,5vw,64px) clamp(30px,5vh,44px)}
  .space-head .sh-grid{gap:22px}
  .space-head .note{margin-top:4px}
  .space-grid{grid-template-columns:1fr}
  .space-cell{aspect-ratio:16/10}
  .privacy-grid{grid-template-columns:1fr}
  .privacy-media{min-height:54vh}
  .privacy-media::after{background:linear-gradient(180deg,rgba(8,7,6,.15),rgba(8,7,6,.7))}
  .access-grid{grid-template-columns:1fr}
  .foot-top{grid-template-columns:1fr 1fr}
  .foot .fcol-brand{grid-column:1/-1}
}
@media (max-width:560px){
  .pillar{grid-template-columns:1fr}
  .pillar .idx{padding-top:0}
  .pillar .desc{padding-left:0}
  .foot-top{grid-template-columns:1fr}
  .access-info dl{grid-template-columns:1fr}
  .access-info dt{padding-bottom:4px;border-bottom:0}
  .access-info dd{padding-top:6px}
}

/* ── CREAM × GOLD THEME (main page) ── */
body.theme-cream{
  --ink:#ebe1cf;--ink-2:#e3d8c2;--ink-3:#dbcfb7;--ink-4:#d3c6aa;
  --paper:#1a1008;--mute:#6a5840;--mute-2:#8a7460;--mute-3:#aa9478;
  --gold:#9e7428;--gold-2:#b88c3a;
  --line:rgba(158,116,40,.28);--line-2:rgba(26,16,8,.11);
}
body.theme-cream::after{mix-blend-mode:multiply;opacity:.04}
body.theme-cream .nav.reveal{background:rgba(235,225,207,.94);border-bottom-color:rgba(26,16,8,.11)}
body.theme-cream .drawer{background:rgba(227,216,194,.98)}
body.theme-cream .btn-solid{color:#fff}
body.theme-cream .hero .scrim{background:linear-gradient(180deg,rgba(8,10,16,.28) 0%,rgba(8,10,16,0) 38%,rgba(6,7,12,.60) 100%)}

/* theme switch in nav */
.theme-sw{display:inline-flex;align-items:center;border:1px solid var(--line);border-radius:999px;overflow:hidden;background:rgba(255,255,255,.06);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}
.ts-btn{font-family:var(--serif-en);font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:7px 14px;border:none;background:transparent;color:var(--mute-2);cursor:pointer;transition:background .4s var(--ease),color .4s var(--ease);white-space:nowrap}
.ts-btn.active{background:var(--gold);color:#1a1409}
body.theme-cream .theme-sw{background:rgba(26,16,8,.06)}
body.theme-cream .ts-btn.active{color:#fff}
@media (max-width:880px){.theme-sw:not(.drawer-theme-sw){display:none}}
.drawer-theme-sw{margin-top:10px}

/* hero member link — fixed, always visible until nav reveals */
.hero-member-link{position:fixed;top:18px;right:clamp(24px,5vw,64px);z-index:52;font-family:var(--serif-en);font-size:11.5px;letter-spacing:.26em;text-transform:uppercase;color:#fff;border:1px solid rgba(255,255,255,.6);padding:10px 22px;background:rgba(0,0,0,.28);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);transition:border-color .4s var(--ease),color .4s var(--ease),background .4s var(--ease),opacity .4s var(--ease)}
.hero-member-link:hover{border-color:var(--gold);color:var(--gold-2);background:rgba(0,0,0,.18)}
.hero-member-link.hidden{opacity:0;pointer-events:none;transition:opacity .3s var(--ease)}
@media(max-width:880px){
  .hero-member-link{
    display:block;
    position:fixed;
    top:auto;
    bottom:auto;
    left:auto;
    transform:none;
    top:clamp(60px,9vh,80px);
    right:16px;
    font-size:10.5px;
    padding:7px 14px;
    white-space:nowrap;
    backdrop-filter:none;
    -webkit-backdrop-filter:none;
    background:rgba(0,0,0,.38);
  }
}
