/* ====== FIVRA · SHARED STYLES ====== */
:root{
  --canvas:#F4F0EA;
  --paper:#FBF8F3;
  --surface:#FFFFFF;
  --ink:#1F2430;
  --hair:#E4DDD2;
  --hair-strong:#C8BFA9;
  --muted:#6E685E;
  --accent:#B0532E;
  --accent-soft:#C8693F;
  --accent-bright:#E07A47;
  --ok:#16A34A;
  --warn:#B5742B;
  --danger:#DC2626;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;background:var(--canvas);color:var(--ink);
  font-family:'Outfit',system-ui,sans-serif;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}

.display{letter-spacing:-0.035em;line-height:1.0;font-weight:600;font-family:'Outfit',system-ui,sans-serif}
.balance{text-wrap:balance}
.eyebrow{font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);font-weight:600}
.eyebrow-muted{color:var(--muted)}
.serif-it{font-family:'Fraunces',serif;font-style:italic;font-weight:400;letter-spacing:-.01em}
.mono{font-family:ui-monospace,monospace;font-feature-settings:'tnum' 1}

.hair-t{border-top:1px solid var(--hair)}
.hair-b{border-bottom:1px solid var(--hair)}
.hair-l{border-left:1px solid var(--hair)}

.btn{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;transition:all .25s ease;white-space:nowrap;text-decoration:none}
.btn-solid{background:var(--ink);color:#fff;padding:.7rem 1.3rem;border-radius:3px}
.btn-solid:hover{background:#2a2a2a;transform:translateY(-1px)}
.btn-solid.is-accent{background:var(--accent)}
.btn-solid.is-accent:hover{background:#99441f;box-shadow:0 14px 30px -12px rgba(176,83,46,.65)}
.btn-ghost{color:var(--ink);padding:.7rem 0;font-weight:500}
.btn-ghost:hover{color:var(--accent);gap:.8rem}
.btn-ghost svg{transition:transform .25s ease}
.btn-ghost:hover svg{transform:translateX(4px)}
.btn-line{display:inline-flex;align-items:center;gap:.5rem;font-weight:500;padding:.65rem 1.1rem;border:1px solid var(--ink);border-radius:3px;color:var(--ink);transition:.2s;text-decoration:none}
.btn-line:hover{background:rgba(31,36,48,.04)}
a:focus-visible,button:focus-visible,summary:focus-visible{outline:2px solid var(--accent);outline-offset:3px;border-radius:6px}

.card{background:#fff;border:1px solid var(--hair);border-radius:16px}
.shadow-soft{box-shadow:0 30px 70px -34px rgba(31,36,48,.28)}
.grain-tile{background:linear-gradient(180deg,#fff,#FBF8F3)}

/* ===== Nav ===== */
.nav-scrolled{background:rgba(244,240,234,.82);backdrop-filter:blur(14px);border-bottom:1px solid var(--hair)}
.nav-wrap{position:fixed;top:0;inset-inline:0;z-index:50;transition:all .3s}
.nav-inner{max-width:1280px;margin:0 auto;padding:0 24px;height:68px;display:flex;align-items:center;justify-content:space-between}
.brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none}
.brand-mark{display:inline-grid;place-items:center;width:28px;height:28px;background:transparent;color:var(--accent);border-radius:0}
.brand-mark img{width:24px;height:24px}
.brand-text{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--accent)}
.nav-links{display:none;gap:32px;font-size:.93rem}
.nav-links a{color:var(--ink);opacity:.8;text-decoration:none;transition:all .2s;position:relative}
.nav-links a:hover{color:var(--accent);opacity:1}
.nav-links a.active{color:var(--accent);opacity:1}
.nav-cta{display:flex;align-items:center;gap:8px}
.loginlink{display:none;font-size:.93rem;color:var(--ink);opacity:.8;text-decoration:none;padding:0 8px}
.loginlink:hover{color:var(--accent);opacity:1}
@media (min-width:768px){
  .nav-links{display:flex}
  .loginlink{display:inline}
}
.nav-toggle{display:grid;place-items:center;width:36px;height:36px;background:transparent;border:0;color:var(--ink);cursor:pointer}
@media (min-width:768px){.nav-toggle{display:none}}
.mobile-nav{display:none;padding:8px 24px 20px;background:#fff;border-bottom:1px solid var(--hair)}
.mobile-nav.open{display:block}
.mobile-nav a{display:block;padding:10px 0;border-bottom:1px solid var(--hair);font-size:1rem;color:var(--ink);text-decoration:none}
.mobile-nav a:last-child{border-bottom:0}
.mobile-nav a:hover{color:var(--accent)}

/* ===== Mega-menu (Adaptive-style flyout) ===== */
.nav-item{position:relative}
/* Extend the hover area downward to bridge the visual gap between the link
   and the mega-menu — without this, moving the cursor toward the menu
   passes through dead space and the menu closes. */
.nav-item.has-mega{padding-bottom:28px;margin-bottom:-28px}
.nav-item.has-mega > a{display:inline-flex;align-items:center;gap:5px}
.nav-item.has-mega > a .chev{width:10px;height:6px;transition:transform .2s ease;opacity:.6}
.nav-item.has-mega:hover > a{color:var(--accent);opacity:1}
.nav-item.has-mega:hover > a .chev{transform:rotate(180deg)}
.nav-item.has-mega > a::after{content:none}

.mega-menu{
  position:fixed;
  left:0;right:0;top:68px;
  background:#fff;
  border-top:1px solid var(--hair);
  border-bottom:1px solid var(--hair);
  box-shadow:0 30px 80px -30px rgba(31,36,48,.18);
  padding:44px 24px 48px;
  opacity:0;visibility:hidden;
  transform:translateY(-6px);
  transition:opacity .18s ease, transform .18s ease, visibility .18s;
  z-index:40;
  pointer-events:none;
}
.nav-item.has-mega:hover .mega-menu,
.mega-menu:hover{
  opacity:1;visibility:visible;
  transform:translateY(0);
  pointer-events:auto;
}
.mega-grid{
  max-width:1280px;margin:0 auto;
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:48px;
}
.mega-grid.is-two{grid-template-columns:1.5fr 1fr;gap:80px}
.mega-col{display:flex;flex-direction:column;gap:10px}
.mega-col-header{font-family:'Outfit',sans-serif;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:6px}
.mega-lead{display:flex;gap:14px;align-items:flex-start;text-decoration:none;color:var(--ink);padding:10px 12px;border-radius:8px;transition:background .15s ease;margin-left:-12px}
.mega-lead:hover{background:rgba(176,83,46,.06)}
.mega-lead .ic{width:36px;height:36px;border-radius:8px;background:var(--canvas);display:grid;place-items:center;color:var(--ink);flex-shrink:0}
.mega-lead:hover .ic{background:var(--accent);color:#fff}
.mega-lead-text{display:flex;flex-direction:column;gap:3px;min-width:0}
.mega-lead-title{font-weight:600;font-size:.95rem;letter-spacing:-.01em;line-height:1.2}
.mega-lead-desc{font-size:.82rem;color:rgba(31,36,48,.6);line-height:1.4}

.mega-sub{display:flex;align-items:center;gap:10px;padding:8px 12px;border-radius:6px;text-decoration:none;color:var(--ink);font-size:.93rem;transition:all .15s ease;margin-left:-12px;font-weight:400}
.mega-sub:hover{background:rgba(176,83,46,.06);color:var(--accent)}
.mega-sub .ic{width:18px;height:18px;color:rgba(31,36,48,.5);flex-shrink:0}
.mega-sub:hover .ic{color:var(--accent)}
.mega-sub .pill{display:inline-block;margin-left:6px;padding:2px 8px;border-radius:99px;background:rgba(224,122,71,.15);color:var(--accent);font-family:'Outfit',sans-serif;font-size:9.5px;font-weight:600;letter-spacing:.08em}

.mega-solo{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;text-decoration:none;color:var(--ink);margin-left:-12px;transition:background .15s ease}
.mega-solo:hover{background:rgba(176,83,46,.06)}
.mega-solo .ic{width:18px;height:18px;color:var(--muted);flex-shrink:0}
.mega-solo:hover .ic{color:var(--accent)}
.mega-solo-text{display:flex;flex-direction:column;gap:2px;min-width:0}
.mega-solo-title{font-weight:500;font-size:.95rem;line-height:1.2}
.mega-solo-desc{font-size:.78rem;color:rgba(31,36,48,.55);line-height:1.3}

@media (max-width:1024px){
  .mega-menu{display:none}
}

/* ===== Page header (subpage hero) ===== */
.page-header{position:relative;padding:128px 24px 60px;background:var(--canvas);overflow:hidden;isolation:isolate}
.page-header::before{content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse 80% 90% at 95% 0%, rgba(247,206,168,.55), transparent 55%),
             radial-gradient(ellipse 50% 60% at 75% 40%, rgba(224,122,71,.10), transparent 60%);
  pointer-events:none;z-index:1}
.page-header-inner{position:relative;z-index:2;max-width:1180px;margin:0 auto}
.crumb{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  font-weight:600;color:var(--muted);display:inline-flex;align-items:center;gap:8px;margin-bottom:24px}
.crumb a{color:var(--muted);text-decoration:none}
.crumb a:hover{color:var(--accent)}
.crumb .sep{opacity:.5}
.page-title{font-family:'Outfit',sans-serif;font-weight:600;letter-spacing:-.03em;line-height:1;
  font-size:clamp(2.4rem,5vw,4rem);color:var(--ink);margin:0;text-wrap:balance}
.page-title .it{color:var(--accent);font-style:italic;font-family:'Fraunces',serif;font-weight:500;letter-spacing:-.01em}
.page-sub{margin:22px 0 0;max-width:54ch;font-size:clamp(1rem,1.1vw,1.12rem);line-height:1.6;color:rgba(31,36,48,.7)}
.page-ctas{margin-top:30px;display:flex;gap:18px;align-items:center;flex-wrap:wrap}

/* ===== Sections ===== */
.section{padding:80px 24px}
.section-inner{max-width:1180px;margin:0 auto}
.section-eyebrow{font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--accent);font-weight:700;margin-bottom:20px;display:inline-block}
.section-title{font-family:'Outfit',sans-serif;font-weight:600;letter-spacing:-.03em;line-height:1.05;
  font-size:clamp(2rem,3.6vw,2.8rem);color:var(--ink);margin:0;text-wrap:balance}
.section-sub{margin:18px 0 0;font-size:1.04rem;line-height:1.6;color:rgba(31,36,48,.7);max-width:50ch}

.frame{border-radius:18px;overflow:hidden;border:1px solid var(--hair);background:#fff}
.frame-bar{display:flex;align-items:center;gap:.6rem;padding:.8rem 1rem;border-bottom:1px solid var(--hair);background:linear-gradient(180deg,#fff,#FBF8F3)}
.dot{width:10px;height:10px;border-radius:50%}

/* ===== Marquee ===== */
@keyframes drift{from{transform:translateX(0)}to{transform:translateX(-50%)}}
.marquee{display:flex;width:max-content;animation:drift 40s linear infinite}

/* ===== Footer (full-width white, animated) ===== */
.footer{
  position:relative;
  background:#fff;
  border-top:1px solid var(--hair);
  margin:80px 0 0;
  padding:80px 40px 40px;
  isolation:isolate;
}
/* subtle rust top-edge highlight */
.footer::before{
  content:'';
  position:absolute;
  top:0;left:50%;
  width:240px;height:1px;
  transform:translate(-50%,-50%);
  background:linear-gradient(90deg,transparent,var(--accent),transparent);
  filter:blur(2px);
  opacity:.6;
  border-radius:99px;
  pointer-events:none;
}
.footer::after{
  content:'';
  position:absolute;
  inset:0 0 auto 0;
  height:200px;
  background:radial-gradient(30% 160px at 50% 0%, rgba(176,83,46,.05), transparent 70%);
  pointer-events:none;
  z-index:-1;
}
.footer-grid{display:grid;grid-template-columns:1.5fr repeat(3,1fr);gap:64px;max-width:1280px;margin:0 auto;padding:0 8px}
@media (max-width:768px){.footer-grid{grid-template-columns:1fr 1fr;gap:40px}}
.footer-col{opacity:0;transform:translateY(-8px);filter:blur(4px);transition:opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1), filter .8s ease}
.footer.is-in .footer-col{opacity:1;transform:translateY(0);filter:blur(0)}
.footer.is-in .footer-col:nth-child(2){transition-delay:.10s}
.footer.is-in .footer-col:nth-child(3){transition-delay:.20s}
.footer.is-in .footer-col:nth-child(4){transition-delay:.30s}
.footer-col h6{font-family:'Outfit',sans-serif;font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:0 0 16px;font-weight:700}
.footer-col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.footer-col a{color:rgba(31,36,48,.72);text-decoration:none;font-size:.93rem;display:inline-flex;align-items:center;transition:color .25s ease,padding-left .25s ease}
.footer-col a:hover{color:var(--ink);padding-left:2px}
.footer-bottom{max-width:1280px;margin:64px auto 0;padding:24px 8px 0;border-top:1px solid var(--hair);
  display:flex;justify-content:space-between;align-items:center;font-size:.82rem;color:var(--muted);flex-wrap:wrap;gap:8px}
@media (max-width:768px){.footer{margin-top:60px;padding:60px 24px 32px}}
@media (prefers-reduced-motion:reduce){
  .footer-col{opacity:1;transform:none;filter:none;transition:none}
}

/* ===== CTA section · split card with checklist + animated button ===== */
.cta-band{padding:80px 24px;background:var(--canvas)}
.cta-card{max-width:1180px;margin:0 auto;background:#EAE3D7;border-radius:18px;padding:64px 80px;
  display:flex;justify-content:space-between;gap:48px;align-items:center;flex-wrap:wrap;position:relative;overflow:hidden}
@media (max-width:900px){.cta-card{padding:40px 32px;gap:32px;flex-direction:column;align-items:flex-start}}
.cta-left{flex:1 1 480px;max-width:560px}
.cta-left h2{font-family:'Outfit',sans-serif;font-weight:600;letter-spacing:-.025em;line-height:1.1;font-size:clamp(1.8rem,3.2vw,2.4rem);color:var(--ink);margin:0;text-wrap:balance}
.cta-left h2 .it{font-family:'Fraunces',serif;font-style:italic;font-weight:500;color:var(--accent);letter-spacing:-.01em}
.cta-left p{margin:14px 0 0;color:rgba(31,36,48,.65);font-size:1rem;line-height:1.6;max-width:46ch}
.cta-right{flex:0 1 280px;min-width:240px}
.cta-checklist{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:14px}
.cta-checklist li{display:flex;align-items:center;gap:14px;font-family:'Outfit',sans-serif;font-size:.92rem;font-weight:500;color:var(--ink);line-height:1.4}
.cta-checklist .ck{flex-shrink:0;width:18px;height:18px;display:grid;place-items:center;border-radius:50%;background:rgba(176,83,46,.15);color:var(--accent)}
.cta-checklist .ck svg{width:11px;height:11px;stroke-width:2.6}

/* Animated Get Started button (text slides, chevron square expands on hover) */
.cta-btn{position:relative;overflow:hidden;display:inline-flex;align-items:center;background:var(--accent);color:#fff;padding:0 22px;height:50px;border-radius:9px;font-family:'Outfit',sans-serif;font-weight:600;font-size:1rem;letter-spacing:-.005em;text-decoration:none;cursor:pointer;margin-top:28px;box-shadow:0 6px 18px -6px rgba(176,83,46,.55);transition:transform .2s ease,box-shadow .2s ease;border:0;min-width:200px}
.cta-btn:hover{transform:translateY(-1px);box-shadow:0 10px 24px -6px rgba(176,83,46,.65)}
.cta-btn:active{transform:translateY(0)}
.cta-btn-label{margin-right:64px;transition:opacity .45s ease;position:relative;z-index:1}
.cta-btn:hover .cta-btn-label{opacity:0}
.cta-btn-icon{position:absolute;right:4px;top:4px;bottom:4px;width:42px;display:grid;place-items:center;background:rgba(255,255,255,.18);border-radius:6px;z-index:10;transition:width .45s cubic-bezier(.4,0,.2,1),transform .15s ease;color:#fff}
.cta-btn:hover .cta-btn-icon{width:calc(100% - 8px)}
.cta-btn:active .cta-btn-icon{transform:scale(.96)}
.cta-btn-icon svg{width:18px;height:18px;stroke:currentColor;stroke-width:2.2;fill:none;stroke-linecap:round;stroke-linejoin:round}

.cta-secondary{display:inline-flex;align-items:center;gap:8px;margin-left:14px;font-family:'Outfit',sans-serif;font-size:.95rem;font-weight:500;color:var(--ink);text-decoration:none;height:50px;padding:0 14px}
.cta-secondary:hover{color:var(--accent)}
.cta-secondary svg{width:14px;height:14px;transition:transform .2s ease}
.cta-secondary:hover svg{transform:translateX(3px)}

/* ===== Reveal ===== */
.reveal{opacity:0;transform:translateY(20px)}

/* ===== Shared section patterns ===== */
/* FAQ accordion (plain — kept for compatibility) */
details.faq{border-bottom:1px solid var(--hair);padding:0}
details.faq:last-child{border-bottom:0}
details.faq summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-weight:600;font-size:1.05rem;color:var(--ink)}
details.faq summary::-webkit-details-marker{display:none}
.faq-icon{transition:transform .25s ease;color:var(--accent);font-size:1.3rem;flex-shrink:0;margin-left:16px;line-height:1}
details.faq[open] .faq-icon{transform:rotate(45deg)}
details.faq p{margin:0 0 22px;color:rgba(31,36,48,.7);font-size:.97rem;line-height:1.6;max-width:60ch}

/* ===== FAQ with preview (Feature197 pattern) ===== */
.faq-feature{max-width:1280px;margin:0 auto;padding:0 32px;display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:start}
@media (max-width:1024px){.faq-feature{grid-template-columns:1fr;gap:32px}}
.faq-feature .faq-accordion{display:flex;flex-direction:column}
.faq-feature details.faq-item{border-bottom:1px solid var(--hair);padding:0;transition:opacity .25s ease}
.faq-feature details.faq-item:last-child{border-bottom:0}
.faq-feature details.faq-item summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;padding:22px 0;font-weight:600;font-size:1.05rem;color:rgba(31,36,48,.55);transition:color .25s ease}
.faq-feature details.faq-item summary::-webkit-details-marker{display:none}
.faq-feature details.faq-item[open] summary{color:var(--ink)}
.faq-feature details.faq-item:not([open]) summary:hover{color:var(--ink)}
.faq-feature details.faq-item .faq-icon{transition:transform .3s cubic-bezier(.2,.7,.2,1);color:var(--accent);font-size:1.4rem;flex-shrink:0;margin-left:16px;line-height:1;font-weight:300}
.faq-feature details.faq-item[open] .faq-icon{transform:rotate(45deg)}
.faq-feature details.faq-item p{margin:0 0 22px;color:rgba(31,36,48,.7);font-size:.96rem;line-height:1.6;max-width:54ch}
.faq-feature details.faq-item p code{font-family:monospace;font-size:.85em;background:rgba(176,83,46,.08);color:var(--accent);padding:1px 6px;border-radius:3px}

/* Right-side preview panel — shows the active question's title + expanded answer text */
.faq-preview{position:sticky;top:120px;background:transparent;min-height:280px;padding:0;align-self:flex-start;display:block}
@media (max-width:1024px){.faq-preview{display:none}}
.faq-preview-item{position:absolute;inset:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:8px 0 0;opacity:0;transform:translateY(8px);transition:opacity .35s ease, transform .35s cubic-bezier(.2,.7,.2,1);pointer-events:none}
.faq-preview-item.is-active{opacity:1;transform:translateY(0);pointer-events:auto}

/* The expanded answer typography on the right panel */
.faq-answer-h{font-family:'Outfit',sans-serif;font-weight:600;letter-spacing:-.025em;line-height:1.15;
  font-size:clamp(1.6rem,2.6vw,2.4rem);color:var(--ink);margin:0 0 28px;max-width:18ch;text-wrap:balance}
.faq-answer-body{font-size:clamp(1.02rem,1.1vw,1.15rem);line-height:1.65;color:rgba(31,36,48,.78);max-width:48ch}
.faq-answer-body code{font-family:monospace;font-size:.85em;background:rgba(176,83,46,.08);color:var(--accent);padding:2px 8px;border-radius:4px}

/* Hide inline accordion answer text on desktop — it's shown in the right panel instead.
   On mobile, the right panel hides and the inline answer is the source of truth. */
@media (min-width:1025px){
  .faq-feature details.faq-item p{display:none}
  .faq-feature details.faq-item summary{padding:18px 0}
}

/* Preview building blocks */
.fp-card{width:100%;max-width:340px;background:var(--canvas);border:1px solid var(--hair);border-radius:12px;padding:22px;display:flex;flex-direction:column;gap:14px}
.fp-card.is-dark{background:#1a1816;border-color:rgba(255,255,255,.08);color:#F4F0EA}
.fp-icon{width:44px;height:44px;border-radius:10px;background:rgba(176,83,46,.1);color:var(--accent);display:grid;place-items:center}
.fp-icon svg{width:22px;height:22px}
.fp-label{font-family:'Outfit',sans-serif;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);font-weight:700}
.fp-stat{font-family:'Outfit',sans-serif;font-weight:700;font-size:2rem;letter-spacing:-.02em;color:var(--ink);line-height:1}
.fp-row{display:flex;justify-content:space-between;align-items:center;font-family:monospace;font-size:.88rem;padding:7px 0;border-bottom:1px dashed rgba(31,36,48,.12)}
.fp-row:last-child{border-bottom:0}
.fp-row .v{color:var(--accent)}
.fp-row.is-bad{opacity:.4}
.fp-row.is-bad span:first-child{text-decoration:line-through}
.fp-bar{height:8px;background:var(--hair);border-radius:99px;overflow:hidden;width:100%}
.fp-bar span{display:block;height:100%;background:var(--accent);border-radius:99px}
.fp-token{display:inline-flex;align-items:center;font-family:monospace;font-size:.84rem;padding:4px 10px;border-radius:6px;background:rgba(176,83,46,.1);color:var(--accent);font-weight:500}
.fp-tokens{display:flex;flex-wrap:wrap;gap:6px}

/* Integration grid */
.integration-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--hair);max-width:1180px;margin:0 auto;border:1px solid var(--hair)}
@media (max-width:640px){.integration-grid{grid-template-columns:repeat(2,1fr)}}
.integration-cell{background:#fff;padding:28px;display:grid;place-items:center;font-size:1rem;font-weight:600;color:rgba(31,36,48,.55);letter-spacing:-.01em;transition:all .2s ease;position:relative}
.integration-cell:hover{background:var(--paper);color:var(--accent)}
.integration-cell .soon{position:absolute;top:8px;right:8px;font-family:'Outfit',sans-serif;font-size:9.5px;letter-spacing:.14em;color:var(--muted);text-transform:uppercase;font-weight:700;background:rgba(31,36,48,.06);padding:2px 7px;border-radius:99px}

/* Use-case grid (4 cards) */
.usecase-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--hair);max-width:1180px;margin:0 auto;border:1px solid var(--hair)}
@media (max-width:768px){.usecase-grid{grid-template-columns:1fr}}
.usecase{background:#fff;padding:34px;display:flex;flex-direction:column;gap:14px}
.usecase-tag{font-family:'Outfit',sans-serif;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);font-weight:700}
.usecase-h{font-family:'Fraunces',serif;font-style:italic;font-weight:400;letter-spacing:-.01em;font-size:1.5rem;line-height:1.3;color:var(--ink);margin:0}
.usecase-meta{margin:0;color:rgba(31,36,48,.7);font-size:.92rem;line-height:1.5}
.usecase-stat{margin-top:auto;padding-top:18px;border-top:1px dashed var(--hair-strong);display:inline-flex;align-items:baseline;gap:8px;font-family:'Outfit',sans-serif;font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:var(--muted)}
.usecase-stat b{font-family:'Outfit',sans-serif;font-weight:700;font-size:1.4rem;color:var(--ink);letter-spacing:-.02em}

/* Alternating feature layout (used on home + subpages) */
.feature-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;max-width:1180px;margin:0 auto;padding:0 24px}
@media (max-width:900px){.feature-grid{grid-template-columns:1fr}}
.feature-list{list-style:none;padding:0;margin:28px 0 0;display:flex;flex-direction:column;gap:14px}
.feature-list li{display:flex;gap:12px;font-size:.97rem;line-height:1.5}
.feature-list li::before{content:'—';color:var(--accent);flex-shrink:0;margin-top:2px}
.feature-list b{font-weight:600}

/* ===== Selection ===== */
::selection{background:var(--accent);color:#fff}

@media (prefers-reduced-motion:reduce){
  .reveal{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
  .marquee{animation:none}
}

/* ===== Accessibility ===== */
.skip-link{position:fixed;top:8px;left:8px;background:var(--accent);color:#fff;padding:10px 18px;border-radius:6px;font-weight:600;font-size:.9rem;z-index:9999;transform:translateY(-200%);transition:transform .2s ease;text-decoration:none}
.skip-link:focus{transform:translateY(0)}

/* Keyboard focus for mega-menu */
.nav-item.has-mega > a:focus-visible{outline:2px solid var(--accent);outline-offset:4px;border-radius:4px}
.nav-item.has-mega.is-open .mega-menu{opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto}
