/* ============================================================
   DMDL — The Architect Portal · Stylesheet (VOID edition)
   Dark void + the building 3D structure. Gold-on-black.
   Big Shoulders Display (display) · Inter Tight (body) ·
   JetBrains Mono (meta) · Archivo (structural).
   Same class contract as the white edition — reskinned dark.
   ============================================================ */

:root{
  --black:#0A0A0A;
  --charcoal:#1A1A1A;
  --charcoal-2:#2D2D2D;
  --grey:#3A3A3A;
  --silver:#A8A9AD;
  --light-silver:#D0D0D2;
  --off-white:#F5F5F0;
  --gold:#C4963A;
  --gold-deep:#C4963A;          /* on dark, gold reads bright already */
  --gold-soft:#E2D2A8;
  --line:rgba(255,255,255,.14);
  --line-2:rgba(255,255,255,.08);
  --mute:#A8A9AD;
  --placeholder:rgba(245,245,240,.26);

  --display:'Big Shoulders Display','Arial Black',sans-serif;
  --structural:'Archivo','Arial Narrow',sans-serif;
  --body:'Inter Tight',system-ui,-apple-system,sans-serif;
  --mono:'JetBrains Mono','SF Mono',Menlo,monospace;

  --ease-reveal:cubic-bezier(.16,1,.3,1);
  --ease-wipe:cubic-bezier(.7,0,.3,1);
  --ease-fill:cubic-bezier(.4,0,.2,1);
}

*{margin:0;padding:0;box-sizing:border-box;}
html,body{height:100%;}
body{
  background:var(--black);
  color:var(--off-white);
  font-family:var(--body);
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  overflow:hidden;
}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit;}
::selection{background:var(--gold);color:var(--black);}

/* ---------- the void + structure ---------- */
#void{position:fixed;inset:0;z-index:0;
  background:radial-gradient(120% 90% at 52% 40%, #141414 0%, #0c0c0c 44%, #060606 100%);}
#void-scene{width:100%;height:100%;display:block;opacity:.92;}
.void-scrim{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(58% 60% at 40% 50%, rgba(6,6,6,.74), rgba(6,6,6,.30) 60%, transparent 85%);
  transition:opacity 1.1s var(--ease-reveal);}
/* during the synthesis, pull the scrim back so the assembling structure is the hero */
.synth-open .void-scrim{opacity:.35;}
.synth-open .submitting{background:radial-gradient(46% 50% at 50% 46%, rgba(8,8,8,.55), transparent 80%);}
.void-vignette{position:fixed;inset:0;z-index:1;pointer-events:none;
  background:radial-gradient(120% 95% at 50% 42%, transparent 38%, rgba(5,5,5,.55) 80%, #040404 100%);}
#root{position:fixed;inset:0;z-index:2;}

.layer{position:fixed;inset:0;}
.gate-layer{z-index:2;}
.sanctum-layer{z-index:1;}
.grain{position:fixed;inset:0;z-index:6;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='220' height='220'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2'/%3E%3CfeColorMatrix values='0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.55 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");}

/* ============================================================
   THE GATE
   ============================================================ */
.gate{position:absolute;inset:0;background:transparent;
  display:flex;align-items:center;justify-content:center;overflow:hidden;}
.gate-layer.is-exiting .gate{animation:gateExit .7s ease forwards;}
@keyframes gateExit{to{opacity:0;transform:scale(1.04);}}

.gate-glow{position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(44% 38% at 50% 46%, rgba(196,150,58,.10), transparent 70%);}
.gate-frame{position:absolute;inset:26px;border:1px solid rgba(196,150,58,.26);
  opacity:0;transform:scale(.97);animation:frameIn 1.6s var(--ease-reveal) .2s forwards;}
@keyframes frameIn{to{opacity:1;transform:scale(1);}}
.tick{position:absolute;width:12px;height:12px;border:1px solid var(--gold);}
.tick.tl{top:-1px;left:-1px;border-right:0;border-bottom:0;}
.tick.tr{top:-1px;right:-1px;border-left:0;border-bottom:0;}
.tick.bl{bottom:-1px;left:-1px;border-right:0;border-top:0;}
.tick.br{bottom:-1px;right:-1px;border-left:0;border-top:0;}

.gate-inner{position:relative;z-index:2;width:min(468px,86vw);
  display:flex;flex-direction:column;align-items:center;text-align:center;}
.gate-mark{color:var(--gold-soft);opacity:0;transform:translateY(14px);
  animation:fadeUp .9s var(--ease-reveal) .5s forwards;}
.gate-eyebrow{margin-top:22px;font-family:var(--mono);font-size:10.5px;letter-spacing:.34em;
  text-transform:uppercase;white-space:nowrap;color:rgba(226,210,168,.72);
  opacity:0;animation:fadeUp .8s var(--ease-reveal) .7s forwards;
  display:flex;align-items:center;justify-content:center;gap:9px;}
.gate-eyebrow .mid{color:var(--gold);}
.gate-title{margin-top:16px;font-family:var(--display);font-weight:900;
  font-size:clamp(38px,5.2vw,58px);line-height:.96;color:var(--off-white);
  letter-spacing:.02em;text-transform:uppercase;
  opacity:0;transform:translateY(16px);animation:fadeUp 1s var(--ease-reveal) .9s forwards;
  text-shadow:0 2px 40px rgba(0,0,0,.8);}
.gate-title em{font-style:normal;color:var(--gold);}
.gate-rule{width:46px;height:1px;background:var(--gold);margin:22px 0 0;
  transform:scaleX(0);animation:ruleGrow .9s var(--ease-reveal) 1.1s forwards;}
@keyframes ruleGrow{to{transform:scaleX(1);}}
.gate-sub{margin-top:20px;font-weight:300;font-size:14px;line-height:1.7;
  color:var(--silver);max-width:34ch;
  opacity:0;animation:fadeUp .8s var(--ease-reveal) 1.2s forwards;}

.gate-fields{width:100%;margin-top:30px;display:flex;flex-direction:column;gap:22px;}
.gate-field{text-align:left;opacity:0;transform:translateY(16px);}
.gate-field.f1{animation:fadeUp .8s var(--ease-reveal) 1.32s forwards;}
.gate-field.f2{animation:fadeUp .8s var(--ease-reveal) 1.47s forwards;}
.gate-field label{display:block;font-family:var(--mono);font-size:9.5px;letter-spacing:.3em;
  text-transform:uppercase;color:rgba(226,210,168,.62);margin-bottom:11px;}
.gate-field input{width:100%;background:transparent;border:0;border-bottom:1px solid rgba(245,245,240,.18);
  font-family:var(--body);font-weight:300;font-size:20px;color:var(--off-white);padding:9px 0;outline:none;
  transition:border-color .4s var(--ease-reveal);}
.gate-field input::placeholder{color:rgba(245,245,240,.24);}
.gate-field input:focus{border-color:var(--gold);}

.gate-enter{position:relative;overflow:hidden;margin-top:34px;width:100%;
  border:1px solid rgba(196,150,58,.55);padding:18px 28px;
  display:flex;align-items:center;justify-content:center;gap:14px;
  font-family:var(--structural);font-weight:700;font-size:12px;letter-spacing:.26em;
  text-transform:uppercase;color:var(--off-white);
  opacity:0;transform:translateY(16px);animation:fadeUp .8s var(--ease-reveal) 1.62s forwards;
  transition:color .45s var(--ease-fill),border-color .45s ease;}
.gate-enter::before{content:'';position:absolute;inset:0;background:var(--gold);
  transform:translateX(-101%);transition:transform .45s var(--ease-fill);z-index:0;}
.gate-enter span{position:relative;z-index:1;white-space:nowrap;}
.gate-enter .arr{transition:transform .45s var(--ease-reveal);}
.gate-enter:hover{color:var(--black);border-color:var(--gold);}
.gate-enter:hover::before{transform:translateX(0);}
.gate-enter:hover .arr{transform:translateX(6px);}
.gate-enter:active{transform:scale(.99);}
.gate-foot{margin-top:26px;font-family:var(--mono);font-weight:300;font-size:10px;letter-spacing:.22em;
  text-transform:uppercase;color:rgba(245,245,240,.3);opacity:0;animation:fadeUp .8s ease 1.8s forwards;}

/* invalid-key / connection error — surfaced under the fields */
.gate-error{margin-top:18px;font-family:var(--mono);font-size:11px;line-height:1.6;letter-spacing:.04em;
  color:var(--gold-soft);background:rgba(196,150,58,.08);border-left:2px solid var(--gold);
  padding:9px 13px;text-align:left;animation:fadeUp .4s var(--ease-reveal) both;}
.gate-field input:disabled{opacity:.5;cursor:default;}
.gate-field input[aria-invalid="true"]{border-color:var(--gold);}
/* verifying state — freeze the gold fill mid-press, dim slightly, block input */
.gate-enter.is-busy{cursor:progress;color:var(--black);}
.gate-enter.is-busy::before{transform:translateX(0);}
.gate-enter:disabled{pointer-events:none;}
.gate-enter.is-busy .arr{letter-spacing:.1em;animation:gatePulse 1.1s ease-in-out infinite;}
@keyframes gatePulse{0%,100%{opacity:.4;}50%{opacity:1;}}

/* ============================================================
   MOTION PRIMITIVES
   ============================================================ */
@keyframes fadeUp{to{opacity:1;transform:none;}}
.fade-up{opacity:0;transform:translateY(26px);animation:fadeUp .7s var(--ease-reveal) both;}
.reveal{display:block;}
.reveal-i{display:block;transform:translateY(22px);opacity:0;
  animation:clipUp .85s var(--ease-reveal) both;}
@keyframes clipUp{to{transform:none;opacity:1;}}
.sanctum-layer.is-entering{opacity:0;animation:fadeIn .85s ease .45s forwards;}
@keyframes fadeIn{to{opacity:1;}}

/* ============================================================
   SANCTUM — shared (now transparent over the void)
   ============================================================ */
.sanctum{position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:stretch;overflow-y:auto;
  padding:clamp(36px,7vh,80px) max(clamp(24px,6vw,64px), calc((100% - 860px)/2));}
.sanctum>:first-child{margin-top:auto;}
.sanctum>:last-child{margin-bottom:auto;}

/* ---- buttons ---- */
.btn-primary{position:relative;overflow:hidden;border:1px solid rgba(196,150,58,.55);
  padding:16px 34px;font-family:var(--structural);font-weight:700;font-size:12px;
  letter-spacing:.24em;text-transform:uppercase;color:var(--off-white);
  transition:color .45s var(--ease-fill),border-color .45s ease;}
.btn-fill{position:absolute;inset:0;background:var(--gold);transform:translateX(-101%);
  transition:transform .45s var(--ease-fill);}
.btn-label{position:relative;z-index:1;white-space:nowrap;}
.btn-primary:hover{color:var(--black);border-color:var(--gold);}
.btn-primary:hover .btn-fill{transform:translateX(0);}
.btn-primary:active{transform:scale(.985);}
.btn-ghost{border:1px solid var(--line);padding:15px 26px;font-family:var(--structural);
  font-weight:600;font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--silver);
  transition:border-color .3s ease,color .3s ease;}
.btn-ghost:hover{border-color:var(--gold);color:var(--off-white);}
.btn-ghost.is-hidden{visibility:hidden;}
.btn-ghost .arr-l{display:inline-block;margin-right:4px;}
.btn-skip{font-family:var(--mono);font-size:11px;letter-spacing:.22em;text-transform:uppercase;
  color:var(--silver);padding:15px 14px;transition:color .3s ease;}
.btn-skip:hover{color:var(--off-white);}

/* ---- welcome ---- */
.welcome-eyebrow{font-family:var(--mono);font-size:11px;letter-spacing:.36em;text-transform:uppercase;color:var(--gold);}
.welcome-title{margin-top:20px;font-family:var(--display);font-weight:900;
  font-size:clamp(40px,5.4vw,68px);line-height:1.0;color:var(--off-white);
  letter-spacing:.01em;text-transform:uppercase;text-shadow:0 2px 40px rgba(0,0,0,.8);}
.welcome-title em{font-style:normal;color:var(--gold);}
.welcome-body{margin-top:28px;font-weight:300;font-size:16px;line-height:1.75;
  color:var(--silver);max-width:56ch;}
.welcome-stats{margin-top:40px;display:flex;align-items:center;gap:clamp(20px,4vw,48px);}
.wstat{display:flex;flex-direction:column;gap:8px;}
.wstat-n{font-family:var(--mono);font-weight:500;font-size:32px;line-height:1;color:var(--gold);}
.wstat-l{font-family:var(--mono);font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--silver);}
.wstat-div{width:1px;height:42px;background:var(--line);}
.welcome-cta{margin-top:46px;display:flex;flex-direction:column;gap:18px;align-items:flex-start;}
.welcome-stats{flex-wrap:wrap;}
.welcome-note{font-family:var(--mono);font-weight:300;font-size:11px;letter-spacing:.06em;color:var(--grey);}

/* ============================================================
   PORTAL (question flow)
   ============================================================ */
.portal{position:absolute;inset:0;}
.topbar{position:absolute;top:0;left:0;right:0;height:64px;z-index:4;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 clamp(20px,5vw,52px);
  background:rgba(10,10,10,.72);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line-2);}
.topbar-mark{display:flex;align-items:center;gap:12px;color:var(--off-white);}
.topbar-word{font-family:var(--display);font-weight:900;font-size:16px;letter-spacing:.28em;color:var(--off-white);}
.topbar-count{font-family:var(--mono);font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--silver);}
.count-n{color:var(--gold);}
.progress{position:absolute;left:0;bottom:-1px;width:100%;height:2px;background:var(--line-2);}
.progress-fill{display:block;height:100%;background:var(--gold);width:0;
  box-shadow:0 0 12px rgba(196,150,58,.5);transition:width .7s var(--ease-reveal);}

.portal-scroll{position:absolute;top:64px;bottom:0;left:0;right:0;overflow-y:auto;}
.portal-stage{min-height:100%;display:flex;align-items:center;
  max-width:900px;margin:0 auto;padding:clamp(36px,6vw,72px) clamp(24px,6vw,64px);}

.q-body{width:100%;}
.q-head{display:flex;align-items:baseline;gap:16px;flex-wrap:wrap;}
.q-eyebrow{font-family:var(--mono);font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;
  color:var(--gold);flex:0 0 auto;white-space:nowrap;}
.q-framework{font-family:var(--body);font-style:italic;font-weight:300;font-size:14.5px;
  color:var(--silver);white-space:nowrap;margin-left:auto;padding-left:24px;}
.q-text{margin-top:24px;font-family:var(--body);font-weight:300;
  font-size:clamp(28px,3.9vw,42px);line-height:1.34;color:var(--off-white);max-width:24ch;
  letter-spacing:.002em;text-shadow:0 2px 30px rgba(0,0,0,.85);}
.q-text em{font-style:italic;color:var(--gold);}
.q-hint{margin-top:18px;font-weight:300;font-style:italic;font-size:14.5px;color:var(--silver);}
.q-input{margin-top:38px;}
.q-nav{margin-top:50px;display:flex;align-items:center;justify-content:space-between;gap:16px;}
.q-nav-right{display:flex;align-items:center;gap:8px;}

/* ============================================================
   INPUTS (over the void)
   ============================================================ */
.ip-area,.ip-text{width:100%;background:transparent;border:0;border-bottom:1px solid var(--line);
  font-family:var(--body);font-weight:300;color:var(--off-white);padding:11px 0;outline:none;
  transition:border-color .4s var(--ease-reveal);}
.ip-area{font-size:20px;line-height:1.55;resize:none;overflow:hidden;min-height:52px;}
.ip-text{font-size:20px;}
.ip-area::placeholder,.ip-text::placeholder{color:var(--placeholder);}
.ip-area:focus,.ip-text:focus{border-color:var(--gold);}

.ip-stats{display:grid;grid-template-columns:1fr 1fr;gap:28px 44px;}
.ip-stat{display:flex;flex-direction:column;}
.ip-stat-label{font-family:var(--mono);font-size:9.5px;letter-spacing:.28em;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px;}

.ip-multi{display:flex;flex-direction:column;gap:24px;}
.ip-chips{display:flex;flex-wrap:wrap;gap:12px;}
.chip{display:inline-flex;align-items:center;gap:11px;border:1px solid var(--line);
  background:rgba(255,255,255,.03);padding:13px 20px;font-family:var(--body);font-weight:300;
  font-size:14.5px;color:var(--off-white);transition:border-color .3s ease,background .3s ease;}
.chip-tick{width:11px;height:11px;border:1px solid var(--silver);display:inline-block;transition:all .3s ease;}
.chip.is-on{border-color:var(--gold);background:rgba(196,150,58,.16);}
.chip.is-on .chip-tick{background:var(--gold);border-color:var(--gold);}
.ip-note{font-size:18px;}

.ip-sentence{font-family:var(--body);font-weight:300;font-size:clamp(24px,3.4vw,38px);
  line-height:1.5;color:var(--off-white);}
.ip-blank{font-family:var(--body);font-weight:400;font-size:inherit;color:var(--gold);
  background:transparent;border:0;border-bottom:1.5px solid var(--gold);
  text-align:center;padding:0 8px 2px;outline:none;min-width:8ch;}
.ip-blank::placeholder{color:var(--placeholder);font-style:italic;}

.ip-rank{list-style:none;display:flex;flex-direction:column;gap:8px;}
.rank-item{display:flex;align-items:center;gap:16px;padding:15px 18px;
  border:1px solid var(--line);background:rgba(255,255,255,.03);cursor:grab;
  transition:border-color .2s ease;}
.rank-item:hover{border-color:rgba(196,150,58,.5);}
.rank-item.is-drag{opacity:.45;border-color:var(--gold);}
.rank-num{font-family:var(--mono);font-weight:500;font-size:18px;color:var(--gold);width:30px;}
.rank-label{flex:1;font-family:var(--body);font-weight:300;font-size:16px;color:var(--off-white);}
.rank-ctl{display:flex;gap:2px;}
.rank-ctl button{width:30px;height:30px;border:1px solid var(--line);color:var(--silver);font-size:13px;
  transition:border-color .2s,color .2s;}
.rank-ctl button:hover:not(:disabled){border-color:var(--gold);color:var(--off-white);}
.rank-ctl button:disabled{opacity:.3;cursor:default;}
.rank-grip{color:var(--grey);font-size:18px;cursor:grab;}

.ip-scale-wrap{display:flex;flex-direction:column;gap:14px;}
.ip-scale{display:flex;gap:8px;flex-wrap:wrap;}
.scale-dot{width:48px;height:48px;border:1px solid var(--line);background:transparent;
  font-family:var(--mono);font-size:16px;color:var(--silver);transition:all .25s ease;}
.scale-dot:hover{border-color:rgba(196,150,58,.5);color:var(--off-white);}
.scale-dot.is-on{background:var(--gold);border-color:var(--gold);color:var(--black);}
.ip-scale-ends{display:flex;justify-content:space-between;font-family:var(--mono);font-size:10px;
  letter-spacing:.14em;text-transform:uppercase;color:var(--silver);max-width:540px;}
.ip-followup{margin-top:28px;display:flex;flex-direction:column;}

/* ============================================================
   SUBMITTING
   ============================================================ */
.submitting{align-items:center;justify-content:center;text-align:center;}
.submitting>:first-child{margin-top:auto;}
.submitting>:last-child{margin-bottom:auto;}
.submit-mark{color:var(--gold);animation:breathe 2.4s ease-in-out infinite;}
@keyframes breathe{0%,100%{opacity:.5;}50%{opacity:1;}}
.submit-eyebrow{margin-top:30px;font-family:var(--mono);font-size:12px;letter-spacing:.4em;
  text-transform:uppercase;color:var(--off-white);}

/* staged pillar checklist */
.synth-stages{margin-top:30px;display:flex;flex-direction:column;gap:12px;align-items:flex-start;
  width:min(360px,78vw);}
.synth-stage{display:flex;align-items:center;gap:14px;width:100%;
  opacity:.32;transition:opacity .5s var(--ease-reveal);}
.synth-stage.is-active{opacity:1;}
.synth-stage.is-done{opacity:.62;}
.synth-tick{position:relative;width:13px;height:13px;border:1px solid var(--silver);flex:0 0 auto;
  transition:border-color .4s ease,background .4s ease;}
.synth-stage.is-active .synth-tick{border-color:var(--gold);box-shadow:0 0 10px rgba(196,150,58,.5);}
.synth-stage.is-active .synth-tick::after{content:'';position:absolute;inset:3px;background:var(--gold);
  animation:tickPulse 1.1s ease-in-out infinite;}
.synth-stage.is-done .synth-tick{background:var(--gold);border-color:var(--gold);}
@keyframes tickPulse{0%,100%{opacity:.4;}50%{opacity:1;}}
.synth-label{font-family:var(--structural);font-weight:600;font-size:12px;letter-spacing:.14em;
  text-transform:uppercase;color:var(--off-white);}
.synth-stage.is-done .synth-label{color:var(--silver);}

.submit-line{margin-top:30px;width:min(360px,78vw);height:1px;background:var(--line);overflow:hidden;position:relative;}
.submit-line span{display:block;height:100%;width:0;background:var(--gold);
  box-shadow:0 0 12px rgba(196,150,58,.6);transition:width 1s var(--ease-reveal);}
.submit-sub{margin-top:22px;font-weight:300;font-size:13px;color:var(--silver);min-height:1.2em;}

/* ============================================================
   CONFIRMATION
   ============================================================ */
.confirm{align-items:stretch;}
.seal{position:relative;width:74px;height:74px;display:flex;align-items:center;justify-content:center;}
.seal-ring{position:absolute;inset:0;border-radius:50%;border:1px solid var(--gold);
  animation:sealPulse 2.6s ease-in-out infinite;}
@keyframes sealPulse{0%,100%{box-shadow:0 0 0 0 rgba(196,150,58,.32);}50%{box-shadow:0 0 0 13px rgba(196,150,58,0);}}
.seal-check{stroke-dasharray:48;stroke-dashoffset:48;animation:draw .8s var(--ease-reveal) .5s forwards;}
@keyframes draw{to{stroke-dashoffset:0;}}
.confirm-eyebrow{margin-top:34px;font-family:var(--mono);font-size:11px;letter-spacing:.36em;
  text-transform:uppercase;color:var(--gold);}
.confirm-title{margin-top:18px;font-family:var(--display);font-weight:900;
  font-size:clamp(42px,6vw,76px);line-height:1.0;color:var(--off-white);
  text-transform:uppercase;text-shadow:0 2px 40px rgba(0,0,0,.8);}
.confirm-title em{font-style:normal;color:var(--gold);}
.confirm-body{margin-top:28px;font-weight:300;font-size:16px;line-height:1.75;color:var(--silver);max-width:52ch;}
.gold-it{font-family:var(--body);font-style:italic;color:var(--gold);}
.confirm-foot{margin-top:40px;font-family:var(--mono);font-weight:300;font-size:10.5px;letter-spacing:.24em;
  text-transform:uppercase;color:var(--silver);display:flex;gap:10px;align-items:center;}
.confirm-foot .mid{color:var(--gold);}

/* ============================================================
   RESPONSIVE — clean at 380px
   ============================================================ */
@media (max-width:560px){
  .ip-stats{grid-template-columns:1fr;gap:22px;}
  .welcome-stats{gap:16px;flex-wrap:wrap;}
  .wstat-n{font-size:27px;}
  .q-nav{flex-direction:row;flex-wrap:wrap;}
  .scale-dot{width:42px;height:42px;font-size:15px;}
  .topbar{padding:0 18px;}
  .q-text{font-size:clamp(25px,7vw,32px);}
  .q-framework{margin-left:0;padding-left:0;white-space:normal;}
  .gate-enter{padding:16px 20px;}
  .void-scrim{background:radial-gradient(80% 60% at 50% 50%, rgba(6,6,6,.8), rgba(6,6,6,.4) 70%, transparent 95%);}
}

/* ============================================================
   REDUCED MOTION
   ============================================================ */
@media (prefers-reduced-motion:reduce){
  .fade-up,.reveal-i,.gate-mark,.gate-eyebrow,.gate-title,.gate-sub,
  .gate-field,.gate-enter,.gate-foot,.gate-frame,.gate-rule,
  .sanctum-layer.is-entering{
    animation:none !important;opacity:1 !important;transform:none !important;}
  .submit-line span{animation:none;width:100%;}
  .seal-check{animation:none;stroke-dashoffset:0;}
  .seal-ring,.submit-mark{animation:none;opacity:1;}
}
