*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#020205;--gold:#c9a227;--fn:'Inter',sans-serif;--jp:'Noto Sans JP',sans-serif}
html,body{background:var(--bg);color:#fff;font-family:var(--fn);overflow:hidden;height:100%;cursor:none}
.cur{position:fixed;width:32px;height:32px;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
.cur::before,.cur::after,.cur i::before,.cur i::after{content:'';position:absolute;width:8px;height:8px;border-color:rgba(255,255,255,.5);border-style:solid}
.cur::before{top:0;left:0;border-width:1px 0 0 1px}
.cur::after{top:0;right:0;border-width:1px 1px 0 0}
.cur i::before{bottom:0;left:0;border-width:0 0 1px 1px;position:absolute}
.cur i::after{bottom:0;right:0;border-width:0 1px 1px 0;position:absolute}
.cur i{position:absolute;inset:0}
.dot{position:fixed;width:0;height:0;pointer-events:none;z-index:9999;transform:translate(-50%,-50%)}
.cur-coords{position:fixed;pointer-events:none;z-index:9998;font-size:8px;color:rgba(255,255,255,.3);font-variant-numeric:tabular-nums;letter-spacing:.06em;transform:translate(0,0)}
#cv{position:fixed;top:0;left:0;width:100%;height:100%;z-index:1}
.vig{position:fixed;inset:0;background:radial-gradient(ellipse at center,transparent 25%,rgba(1,1,3,.85) 100%);z-index:2;pointer-events:none}
.noise{position:fixed;inset:0;z-index:3;pointer-events:none;opacity:.02;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='1'/%3E%3C/svg%3E");background-size:128px}
.grd{position:fixed;inset:0;z-index:4;pointer-events:none;opacity:.01;background-image:linear-gradient(rgba(255,255,255,.3) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.3) 1px,transparent 1px);background-size:140px 140px}
.hdr{position:fixed;top:0;left:0;right:0;display:flex;justify-content:space-between;align-items:center;padding:30px 44px;z-index:100;pointer-events:none}
.hdr-left{display:flex;align-items:center;gap:24px}
.hdr-right{display:flex;align-items:center;gap:20px;pointer-events:auto}
.logo{display:flex;align-items:center;gap:10px;font-size:13px;font-weight:300;letter-spacing:.08em;color:rgba(255,255,255,.87);text-decoration:none;pointer-events:auto;transition:color .3s}.logo:hover{color:#fff}.logo span{color:rgba(201,162,39,.87)}
.logo-img{height:18px;width:auto;opacity:.9}
.logo-text{font-size:13px;font-weight:300;letter-spacing:.08em}.logo-text span{color:rgba(201,162,39,.87)}
.cnt{font-size:13px;font-weight:300;letter-spacing:.15em;color:rgba(255,255,255,.6);font-variant-numeric:tabular-nums}.cnt .c{color:rgba(255,255,255,.87);font-weight:400}
/* Language Toggle */
.lang{display:flex;gap:2px;font-size:11px;font-weight:400;letter-spacing:.1em}
.lang a{color:rgba(255,255,255,.6);text-decoration:none;padding:4px 6px;transition:color .3s;cursor:pointer}
.lang a.active{color:rgba(255,255,255,.87)}
.lang a:hover{color:var(--gold)}
.lang-sep{color:rgba(255,255,255,.38);padding:4px 0}
/* Hamburger */
.ham{width:20px;height:20px;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:4px;cursor:pointer;transition:opacity .3s}
.ham:hover{opacity:1}
.ham i{width:3px;height:3px;background:rgba(255,255,255,.6);border-radius:50%;transition:background .3s}
.ham:hover i{background:var(--gold)}
.ham.open i:nth-child(1){transform:translate(-3px,0)}.ham.open i:nth-child(3){transform:translate(3px,0)}
/* Right Progress Bar (vertical) */
.vpb{position:fixed;right:30px;top:50%;transform:translateY(-50%);width:1px;height:120px;background:rgba(255,255,255,.03);z-index:100;pointer-events:none}
.vpb-fill{position:absolute;top:0;left:0;width:100%;height:0%;background:linear-gradient(to bottom,var(--gold),rgba(201,162,39,.15));transition:height .8s cubic-bezier(.16,1,.3,1)}
.vpb-dots{position:absolute;top:0;left:50%;transform:translateX(-50%);width:100%;height:100%;display:flex;flex-direction:column;justify-content:space-between}
.vpb-dot{width:5px;height:5px;margin-left:-2px;border-radius:50%;background:rgba(255,255,255,.38);transition:background .4s,transform .4s}
.vpb-dot.active{background:var(--gold);transform:scale(1.4)}
.vpb-label{position:absolute;right:14px;top:50%;transform:translateY(-50%);font-size:6px;letter-spacing:.3em;text-transform:uppercase;color:rgba(255,255,255,.38);writing-mode:vertical-rl}
/* Ticker Bar — 3-line notification */
.ticker{position:fixed;top:64px;left:44px;right:280px;z-index:100;display:flex;align-items:stretch;pointer-events:auto;cursor:pointer;overflow:hidden;gap:0;padding:8px 0}
.ticker-icon{flex-shrink:0;width:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;border-right:1px solid rgba(201,162,39,.1);margin-right:14px}
.ticker-icon-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.6}
.ticker-icon-label{font-size:8px;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,162,39,.7);margin-top:4px}
.ticker-body{flex:1;position:relative;min-width:0;overflow:visible;min-height:72px}
.ticker-slide{position:absolute;top:0;left:0;right:0;display:flex;flex-direction:column;justify-content:flex-start;gap:5px;pointer-events:none;visibility:hidden}
.ticker-slide.active{visibility:visible;pointer-events:auto}
.ticker-row1{display:flex;align-items:baseline;gap:10px;min-width:0}
.ticker-cat{flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--gold);opacity:.7;padding:3px 10px;border:1px solid rgba(201,162,39,.25);border-radius:1px;white-space:nowrap;align-self:flex-start;margin-top:2px}
.ticker-q{flex:1;font-size:15px;font-weight:400;color:rgba(255,255,255,.85);line-height:1.5;font-family:var(--jp);min-width:0}
.ticker-row2,.ticker-row3{display:flex;align-items:baseline;gap:8px;min-width:0}
.ticker-a-prefix{flex-shrink:0;font-size:10px;font-weight:600;letter-spacing:.1em;color:var(--gold);opacity:.7}
.ticker-a{font-size:14px;font-weight:300;color:rgba(255,255,255,.55);line-height:1.6;font-family:var(--jp);min-width:0}
.ticker:hover .ticker-slide.active .ticker-q{color:rgba(255,255,255,.9)}
.ticker:hover .ticker-slide.active .ticker-a{color:rgba(255,255,255,.55)}
.ticker:hover .ticker-slide.active .ticker-cat{border-color:rgba(201,162,39,.5);background:rgba(201,162,39,.08)}
.ticker-progress{position:absolute;bottom:0;left:44px;right:0;height:1px;background:rgba(201,162,39,.2);transform-origin:left;transform:scaleX(0)}
/* QA button */
.ticker-qa{position:fixed;top:82px;right:200px;z-index:100;font-size:9px;font-weight:600;letter-spacing:.15em;color:rgba(201,162,39,.5);cursor:pointer;padding:5px 12px;border:1px solid rgba(201,162,39,.15);border-radius:1px;transition:all .3s;text-transform:uppercase;pointer-events:auto}
.ticker-qa:hover{color:var(--gold);background:rgba(201,162,39,.08);border-color:rgba(201,162,39,.45)}
.ticker-qa .tq-n{font-size:8px;font-weight:400;opacity:.35;margin-left:3px}
/* Modal */
.modal-ov{position:fixed;inset:0;background:rgba(0,0,0,.92);backdrop-filter:blur(30px);z-index:2000;opacity:0;pointer-events:none;transition:opacity .4s;display:flex;flex-direction:column}
.modal-ov.open{opacity:1;pointer-events:auto}
.modal-hdr{display:flex;align-items:center;justify-content:space-between;padding:24px 44px;border-bottom:1px solid rgba(201,162,39,.12);flex-shrink:0}
.modal-ttl{font-size:12px;font-weight:600;letter-spacing:.12em;color:var(--gold)}
.modal-cnt{font-size:10px;color:rgba(255,255,255,.4);margin-top:2px}
.modal-x{width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:rgba(255,255,255,.4);font-size:16px;transition:color .3s;border-radius:50%}
.modal-x:hover{color:var(--gold)}
.modal-tabs{display:flex;padding:16px 44px 0;gap:4px;flex-shrink:0;flex-wrap:wrap}
.modal-tab{padding:7px 14px;font-size:10px;font-weight:500;letter-spacing:.06em;color:rgba(255,255,255,.4);cursor:pointer;border-radius:2px;transition:all .3s;border:1px solid transparent}
.modal-tab:hover{color:rgba(255,255,255,.7)}
.modal-tab.act{color:var(--gold);border-color:rgba(201,162,39,.25);background:rgba(201,162,39,.06)}
.modal-tab .tn{font-size:8px;opacity:.4;margin-left:3px}
.modal-body{flex:1;overflow-y:auto;padding:20px 44px 40px;scrollbar-width:none}
.modal-body::-webkit-scrollbar{display:none}
.mq-item{border-bottom:1px solid rgba(255,255,255,.04)}
.mq-q{display:flex;align-items:flex-start;gap:14px;padding:18px 0;cursor:pointer;transition:padding-left .3s}
.mq-q:hover{padding-left:6px}
.mq-num{font-size:9px;font-weight:600;color:var(--gold);opacity:.4;flex-shrink:0;width:24px;padding-top:2px}
.mq-qt{flex:1;font-size:13px;font-weight:400;line-height:1.8;color:rgba(255,255,255,.65);transition:color .3s;font-family:var(--jp)}
.mq-q:hover .mq-qt{color:rgba(255,255,255,.9)}
.mq-tog{flex-shrink:0;width:18px;height:18px;display:flex;align-items:center;justify-content:center;margin-top:2px;transition:transform .3s}
.mq-tog svg{width:10px;height:10px;stroke:rgba(255,255,255,.3);transition:stroke .3s}
.mq-item.open .mq-tog{transform:rotate(45deg)}
.mq-item.open .mq-tog svg{stroke:var(--gold)}
.mq-a{max-height:0;overflow:hidden;transition:max-height .4s ease}
.mq-item.open .mq-a{max-height:400px}
.mq-a-in{margin-left:38px;padding:14px 18px;background:rgba(201,162,39,.03);border-left:2px solid rgba(201,162,39,.25);border-radius:0 4px 4px 0}
.mq-a-lb{font-size:8px;font-weight:600;letter-spacing:.18em;color:var(--gold);margin-bottom:6px;opacity:.6}
.mq-a-tx{font-size:12px;line-height:1.9;color:rgba(255,255,255,.55);font-family:var(--jp)}
/* Quick Action Links */
.qa{position:fixed;right:60px;top:80px;z-index:100;display:flex;gap:12px;align-items:center;pointer-events:auto}
.qa a{font-size:11px;font-weight:600;letter-spacing:.15em;text-transform:uppercase;color:var(--gold);text-decoration:none;padding:10px 24px;border:1px solid rgba(201,162,39,.5);border-radius:1px;transition:all .4s;position:relative;overflow:hidden}
.qa a::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(201,162,39,.08),transparent);opacity:0;transition:opacity .4s}
.qa a:hover{color:#fff;border-color:var(--gold);box-shadow:0 0 20px rgba(201,162,39,.15)}
.qa a:hover::before{opacity:1}
.qa-jp{display:none}
@keyframes qaPulse{0%,100%{box-shadow:0 0 0 0 rgba(201,162,39,0),inset 0 0 0 0 rgba(201,162,39,0)}50%{box-shadow:0 0 20px 4px rgba(201,162,39,.25),inset 0 0 15px rgba(201,162,39,.08)}}
.qa-pulse{animation:qaPulse 2s ease-in-out infinite;background:rgba(201,162,39,.08)}
/* Fullscreen Menu */
.menu-overlay{position:fixed;inset:0;z-index:500;pointer-events:none;opacity:0;transition:opacity .5s}
.menu-overlay.open{opacity:1;pointer-events:auto}
.menu-bg{position:absolute;inset:0;background:#0a0a0f}
.menu-scanline{position:absolute;inset:0;background-image:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,255,255,.006) 2px,rgba(255,255,255,.006) 4px);pointer-events:none}
.menu-hdr{position:absolute;top:30px;left:44px;display:flex;align-items:center;gap:12px;z-index:2}
.menu-hdr-logo{font-size:12px;font-weight:300;letter-spacing:.08em;color:rgba(255,255,255,.87)}.menu-hdr-logo span{color:rgba(201,162,39,.87)}
.menu-content{position:relative;height:100%;display:flex;padding:0 12vw;gap:10vw}
.menu-col{flex:1;display:flex;flex-direction:column;justify-content:center}
.menu-col h3{font-size:10px;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--gold);opacity:.5;margin-bottom:32px}
.menu-item{display:block;font-size:clamp(28px,4vw,56px);font-weight:700;color:rgba(255,255,255,.75);text-decoration:none;line-height:1.5;transition:color .4s,text-shadow .4s}
.menu-item::after{content:'.';color:var(--gold);font-weight:700;transition:color .4s,text-shadow .4s}
/* Hover: item lights up, siblings dim */
.menu-col:hover .menu-item{color:rgba(255,255,255,.3)}
.menu-col:hover .menu-item::after{color:rgba(201,162,39,.2)}
.menu-col:hover .menu-item:hover{color:#fff;text-shadow:0 0 30px rgba(201,162,39,.15)}
.menu-col:hover .menu-item:hover::after{color:var(--gold);text-shadow:0 0 12px rgba(201,162,39,.5)}
.menu-footer{position:absolute;bottom:40px;left:0;right:0;display:flex;justify-content:center;gap:40px;z-index:2}
.menu-footer a{font-size:12px;font-weight:400;color:rgba(255,255,255,.6);text-decoration:none;transition:color .3s;letter-spacing:.02em}
.menu-footer a:hover{color:var(--gold)}
.sc{position:fixed;bottom:76px;left:44px;z-index:100;pointer-events:none}
.sn{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border:1px solid rgba(255,255,255,.38);border-radius:50%;font-size:11px;font-weight:300;color:rgba(255,255,255,.6);margin-bottom:18px}
.st{font-size:clamp(32px,5vw,64px);font-weight:700;line-height:.9;letter-spacing:-.03em;text-transform:uppercase;color:rgba(255,255,255,.95);pointer-events:auto;cursor:default;transition:letter-spacing .3s}
.st:hover{letter-spacing:-.01em}
.st.jp-mode{font-family:var(--jp);text-transform:none;letter-spacing:.02em;font-weight:700}
.st .ln{display:block;overflow:hidden}.st .ln span{display:block}
.st-jp{position:absolute;top:0;left:0;opacity:0;font-family:var(--jp);text-transform:none;letter-spacing:.02em;pointer-events:none;transition:opacity .25s}
.ss{font-family:var(--jp);font-size:14px;font-weight:300;color:rgba(255,255,255,.6);margin-top:18px;letter-spacing:.12em;opacity:0}
.sd{max-width:380px;pointer-events:none;margin-top:12px}
.sd p{font-size:13px;font-weight:300;line-height:2.1;color:rgba(255,255,255,.45);opacity:0;font-family:var(--jp)}
.sb{position:fixed;left:44px;top:50%;transform:translateY(-50%);z-index:100;pointer-events:none;opacity:.35}
.bl{width:12px;height:12px;position:relative}.bl::before,.bl::after{content:'';position:absolute;border-color:rgba(255,255,255,.38);border-style:solid}.bl::before{top:0;left:0;width:6px;height:6px;border-width:1px 0 0 1px}.bl::after{bottom:0;right:0;width:6px;height:6px;border-width:0 1px 1px 0}
.sco{font-size:7px;color:rgba(255,255,255,.38);font-variant-numeric:tabular-nums;margin-top:6px;letter-spacing:.06em}
.sla{font-size:6px;color:rgba(201,162,39,.6);letter-spacing:.2em;text-transform:uppercase;margin-top:2px}
.ft{position:fixed;bottom:0;left:0;right:0;display:flex;justify-content:flex-end;align-items:center;padding:20px 44px;z-index:100;pointer-events:none}
.ft div{font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.08em}
.ft a{font-size:11px;color:rgba(255,255,255,.6);text-decoration:none;pointer-events:auto;transition:color .3s}.ft a:hover{color:var(--gold)}
.dov{position:fixed;inset:0;z-index:600;pointer-events:none;opacity:0;transition:opacity .35s}
.dov.open{opacity:1;pointer-events:auto}
.dov-bg{position:absolute;inset:0;background:rgba(0,0,0,.78);backdrop-filter:blur(10px)}
.dov-box{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:74vw;height:74vh;border:1px solid rgba(201,162,39,.25);border-radius:2px;overflow:hidden;box-shadow:0 0 80px rgba(201,162,39,.08)}
.dov-box iframe{width:100%;height:calc(100% - 44px);border:none;background:#0a0a0a;margin-top:44px}
.dov-bar{position:absolute;top:0;left:0;right:0;height:44px;display:flex;justify-content:space-between;align-items:center;padding:0 22px;background:rgba(10,10,12,.95);border-bottom:1px solid rgba(201,162,39,.12);z-index:1}
.dov-name{font-size:11px;font-weight:500;color:var(--gold);letter-spacing:.1em;font-family:var(--jp)}
.dov-x{font-size:18px;color:rgba(255,255,255,.45);cursor:pointer;background:none;border:none;transition:color .3s;pointer-events:auto;padding:4px 8px}.dov-x:hover{color:#fff}
.ft-links{display:flex;gap:20px}
.ft-links a{font-size:11px;letter-spacing:.12em;text-transform:uppercase}
.sh{position:fixed;bottom:76px;left:50%;transform:translateX(-50%);z-index:100;display:flex;flex-direction:column;align-items:center;gap:8px;pointer-events:none}
.sh span{font-size:6px;letter-spacing:.4em;text-transform:uppercase;color:rgba(255,255,255,.38)}
.shl{width:1px;height:44px;position:relative;overflow:hidden}.shl::after{content:'';position:absolute;top:-100%;left:0;width:100%;height:100%;background:linear-gradient(to bottom,transparent,rgba(201,162,39,.25),transparent);animation:sd 3s ease-in-out infinite}
@keyframes sd{0%{top:-100%}100%{top:100%}}
.pb{display:none}
/* Floating Card */
.fcard{position:fixed;right:10vw;top:50%;transform:translateY(-50%);width:420px;z-index:100;pointer-events:none;opacity:0}
.fcard-inner{border:1px solid rgba(201,162,39,.15);border-radius:2px;padding:36px 36px;background:rgba(10,10,15,.75);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);position:relative;clip-path:inset(45% 45% 45% 45%);transition:none}
.fcard-inner::before,.fcard-inner::after{content:'';position:absolute;width:6px;height:6px;border-radius:50%;background:var(--gold);opacity:.5}
.fcard-inner::before{top:-3px;left:-3px}
.fcard-inner::after{bottom:-3px;right:-3px}
.fcard-label{font-size:12px;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:.7;margin-bottom:16px}
.fcard-body{font-family:var(--jp);font-size:16px;font-weight:300;line-height:2.0;color:rgba(255,255,255,.75)}
.fcard-foot{font-size:12px;color:rgba(255,255,255,.35);margin-top:20px;letter-spacing:.05em;padding-top:12px;border-top:1px solid rgba(255,255,255,.06)}
.fcard-text{opacity:0}
/* Deliverable Tags — below card */
.dtags{position:fixed;right:10vw;bottom:80px;z-index:100;pointer-events:none;display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;max-width:420px;opacity:0}
.dtag{display:inline-block;font-size:13px;font-weight:400;letter-spacing:.06em;color:rgba(255,255,255,.55);border:1px solid rgba(255,255,255,.12);padding:10px 22px;border-radius:1px;background:rgba(255,255,255,.03);font-family:var(--jp);transition:all .3s;cursor:default;pointer-events:auto}
.dtag:hover{color:var(--gold);border-color:rgba(201,162,39,.5);background:rgba(201,162,39,.06);box-shadow:0 0 12px rgba(201,162,39,.1)}
.ld{position:fixed;inset:0;background:var(--bg);z-index:10000;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:20px}
.lt{font-size:8px;letter-spacing:.5em;color:rgba(255,255,255,.6);text-transform:uppercase}
.ldb{width:50px;height:1px;background:rgba(255,255,255,.03);position:relative;overflow:hidden}.ldb::after{content:'';position:absolute;top:0;left:-100%;width:40%;height:100%;background:rgba(201,162,39,.3);animation:ls 2.2s ease-in-out infinite}
@keyframes ls{0%{left:-40%}100%{left:100%}}

/* ============================================================
   MOBILE RESPONSIVE — max-width: 768px
   ============================================================ */
@media (max-width:768px){
  /* System cursor — restore default on touch devices */
  html,body{cursor:auto;-webkit-tap-highlight-color:transparent;touch-action:pan-y}
  .cur,.dot,.cur-coords{display:none!important}

  /* Hide decorative sidebar */
  .sb{display:none}
  .grd{display:none}

  /* Header — compact */
  .hdr{padding:14px 16px}
  .hdr-left{gap:12px}
  .logo{gap:6px}
  .logo-img{height:14px}
  .logo-text{font-size:11px}
  .cnt{font-size:10px;letter-spacing:.08em}
  .hdr-right{gap:12px}
  .lang{font-size:10px}
  .lang a{padding:4px 4px}

  /* Ticker — question only, single row */
  .ticker{top:48px;left:16px;right:16px;padding:4px 0}
  .ticker-icon{width:24px;margin-right:6px}
  .ticker-icon-label{display:none}
  .ticker-icon-dot{width:4px;height:4px}
  .ticker-body{min-height:22px}
  .ticker-cat{font-size:7px;padding:2px 5px}
  .ticker-q{font-size:11px;line-height:1.3;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .ticker-row2,.ticker-row3{display:none}
  .ticker-progress{left:24px}

  /* QA button — compact, next to ticker */
  .ticker-qa{top:48px;right:16px;font-size:7px;padding:3px 7px}

  /* Quick Action Links — fixed bottom bar */
  .qa{position:fixed;right:0;left:0;top:auto;bottom:0;justify-content:center;padding:10px 16px;gap:6px;background:linear-gradient(transparent,rgba(2,2,5,.97) 40%);z-index:200}
  .qa a{font-size:9px;padding:10px 14px;letter-spacing:.08em;flex:1;text-align:center;max-width:150px}
  @keyframes qaPulse{0%,100%{box-shadow:none}50%{box-shadow:0 0 10px 2px rgba(201,162,39,.15)}}

  /* Main slide content — centered vertically */
  .sc{bottom:auto;top:80px;left:16px;right:16px;transform:none}
  .sn{width:26px;height:26px;font-size:9px;margin-bottom:10px}
  .st{font-size:clamp(26px,9vw,42px);line-height:.95}
  .ss{font-size:11px;margin-top:10px;letter-spacing:.06em}
  .sd{margin-top:6px}
  .sd p{font-size:10px;line-height:1.7}

  /* Floating Card — bottom sheet above CTA */
  .fcard{position:fixed;right:16px;left:16px;top:auto;bottom:54px;transform:none;width:auto;max-width:100%;max-height:45vh;overflow-y:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;pointer-events:auto}
  .fcard::-webkit-scrollbar{display:none}
  .fcard-inner{padding:16px 16px}
  .fcard-label{font-size:9px;margin-bottom:8px;letter-spacing:.12em}
  .fcard-body{font-size:12px;line-height:1.7}
  .fcard-foot{font-size:9px;margin-top:10px;padding-top:8px}

  /* Deliverable Tags — hidden on mobile (integrated into card) */
  .dtags{display:none!important}

  /* Card-integrated deliverable list */
  .fcard-delivs{display:flex;flex-direction:column;gap:0;margin-top:12px;border-top:1px solid rgba(201,162,39,.12);padding-top:10px}
  .fcard-deliv-item{display:flex;align-items:center;gap:8px;padding:9px 0;border-bottom:1px solid rgba(255,255,255,.04);cursor:pointer;transition:padding-left .2s}
  .fcard-deliv-item:last-child{border-bottom:none}
  .fcard-deliv-item:active{padding-left:4px}
  .fcard-deliv-num{font-size:8px;font-weight:600;color:var(--gold);opacity:.5;flex-shrink:0;width:18px}
  .fcard-deliv-name{font-size:11px;font-weight:400;color:rgba(255,255,255,.6);font-family:var(--jp);flex:1;min-width:0}
  .fcard-deliv-arrow{font-size:9px;color:rgba(201,162,39,.4);flex-shrink:0;transition:color .2s}
  .fcard-deliv-item:active .fcard-deliv-name{color:var(--gold)}
  .fcard-deliv-item:active .fcard-deliv-arrow{color:var(--gold)}

  /* Deliverable preview overlay — near fullscreen */
  .dov-box{width:96vw;height:80vh;border-radius:4px}
  .dov-bar{padding:0 14px;height:36px}
  .dov-name{font-size:9px}
  .dov-box iframe{height:calc(100% - 36px);margin-top:36px}

  /* Vertical Progress Bar — compact */
  .vpb{right:8px;height:70px}
  .vpb-dot{width:3px;height:3px;margin-left:-1px}
  .vpb-label{display:none}

  /* Scroll hint — above CTA bar */
  .sh{bottom:60px}

  /* Footer — above CTA bar, centered */
  .ft{padding:4px 16px;bottom:42px;justify-content:center}
  .ft div{font-size:8px}

  /* Fullscreen Menu — single column stack */
  .menu-content{flex-direction:column;padding:70px 24px 80px;gap:24px;overflow-y:auto}
  .menu-col{flex:none}
  .menu-col h3{margin-bottom:12px;font-size:8px}
  .menu-item{font-size:clamp(20px,7vw,32px);line-height:1.5}
  .menu-footer{gap:16px;bottom:20px}
  .menu-footer a{font-size:10px}
  .menu-hdr{left:16px;top:16px}

  /* Modal — tighter mobile spacing */
  .modal-hdr{padding:14px 16px}
  .modal-ttl{font-size:9px;letter-spacing:.06em}
  .modal-tabs{padding:10px 16px 0;gap:3px}
  .modal-tab{padding:4px 8px;font-size:8px}
  .modal-body{padding:14px 16px 70px}
  .mq-q{gap:8px;padding:12px 0}
  .mq-num{width:18px;font-size:7px}
  .mq-qt{font-size:11px;line-height:1.6}
  .mq-a-in{margin-left:26px;padding:8px 12px}
  .mq-a-tx{font-size:10px;line-height:1.7}
}

/* ============================================================
   SMALL MOBILE — max-width: 400px
   ============================================================ */
@media (max-width:400px){
  .hdr{padding:10px 12px}
  .sc{left:12px;right:12px}
  .st{font-size:clamp(22px,10vw,32px)}
  .ss{font-size:10px}
  .fcard{left:12px;right:12px;bottom:50px}
  .fcard-inner{padding:12px}
  .fcard-body{font-size:11px}
  .qa a{font-size:8px;padding:8px 10px}
  .ticker{left:12px;right:12px}
  .ticker-qa{right:12px}
  .menu-content{padding:60px 16px 70px}
}