/* ============================================================================
   FREDERICK & SONS — flagship site
   Infrastructure-grade luxury: near-black canvas, gold as the precious accent,
   terminal-green exclusively for trust, Fraunces display over a clean body.
   ========================================================================== */

:root{
  --ink:#0a0b0d; --ink2:#0e1014; --panel:#14161b; --panel2:#181b21;
  --line:#23262e; --line2:#2e323c;
  --text:#ece9e3; --dim:#9a958c; --faint:#a39d92; /* --faint raised from #6b6760 for WCAG AA (>=4.5:1 on near-black) */
  --gold:#d8a657; --gold-soft:#e6c489; --gold-deep:#a87b35;
  --green:#34d399; --green-dim:#1f8f63;
  --serif:"Fraunces",Georgia,"Times New Roman",serif;
  --sans:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;
  --ease:cubic-bezier(.22,1,.36,1);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;
    transition-duration:.01ms!important}
}
body{
  margin:0;background:var(--ink);color:var(--text);font-family:var(--sans);
  font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;overflow-x:hidden;
  background-image:
    radial-gradient(1400px 700px at 72% -12%, rgba(216,166,87,.09), transparent 60%),
    radial-gradient(900px 520px at -8% 14%, rgba(52,211,153,.04), transparent 55%);
  background-attachment:fixed;
}
::selection{background:rgba(216,166,87,.32);color:#fff}
a{color:var(--gold);text-decoration:none}
.wrap{position:relative;max-width:1160px;margin:0 auto;padding:0 2rem}

/* keyboard focus — gold ring, only for keyboard users */
a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{
  outline:2px solid var(--gold);outline-offset:3px;border-radius:6px}
.lf input:focus-visible,.chat-form input:focus-visible{outline:none}

/* skip link — visible only when focused */
.skip-link{position:fixed;top:-100px;left:1rem;z-index:100;padding:.7rem 1.2rem;
  background:var(--gold);color:var(--ink);font-weight:600;font-size:.88rem;
  border-radius:0 0 10px 10px;transition:top .25s var(--ease)}
.skip-link:focus{top:0}

/* fine grain over everything */
.grain{position:fixed;inset:-50%;width:200%;height:200%;z-index:60;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='180' height='180'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.78' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:grain 9s steps(6) infinite}
@keyframes grain{
  0%,100%{transform:translate(0,0)} 17%{transform:translate(-2%,1%)}
  34%{transform:translate(1%,-2%)} 51%{transform:translate(-1%,2%)}
  68%{transform:translate(2%,1%)}  85%{transform:translate(-2%,-1%)}}

/* ------------------------------------------------------------------ buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:.92rem;letter-spacing:.01em;
  padding:.85rem 1.7rem;border-radius:10px;border:1px solid rgba(216,166,87,.7);
  color:var(--ink)!important;cursor:pointer;position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 1px 0 rgba(255,255,255,.25) inset, 0 10px 30px -12px rgba(216,166,87,.45);
  transition:box-shadow .3s var(--ease), filter .3s var(--ease);
  will-change:transform;
}
.btn::after{content:"";position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,.42) 50%,transparent 62%);
  transform:translateX(-130%);transition:transform .7s var(--ease)}
.btn:hover::after{transform:translateX(130%)}
.btn:hover{box-shadow:0 1px 0 rgba(255,255,255,.3) inset, 0 16px 42px -12px rgba(216,166,87,.6);
  filter:brightness(1.05)}
.btn-lg{padding:1.05rem 2.3rem;font-size:1rem;border-radius:12px}
.btn-small{padding:.5rem 1.1rem;font-size:.82rem}
.btn-block{width:100%}
.btn-ghost{background:none;color:var(--gold)!important;border:1px solid var(--line2);box-shadow:none}
.btn-ghost::after{display:none}
.btn-ghost:hover{border-color:var(--gold);box-shadow:none}

/* ------------------------------------------------------------------ top nav */
.topnav{position:fixed;top:0;left:0;right:0;z-index:40;
  transition:background .4s var(--ease), border-color .4s var(--ease), backdrop-filter .4s;
  border-bottom:1px solid transparent}
.topnav.scrolled{background:rgba(10,11,13,.78);backdrop-filter:blur(14px);
  border-bottom-color:var(--line)}
.topnav-in{max-width:1280px;margin:0 auto;padding:0 2rem;height:72px;
  display:flex;align-items:center;gap:1.4rem}
.mark{font-family:var(--serif);font-weight:500;font-size:1.12rem;letter-spacing:.06em;
  color:var(--text);white-space:nowrap}
.mark .amp{color:var(--gold);font-style:italic}
.toplinks{display:flex;gap:1.9rem;align-items:center;margin-left:auto;font-size:.86rem}
.toplinks a:not(.btn){color:var(--dim);position:relative;transition:color .25s}
.toplinks a:not(.btn):hover{color:var(--text)}
.toplinks a:not(.btn)::after{content:"";position:absolute;left:0;right:100%;bottom:-5px;
  height:1px;background:var(--gold);transition:right .35s var(--ease)}
.toplinks a:not(.btn):hover::after{right:0}

.nav-toggle{display:none;flex-direction:column;gap:5px;background:none;border:none;
  padding:.5rem;cursor:pointer}
.nav-toggle span{display:block;width:22px;height:1.5px;background:var(--gold);
  transition:transform .3s var(--ease), opacity .3s}

/* ------------------------------------------------------------------ drawer */
.drawer-zone{position:fixed;inset:0 auto 0 0;z-index:50;pointer-events:none}
.drawer-tab{position:fixed;left:0;top:50%;transform:translateY(-50%);z-index:51;
  width:30px;height:148px;border:1px solid rgba(216,166,87,.4);border-left:none;
  border-radius:0 10px 10px 0;cursor:pointer;pointer-events:auto;
  background:linear-gradient(90deg,rgba(216,166,87,.13),rgba(216,166,87,.04));
  backdrop-filter:blur(8px);
  display:flex;align-items:center;justify-content:center;
  transition:background .3s,border-color .3s,opacity .4s var(--ease),transform .45s var(--ease)}
.drawer-tab:hover{background:linear-gradient(90deg,rgba(216,166,87,.24),rgba(216,166,87,.08));
  border-color:var(--gold)}
.drawer-tab-label{writing-mode:vertical-rl;transform:rotate(180deg);
  font-family:var(--mono);font-size:.62rem;letter-spacing:.42em;color:var(--gold)}
.drawer-zone.open .drawer-tab{opacity:0;transform:translateY(-50%) translateX(-34px)}

.drawer{position:fixed;left:0;top:0;bottom:0;width:min(360px,88vw);z-index:52;
  pointer-events:auto;display:flex;flex-direction:column;
  background:linear-gradient(135deg,#101218,#0c0d11 60%);
  border-right:1px solid rgba(216,166,87,.28);
  box-shadow:30px 0 90px -30px rgba(0,0,0,.85);
  transform:translateX(-103%);visibility:hidden;
  transition:transform .55s var(--ease), visibility 0s linear .55s;
  will-change:transform}
.drawer-zone.open .drawer{transform:translateX(0);visibility:visible;transition-delay:0s,0s}
.drawer-veil{position:fixed;inset:0;z-index:49;background:rgba(6,7,9,.55);
  backdrop-filter:blur(3px);opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity .45s var(--ease), visibility 0s linear .45s}
.drawer-zone.open .drawer-veil{opacity:1;visibility:visible;pointer-events:auto;transition-delay:0s,0s}
/* the concierge seal yields while the catalog is open */
.drawer-zone.open~.chat-seal{opacity:0;visibility:hidden;pointer-events:none}

.drawer-head{display:flex;align-items:baseline;gap:.8rem;padding:1.6rem 1.6rem 1.2rem;
  border-bottom:1px solid var(--line)}
.drawer-mark{font-family:var(--serif);font-size:1.3rem;letter-spacing:.08em}
.drawer-mark em{color:var(--gold);font-style:italic}
.drawer-sub{font-family:var(--mono);font-size:.66rem;letter-spacing:.3em;
  text-transform:uppercase;color:var(--faint)}
.drawer-close{margin-left:auto;background:none;border:none;color:var(--dim);font-size:1.5rem;
  line-height:1;cursor:pointer;padding:.2rem .4rem;transition:color .25s}
.drawer-close:hover{color:var(--gold)}
.drawer-scroll{flex:1;overflow-y:auto;padding:1rem 0;scrollbar-width:thin;
  scrollbar-color:var(--line2) transparent}
.drawer-group{padding:.6rem 1rem .9rem}
.drawer-k{font-family:var(--mono);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase;
  color:var(--gold);padding:0 .6rem .55rem}
.drawer-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:.58rem .65rem;border-radius:8px;color:var(--dim);font-size:.9rem;
  transition:background .25s,color .25s,transform .3s var(--ease);
  opacity:0;transform:translateX(-14px)}
.drawer-zone.open .drawer-item{opacity:1;transform:translateX(0);
  transition:background .25s,color .25s,
    opacity .5s var(--ease) var(--dd,.1s), transform .5s var(--ease) var(--dd,.1s)}
.drawer-item:hover{background:rgba(216,166,87,.08);color:var(--text)}
.drawer-item b{font-family:var(--mono);font-weight:500;font-size:.74rem;color:var(--gold)}
.drawer-item.key span{color:var(--gold-soft)}
.drawer-item.bundle-item{border:1px solid rgba(216,166,87,.35);background:rgba(216,166,87,.05)}
.live-dot{width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 9px var(--green);animation:pulse 2.2s infinite}
.drawer-foot{padding:1.2rem 1.6rem 1.5rem;border-top:1px solid var(--line)}

/* ------------------------------------------------------------------ hero */
.hero{position:relative;min-height:100svh;display:flex;align-items:center;
  justify-content:center;text-align:center;overflow:hidden;padding:7rem 0 5rem}
#embers{position:absolute;inset:0;width:100%;height:100%;pointer-events:none}
.hero-glow{position:absolute;inset:-12% -10%;pointer-events:none;
  background:
    radial-gradient(58% 44% at 50% 30%, rgba(216,166,87,.16), transparent 70%),
    radial-gradient(34% 28% at 50% 26%, rgba(230,196,137,.10), transparent 70%);
  will-change:transform}
.hero-amp{position:absolute;top:50%;left:50%;transform:translate(-50%,-54%);
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:min(74vh,58vw);line-height:1;color:transparent;pointer-events:none;
  -webkit-text-stroke:1px rgba(216,166,87,.13);user-select:none;will-change:transform}
.hero-in{position:relative;max-width:980px;padding:0 2rem;will-change:transform}

.eyebrow{font-family:var(--mono);font-size:.7rem;letter-spacing:.42em;
  text-transform:uppercase;color:var(--gold);margin:0 0 2.2rem}
.hero-h{font-family:var(--serif);font-weight:400;margin:0 0 1.8rem;
  font-size:clamp(3rem,8.4vw,6.6rem);line-height:1.02;letter-spacing:-.022em}
.hero-h em{font-style:italic;font-weight:400;
  background:linear-gradient(115deg,var(--gold-soft) 20%,var(--gold) 55%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent}
.hero-h .line{display:block;overflow:hidden;padding:0 .08em .08em}
.hero-h .line-in{display:inline-block;transform:translateY(115%);
  animation:lineup 1.1s var(--ease) var(--d,0s) forwards}
@keyframes lineup{to{transform:translateY(0)}}
.hero-sub{font-size:clamp(1.02rem,1.7vw,1.22rem);color:var(--dim);max-width:660px;
  margin:0 auto 2.6rem;line-height:1.7}
.hero-cta{margin-bottom:3.4rem;display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}

.rise{opacity:0;transform:translateY(26px);
  animation:rise 1s var(--ease) var(--d,0s) forwards}
@keyframes rise{to{opacity:1;transform:translateY(0)}}

.hero-stats{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:1.2rem;font-family:var(--mono);font-size:.74rem;color:var(--faint);letter-spacing:.04em}
.hero-stats b{color:var(--gold);font-weight:500;margin-right:.35rem}
.hero-stats b.green{color:var(--green)}
.hero-stats i{width:1px;height:14px;background:var(--line2)}

.hero-scrollhint{position:absolute;bottom:2.2rem;left:50%;transform:translateX(-50%);
  width:1px;height:54px;background:linear-gradient(var(--line2),transparent);overflow:hidden}
.hero-scrollhint span{position:absolute;left:0;top:-30%;width:1px;height:30%;
  background:var(--gold);animation:scrollhint 2.4s var(--ease) infinite}
@keyframes scrollhint{0%{top:-30%}70%,100%{top:110%}}

/* ------------------------------------------------------------------ ticker */
.ticker{border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  background:rgba(14,16,20,.6);overflow:hidden;padding:.85rem 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent)}
.ticker-track{display:flex;gap:3rem;width:max-content;align-items:center;
  font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--faint);animation:ticker 46s linear infinite;will-change:transform}
.ticker-track em{color:var(--gold);font-family:var(--serif);font-size:1rem;font-style:italic}
@keyframes ticker{to{transform:translateX(-50%)}}

/* ------------------------------------------------------------------ sections */
.section{padding:8.5rem 0;position:relative}
.snum{display:flex;align-items:center;gap:1.2rem;font-family:var(--mono);font-size:.7rem;
  letter-spacing:.34em;text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem;
  white-space:nowrap}
.snum::after{content:"";height:1px;flex:1;max-width:180px;
  background:linear-gradient(90deg,rgba(216,166,87,.5),transparent)}
.manifesto .snum,.lead-card .snum{justify-content:center}
.manifesto .snum::after,.lead-card .snum::after{display:none}
.shead{margin-bottom:4rem;max-width:720px}
.shead h2{font-family:var(--serif);font-weight:400;letter-spacing:-.015em;
  font-size:clamp(2.2rem,4.6vw,3.6rem);line-height:1.08;margin:0 0 1.2rem}
.shead h2 em,.mani-h em,.lead-card h2 em{font-style:italic;color:var(--gold-soft)}
.shead p{color:var(--dim);margin:0;font-size:1.04rem}

/* scroll reveals — hidden state only when JS is running (no-JS stays visible) */
.io{transition:opacity .9s var(--ease) var(--d,0s), transform .9s var(--ease) var(--d,0s)}
.js .io{opacity:0;transform:translateY(34px)}
.js .io.in{opacity:1;transform:translateY(0)}

/* ---- defensive reveal (BLOCKER 1): content is visible by DEFAULT.
   Hidden start-states only apply once JS is confirmed (.js set in <head>);
   without JS, with reduced motion, or after the inline 1500ms failsafe
   (.force-reveal / .is-visible) everything paints — the page can never be
   left a black void by a stalled IntersectionObserver. */
html:not(.js) .rise,html:not(.js) .reveal,html:not(.js) .line-in,html:not(.js) .io{
  opacity:1!important;transform:none!important;animation:none!important}
@media (prefers-reduced-motion:reduce){
  .rise,.reveal,.line-in,.io,.js .io{opacity:1!important;transform:none!important;animation:none!important}}
html.force-reveal .io,html.force-reveal .rise,html.force-reveal .reveal,html.force-reveal .line-in,
.io.is-visible,.rise.is-visible,.reveal.is-visible,.line-in.is-visible{
  opacity:1!important;transform:none!important;animation:none!important}

/* ------------------------------------------------------------------ stack viz */
@media (min-width:980px){
  #stack .wrap{display:grid;grid-template-columns:.82fr 1.18fr;gap:4.5rem;align-items:start}
  #stack .shead{position:sticky;top:7.5rem;margin-bottom:0}
  #stack .loopline{grid-column:1/-1}
  #stack .stackviz{margin:0}
}
.stackviz{position:relative;max-width:780px;margin:0 auto;padding-left:3.2rem}
.spine{position:absolute;left:1.1rem;top:1.4rem;bottom:1.4rem;width:1px;
  background:var(--line)}
.spine i{position:absolute;left:0;top:0;width:1px;height:100%;
  background:linear-gradient(var(--gold-soft),var(--gold));
  transform-origin:top;transform:scaleY(var(--p,0));
  box-shadow:0 0 12px rgba(216,166,87,.5);will-change:transform}
.slayer{display:flex;align-items:center;gap:1.3rem;padding:1.45rem 1.7rem;margin-bottom:.9rem;
  border-radius:14px;border:1px solid var(--line);position:relative;
  background:linear-gradient(180deg,var(--panel),var(--ink2));
  transition:opacity .8s var(--ease) var(--d,0s), transform .8s var(--ease) var(--d,0s),
    border-color .4s, box-shadow .4s}
.js .slayer.io{transform:translateY(34px) translateX(-18px)}
.js .slayer.io.in{transform:none}
.slayer:hover{border-color:var(--line2);box-shadow:0 14px 44px -22px rgba(0,0,0,.9)}
.slayer::before{content:"";position:absolute;left:-2.13rem;top:50%;width:9px;height:9px;
  margin-top:-4.5px;border-radius:50%;background:var(--ink);border:1px solid var(--line2);
  transition:background .5s,border-color .5s,box-shadow .5s}
.slayer.in::before{background:var(--gold);border-color:var(--gold);
  box-shadow:0 0 10px rgba(216,166,87,.7)}
.lk{font-family:var(--mono);font-size:.72rem;color:var(--gold);letter-spacing:.12em;
  width:34px;flex:none}
.lt b{display:block;font-weight:600;font-size:1.02rem;letter-spacing:.01em}
.lt small{display:block;color:var(--dim);font-size:.86rem;margin-top:.15rem}
.slayer.key{border-color:rgba(216,166,87,.65);
  background:linear-gradient(180deg,rgba(216,166,87,.10),var(--panel) 70%);
  box-shadow:0 0 0 1px rgba(216,166,87,.18), 0 14px 56px -18px rgba(216,166,87,.3)}
.slayer.key .lt b{color:var(--gold-soft)}
.keystone-tag{margin-left:auto;font-family:var(--mono);font-size:.6rem;letter-spacing:.3em;
  color:var(--gold);border:1px solid rgba(216,166,87,.45);border-radius:999px;
  padding:.28rem .7rem;flex:none}
.loopline{text-align:center;font-family:var(--mono);font-size:.76rem;color:var(--faint);
  margin:2.6rem auto 0;max-width:780px;letter-spacing:.06em}
.loop-arrow{color:var(--gold);display:inline-block;animation:spin 8s linear infinite}
@keyframes spin{to{transform:rotate(-360deg)}}

/* ------------------------------------------------------------------ flagships */
.flags{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.flag{position:relative;overflow:hidden;padding:2.6rem 2.4rem 2.2rem;border-radius:20px;
  border:1px solid var(--line2);
  background:linear-gradient(160deg,rgba(216,166,87,.08),var(--panel) 42%)}
.flag::before{content:"";position:absolute;inset:0;opacity:0;pointer-events:none;
  background:radial-gradient(520px 280px at 30% 0%,rgba(216,166,87,.14),transparent 70%);
  transition:opacity .5s var(--ease)}
.flag:hover::before{opacity:1}
.flag::after{content:"";position:absolute;top:0;left:8%;right:8%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(216,166,87,.55),transparent)}
.badge-live{position:absolute;top:1.7rem;right:1.7rem;font-family:var(--mono);
  font-size:.68rem;letter-spacing:.22em;color:var(--green);
  display:flex;align-items:center;gap:.5rem}
.badge-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--green);
  box-shadow:0 0 10px var(--green);animation:pulse 2.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.35}}
.flag h3{font-family:var(--serif);font-weight:500;font-size:2.4rem;margin:.3rem 0 .5rem;
  letter-spacing:-.01em}
.flag-num{position:absolute;right:1rem;bottom:-1.6rem;font-family:var(--serif);
  font-style:italic;font-weight:300;font-size:8.5rem;line-height:1;color:transparent;
  -webkit-text-stroke:1px rgba(216,166,87,.16);pointer-events:none;user-select:none}
.flag .tg{color:var(--gold-soft);font-style:italic;font-family:var(--serif);
  font-size:1.06rem;margin:0 0 1rem}
.flag .bl{color:var(--dim);font-size:.96rem;margin:0 0 1rem}
.flag .for{font-size:.82rem;color:var(--faint);margin:0 0 1.8rem}
.flag-cta{display:inline-flex;align-items:center;gap:.5rem;font-weight:600;font-size:.9rem;
  color:var(--gold);border:1px solid var(--line2);border-radius:10px;padding:.7rem 1.3rem;
  transition:border-color .3s,background .3s;will-change:transform}
.flag-cta:hover{border-color:var(--gold);background:rgba(216,166,87,.07)}
.flag-cta .arr{transition:transform .3s var(--ease)}
.flag-cta:hover .arr{transform:translateX(4px)}

/* ------------------------------------------------------------------ modules */
.mgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.15rem}
.mcard{display:flex;flex-direction:column;padding:1.7rem 1.6rem 1.45rem;border-radius:16px;
  border:1px solid var(--line);color:inherit;position:relative;overflow:hidden;
  background:linear-gradient(180deg,var(--panel),var(--ink2));
  transition:opacity .9s var(--ease) var(--d,0s), transform .9s var(--ease) var(--d,0s),
    border-color .35s, box-shadow .35s;
  will-change:transform}
.mcard.in{transition:border-color .35s, box-shadow .35s, transform .35s var(--ease)}
.mcard:hover{border-color:rgba(216,166,87,.6);transform:translateY(-5px);
  box-shadow:0 26px 60px -28px rgba(0,0,0,.85), 0 0 0 1px rgba(216,166,87,.14),
    0 18px 50px -26px rgba(216,166,87,.22)}
.mcard::before{content:"";position:absolute;inset:0;opacity:0;pointer-events:none;
  background:radial-gradient(420px 200px at 50% -8%,rgba(216,166,87,.12),transparent 70%);
  transition:opacity .45s}
.mcard:hover::before{opacity:1}
.mk{font-family:var(--mono);font-size:.62rem;letter-spacing:.26em;text-transform:uppercase;
  color:var(--faint)}
.mk.new{color:var(--gold)}
.mcard h3{font-family:var(--serif);font-weight:500;font-size:1.42rem;margin:.6rem 0 .35rem;
  letter-spacing:-.005em}
.mcard .tg{font-family:var(--serif);font-style:italic;color:var(--gold-soft);
  font-size:.93rem;line-height:1.45;margin:0 0 .8rem}
.mcard .bl{color:var(--dim);font-size:.88rem;margin:0 0 1rem;line-height:1.6}
.mcard .meta{font-size:.78rem;color:var(--faint);margin:0 0 .4rem}
.trust{display:inline-flex;align-items:center;gap:.45rem;font-family:var(--mono);
  font-size:.68rem;color:var(--green);border:1px solid rgba(31,143,99,.55);
  background:rgba(52,211,153,.06);border-radius:999px;padding:.26rem .7rem;
  margin-top:auto;align-self:flex-start}
.trust::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--green);
  box-shadow:0 0 8px var(--green)}
.mfoot{display:flex;align-items:baseline;justify-content:space-between;margin-top:1.15rem;
  padding-top:1.05rem;border-top:1px solid var(--line)}
.price{font-family:var(--serif);font-size:1.3rem;color:var(--gold);letter-spacing:.01em}
.price small{display:block;font-family:var(--mono);font-size:.62rem;color:var(--faint);
  letter-spacing:.04em;margin-top:.2rem}
.mcard .arr{color:var(--faint);font-size:.82rem;transition:color .3s,transform .3s var(--ease)}
.mcard:hover .arr{color:var(--gold);transform:translateX(3px)}
.keycard{grid-column:span 2;border-color:rgba(216,166,87,.45);
  background:linear-gradient(165deg,rgba(216,166,87,.09),var(--panel) 50%)}
.keycard h3{font-size:1.8rem}

/* entry product — The Verified Toolkit */
.entrycard{grid-column:1/-1;flex-direction:row;align-items:center;gap:2.4rem;
  padding:1.45rem 1.8rem;border-color:rgba(52,211,153,.32);
  background:linear-gradient(100deg,rgba(52,211,153,.07),var(--panel) 55%)}
.entrycard:hover{border-color:rgba(52,211,153,.6);
  box-shadow:0 26px 60px -28px rgba(0,0,0,.85), 0 0 0 1px rgba(52,211,153,.14),
    0 18px 50px -26px rgba(52,211,153,.22)}
.entrycard::before{background:radial-gradient(420px 200px at 20% -8%,rgba(52,211,153,.10),transparent 70%)}
.entrycard .entry-main{flex:1 1 auto;min-width:0}
.entrycard .entry-main .tg{margin-bottom:0}
.entrycard .entry-side{flex:0 0 auto;display:flex;flex-direction:column;align-items:flex-end;gap:.8rem}
.entrycard .entry-side .trust{align-self:flex-end;margin-top:0}
.entrycard .entry-side .mfoot{margin-top:0;padding-top:0;border-top:0;gap:1.2rem}
.entrycard .price{color:var(--green)}
.mk.entry{color:var(--green)}
.drawer-item.entry{border:1px solid rgba(52,211,153,.3);background:rgba(52,211,153,.05)}
.drawer-item.entry b{color:var(--green)}

/* ------------------------------------------------------------------ manifesto */
.manifesto{background:
  radial-gradient(900px 480px at 50% 8%,rgba(216,166,87,.07),transparent 70%),
  linear-gradient(180deg,var(--ink2),var(--ink));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);text-align:center}
.mani-h{font-family:var(--serif);font-weight:400;letter-spacing:-.02em;
  font-size:clamp(2.6rem,6vw,4.6rem);margin:0 0 3.4rem;line-height:1.05}
.mani-lines{max-width:760px;margin:0 auto 3rem}
.mani-line{font-family:var(--serif);font-weight:300;font-size:clamp(1.3rem,2.6vw,1.9rem);
  margin:0 0 1.1rem;color:var(--text);letter-spacing:-.01em}
.mani-line em{font-style:italic;color:var(--gold-soft)}
.mani-body{max-width:620px;margin:0 auto 2.6rem;color:var(--dim);font-size:1rem}
.mani-seals{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap}
.mani-seals .trust{margin-top:0}

/* ------------------------------------------------------------------ bundle */
.bundle{position:relative;overflow:hidden;text-align:center;border-radius:24px;
  border:1px solid rgba(216,166,87,.6);padding:4.5rem 3rem 4rem;
  background:linear-gradient(180deg,rgba(216,166,87,.09),var(--ink2) 70%)}
.bundle::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(720px 340px at 50% -6%,rgba(216,166,87,.2),transparent 70%)}
.bundle::after{content:"&";position:absolute;right:-3rem;bottom:-7rem;
  font-family:var(--serif);font-style:italic;font-size:22rem;line-height:1;
  color:transparent;-webkit-text-stroke:1px rgba(216,166,87,.12);pointer-events:none}
.bundle-k{font-family:var(--mono);font-size:.68rem;letter-spacing:.32em;
  text-transform:uppercase;color:var(--gold);margin-bottom:1.4rem}
.bundle h2{font-family:var(--serif);font-weight:400;font-size:clamp(2.4rem,5vw,3.8rem);
  margin:0 0 1.2rem;letter-spacing:-.015em}
.bundle-price{font-family:var(--serif);font-size:clamp(3rem,6vw,4.6rem);line-height:1;
  background:linear-gradient(115deg,var(--gold-soft) 15%,var(--gold) 55%,var(--gold-deep));
  -webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.6rem}
.bundle-sub{font-family:var(--mono);font-size:.74rem;color:var(--faint);
  letter-spacing:.08em;margin-bottom:1.8rem}
.bundle p{position:relative;color:var(--dim);max-width:600px;margin:0 auto 2.4rem}

/* ------------------------------------------------------------------ access */
.lead-card{border:1px solid var(--line);border-radius:24px;padding:4rem 3rem;
  background:linear-gradient(180deg,var(--panel),var(--ink2));text-align:center;
  position:relative;overflow:hidden}
.lead-card::after{content:"";position:absolute;top:0;left:14%;right:14%;height:1px;
  background:linear-gradient(90deg,transparent,rgba(216,166,87,.5),transparent)}
.lead-card .snum{margin-bottom:1.2rem}
.lead-card h2{font-family:var(--serif);font-weight:400;letter-spacing:-.015em;
  font-size:clamp(2rem,4vw,3rem);margin:0 0 1rem}
.lead-card>p{color:var(--dim);max-width:540px;margin:0 auto 2.4rem}
.lf{display:flex;gap:.8rem;max-width:640px;margin:0 auto;flex-wrap:wrap;justify-content:center}
.lf input{flex:1;min-width:210px;padding:.95rem 1.15rem;border-radius:11px;
  border:1px solid var(--line2);background:var(--ink);color:var(--text);
  font-family:var(--sans);font-size:1rem;transition:border-color .3s,box-shadow .3s}
.lf input::placeholder{color:var(--faint)}
.lf input:focus{outline:none;border-color:var(--gold);
  box-shadow:0 0 0 3px rgba(216,166,87,.14)}
.lf-ok{display:none;margin-top:1.4rem;font-family:var(--mono);font-size:.84rem;color:var(--green)}
.lf-note{font-size:.76rem;color:var(--faint);margin-top:1.2rem;font-family:var(--mono);
  letter-spacing:.04em}

/* ------------------------------------------------------------------ footer */
footer{border-top:1px solid var(--line);padding:3.6rem 0 3.2rem}
.foot-in{display:flex;align-items:baseline;gap:2rem;flex-wrap:wrap}
.foot-mark{font-family:var(--serif);font-size:1.05rem;letter-spacing:.06em}
.foot-mark .amp{color:var(--gold);font-style:italic}
.foot-tag{color:var(--faint);font-size:.84rem}
.foot-trust{margin-left:auto;font-family:var(--mono);font-size:.7rem;color:var(--green);
  letter-spacing:.06em}

/* ------------------------------------------------------------------ chat */
.chat-seal{position:fixed;right:1.8rem;bottom:1.8rem;z-index:55;width:62px;height:62px;
  border-radius:50%;cursor:pointer;border:1px solid rgba(216,166,87,.75);
  background:radial-gradient(circle at 32% 28%,var(--gold-soft),var(--gold) 55%,var(--gold-deep));
  box-shadow:0 14px 40px -10px rgba(216,166,87,.55), 0 2px 0 rgba(255,255,255,.25) inset;
  display:flex;align-items:center;justify-content:center;
  transition:box-shadow .35s,opacity .4s,visibility .4s;will-change:transform}
.chat-seal:hover{box-shadow:0 18px 52px -10px rgba(216,166,87,.75), 0 2px 0 rgba(255,255,255,.3) inset}
.seal-amp{font-family:var(--serif);font-style:italic;font-size:1.85rem;color:var(--ink);
  line-height:1;transform:translateY(-1px)}
.seal-ring{position:absolute;inset:-7px;border-radius:50%;
  border:1px solid rgba(216,166,87,.5);animation:sealring 3.2s var(--ease) infinite}
@keyframes sealring{0%{transform:scale(.92);opacity:.9}70%,100%{transform:scale(1.22);opacity:0}}
.chat-seal.hidden{opacity:0;visibility:hidden;pointer-events:none}

.chat-panel{position:fixed;right:1.8rem;bottom:1.8rem;z-index:56;
  width:min(396px,calc(100vw - 2rem));height:min(600px,calc(100svh - 4rem));
  display:flex;flex-direction:column;border-radius:20px;overflow:hidden;
  border:1px solid rgba(216,166,87,.4);
  background:linear-gradient(170deg,#13151b,#0c0d11 65%);
  box-shadow:0 40px 110px -24px rgba(0,0,0,.95), 0 0 0 1px rgba(216,166,87,.08);
  opacity:0;transform:translateY(28px) scale(.97);visibility:hidden;
  transition:opacity .45s var(--ease),transform .45s var(--ease),visibility 0s linear .45s;
  will-change:transform}
.chat-panel.open{opacity:1;transform:none;visibility:visible;transition-delay:0s}
.chat-head{display:flex;align-items:center;justify-content:space-between;
  padding:1.15rem 1.3rem 1rem;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,rgba(216,166,87,.07),transparent)}
.chat-title{font-family:var(--serif);font-size:1.3rem;letter-spacing:.01em}
.chat-sub{font-family:var(--mono);font-size:.62rem;letter-spacing:.26em;
  text-transform:uppercase;color:var(--gold);margin-top:.25rem}
.chat-min{background:none;border:none;color:var(--dim);font-size:1.45rem;cursor:pointer;
  padding:.2rem .5rem;line-height:1;transition:color .25s}
.chat-min:hover{color:var(--gold)}
.chat-log{flex:1;overflow-y:auto;padding:1.2rem 1.2rem .6rem;display:flex;
  flex-direction:column;gap:.85rem;scrollbar-width:thin;
  scrollbar-color:var(--line2) transparent}
.msg{max-width:86%;padding:.75rem 1rem;border-radius:14px;font-size:.9rem;line-height:1.55;
  animation:msgin .4s var(--ease)}
@keyframes msgin{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
.msg .t{display:block;font-family:var(--mono);font-size:.6rem;color:var(--faint);
  margin-top:.45rem;letter-spacing:.06em}
.msg.bot{align-self:flex-start;background:var(--panel2);border:1px solid var(--line);
  border-bottom-left-radius:4px;color:var(--text)}
.msg.user{align-self:flex-end;border-bottom-right-radius:4px;color:var(--ink);
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));font-weight:500}
.msg.user .t{color:rgba(10,11,13,.55)}
.chat-typing{display:flex;gap:5px;padding:.4rem 1.4rem .8rem}
.chat-typing i{width:6px;height:6px;border-radius:50%;background:var(--gold);
  animation:typing 1.2s infinite}
.chat-typing i:nth-child(2){animation-delay:.18s}
.chat-typing i:nth-child(3){animation-delay:.36s}
@keyframes typing{0%,60%,100%{opacity:.25;transform:translateY(0)}
  30%{opacity:1;transform:translateY(-4px)}}
.chat-form{display:flex;gap:.6rem;padding: .9rem 1rem 1rem;border-top:1px solid var(--line)}
.chat-form input{flex:1;min-width:0;padding:.78rem 1rem;border-radius:11px;border:1px solid var(--line2);
  background:var(--ink);color:var(--text);font-size:1rem;font-family:var(--sans);
  transition:border-color .3s}
.chat-form input:focus{outline:none;border-color:var(--gold)}
.chat-send{width:44px;border-radius:11px;border:1px solid rgba(216,166,87,.7);cursor:pointer;
  background:linear-gradient(180deg,var(--gold-soft),var(--gold));color:var(--ink);
  font-size:1.1rem;font-weight:700;transition:filter .25s}
.chat-send:hover{filter:brightness(1.08)}

/* ------------------------------------------------------------------ responsive */
@media (max-width:1020px){
  .mgrid{grid-template-columns:1fr 1fr}
  .keycard{grid-column:span 2}
}
@media (max-width:800px){
  /* the inline links wrap below ~800px — switch to the hamburger + drawer */
  .toplinks a:not(.btn){display:none}
  .nav-toggle{display:flex}
}
@media (max-width:760px){
  .wrap{padding:0 1.25rem}
  .section{padding:5.5rem 0}
  .topnav-in{padding:0 1.1rem;gap:.9rem;height:64px}
  .drawer-tab{display:none}
  .flags{grid-template-columns:1fr}
  .mgrid{grid-template-columns:1fr}
  .keycard{grid-column:span 1}
  .keycard h3{font-size:1.5rem}
  .entrycard{flex-direction:column;align-items:flex-start;gap:1.1rem;padding:1.5rem 1.4rem}
  .entrycard .entry-side{align-items:flex-start;width:100%;flex-direction:row;
    justify-content:space-between;align-items:center}
  .stackviz{padding-left:2.4rem}
  .spine{left:.7rem}
  .slayer{padding:1rem 1.1rem;gap:.9rem}
  .slayer::before{left:-1.74rem}
  .keystone-tag{display:none}
  .hero-amp{font-size:120vw}
  .hero-stats{gap:.8rem;font-size:.66rem}
  .hero-stats i{display:none}
  .bundle{padding:3rem 1.5rem}
  .lead-card{padding:2.8rem 1.4rem}
  .lf{flex-direction:column}
  .lf input{min-width:0}
  .foot-trust{margin-left:0}
  .chat-seal{right:1.1rem;bottom:1.1rem}
  .chat-panel{right:1rem;bottom:1rem}
}

/* Built-by-Fable trust mark (Anthropic clay #d97757 set into the F&S black+gold) */
.fable-seal{display:inline-flex;align-items:center;gap:.7rem;margin:1.6rem auto 0;
  border:1px solid #2e323c;border-radius:999px;padding:.5rem 1.1rem;
  background:linear-gradient(180deg,#15161a,#0d0e11);text-decoration:none;
  font-family:var(--mono,monospace)}
.fable-seal:hover{border-color:#d97757}
.fable-seal .fs-t1{color:#ece9e3;font-size:.76rem;letter-spacing:.03em}
.fable-seal .fs-t1 b{color:#d97757}
.fable-seal .fs-sep{width:1px;height:14px;background:#2e323c}
.fable-seal .fs-t2{color:#d97757;font-size:.68rem;letter-spacing:.14em;text-transform:uppercase}
.fable-note{color:var(--t-3,#6b6760);font-size:.76rem;line-height:1.5;max-width:540px;
  margin:.8rem auto 0;text-align:center}

/* Honest-proof layer (wave 2): linked trust badges, why-trust block, legal footer */
a.trust{text-decoration:none;cursor:pointer}
a.trust:hover{border-color:var(--green);background:rgba(52,211,153,.13)}
.whytrust{max-width:680px;margin:3.4rem auto 0;text-align:left;border:1px solid var(--line);
  border-radius:16px;padding:2rem 2.2rem;background:rgba(20,22,27,.5)}
.whytrust h3{font-family:var(--serif);font-weight:500;font-size:1.35rem;color:var(--gold-soft);
  margin:0 0 .8rem}
.whytrust p{color:var(--dim);font-size:.92rem;margin:0 0 .9rem}
.whytrust ul{margin:0 0 1rem;padding-left:1.2rem;color:var(--dim);font-size:.92rem}
.whytrust li{margin-bottom:.55rem}
.whytrust a{color:var(--gold)}
.whytrust .wt-contact{margin-bottom:0;font-size:.85rem;color:var(--faint)}
.foot-legal{margin-top:1.6rem;padding-top:1.2rem;border-top:1px solid var(--line);
  font-family:var(--mono);font-size:.72rem;color:var(--faint);letter-spacing:.03em}
.foot-legal a{color:var(--dim)}
.foot-legal a:hover{color:var(--gold)}
.foot-tag a{color:var(--dim)}
