/* =====================================================================
   The Flat World Network × My Local Everything — Design System
   Brand: hot-orange (#F97516) on clean white, Lato display + Nunito Sans
   ===================================================================== */

:root{
  /* Color */
  --orange:       #F97516;
  --orange-700:   #d9610f;
  --orange-soft:  #fff3ea;
  --orange-tint:  #ffe7d3;
  --white:        #ffffff;
  --off-white:    #f9f9f9;
  --paper:        #fbfafa;
  --ink:          #1d1d1d;
  --ink-800:      #232323;
  --heading:      #2d2d2d;
  --text:         #4a4a4a;
  --muted:        #80726c;
  --line:         #ececec;
  --line-2:       #e2e2e2;
  --blue:         #1e73be;

  /* Type */
  --font-head: "Lato", system-ui, sans-serif;
  --font-body: "Nunito Sans", system-ui, sans-serif;

  /* Shape & motion */
  --radius:       18px;
  --radius-sm:    12px;
  --radius-pill:  50px;
  --shadow-sm:    0 2px 10px rgba(29,29,29,.05);
  --shadow:       0 18px 50px -20px rgba(29,29,29,.18);
  --shadow-orange:0 18px 44px -16px rgba(249,117,22,.45);
  --ease:         cubic-bezier(.22,1,.36,1);
  --nav-h:        78px;
  --maxw:         1200px;
}

*{ box-sizing:border-box; margin:0; padding:0; }
html{ -webkit-text-size-adjust:100%; }
html.lenis{ height:auto; }
.lenis.lenis-smooth{ scroll-behavior:auto !important; }
.lenis.lenis-smooth [data-lenis-prevent]{ overscroll-behavior:contain; }

body{
  font-family:var(--font-body);
  font-size:1.0625rem;
  line-height:1.65;
  color:var(--text);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}

h1,h2,h3,h4,h5{ font-family:var(--font-head); color:var(--heading); line-height:1.1; font-weight:800; }
a{ color:inherit; text-decoration:none; }
img,svg,canvas{ display:block; max-width:100%; }
section{ position:relative; }

/* ---------- Layout helpers ---------- */
.wrap{ width:100%; max-width:var(--maxw); margin-inline:auto; padding-inline:clamp(20px,5vw,40px); }
.section{ padding:clamp(64px,9vw,120px) 0; }
.section--tint{ background:var(--off-white); }
.section--ink{ background:var(--ink); color:#cfcfcf; }
.section--ink h1,.section--ink h2,.section--ink h3{ color:#fff; }
.eyebrow{
  display:inline-flex; align-items:center; gap:.55rem;
  font-family:var(--font-head); font-weight:800; font-size:.78rem;
  letter-spacing:.16em; text-transform:uppercase; color:var(--orange);
  margin-bottom:1.1rem;
}
.eyebrow::before{ content:""; width:26px; height:2px; background:var(--orange); border-radius:2px; }
.section--ink .eyebrow{ color:var(--orange); }

.h-display{ font-size:clamp(2.3rem,5.2vw,3.9rem); letter-spacing:-.015em; }
.h-section{ font-size:clamp(1.9rem,3.6vw,2.9rem); letter-spacing:-.01em; }
.lead{ font-size:clamp(1.05rem,1.6vw,1.25rem); color:var(--text); max-width:62ch; }
.center{ text-align:center; }
.center .lead{ margin-inline:auto; }
.text-orange{ color:var(--orange); }

/* ---------- Buttons (FWN pill language) ---------- */
.btn{
  display:inline-flex; align-items:center; gap:.6rem;
  font-family:var(--font-head); font-weight:800; text-transform:uppercase;
  letter-spacing:.04em; font-size:.95rem; line-height:1;
  padding:1rem 1.75rem; border-radius:var(--radius-pill);
  cursor:pointer; border:2px solid transparent; position:relative; overflow:hidden;
  transition:transform .35s var(--ease), box-shadow .35s var(--ease), background .3s var(--ease), color .3s var(--ease);
}
.btn svg{ width:18px; height:18px; }
.btn--primary{ background:var(--orange); color:#fff; box-shadow:var(--shadow-orange); }
.btn--primary:hover{ transform:translateY(-3px); background:var(--orange-700); }
.btn--ghost{ background:transparent; color:var(--orange); border-color:var(--orange); }
.btn--ghost:hover{ background:var(--orange); color:#fff; transform:translateY(-3px); }
.btn--light{ background:#fff; color:var(--ink); }
.btn--light:hover{ transform:translateY(-3px); box-shadow:var(--shadow); }
.btn--lg{ padding:1.15rem 2.1rem; font-size:1.02rem; }
/* sheen */
.btn--primary::after{
  content:""; position:absolute; inset:0; transform:translateX(-130%);
  background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);
  transition:transform .8s var(--ease);
}
.btn--primary:hover::after{ transform:translateX(130%); }
.btn .arr{ transition:transform .35s var(--ease); }
.btn:hover .arr{ transform:translatex(4px); }

/* ---------- Header ---------- */
.site-header{
  position:fixed; inset:0 0 auto 0; height:var(--nav-h); z-index:900;
  display:flex; align-items:center;
  background:rgba(255,255,255,.82); backdrop-filter:blur(14px);
  border-bottom:1px solid transparent; transition:border-color .3s, box-shadow .3s;
}
.site-header.scrolled{ border-bottom-color:var(--line); box-shadow:var(--shadow-sm); }
.site-header .wrap{ display:flex; align-items:center; justify-content:space-between; gap:1.5rem; }
.brand{ display:flex; align-items:center; gap:.7rem; }
.brand .mark{ width:40px; height:40px; flex:0 0 auto; }
.brand-txt{ display:flex; flex-direction:column; line-height:1; }
.brand-txt b{ font-family:var(--font-head); font-weight:900; font-size:.92rem; letter-spacing:.02em; color:var(--ink); text-transform:uppercase; }
.brand-txt span{ font-size:.66rem; letter-spacing:.12em; text-transform:uppercase; color:var(--orange); font-weight:700; margin-top:3px; }
.nav{ display:flex; align-items:center; gap:2rem; }
.nav a.navlink{ font-family:var(--font-head); font-weight:700; font-size:.92rem; color:var(--heading); position:relative; }
.nav a.navlink::after{ content:""; position:absolute; left:0; bottom:-6px; width:0; height:2px; background:var(--orange); transition:width .3s var(--ease); }
.nav a.navlink:hover{ color:var(--orange); }
.nav a.navlink:hover::after,.nav a.navlink.active::after{ width:100%; }
.nav a.navlink.active{ color:var(--orange); }
.has-drop{ position:relative; }
.drop{
  position:absolute; top:100%; margin-top:14px; left:50%; transform:translateX(-50%) translateY(8px);
  background:#fff; border:1px solid var(--line); border-radius:16px; box-shadow:var(--shadow);
  padding:.6rem; width:min(560px,90vw); display:grid; grid-template-columns:1fr 1fr; gap:.2rem;
  opacity:0; visibility:hidden; transition:opacity .25s var(--ease), transform .25s var(--ease);
}
/* invisible bridge so the cursor can cross the gap without losing hover */
.drop::before{ content:""; position:absolute; left:0; right:0; top:-18px; height:18px; }
.has-drop:hover .drop{ opacity:1; visibility:visible; transform:translateX(-50%) translateY(0); }
.drop a{ display:flex; gap:.7rem; align-items:center; padding:.7rem .8rem; border-radius:11px; transition:background .2s; }
.drop a:hover{ background:var(--orange-soft); }
.drop a svg{ width:22px; height:22px; flex:0 0 auto; color:var(--orange); }
.drop a b{ font-family:var(--font-head); font-size:.9rem; color:var(--ink); display:block; }
.drop a small{ font-size:.76rem; color:var(--muted); }
.nav-cta{ display:flex; align-items:center; gap:1rem; }
.menu-btn{ display:none; background:none; border:0; cursor:pointer; width:30px; height:24px; position:relative; }
.menu-btn span{ position:absolute; left:0; height:3px; width:100%; background:var(--ink); border-radius:3px; transition:.3s; }
.menu-btn span:nth-child(1){ top:0; } .menu-btn span:nth-child(2){ top:10px; } .menu-btn span:nth-child(3){ top:20px; }
body.nav-open .menu-btn span:nth-child(1){ top:10px; transform:rotate(45deg); }
body.nav-open .menu-btn span:nth-child(2){ opacity:0; }
body.nav-open .menu-btn span:nth-child(3){ top:10px; transform:rotate(-45deg); }

/* ---------- Hero ---------- */
.hero{ position:relative; padding-top:calc(var(--nav-h) + 40px); min-height:100vh; display:flex; align-items:center; overflow:hidden; }
#hero-canvas{ position:absolute; inset:0; width:100%; height:100%; z-index:0; }
.hero::before{ /* soft orange blob */
  content:""; position:absolute; right:-8%; top:8%; width:46vw; height:46vw; max-width:680px; max-height:680px;
  background:radial-gradient(circle at 50% 50%, rgba(249,117,22,.14), rgba(249,117,22,0) 68%); z-index:0; pointer-events:none;
}
.hero .wrap{ position:relative; z-index:2; }
.hero-inner{ max-width:760px; }
.partner-badge{
  display:inline-flex; align-items:center; gap:.6rem; background:#fff; border:1px solid var(--line-2);
  border-radius:var(--radius-pill); padding:.5rem .9rem .5rem .55rem; box-shadow:var(--shadow-sm);
  font-family:var(--font-head); font-weight:700; font-size:.8rem; color:var(--heading); margin-bottom:1.6rem;
}
.partner-badge .dot{ width:9px; height:9px; border-radius:50%; background:var(--orange); box-shadow:0 0 0 4px var(--orange-soft); }
.partner-badge b{ color:var(--orange); }
.hero h1{ font-size:clamp(2.5rem,6vw,4.6rem); letter-spacing:-.02em; color:var(--ink); }
.hero h1 .o{ color:var(--orange); }
.hero p.sub{ margin-top:1.5rem; font-size:clamp(1.1rem,1.7vw,1.35rem); color:var(--text); max-width:54ch; }
.hero-cta{ margin-top:2.4rem; display:flex; gap:1rem; flex-wrap:wrap; }
.hero-trust{ margin-top:3rem; display:flex; gap:2.4rem; flex-wrap:wrap; }
.hero-trust .stat b{ font-family:var(--font-head); font-weight:900; font-size:clamp(1.7rem,3vw,2.3rem); color:var(--ink); display:block; line-height:1; }
.hero-trust .stat span{ font-size:.8rem; text-transform:uppercase; letter-spacing:.08em; color:var(--muted); font-weight:700; }
.hero-trust .stat b em{ color:var(--orange); font-style:normal; }

/* ---------- Logo / trust strip ---------- */
.trust-strip{ border-top:1px solid var(--line); border-bottom:1px solid var(--line); background:#fff; }
.trust-strip .wrap{ display:flex; align-items:center; gap:2rem; flex-wrap:wrap; justify-content:space-between; padding-block:1.6rem; }
.trust-strip p{ font-family:var(--font-head); font-weight:700; font-size:.8rem; letter-spacing:.12em; text-transform:uppercase; color:var(--muted); }
.trust-strip .stack{ display:flex; gap:2.4rem; flex-wrap:wrap; align-items:center; }
.trust-strip .stack span{ font-family:var(--font-head); font-weight:800; color:var(--heading); opacity:.65; font-size:1.05rem; }

/* ---------- Section intro ---------- */
.sec-head{ max-width:720px; margin-bottom:clamp(2.4rem,5vw,3.6rem); }
.sec-head.center{ margin-inline:auto; }

/* ---------- Service grid ---------- */
.svc-grid{ display:grid; grid-template-columns:repeat(auto-fit,minmax(290px,1fr)); gap:1.4rem; }
.svc-card{
  position:relative; background:#fff; border:1px solid var(--line); border-radius:var(--radius);
  padding:2.1rem 1.9rem; overflow:hidden; transition:transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s;
  display:flex; flex-direction:column; min-height:100%;
}
.svc-card::before{ content:""; position:absolute; left:0; top:0; height:4px; width:100%; background:linear-gradient(90deg,var(--orange),var(--orange-700)); transform:scaleX(0); transform-origin:left; transition:transform .4s var(--ease); }
.svc-card:hover{ transform:translateY(-6px); box-shadow:var(--shadow); border-color:transparent; }
.svc-card:hover::before{ transform:scaleX(1); }
.svc-ico{
  width:60px; height:60px; border-radius:16px; background:var(--orange-soft);
  display:grid; place-items:center; margin-bottom:1.3rem; color:var(--orange); transition:.4s var(--ease);
}
.svc-ico svg{ width:30px; height:30px; }
.svc-card:hover .svc-ico{ background:var(--orange); color:#fff; transform:rotate(-6deg); }
.svc-card h3{ font-size:1.28rem; margin-bottom:.6rem; }
.svc-card p{ font-size:.97rem; color:var(--text); margin-bottom:1.2rem; }
.svc-card .more{ margin-top:auto; font-family:var(--font-head); font-weight:800; font-size:.84rem; text-transform:uppercase; letter-spacing:.06em; color:var(--orange); display:inline-flex; align-items:center; gap:.4rem; }
.svc-card .more svg{ width:15px; height:15px; transition:transform .3s var(--ease); }
.svc-card:hover .more svg{ transform:translateX(4px); }
.svc-card .num{ position:absolute; top:1.4rem; right:1.6rem; font-family:var(--font-head); font-weight:900; font-size:1rem; color:var(--line-2); }

/* ---------- Feature split ---------- */
.split{ display:grid; grid-template-columns:1fr 1fr; gap:clamp(2.4rem,6vw,5rem); align-items:center; }
.split.rev .split-media{ order:-1; }
.split-media{ position:relative; }
.media-card{ background:linear-gradient(160deg,#fff,var(--off-white)); border:1px solid var(--line); border-radius:24px; padding:1.8rem; box-shadow:var(--shadow); }
.fact-list{ list-style:none; display:grid; gap:1rem; margin-top:1.6rem; }
.fact-list li{ display:flex; gap:.9rem; align-items:flex-start; font-size:1rem; color:var(--text); }
.fact-list li svg{ width:24px; height:24px; flex:0 0 auto; color:var(--orange); margin-top:2px; }
.fact-list li b{ color:var(--ink); font-family:var(--font-head); }

/* ---------- Process / how it works ---------- */
.steps{ display:grid; grid-template-columns:repeat(auto-fit,minmax(230px,1fr)); gap:1.4rem; counter-reset:step; }
.step{ background:#fff; border:1px solid var(--line); border-radius:var(--radius); padding:2rem 1.7rem; position:relative; }
.section--ink .step{ background:var(--ink-800); border-color:#333; }
.step .n{ width:46px; height:46px; border-radius:50%; background:var(--orange); color:#fff; font-family:var(--font-head); font-weight:900; font-size:1.2rem; display:grid; place-items:center; margin-bottom:1.1rem; }
.step h3{ font-size:1.18rem; margin-bottom:.55rem; }
.section--ink .step p{ color:#bdbdbd; }

/* ---------- Stats band ---------- */
.statband{ display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:1.5rem; text-align:center; }
.statband .s b{ font-family:var(--font-head); font-weight:900; font-size:clamp(2.4rem,5vw,3.6rem); color:var(--orange); display:block; line-height:1; }
.statband .s span{ display:block; margin-top:.6rem; font-size:.9rem; letter-spacing:.04em; color:#bdbdbd; text-transform:uppercase; font-weight:700; }

/* ---------- Platform marquee (signature) ---------- */
.marquee{ overflow:hidden; -webkit-mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); mask:linear-gradient(90deg,transparent,#000 8%,#000 92%,transparent); }
.marquee-row{ display:flex; gap:1rem; width:max-content; animation:scroll-x 40s linear infinite; }
.marquee-row.r2{ animation-duration:55s; animation-direction:reverse; margin-top:1rem; }
.marquee:hover .marquee-row{ animation-play-state:paused; }
.chip{ display:inline-flex; align-items:center; gap:.6rem; padding:.85rem 1.4rem; border:1px solid var(--line-2); border-radius:var(--radius-pill); background:#fff; font-family:var(--font-head); font-weight:700; color:var(--heading); white-space:nowrap; }
.chip .d{ width:9px; height:9px; border-radius:50%; background:var(--orange); }
@keyframes scroll-x{ to{ transform:translateX(-50%); } }

/* ---------- AEO quick-answer + key facts (service pages) ---------- */
.quick-answer{ background:var(--orange-soft); border:1px solid var(--orange-tint); border-left:5px solid var(--orange); border-radius:14px; padding:1.5rem 1.7rem; margin:1.8rem 0; }
.quick-answer .lbl{ font-family:var(--font-head); font-weight:800; font-size:.74rem; letter-spacing:.12em; text-transform:uppercase; color:var(--orange-700); display:block; margin-bottom:.5rem; }
.quick-answer p{ color:var(--ink-800); font-size:1.08rem; margin:0; }
.keyfacts{ width:100%; border-collapse:collapse; margin:1.4rem 0; font-size:.97rem; }
.keyfacts td{ padding:.85rem 1rem; border-bottom:1px solid var(--line); vertical-align:top; }
.keyfacts tr td:first-child{ font-family:var(--font-head); font-weight:800; color:var(--ink); width:38%; }

/* ---------- Page hero (inner) ---------- */
.page-hero{ position:relative; padding:calc(var(--nav-h) + clamp(46px,8vw,90px)) 0 clamp(46px,7vw,80px); background:var(--ink); color:#cfcfcf; overflow:hidden; }
.page-hero::after{ content:""; position:absolute; right:-6%; top:-30%; width:50vw; height:120%; background:radial-gradient(circle at 60% 40%, rgba(249,117,22,.22), transparent 62%); pointer-events:none; }
.page-hero .wrap{ position:relative; z-index:2; max-width:860px; }
.page-hero .eyebrow{ color:var(--orange); }
.page-hero h1{ color:#fff; font-size:clamp(2.3rem,5vw,3.7rem); letter-spacing:-.015em; }
.page-hero p{ margin-top:1.2rem; font-size:clamp(1.05rem,1.6vw,1.25rem); color:#d7d7d7; max-width:60ch; }
.crumbs{ display:flex; gap:.5rem; font-size:.82rem; color:#9a9a9a; margin-bottom:1.2rem; font-weight:600; }
.crumbs a:hover{ color:var(--orange); }
.crumbs span{ color:#6c6c6c; }
.page-hero .ico-big{ position:absolute; right:6%; bottom:-10%; width:230px; height:230px; color:rgba(249,117,22,.18); z-index:1; }

/* ---------- Two-col content (service body) ---------- */
.content-grid{ display:grid; grid-template-columns:1fr 320px; gap:clamp(2rem,5vw,4rem); align-items:start; }
.prose h2{ font-size:clamp(1.6rem,3vw,2.2rem); margin:2.2rem 0 1rem; }
.prose h3{ font-size:1.3rem; margin:1.8rem 0 .7rem; color:var(--ink); }
.prose p{ margin-bottom:1.1rem; }
.prose > p:first-of-type{ font-size:1.15rem; color:var(--ink-800); }
.check-list{ list-style:none; display:grid; gap:.85rem; margin:1.2rem 0 1.6rem; }
.check-list li{ display:flex; gap:.75rem; align-items:flex-start; }
.check-list li svg{ width:22px; height:22px; flex:0 0 auto; color:var(--orange); margin-top:2px; }
.feature-pair{ display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; margin:1.6rem 0; }
.mini-card{ background:var(--off-white); border:1px solid var(--line); border-radius:14px; padding:1.4rem; }
.mini-card h4{ font-family:var(--font-head); font-size:1.05rem; color:var(--ink); margin-bottom:.4rem; display:flex; align-items:center; gap:.5rem; }
.mini-card h4 svg{ width:20px; height:20px; color:var(--orange); }
.mini-card p{ font-size:.92rem; margin:0; }

.aside{ position:sticky; top:calc(var(--nav-h) + 20px); display:grid; gap:1.2rem; }
.aside-card{ background:#fff; border:1px solid var(--line); border-radius:18px; padding:1.6rem; box-shadow:var(--shadow-sm); }
.aside-card.cta-card{ background:var(--ink); color:#cfcfcf; border-color:var(--ink); }
.aside-card.cta-card h4{ color:#fff; }
.aside-card h4{ font-family:var(--font-head); font-size:1.1rem; color:var(--ink); margin-bottom:.7rem; }
.aside-card ul{ list-style:none; display:grid; gap:.55rem; }
.aside-card ul a{ font-size:.92rem; color:var(--text); display:flex; gap:.5rem; align-items:center; }
.aside-card ul a::before{ content:""; width:6px; height:6px; border-radius:50%; background:var(--orange); flex:0 0 auto; }
.aside-card ul a:hover{ color:var(--orange); }

/* ---------- FAQ ---------- */
.faq{ max-width:820px; margin-inline:auto; }
.faq-item{ border-bottom:1px solid var(--line); }
.faq-q{ width:100%; text-align:left; background:none; border:0; cursor:pointer; padding:1.4rem 3rem 1.4rem 0; position:relative; font-family:var(--font-head); font-weight:800; font-size:1.1rem; color:var(--ink); }
.faq-q::after{ content:"+"; position:absolute; right:.4rem; top:50%; transform:translateY(-50%); font-size:1.6rem; color:var(--orange); transition:transform .3s; }
.faq-item.open .faq-q::after{ content:"–"; }
.faq-a{ max-height:0; overflow:hidden; transition:max-height .4s var(--ease); }
.faq-a p{ padding:0 0 1.4rem; color:var(--text); }

/* ---------- CTA band ---------- */
.cta-band{ background:linear-gradient(135deg,var(--orange),var(--orange-700)); color:#fff; border-radius:28px; padding:clamp(2.6rem,6vw,4.5rem); text-align:center; position:relative; overflow:hidden; }
.cta-band::before{ content:""; position:absolute; inset:0; background:radial-gradient(circle at 15% 20%, rgba(255,255,255,.18), transparent 40%), radial-gradient(circle at 85% 80%, rgba(255,255,255,.14), transparent 40%); }
.cta-band > *{ position:relative; }
.cta-band h2{ color:#fff; font-size:clamp(1.9rem,4vw,3rem); }
.cta-band p{ color:rgba(255,255,255,.92); max-width:54ch; margin:1rem auto 2rem; font-size:1.1rem; }
.cta-band .btn--light{ color:var(--orange-700); }

/* ---------- Contact form ---------- */
.form-grid{ display:grid; grid-template-columns:1fr 1fr; gap:1.1rem; }
.field{ display:flex; flex-direction:column; gap:.4rem; }
.field.full{ grid-column:1/-1; }
.field label{ font-family:var(--font-head); font-weight:700; font-size:.85rem; color:var(--ink); }
.field input,.field textarea,.field select{
  font-family:var(--font-body); font-size:1rem; padding:.85rem 1rem; border:1px solid var(--line-2);
  border-radius:12px; background:#fff; color:var(--ink); transition:border-color .2s, box-shadow .2s;
}
.field input:focus,.field textarea:focus,.field select:focus{ outline:none; border-color:var(--orange); box-shadow:0 0 0 3px var(--orange-soft); }
.form-note{ font-size:.85rem; color:var(--muted); margin-top:.6rem; }
.form-status{ margin-top:1rem; font-weight:700; font-family:var(--font-head); display:none; }
.form-status.ok{ display:block; color:#1a8a4f; } .form-status.err{ display:block; color:#c0392b; }
.hp{ position:absolute; left:-9999px; opacity:0; }

/* ---------- Footer ---------- */
.site-footer{ background:var(--ink); color:#9c9c9c; padding:clamp(3.5rem,6vw,5rem) 0 2rem; }
.footer-grid{ display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:2.4rem; }
.site-footer .brand-txt b{ color:#fff; } .site-footer .brand-txt span{ color:var(--orange); }
.footer-about{ margin-top:1.2rem; font-size:.95rem; max-width:34ch; }
.footer-col h5{ font-family:var(--font-head); color:#fff; font-size:.82rem; letter-spacing:.1em; text-transform:uppercase; margin-bottom:1.1rem; }
.footer-col a{ display:block; font-size:.93rem; color:#9c9c9c; padding:.32rem 0; transition:color .2s; }
.footer-col a:hover{ color:var(--orange); }
.footer-bottom{ border-top:1px solid #333; margin-top:3rem; padding-top:1.6rem; display:flex; justify-content:space-between; gap:1rem; flex-wrap:wrap; font-size:.85rem; }
.footer-bottom a:hover{ color:var(--orange); }

/* ---------- Reveal ---------- */
.reveal{ opacity:0; transform:translateY(26px); }
.revealed{ opacity:1; transform:none; }
html.no-anim .reveal{ opacity:1 !important; transform:none !important; }

/* ---------- Custom cursor ---------- */
.cursor-dot,.cursor-ring{ position:fixed; top:0; left:0; border-radius:50%; pointer-events:none; z-index:9999; mix-blend-mode:normal; }
.cursor-dot{ width:7px; height:7px; background:var(--orange); transform:translate(-50%,-50%); }
.cursor-ring{ width:34px; height:34px; border:2px solid rgba(249,117,22,.55); transform:translate(-50%,-50%); transition:width .25s,height .25s,background .25s; }
.cursor-ring.hovered{ width:54px; height:54px; background:rgba(249,117,22,.1); }
@media (hover:none),(pointer:coarse){ .cursor-dot,.cursor-ring{ display:none; } }

/* ---------- Grain ---------- */
.grain{ position:fixed; inset:0; z-index:8000; pointer-events:none; opacity:.035;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.85' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E"); }

/* ---------- Preloader ---------- */
.preloader{ position:fixed; inset:0; z-index:10000; background:#fff; display:grid; place-items:center; transition:opacity .6s var(--ease), visibility .6s; }
.preloader.done{ opacity:0; visibility:hidden; }
.preloader .pl-mark{ width:64px; height:64px; animation:spin 1.4s linear infinite; }
@keyframes spin{ to{ transform:rotate(360deg); } }

/* ---------- Mobile nav ---------- */
@media (max-width:980px){
  .footer-grid{ grid-template-columns:1fr 1fr; }
  .content-grid{ grid-template-columns:1fr; }
  .aside{ position:static; }
  .split,.split.rev .split-media{ grid-template-columns:1fr; order:0; }
}
@media (max-width:860px){
  .menu-btn{ display:block; }
  .nav{
    position:fixed; inset:var(--nav-h) 0 auto 0; flex-direction:column; align-items:flex-start; gap:0;
    background:#fff; border-bottom:1px solid var(--line); padding:1rem clamp(20px,5vw,40px) 2rem;
    transform:translateY(-130%); transition:transform .4s var(--ease); box-shadow:var(--shadow); max-height:calc(100vh - var(--nav-h)); overflow:auto;
  }
  body.nav-open .nav{ transform:translateY(0); }
  .nav a.navlink{ width:100%; padding:.95rem 0; border-bottom:1px solid var(--line); font-size:1.05rem; }
  .has-drop{ width:100%; }
  .drop{ position:static; margin-top:0; transform:none; opacity:1; visibility:visible; box-shadow:none; border:0; grid-template-columns:1fr; width:100%; padding:.2rem 0 .6rem 1rem; }
  .drop::before{ display:none; }
  .nav .nav-cta{ display:none; }
  .feature-pair{ grid-template-columns:1fr; }
  .form-grid{ grid-template-columns:1fr; }
  .hero-trust{ gap:1.6rem; }
}
@media (max-width:560px){
  .footer-grid{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; }
}

@media (prefers-reduced-motion:reduce){
  *{ animation-duration:.001ms !important; transition-duration:.001ms !important; }
  .marquee-row{ animation:none; }
  .reveal{ opacity:1 !important; transform:none !important; }
}
