/* ═══════════════════════════════════════════════════
   EQUILANCE — base.css
   Shared design system: tokens, primitives, components
   Locked brand: Bebas Neue / Syne / DM Mono
   Acid #C8F135 — TEXT ONLY
═══════════════════════════════════════════════════ */

@import url("https://fonts.googleapis.com/css2?family=Bebas+Neue&family=DM+Mono:ital,wght@0,400;0,500;1,400&family=Syne:wght@400;500;600;700;800&display=swap");

/* ─── TOKENS ─── */
:root{
  --black:#0a0a0a;
  --white:#f5f2eb;
  --acid:#c8f135;
  --border-glow:rgba(255,255,255,0.08);
  --border-dim:rgba(255,255,255,0.05);
  --text-bright:#f5f2eb;
  --text-mid:rgba(245,242,235,0.55);
  --text-dim:rgba(245,242,235,0.28);
  --text-ghost:rgba(245,242,235,0.12);
  --green:#4ade80;
  --red:#e84040;
  --orange:#f97316;
}

/* ─── RESET ─── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{background:var(--black);color:var(--white);font-family:'Syne',sans-serif;min-height:100%;scroll-behavior:smooth;}
body{
  min-height:100vh;
  display:flex;
  flex-direction:column;
  align-items:center;
  position:relative;
  overflow-x:hidden;
  font-family:'Syne',sans-serif;
  font-size:16px;
  line-height:1.6;
  color:var(--white);
  background:var(--black);
}

/* ─── NOISE TEXTURE ─── */
body::before{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.038'/%3E%3C/svg%3E");
  background-size:180px 180px;
}

/* ─── GLOW FIELD ─── */
.glow-field{position:fixed;inset:0;z-index:0;pointer-events:none;}
.glow-field::before{
  content:'';position:absolute;width:900px;height:700px;top:-280px;left:50%;transform:translateX(-50%);
  background:radial-gradient(ellipse at center,rgba(255,255,255,0.07) 0%,rgba(255,255,255,0.02) 38%,transparent 68%);
  filter:blur(35px);animation:breathe 14s ease-in-out infinite alternate;
}
@keyframes breathe{
  0%{opacity:0.6;transform:translateX(-50%) scale(1);}
  100%{opacity:1;transform:translateX(-50%) scale(1.08);}
}

/* ─── PAGE CONTAINERS ─── */
.page{position:relative;z-index:1;width:100%;padding:64px 20px 80px;display:flex;flex-direction:column;align-items:center;}
.page--narrow{max-width:520px;}
.page--prose{max-width:760px;}
.page--wide{max-width:1040px;}
.page--full{max-width:100%;}
.page--center{text-align:center;justify-content:center;min-height:100vh;padding:40px 20px 60px;}

/* ─── BACK LINK ─── */
.back-link{width:100%;margin-bottom:40px;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.22em;color:var(--text-ghost);text-transform:uppercase;text-decoration:none;display:flex;align-items:center;gap:8px;transition:color 0.2s;animation:fadeUp 0.4s ease both;}
.back-link:hover{color:var(--text-mid);}
.back-link::before{content:'←';font-size:12px;}

/* ─── BRAND MARK ─── */
/* Slash atom — tall dim + short bright, horizontal lockup with wordmark */
.logo-mark{display:inline-flex;align-items:center;gap:var(--mark-gap,6px);}
.logo-mark .s{display:block;transform:skewX(-12deg);transform-origin:center;flex-shrink:0;}
.logo-mark .s-tall{width:var(--mark-w,5px);height:var(--mark-tall,58px);background:rgba(200,241,53,0.28);}
.logo-mark .s-short{width:var(--mark-w,5px);height:var(--mark-short,37px);background:var(--acid);}

.logo-lockup{display:inline-flex;align-items:center;gap:14px;}
.logo-lockup .wordmark{font-family:'Bebas Neue',sans-serif;color:var(--text-bright);letter-spacing:0.12em;line-height:1;}
.logo-lockup .wordmark .a{color:var(--acid);}
.logo-lockup--xs{--mark-tall:20px;--mark-short:13px;--mark-w:2px;--mark-gap:3px;gap:8px;}
.logo-lockup--xs .wordmark{font-size:14px;letter-spacing:0.22em;}
.logo-lockup--sm{--mark-tall:30px;--mark-short:20px;--mark-w:3px;--mark-gap:4px;gap:10px;}
.logo-lockup--sm .wordmark{font-size:20px;letter-spacing:0.22em;}
.logo-lockup--md{--mark-tall:44px;--mark-short:28px;--mark-w:4px;--mark-gap:5px;gap:12px;}
.logo-lockup--md .wordmark{font-size:30px;letter-spacing:0.22em;}
.logo-lockup--lg{--mark-tall:58px;--mark-short:37px;--mark-w:5px;--mark-gap:6px;gap:14px;}
.logo-lockup--lg .wordmark{font-size:40px;letter-spacing:0.22em;}

/* BRAND BLOCK — centered horizontal lockup at page top */
.brand-block{display:flex;justify-content:center;margin-bottom:40px;animation:fadeUp 0.45s ease both;}

/* DARK-ON-LIGHT OVERRIDE */
.on-light .logo-mark .s-tall{background:rgba(0,0,0,0.18);}
.on-light .logo-mark .s-short{background:var(--black);}
.on-light .wordmark{color:var(--black);}

/* ─── NAV (for top-of-page nav bar) ─── */
.nav-top{position:fixed;top:0;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:18px 28px;background:rgba(10,10,10,0.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--border-dim);}
.nav-logo{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:0.22em;color:var(--text-bright);text-decoration:none;}
.nav-logo .a{color:var(--acid);}
.nav-cta{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;color:var(--acid);background:rgba(200,241,53,0.10);border:1px solid rgba(200,241,53,0.30);padding:10px 18px;border-radius:8px;text-decoration:none;transition:background 0.2s,transform 0.15s;}
.nav-cta:hover{background:rgba(200,241,53,0.16);transform:translateY(-1px);}

/* ─── SECTION LABEL + DIVIDERS ─── */
.ombre-line{width:100%;height:1px;margin:24px 0;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.10) 50%,transparent);}
.sec-lbl{width:100%;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.24em;color:var(--acid);opacity:0.45;text-transform:uppercase;margin:0 0 12px;display:flex;align-items:center;gap:10px;}
.sec-lbl::after{content:'';flex:1;height:1px;background:var(--border-dim);}
.eyebrow{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.22em;color:var(--acid);text-transform:uppercase;opacity:0.7;}

/* ─── HEADINGS ─── */
.page-headline{width:100%;font-family:'Bebas Neue',sans-serif;font-size:clamp(32px,5.5vw,48px);letter-spacing:2px;line-height:1.05;color:var(--text-bright);margin-bottom:12px;animation:fadeUp 0.5s 0.05s ease both;}
.page-headline .accent{color:var(--acid);}
.page-subhead{width:100%;font-family:'Syne',sans-serif;font-size:13px;font-weight:400;color:var(--text-dim);line-height:1.75;margin-bottom:28px;animation:fadeUp 0.5s 0.1s ease both;}

/* ─── GLASS CARD ─── */
.card{width:100%;background:rgba(255,255,255,0.025);border:1px solid var(--border-glow);border-radius:10px;overflow:hidden;animation:fadeUp 0.5s ease both;position:relative;margin-bottom:16px;}
.card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.12) 50%,transparent);pointer-events:none;z-index:2;}
.card-inner{padding:24px 20px;}
.card-eyebrow{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.22em;color:var(--acid);text-transform:uppercase;margin-bottom:14px;opacity:0.7;}

/* ─── PROSE (legal/article body text) ─── */
.prose{width:100%;font-family:'Syne',sans-serif;font-size:14px;color:var(--text-mid);line-height:1.85;}
.prose h1{font-family:'Bebas Neue',sans-serif;font-size:clamp(32px,5vw,44px);letter-spacing:1.5px;color:var(--text-bright);margin:0 0 6px;line-height:1.05;}
.prose h2{font-family:'Bebas Neue',sans-serif;font-size:22px;letter-spacing:1px;color:var(--text-bright);margin:40px 0 14px;padding-top:24px;border-top:1px solid var(--border-dim);}
.prose h2:first-child{border-top:none;padding-top:0;margin-top:0;}
.prose h3{font-family:'Syne',sans-serif;font-size:15px;font-weight:700;color:var(--text-bright);margin:28px 0 10px;letter-spacing:0.02em;}
.prose p{font-size:14px;color:var(--text-mid);line-height:1.85;margin-bottom:14px;}
.prose a{color:var(--acid);text-decoration:none;opacity:0.9;border-bottom:1px solid rgba(200,241,53,0.25);transition:opacity 0.2s,border-color 0.2s;}
.prose a:hover{opacity:1;border-bottom-color:rgba(200,241,53,0.55);}
.prose strong{color:var(--text-bright);font-weight:700;}
.prose em{color:var(--text-bright);font-style:italic;}
.prose ul,.prose ol{list-style:none;padding:0;margin:0 0 16px;}
.prose ul li,.prose ol li{padding-left:22px;position:relative;margin-bottom:8px;font-size:14px;color:var(--text-mid);line-height:1.85;}
.prose ul li::before{content:'';position:absolute;left:2px;top:14px;width:6px;height:6px;background:var(--acid);border-radius:50%;opacity:0.7;}
.prose ol{counter-reset:prose-ol;}
.prose ol li{counter-increment:prose-ol;}
.prose ol li::before{content:counter(prose-ol) '.';position:absolute;left:0;top:0;font-family:'DM Mono',monospace;font-size:12px;color:var(--acid);opacity:0.7;}
.prose blockquote{border-left:2px solid rgba(200,241,53,0.25);padding:4px 0 4px 18px;margin:20px 0;color:var(--text-bright);font-style:italic;}
.callout{background:rgba(255,255,255,0.025);border:1px solid var(--border-glow);border-left:3px solid rgba(200,241,53,0.55);border-radius:0 10px 10px 0;padding:18px 20px;margin:24px 0;font-family:'Syne',sans-serif;font-size:13px;color:var(--text-mid);line-height:1.75;position:relative;}
.callout strong{color:var(--text-bright);}
.prose hr{border:none;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.10) 50%,transparent);margin:32px 0;}
.prose code{font-family:'DM Mono',monospace;font-size:12px;background:rgba(255,255,255,0.05);padding:2px 6px;border-radius:4px;color:var(--acid);}
.doc-meta{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.14em;color:var(--text-dim);text-transform:uppercase;margin-bottom:32px;}

/* ─── FORM PRIMITIVES ─── */
.q-input,.q-select,.q-textarea{width:100%;background:rgba(255,255,255,0.03);border:1px solid rgba(255,255,255,0.08);border-radius:8px;padding:12px 14px;color:var(--white);font-family:'Syne',sans-serif;font-size:14px;font-weight:400;outline:none;-webkit-appearance:none;transition:border-color 0.2s;margin-bottom:8px;}
.q-input:focus,.q-select:focus,.q-textarea:focus{border-color:rgba(255,255,255,0.20);}
.q-input::placeholder,.q-textarea::placeholder{color:rgba(255,255,255,0.16);}
.q-input.error,.q-select.error,.q-textarea.error{border-color:rgba(232,64,64,0.45);}
.q-textarea{min-height:120px;resize:vertical;font-family:'Syne',sans-serif;}
.q-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'><path fill='%23f5f2eb' opacity='0.28' d='M0 0l5 6 5-6z'/></svg>");background-repeat:no-repeat;background-position:right 14px center;padding-right:38px;}
.q-select option{background:#0a0a0a;color:var(--white);}

.field-label{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.16em;color:var(--text-dim);text-transform:uppercase;margin-bottom:6px;display:block;}
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:8px;}
.grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:8px;margin-bottom:8px;}
.grid-2 .q-input,.grid-3 .q-input{margin-bottom:0;}

/* ─── BUTTONS ─── */
.btn-primary{display:inline-block;width:100%;background:rgba(200,241,53,0.10);border:1px solid rgba(200,241,53,0.30);color:var(--acid);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.22em;text-transform:uppercase;padding:16px;border-radius:8px;cursor:pointer;transition:background 0.2s,transform 0.15s;text-decoration:none;text-align:center;}
.btn-primary:hover:not(:disabled){background:rgba(200,241,53,0.16);transform:translateY(-1px);}
.btn-primary:disabled{opacity:0.35;cursor:not-allowed;transform:none;}
.btn-primary--inline{width:auto;padding:14px 24px;}
.btn-back{display:inline-block;background:transparent;border:1px solid rgba(255,255,255,0.08);border-radius:8px;color:var(--text-dim);font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;padding:14px 16px;cursor:pointer;transition:border-color 0.2s,color 0.2s;text-decoration:none;}
.btn-back:hover{border-color:rgba(255,255,255,0.16);color:var(--text-mid);}
.btn-ghost{display:inline-block;font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.18em;color:var(--text-dim);text-transform:uppercase;text-decoration:none;padding:8px 0;transition:color 0.2s;}
.btn-ghost:hover{color:var(--text-bright);}

/* ─── LINK CARD (icon + text + chevron) ─── */
.link-card{width:100%;padding:15px 20px;background:rgba(255,255,255,0.025);border:1px solid var(--border-glow);border-radius:10px;display:flex;align-items:center;gap:15px;cursor:pointer;text-decoration:none;color:inherit;position:relative;overflow:hidden;transition:background 0.2s,border-color 0.2s,transform 0.18s;margin-bottom:12px;}
.link-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,0.10) 50%,transparent);pointer-events:none;}
.link-card:hover{background:rgba(255,255,255,0.045);border-color:rgba(255,255,255,0.14);transform:translateY(-1px);}
.link-ico{width:36px;height:36px;border-radius:8px;flex-shrink:0;background:rgba(255,255,255,0.04);border:1px solid var(--border-dim);display:flex;align-items:center;justify-content:center;position:relative;z-index:1;}
.link-ico svg{width:16px;height:16px;stroke:rgba(245,242,235,0.45);fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
.link-text{flex:1;position:relative;z-index:1;}
.link-title{font-family:'Syne',sans-serif;font-size:13px;font-weight:700;color:var(--text-bright);letter-spacing:0.02em;}
.link-sub{font-family:'DM Mono',monospace;font-size:9px;color:var(--text-dim);letter-spacing:0.10em;margin-top:3px;text-transform:uppercase;}

/* ─── FOOTER (legacy thin variant, kept for back-compat) ─── */
.page-footer{width:100%;margin-top:48px;font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.16em;color:var(--text-ghost);text-transform:uppercase;text-align:center;line-height:2.2;animation:fadeUp 0.5s 0.35s ease both;}
.page-footer a{color:inherit;text-decoration:none;opacity:0.6;transition:opacity 0.2s;}
.page-footer a:hover{opacity:1;}
.footer-links{display:flex;gap:14px;justify-content:center;flex-wrap:wrap;margin-top:6px;list-style:none;}
.footer-links a{font-family:'DM Mono',monospace;font-size:8px;letter-spacing:0.14em;color:var(--text-ghost);text-decoration:none;text-transform:uppercase;}

/* ─── SITE FOOTER (rich, full-width, used sitewide) ─── */
.site-footer{width:100%;padding:56px 28px 32px;border-top:1px solid var(--border-dim);background:rgba(0,0,0,0.4);position:relative;z-index:1;}
.site-footer .footer-inner{max-width:1100px;margin:0 auto;}
.site-footer .footer-top{display:grid;grid-template-columns:1.2fr 0.9fr 0.9fr 0.9fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--border-dim);text-align:left;}
.site-footer .footer-contact{font-family:'Syne',sans-serif;font-size:12px;color:var(--text-mid);line-height:1.8;text-transform:none;letter-spacing:0;}
.site-footer .footer-contact a{color:var(--acid);text-decoration:none;opacity:0.85;}
.site-footer .footer-contact a:hover{opacity:1;}
.site-footer .footer-col-label{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.2em;text-transform:uppercase;color:var(--acid);opacity:0.7;margin-bottom:16px;}
.site-footer .footer-col a{display:block;font-family:'Syne',sans-serif;font-size:12px;color:var(--text-mid);text-decoration:none;margin-bottom:10px;transition:color 0.2s;text-transform:none;letter-spacing:0;opacity:1;}
.site-footer .footer-col a:hover{color:var(--text-bright);}
.site-footer .footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;gap:16px;flex-wrap:wrap;}
.site-footer .footer-copy{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.12em;color:var(--text-ghost);text-transform:uppercase;}
.site-footer .footer-legal{display:flex;gap:16px;list-style:none;flex-wrap:wrap;}
.site-footer .footer-legal a{font-family:'DM Mono',monospace;font-size:9px;letter-spacing:0.12em;text-transform:uppercase;color:var(--text-ghost);text-decoration:none;transition:color 0.2s;}
.site-footer .footer-legal a:hover{color:var(--acid);}

@media (max-width: 960px){
  .site-footer .footer-top{grid-template-columns:1fr 1fr;gap:28px;}
}
@media (max-width: 640px){
  .site-footer{padding:40px 20px 24px;}
  .site-footer .footer-top{grid-template-columns:1fr;gap:24px;}
  .site-footer .footer-bottom{flex-direction:column;align-items:flex-start;}
}

/* ─── ANIMATIONS ─── */
@keyframes fadeUp{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:translateY(0);}}
@keyframes spin{to{transform:rotate(360deg);}}
@keyframes pulse{0%,100%{opacity:0.4;}50%{opacity:1;}}

/* ─── RESPONSIVE ─── */
@media (max-width: 640px){
  .page{padding:48px 16px 60px;}
  .nav-top{padding:14px 18px;}
  .card-inner{padding:20px 16px;}
  .page-headline{font-size:clamp(28px,8vw,40px);}
  .grid-2{grid-template-columns:1fr;}
  .grid-3{grid-template-columns:1fr 1fr 1fr;gap:6px;}
}
