/* Rank On Maps — shared design system */
@font-face{
  font-family:'Bethany Elingston';
  src:url('fonts/Bethany%20Elingston.otf') format('opentype');
  font-display:swap;
}
:root{
  --bg:#ffffff;
  --ink:#1d1d1f;
  --ink-soft:#6e7780;
  --line:#d6dadd;
  --tint:#f4f6f7;
  --green:#22c55e;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-font-smoothing:antialiased}
html{overflow-x:clip}
body{background:var(--bg);color:var(--ink);font-family:'Inter','SF Pro Display',-apple-system,BlinkMacSystemFont,system-ui,sans-serif;line-height:1.47;overflow-x:clip}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}

/* Nav */
.nav{position:sticky;top:0;z-index:50;backdrop-filter:saturate(180%) blur(24px);-webkit-backdrop-filter:saturate(180%) blur(24px);background:rgba(255,255,255,.72);border-bottom:1px solid rgba(0,0,0,.06);transition:background .3s,box-shadow .3s}
.nav.scrolled{background:rgba(255,255,255,.92);box-shadow:0 8px 30px -18px rgba(0,0,0,.12)}
.nav-inner{max-width:1200px;margin:0 auto;padding:0 30px;height:62px;display:flex;align-items:center;justify-content:space-between;font-size:14px}
.brand{display:flex;align-items:center;gap:9px;font-family:'Inter',sans-serif;font-size:15px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);transition:transform .25s}
.brand:hover{transform:translateY(-1px)}
.brand svg{width:24px;height:24px;color:var(--ink);transition:transform .35s cubic-bezier(.34,1.4,.64,1)}
.brand:hover svg{transform:rotate(-8deg) scale(1.1)}
.brand .tld{color:var(--ink-soft);font-weight:700}
.nav-cta{
  font-weight:600;padding:10px 20px;border-radius:980px;
  background:var(--ink);color:#fff;
  transition:transform .25s,box-shadow .3s,background .25s;
  box-shadow:0 4px 14px -4px rgba(0,0,0,.3);
}
.nav-cta:hover{transform:translateY(-2px);box-shadow:0 10px 24px -8px rgba(0,0,0,.4);background:#000}
.nav-cta::after{content:" →";display:inline-block;transition:transform .25s}
.nav-cta:hover::after{transform:translateX(3px)}

/* Desktop nav — original horizontal */
.nav-links{display:flex;gap:6px;color:var(--ink);position:relative}
.nav-links a{
  position:relative;padding:9px 16px;border-radius:980px;
  font-weight:500;color:var(--ink);
  transition:color .25s,background .25s;
}
.nav-links a:hover{background:rgba(0,0,0,.05)}
.nav-links a.active{background:var(--ink);color:#fff}

/* Hamburger — mobile only */
.hamburger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border-radius:12px;background:rgba(0,0,0,.04);border:none;cursor:pointer;padding:0;transition:background .2s;z-index:101;position:relative}
.hamburger:hover{background:rgba(0,0,0,.08)}
.hamburger span{display:block;width:22px;height:2px;background:var(--ink);border-radius:2px;margin:0 auto;transition:transform .35s cubic-bezier(.2,.7,.2,1),opacity .25s}
.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
body.nav-open{overflow:hidden}

/* Layout */
section{padding:130px 28px;text-align:center;position:relative;overflow:hidden}
.container{max-width:1140px;margin:0 auto;position:relative;z-index:2}
.eyebrow{font-size:13px;font-weight:600;color:var(--ink-soft);margin-bottom:14px;letter-spacing:.1em;text-transform:uppercase}
h1,h2,h3.display{font-family:'Bethany Elingston','Playfair Display',Georgia,serif;font-weight:400;letter-spacing:-.02em;line-height:1.02;color:var(--ink)}
h1{font-size:clamp(56px,8.5vw,108px)}
h2{font-size:clamp(42px,5.6vw,72px)}
.sub{font-size:clamp(18px,1.6vw,21px);color:var(--ink-soft);max-width:660px;margin:24px auto 0;line-height:1.5;font-weight:400}
.ctas{margin-top:36px;display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:6px;padding:14px 26px;border-radius:980px;font-size:15px;font-weight:500;transition:all .2s;border:1px solid transparent;cursor:pointer;position:relative;overflow:hidden}
.btn-primary{background:var(--ink);color:#fff;box-shadow:0 6px 20px -8px rgba(0,0,0,.35)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 14px 30px -10px rgba(0,0,0,.45)}
.btn-primary:active{transform:translateY(0)}
.btn-ghost{color:var(--ink);position:relative}
.btn-ghost::after{content:"›";margin-left:2px;font-size:18px;line-height:1}
.btn-ghost::before{content:"";position:absolute;left:24px;right:24px;bottom:10px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .35s cubic-bezier(.2,.7,.2,1)}
.btn-ghost:hover::before{transform:scaleX(1)}

/* Pill */
.pill{display:inline-block;background:var(--ink);color:#fff;padding:3px 16px;border-radius:980px;font-weight:500;font-size:.95em;line-height:1.4;white-space:nowrap;transition:transform .25s}
.pill:hover{transform:translateY(-1px) scale(1.03)}

/* Page hero */
.page-hero{padding:140px 28px 110px;text-align:center;position:relative;overflow:hidden;background:linear-gradient(180deg,#fff 0%,#fafafa 100%)}
.page-hero h1{max-width:980px;margin:18px auto 0}
.page-hero h1 em{font-style:italic;background:linear-gradient(180deg,#1d1d1f 0%,#8a8a8f 100%);-webkit-background-clip:text;background-clip:text;color:transparent}
.page-hero .sub{margin-top:28px}

/* Reveal-on-scroll */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}
.reveal.d2{transition-delay:.16s}
.reveal.d3{transition-delay:.24s}
.reveal.d4{transition-delay:.32s}
.reveal.d5{transition-delay:.40s}
.reveal.d6{transition-delay:.48s}
/* All reveal animations use a single consistent fade-up */
@keyframes heroIn{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
.page-hero .eyebrow,.page-hero h1,.page-hero .sub,.page-hero .ctas{animation:heroIn 1s cubic-bezier(.2,.7,.2,1) both}
.page-hero .eyebrow{animation-delay:.05s}
.page-hero h1{animation-delay:.15s}
.page-hero .sub{animation-delay:.35s}
.page-hero .ctas{animation-delay:.5s}

/* Tile parallax tilt base */
.tilt{transform-style:preserve-3d;will-change:transform;transition:transform .25s cubic-bezier(.2,.7,.2,1)}

/* Footer CTA + footer */
.cta-final{background:linear-gradient(180deg,#fafafa 0%,#eeeef2 100%);padding:150px 28px;text-align:center}
.cta-reassure{margin-top:14px;font-size:13px;color:var(--ink-soft)}
footer{padding:52px 28px 64px;border-top:1px solid var(--line);background:#fafafa}
.foot-inner{max-width:1180px;margin:0 auto}
.foot-top{display:grid;grid-template-columns:1.5fr 1fr 1fr;gap:40px;margin-bottom:48px}
.foot-brand{font-size:15px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--ink);display:flex;align-items:center;gap:8px;margin-bottom:14px}
.foot-brand svg{width:20px;height:20px}
.foot-brand .tld{color:var(--ink-soft)}
.foot-tagline{font-size:14px;color:var(--ink-soft);line-height:1.5;max-width:280px;margin-bottom:22px}
.foot-trust{display:inline-flex;align-items:center;gap:7px;font-size:12px;color:var(--ink-soft);background:#fff;border:1px solid var(--line);border-radius:980px;padding:6px 14px}
.foot-trust::before{content:"✓";color:var(--green);font-weight:700}
.foot-col h5{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-soft);margin-bottom:16px}
.foot-col a{display:block;font-size:14px;color:var(--ink);margin-bottom:10px;transition:color .2s}
.foot-col a:hover{color:var(--green)}
.foot-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:28px;border-top:1px solid var(--line);font-size:12px;color:var(--ink-soft);flex-wrap:wrap;gap:12px}
.foot-legal a{margin-left:18px;color:var(--ink-soft);transition:color .2s}
.foot-legal a:hover{color:var(--ink)}
.foot-social{display:flex;gap:12px}
.foot-social a{width:34px;height:34px;border-radius:50%;border:1px solid var(--line);display:flex;align-items:center;justify-content:center;color:var(--ink-soft);transition:all .2s}
.foot-social a:hover{border-color:var(--ink);color:var(--ink)}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}
/* Mobile: hamburger + side drawer */
@media (max-width:900px){
  .foot-top{grid-template-columns:1fr 1fr}
  .nav-inner{padding:0 20px;height:58px}
  .nav-cta{display:none}
  .nav{backdrop-filter:none;-webkit-backdrop-filter:none;background:#fff}
  .hamburger{display:flex}
  .nav-links{
    position:fixed;top:0;right:0;bottom:0;left:auto;
    width:min(360px,84vw);
    background:#fff;
    flex-direction:column;align-items:stretch;justify-content:flex-start;
    gap:0;padding:88px 28px 40px;
    transform:translateX(100%);
    transition:transform .42s cubic-bezier(.2,.7,.2,1);
    z-index:60;overflow-y:auto;
    box-shadow:-30px 0 80px -20px rgba(0,0,0,.25);
  }
  .nav-links.open{transform:translateX(0)}
  .nav-links a{
    padding:18px 4px;font-size:22px;font-weight:500;
    border-radius:0;border-bottom:1px solid rgba(0,0,0,.06);
    text-align:left;
    opacity:0;transform:translateX(20px);
    transition:opacity .5s cubic-bezier(.2,.7,.2,1),transform .5s cubic-bezier(.2,.7,.2,1),color .25s;
  }
  .nav-links.open a{opacity:1;transform:translateX(0)}
  .nav-links.open a:nth-child(1){transition-delay:.10s}
  .nav-links.open a:nth-child(2){transition-delay:.16s}
  .nav-links.open a:nth-child(3){transition-delay:.22s}
  .nav-links.open a:nth-child(4){transition-delay:.28s}
  .nav-links.open a:nth-child(5){transition-delay:.34s}
  .nav-links a:hover,.nav-links a.active{color:var(--green);background:transparent}
}
@media (max-width:680px){
  section{padding:80px 20px}
  .page-hero{padding:90px 20px 70px}
  h1{font-size:clamp(42px,11vw,64px)}
  h2{font-size:clamp(32px,8vw,48px)}
  .ctas{flex-direction:column;align-items:stretch;gap:10px}
  .ctas .btn{justify-content:center;width:100%}
  .foot-top{grid-template-columns:1fr}
  .foot-bottom{flex-direction:column;text-align:center}
  .foot-legal a{margin:0 8px}
}
