/* Gungnir Leatherworks — design system from the concept sheet */
:root{
  --ink:#13171a;
  --char:#1a1e1f;
  --char2:#222a2c;
  --gold:#ada485;
  --brass:#c9b98c;
  --bone:#e8e2d4;
  --mute:#8f8d7f;
  --ox:#6e2a23;
  --ox-bright:#8a342b;
  --line:rgba(173,164,133,.18);
  --line-strong:rgba(173,164,133,.34);
  --display:"Grenze",Georgia,serif;
  --sans:"Archivo",system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;background:var(--ink)}
body{
  background:transparent;
  color:var(--bone);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:var(--brass);text-decoration:none}
a:focus-visible,button:focus-visible{outline:2px solid var(--brass);outline-offset:2px}

.wrap{max-width:1120px;margin:0 auto;padding:0 28px}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--brass);color:var(--ink);
  padding:10px 16px;z-index:200;font-weight:700}
.skip-link:focus{left:12px;top:12px}

/* ---- shared section scaffold ---- */
.sec{padding:92px 0}
.eyebrow{display:flex;align-items:baseline;gap:16px;margin-bottom:34px}
.numeral{font-family:var(--display);font-weight:900;font-size:.9rem;color:var(--brass);
  letter-spacing:.04em;border:1px solid var(--line-strong);border-radius:2px;padding:3px 10px;line-height:1}
.kicker{font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.34em;
  text-transform:uppercase;color:var(--mute)}
h2{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4.4vw,3.1rem);
  line-height:1.02;letter-spacing:-.01em;color:var(--bone);max-width:18ch}
.lede{font-size:1.12rem;color:#c9c4b6;max-width:62ch;margin-top:20px}

/* woven Norse braid seam — section divider, laced in on scroll */
.seam{display:block;width:100%;height:46px;line-height:0;--seam-bg:var(--ink)}
.foot .seam{--seam-bg:var(--char);height:40px;margin:8px 0 26px}
.seam svg{width:100%;height:100%;display:block;overflow:visible;
  -webkit-clip-path:inset(0 100% 0 0);clip-path:inset(0 100% 0 0)}
.seam.in svg{-webkit-clip-path:inset(0 0 0 0);clip-path:inset(0 0 0 0);
  transition:clip-path 1.5s cubic-bezier(.4,0,.2,1),-webkit-clip-path 1.5s cubic-bezier(.4,0,.2,1)}
.seam-strand,.seam-over{fill:none;stroke:var(--gold);stroke-width:3;
  stroke-linecap:round;stroke-linejoin:round;opacity:.9}
.seam-gap{fill:var(--seam-bg);stroke:none}
@media (prefers-reduced-motion:reduce){
  .seam svg,.seam.in svg{-webkit-clip-path:none;clip-path:none;transition:none}
}

/* ===================== NAV ===================== */
.nav{position:sticky;top:0;z-index:80;background:rgba(19,23,26,.92);
  -webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:20px;
  padding-top:14px;padding-bottom:14px}
.nav-brand{display:flex;align-items:center;gap:13px}
.nav-brand .nb-knot{width:40px;height:40px}
.nav-brand .nb-wordmark{height:36px;width:auto}
.nav-links{display:flex;align-items:center;gap:8px;list-style:none}
.nav-links a{font-family:var(--sans);font-weight:600;font-size:.74rem;letter-spacing:.22em;
  text-transform:uppercase;color:var(--mute);padding:9px 13px;border-radius:3px;transition:color .2s}
.nav-links a:hover{color:var(--bone)}
.nav-links a[aria-current="page"]{color:var(--bone)}
.nav-links a.nav-cta{color:var(--ink);background:var(--gold);transition:background .2s}
.nav-links a.nav-cta:hover{background:var(--bone)}
@media (max-width:640px){
  .nav-inner{flex-wrap:wrap;justify-content:center;padding-top:12px;padding-bottom:12px}
  .nav-links{flex-wrap:wrap;justify-content:center;gap:2px}
  .nav-links a{padding:8px 10px;letter-spacing:.16em}
}

/* ===================== HERO (home) ===================== */
.cover{position:relative;min-height:86vh;display:flex;align-items:center;overflow:hidden}
.cover-bg{position:absolute;inset:0;z-index:0;
  background:
    radial-gradient(78% 115% at 82% 38%, rgba(110,42,35,.28), rgba(110,42,35,.06) 44%, transparent 70%),
    linear-gradient(150deg, #171b1e 0%, #13171a 56%, #15100f 100%)}
.cover .wrap{position:relative;z-index:1;width:100%;display:flex;align-items:center;gap:54px;
  padding-top:64px;padding-bottom:64px}
.cover-content{flex:1 1 auto;min-width:0}
.cover-doc{font-family:var(--sans);font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;
  color:var(--mute);margin-bottom:30px;display:flex;align-items:center;gap:14px}
.cover-doc::before{content:"";width:34px;height:1px;background:var(--gold)}
.cover h1{font-family:var(--display);font-weight:900;font-size:clamp(2.7rem,7vw,5.4rem);
  line-height:.96;letter-spacing:-.02em;color:var(--bone);max-width:15ch}
.cover h1 em{font-style:italic;color:var(--brass)}
.cover-sub{font-size:1.18rem;color:#cbc6b8;max-width:48ch;margin-top:26px}
.cover-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:34px}
.tag{font-family:var(--sans);font-weight:600;font-size:.72rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--gold);border:1px solid var(--line-strong);
  border-radius:2px;padding:8px 14px}
.cover-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:38px}

/* buttons */
.btn{display:inline-block;font-family:var(--sans);font-weight:700;font-size:.8rem;
  letter-spacing:.16em;text-transform:uppercase;border-radius:4px;padding:15px 26px;
  cursor:pointer;border:none;transition:background .2s,color .2s,border-color .2s;text-align:center}
.btn-gold{color:var(--ink);background:var(--brass)}
.btn-gold:hover{background:var(--bone);color:var(--ink)}
.btn-ghost{color:var(--bone);background:transparent;border:1px solid var(--line-strong)}
.btn-ghost:hover{border-color:var(--brass);color:var(--brass)}

/* hero spear */
.hero-spear{flex:0 0 auto;height:min(64vh,500px);width:auto;align-self:center;overflow:visible}
.hero-spear .core{fill:none;stroke:var(--gold);stroke-linecap:round;stroke-linejoin:round;
  stroke-dasharray:1;stroke-dashoffset:1;animation:spearDraw 1.9s ease .35s forwards}
@keyframes spearDraw{to{stroke-dashoffset:0}}
@media (max-width:900px){.cover .wrap{display:block}.hero-spear{display:none}}
@media (prefers-reduced-motion:reduce){.hero-spear .core{stroke-dashoffset:0;animation:none}}

/* page hero (interior pages) — keep .sec's bottom padding so content clears the footer */
.page-hero{padding-top:74px}

/* ===================== PILLARS ===================== */
.pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  margin-top:56px;background:var(--line);border:1px solid var(--line);border-radius:4px;overflow:hidden}
.pillar{background:var(--char);padding:30px 26px}
.pillar .p-rune{font-family:var(--display);font-weight:900;color:var(--brass);font-size:1.1rem;
  display:block;margin-bottom:16px}
.pillar h3{font-family:var(--display);font-weight:600;font-size:1.18rem;color:var(--bone);margin-bottom:10px}
.pillar p{font-size:.96rem;color:var(--mute);line-height:1.55}
.thesis{font-family:var(--display);font-weight:400;font-style:italic;
  font-size:clamp(1.5rem,3.4vw,2.3rem);line-height:1.32;color:var(--bone);max-width:24ch}
.thesis b{font-weight:900;font-style:normal;color:var(--brass)}

/* ===================== CUSTOMIZER ===================== */
.shop-frame{background:var(--char);border:1px solid var(--line-strong);border-radius:10px;overflow:hidden;margin-top:10px}
.wc-maker{display:grid;grid-template-columns:1fr .9fr;gap:0}
.wc-stage{position:relative;background:radial-gradient(120% 100% at 50% 6%,#23292b 0%,#13171a 72%);
  padding:30px;min-height:470px;display:flex;align-items:center;justify-content:center;
  perspective:1250px;perspective-origin:50% 44%;overflow:hidden;cursor:grab;touch-action:none;user-select:none}
.wc-stage:active{cursor:grabbing}
.wc-eye{position:absolute;top:15px;left:18px;font-family:var(--sans);font-size:.64rem;letter-spacing:.28em;
  text-transform:uppercase;color:var(--mute);z-index:3}
.wc-wallet{position:relative;width:344px;height:262px;transform-style:preserve-3d;
  transform:rotateX(16deg) rotateY(-26deg);will-change:transform}
.wc-layer{position:absolute;inset:0;transform-style:preserve-3d}
.wc-layer svg,.wc-slab svg{width:100%;height:100%;display:block;overflow:visible}
.wc-slab{position:absolute;inset:0;transform-style:preserve-3d}
.wc-keyopts .wc-lab{margin:12px 0 8px}
.wc-mini{font-size:.62rem!important;letter-spacing:.18em}
.wc-floor{position:absolute;left:50%;top:50%;width:310px;height:64px;border-radius:50%;
  background:radial-gradient(50% 50% at 50% 50%,rgba(0,0,0,.55),transparent 72%);
  transform:translate(-50%,128px) rotateX(84deg);filter:blur(4px);pointer-events:none}
.wc-hint{position:absolute;bottom:14px;left:0;right:0;text-align:center;font-family:var(--sans);
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--mute);pointer-events:none;transition:opacity .5s}

.wc-controls{padding:30px;background:var(--char);border-left:1px solid var(--line)}
.wc-grp{margin-bottom:22px}
.wc-lab{display:flex;justify-content:space-between;align-items:baseline;gap:10px;margin-bottom:11px}
.wc-lab b{font-family:var(--sans);font-weight:600;font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold)}
.wc-lab span{font-size:.82rem;color:var(--bone);text-align:right}
.wc-tabs{display:flex;gap:6px;margin-bottom:13px}
.wc-tab{flex:1;font-family:var(--sans);font-size:.7rem;font-weight:600;color:var(--mute);background:#15191b;
  border:1px solid var(--line);border-radius:5px;padding:8px 2px 7px;cursor:pointer;transition:all .18s;
  display:flex;flex-direction:column;align-items:center;gap:6px}
.wc-tab:hover{color:var(--bone)}
.wc-tab[aria-selected="true"]{color:var(--bone);border-color:var(--brass);background:#1b2123}
.wc-tab i{width:20px;height:13px;border-radius:2px;border:1px solid rgba(0,0,0,.45);box-shadow:inset 0 0 0 1px rgba(255,255,255,.05)}
.wc-sw{display:flex;flex-wrap:wrap;gap:9px}
.wc-chip{width:31px;height:31px;border-radius:50%;cursor:pointer;border:2px solid transparent;outline:1px solid var(--line);
  position:relative;transition:transform .15s,border-color .2s;padding:0}
.wc-chip:hover{transform:scale(1.1)}
.wc-chip[aria-pressed="true"]{border-color:var(--brass);outline-color:var(--brass)}
.wc-chip:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.wc-pills{display:flex;flex-wrap:wrap;gap:8px}
.wc-pill{font-family:var(--sans);font-size:.78rem;color:var(--mute);cursor:pointer;border:1px solid var(--line);
  border-radius:3px;padding:8px 12px;background:transparent;transition:all .18s;display:flex;align-items:center;gap:7px}
.wc-pill:hover{color:var(--bone);border-color:var(--line-strong)}
.wc-pill[aria-pressed="true"]{color:var(--ink);background:var(--gold);border-color:var(--gold);font-weight:600}
.wc-pill em{width:11px;height:11px;border-radius:50%;display:inline-block;border:1px solid rgba(0,0,0,.35)}
.wc-pill:focus-visible{outline:2px solid var(--brass);outline-offset:2px}
.wc-toggle{display:flex;align-items:center;gap:10px;font-family:var(--sans);font-size:.84rem;color:var(--bone);cursor:pointer}
.wc-toggle input{appearance:none;-webkit-appearance:none;width:38px;height:21px;border-radius:11px;background:#222;
  border:1px solid var(--line);position:relative;cursor:pointer;transition:background .2s;flex:none}
.wc-toggle input::after{content:"";position:absolute;top:1.5px;left:2px;width:15px;height:15px;border-radius:50%;
  background:var(--mute);transition:all .2s}
.wc-toggle input:checked{background:var(--ox)}
.wc-toggle input:checked::after{left:19px;background:var(--bone)}
.wc-price{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--line);padding-top:18px;margin-top:6px}
.wc-price .pl{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute)}
.wc-price .pv{font-family:var(--display);font-weight:900;font-size:1.9rem;color:var(--bone)}
.wc-price .pv small{font-family:var(--sans);font-size:.78rem;font-weight:500;color:var(--mute);margin-left:6px}
.wc-add{width:100%;margin-top:16px;font-family:var(--sans);font-weight:700;font-size:.8rem;letter-spacing:.16em;
  text-transform:uppercase;color:var(--ink);background:var(--brass);border:none;border-radius:4px;padding:15px;cursor:pointer;transition:background .2s}
.wc-add:hover{background:var(--bone)}
.wc-note{font-size:.76rem;color:var(--mute);text-align:center;margin-top:12px}

/* build-spec / checkout modal */
.wc-modal[hidden]{display:none}
.wc-modal{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:20px}
.wc-modal-bg{position:absolute;inset:0;background:rgba(10,12,14,.78)}
.wc-modal-card{position:relative;background:var(--char);border:1px solid var(--line-strong);border-radius:10px;
  max-width:480px;width:100%;padding:34px;box-shadow:0 24px 60px rgba(0,0,0,.55)}
.wc-modal-card h3{font-family:var(--display);font-weight:900;font-size:1.6rem;color:var(--bone);margin-bottom:14px}
.wc-spec{font-size:.88rem;color:#c4bfb2;background:#15191b;border:1px solid var(--line);border-radius:6px;
  padding:16px 18px;margin:14px 0;white-space:pre-line;line-height:1.7}
.wc-modal-card p{font-size:.9rem;color:var(--mute)}
.wc-modal-actions{display:flex;flex-direction:column;gap:10px;margin-top:20px}
.wc-copied{color:var(--brass);font-size:.8rem;letter-spacing:.1em;text-transform:uppercase}
.wc-close{position:absolute;top:14px;right:16px;background:none;border:none;color:var(--mute);
  font-size:1.3rem;cursor:pointer;line-height:1}
.wc-close:hover{color:var(--bone)}

/* ===================== PRODUCTS ===================== */
.shop-list{margin-top:46px}
.sl-head{display:flex;align-items:baseline;gap:16px;margin-bottom:20px}
.sl-head h3,.sl-head h2.sl-h{font-family:var(--display);font-weight:900;font-size:1.5rem;color:var(--bone);max-width:none}
.sl-head .sl-note{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--mute)}
.products{display:grid;grid-template-columns:repeat(auto-fill,minmax(258px,1fr));gap:20px}
.product{border:1px solid var(--line);border-radius:8px;overflow:hidden;background:var(--char);
  display:flex;flex-direction:column;transition:border-color .25s ease,transform .25s ease}
.product:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.p-photo{aspect-ratio:4/3;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden}
.p-photo>img{width:100%;height:100%;object-fit:cover;filter:saturate(.92)}
.p-photo svg{width:62%;height:auto;overflow:visible}
.p-photo .ph-tag{position:absolute;top:12px;left:12px;font-size:.6rem;letter-spacing:.18em;
  text-transform:uppercase;color:var(--gold);background:rgba(19,23,26,.55);padding:4px 9px;border-radius:2px}
.p-line{fill:none;stroke:var(--gold);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;opacity:.92}
.p-body{padding:20px 22px 22px;display:flex;flex-direction:column;flex:1}
.p-name{font-family:var(--display);font-weight:600;font-size:1.25rem;color:var(--bone)}
.p-desc{font-size:.88rem;color:var(--mute);margin-top:8px;flex:1}
.p-foot{display:flex;align-items:center;justify-content:space-between;margin-top:18px}
.p-price{font-family:var(--display);font-weight:900;font-size:1.35rem;color:var(--brass)}
.p-price small{font-family:var(--sans);font-weight:500;font-size:.72rem;color:var(--mute);margin-left:4px}
.p-buy{font-family:var(--sans);font-weight:700;font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--ink);background:var(--gold);border:none;border-radius:4px;padding:11px 16px;cursor:pointer;
  transition:background .2s ease;display:inline-block}
.p-buy:hover{background:var(--bone)}
.p-buy[aria-disabled="true"]{background:#3a3e40;color:var(--mute);cursor:not-allowed}

/* ===================== ABOUT ===================== */
.about-hero{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center;margin-top:8px}
.about-copy h3{font-family:var(--display);font-weight:900;font-size:2.1rem;color:var(--bone);line-height:1.05;margin-bottom:20px}
.about-copy p{color:#c4bfb2;margin-bottom:16px;max-width:54ch}
.about-copy .sig{font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--brass);margin-top:24px}
.about-photo{border:1px solid var(--line);border-radius:8px;overflow:hidden;position:relative}
.about-photo img{width:100%;height:100%;object-fit:cover;min-height:340px;filter:saturate(.92)}
.ph-cap{position:absolute;left:0;bottom:0;right:0;padding:26px 22px 16px;
  background:linear-gradient(0deg,rgba(15,18,20,.92),transparent);
  font-size:.82rem;color:var(--gold);letter-spacing:.1em;text-transform:uppercase}
.about-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:18px}
.about-strip .as{border:1px solid var(--line);border-radius:6px;overflow:hidden;height:170px;position:relative}
.about-strip img{width:100%;height:100%;object-fit:cover;filter:saturate(.9)}
.about-strip .as-tag{position:absolute;left:12px;bottom:10px;font-size:.7rem;letter-spacing:.12em;
  text-transform:uppercase;color:var(--bone);background:rgba(15,18,20,.7);padding:4px 9px;border-radius:2px}

/* contact panel */
.contact-panel{margin-top:46px;background:linear-gradient(180deg,var(--char2),var(--char));
  border:1px solid var(--line-strong);border-radius:6px;padding:30px 32px}
.contact-panel h3{font-family:var(--display);font-weight:600;color:var(--bone);font-size:1.3rem;margin-bottom:8px}
.contact-panel p{font-size:.95rem;color:var(--mute);max-width:70ch;margin-bottom:14px}

/* ===================== BLOG ===================== */
.guide-intro{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:20px;margin-bottom:30px}
.guide-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.article{background:var(--char);border:1px solid var(--line);border-radius:6px;padding:28px;
  display:flex;flex-direction:column;min-height:230px;transition:border-color .25s ease,transform .25s ease}
.article:hover{border-color:var(--line-strong);transform:translateY(-3px)}
.article .a-cat{font-size:.68rem;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:16px}
.article h3{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--bone);line-height:1.18;margin-bottom:12px}
.article h3 a{color:var(--bone)}
.article h3 a:hover{color:var(--brass)}
.article p{font-size:.9rem;color:var(--mute);flex:1}
.article .a-read{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--brass);margin-top:18px}
.article .a-date{font-size:.74rem;color:var(--mute);margin-top:10px;letter-spacing:.06em}

/* post body */
.post{max-width:720px}
.post-meta{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--mute);margin-bottom:20px;
  display:flex;gap:14px;flex-wrap:wrap}
.post-meta .pm-cat{color:var(--gold)}
.post h1{font-family:var(--display);font-weight:900;font-size:clamp(2.1rem,5vw,3.2rem);line-height:1.04;
  letter-spacing:-.01em;color:var(--bone);margin-bottom:22px}
.post-body{margin-top:34px}
.post-body h2{font-size:1.7rem;font-weight:600;margin:42px 0 14px;max-width:none}
.post-body h3{font-family:var(--display);font-weight:600;font-size:1.3rem;color:var(--bone);margin:30px 0 10px}
.post-body p{color:#c4bfb2;margin-bottom:18px}
.post-body ul,.post-body ol{color:#c4bfb2;margin:0 0 18px 22px}
.post-body li{margin-bottom:8px}
.post-body strong{color:var(--bone)}
.post-body blockquote{border-left:3px solid var(--brass);padding:6px 0 6px 20px;margin:24px 0;
  font-family:var(--display);font-style:italic;font-size:1.15rem;color:var(--bone)}
.post-cta{margin-top:48px;background:linear-gradient(180deg,var(--char2),var(--char));
  border:1px solid var(--line-strong);border-radius:6px;padding:26px 28px}
.post-cta h3{font-family:var(--display);font-weight:600;color:var(--bone);font-size:1.2rem;margin-bottom:6px}
.post-cta p{font-size:.94rem;color:var(--mute);margin-bottom:16px}

/* ===================== HOME EXTRAS ===================== */
.maker-tease{margin-top:10px;background:var(--char);border:1px solid var(--line-strong);border-radius:10px;
  display:grid;grid-template-columns:1fr 1fr;overflow:hidden}
.mt-copy{padding:44px 40px;display:flex;flex-direction:column;justify-content:center;align-items:flex-start}
.mt-copy h3{font-family:var(--display);font-weight:900;font-size:2rem;color:var(--bone);line-height:1.05;margin-bottom:14px}
.mt-copy p{color:var(--mute);font-size:.98rem;margin-bottom:24px;max-width:44ch}
.mt-stage{position:relative;min-height:340px;background:radial-gradient(120% 100% at 50% 6%,#23292b 0%,#13171a 72%);
  display:flex;align-items:center;justify-content:center;perspective:1250px;perspective-origin:50% 44%;overflow:hidden}

.backend{margin-top:18px;background:linear-gradient(180deg,var(--char2),var(--char));
  border:1px solid var(--line-strong);border-radius:6px;padding:26px 28px;display:flex;gap:22px;align-items:flex-start;flex-wrap:wrap}
.backend .b-ic{font-family:var(--display);font-weight:900;color:var(--brass);font-size:1.3rem;line-height:1}
.backend h4{font-family:var(--display);font-weight:600;color:var(--bone);font-size:1.2rem;margin-bottom:6px}
.backend p{font-size:.94rem;color:var(--mute);max-width:70ch}
.flow{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.flow span{font-size:.78rem;letter-spacing:.04em;color:var(--gold);border:1px solid var(--line);
  border-radius:2px;padding:6px 11px}
.flow span+span::before{content:"→ ";color:var(--mute);margin-left:-4px}

/* ===================== LEGAL / PLAIN PAGES ===================== */
.plain{max-width:760px}
.plain h1{font-family:var(--display);font-weight:900;font-size:clamp(2rem,4.6vw,2.9rem);color:var(--bone);margin-bottom:8px}
.plain .updated{font-size:.8rem;color:var(--mute);letter-spacing:.08em;text-transform:uppercase;margin-bottom:30px}
.plain h2{font-size:1.45rem;font-weight:600;margin:36px 0 12px;max-width:none}
.plain p,.plain li{color:#c4bfb2;font-size:.97rem}
.plain p{margin-bottom:16px}
.plain ul{margin:0 0 16px 22px}

/* ===================== FOOTER ===================== */
.foot{border-top:1px solid var(--line-strong);background:var(--char);padding:64px 0 50px;margin-top:0}
.foot-grid{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:36px}
.foot-mark img{width:130px;margin-bottom:18px}
.foot-mark p{font-size:.9rem;color:var(--mute);max-width:34ch}
.foot-meta{text-align:right}
.foot-meta .fm-line{font-family:var(--display);font-weight:600;color:var(--bone);font-size:1.05rem;margin-bottom:6px}
.foot-meta .fm-sub{font-size:.82rem;color:var(--mute);letter-spacing:.06em}
.foot-nav{display:flex;gap:4px 18px;flex-wrap:wrap;justify-content:flex-end;margin-top:14px;list-style:none}
.foot-nav a{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:var(--mute)}
.foot-nav a:hover{color:var(--brass)}
.foot-fine{font-size:.78rem;color:var(--mute);letter-spacing:.08em}
.foot-fine b{color:var(--brass);font-weight:600}
.foot-fine+.foot-fine{margin-top:8px}
@media (max-width:880px){.foot-meta{text-align:left}.foot-nav{justify-content:flex-start}}

/* under-construction gate (remove with site.underConstruction flag) */
body.gated > :not(.gate){display:none}
.gate{position:fixed;inset:0;z-index:500;background:
  radial-gradient(78% 115% at 82% 38%, rgba(110,42,35,.28), rgba(110,42,35,.06) 44%, transparent 70%),
  linear-gradient(150deg,#171b1e 0%,#13171a 56%,#15100f 100%);
  display:flex;align-items:center;justify-content:center;padding:24px}
.gate-card{max-width:430px;width:100%;text-align:center;background:var(--char);
  border:1px solid var(--line-strong);border-radius:10px;padding:44px 38px;
  box-shadow:0 24px 60px rgba(0,0,0,.55)}
.gate-card img{margin:0 auto 10px;width:170px;height:auto}
.gate-card h1{font-family:var(--display);font-weight:900;font-size:2rem;color:var(--bone);margin-bottom:10px}
.gate-card p{font-size:.95rem;color:var(--mute);margin-bottom:22px}
.gate-label{display:block;text-align:left;font-size:.7rem;letter-spacing:.24em;
  text-transform:uppercase;color:var(--gold);margin-bottom:8px}
.gate-card input{width:100%;background:#15191b;border:1px solid var(--line);border-radius:4px;
  color:var(--bone);font-family:var(--sans);font-size:1rem;padding:13px 14px;margin-bottom:14px}
.gate-card input:focus{outline:2px solid var(--brass);outline-offset:1px}
.gate-card .btn{width:100%}
.gate-err{color:var(--ox-bright)!important;margin-top:14px;margin-bottom:0!important;font-size:.86rem!important}

/* reveal */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s ease,transform .7s ease}
.reveal.in{opacity:1;transform:none}

/* background lattice texture */
.bg-pattern{position:fixed;inset:0;z-index:-1;pointer-events:none;opacity:.06}
.bg-pattern svg{width:100%;height:100%;display:block}
.bgline{fill:none;stroke:var(--gold);stroke-linecap:round}
.bggap{fill:var(--ink);stroke:none}

@media (max-width:880px){
  .pillars,.guide-grid,.about-strip{grid-template-columns:1fr 1fr}
  .wc-maker,.about-hero,.maker-tease{grid-template-columns:1fr}
  .wc-controls{border-left:none;border-top:1px solid var(--line)}
}
@media (max-width:560px){
  .pillars,.guide-grid,.about-strip{grid-template-columns:1fr}
  .sec{padding:64px 0}
}
@media (prefers-reduced-motion:reduce){
  *{transition:none!important;animation:none!important}
  html{scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}
