/* ship.css — SHIP landing system. Geist · dark editorial · single teal accent. */

:root{
  --bg:#0A0A0C; --bg2:#101013; --surface:#131318; --surface2:#1A1A20;
  --line:#1F1F22; --line2:#2A2A30;
  --text:#ECEAE3; --dim:#A5A29A; --mute:#6E6B64;
  --accent:#5FB3A1; --accent-bg:rgba(95,179,161,.10); --accent-line:rgba(95,179,161,.28);
  --glow:rgba(95,179,161,.30);
  --sans:"Geist",-apple-system,system-ui,sans-serif;
  --mono:"Geist Mono",ui-monospace,SFMono-Regular,monospace;
  --maxw:1200px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; background:var(--bg); color:var(--text);
  font-family:var(--sans); -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale; line-height:1.5;
  overflow-x:hidden;
}
a{color:inherit; text-decoration:none}
img{display:block; max-width:100%}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 32px}
.mono{font-family:var(--mono); text-transform:uppercase; letter-spacing:.16em}
.kicker{font-family:var(--mono); font-size:13px; text-transform:uppercase;
  letter-spacing:.18em; color:var(--accent)}

/* ── Nav ───────────────────────────────────────────── */
.nav{position:fixed; top:0; left:0; right:0; z-index:50;
  border-bottom:1px solid transparent; transition:.3s background,.3s border-color,.3s backdrop-filter}
.nav.scrolled{background:rgba(10,10,12,.78); backdrop-filter:blur(18px);
  border-bottom:1px solid var(--line)}
.nav .row{display:flex; align-items:center; justify-content:space-between; height:76px}
.brand{display:flex; align-items:center; gap:11px; font-weight:500; font-size:20px;
  letter-spacing:-.02em}
.brand img{width:30px; height:30px; border-radius:7px}
.nav-links{display:flex; align-items:center; gap:34px}
.nav-links a{font-size:14px; color:var(--dim); transition:color .15s}
.nav-links a:hover{color:var(--text)}
.nav-cta{display:flex; align-items:center; gap:14px}

/* ── Buttons ───────────────────────────────────────── */
.btn{display:inline-flex; align-items:center; gap:9px; height:46px; padding:0 20px;
  border-radius:12px; font-size:14.5px; font-weight:500; letter-spacing:-.01em;
  cursor:pointer; border:1px solid transparent; transition:.18s transform,.18s box-shadow,.18s background,.18s border-color; white-space:nowrap}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--text); color:var(--bg)}
.btn-primary.glow{box-shadow:0 0 0 1px var(--accent-line), 0 0 34px var(--glow)}
.btn-primary:hover{box-shadow:0 0 0 1px var(--accent-line), 0 0 44px var(--glow)}
.btn-ghost{background:transparent; color:var(--text); border-color:var(--line2)}
.btn-ghost:hover{border-color:var(--accent-line); background:var(--surface)}
.btn-sm{height:40px; padding:0 16px; font-size:13.5px}
.btn svg{width:17px; height:17px}

/* ── Section scaffolding ───────────────────────────── */
section{position:relative}
.sec-pad{padding:120px 0}
.eyebrow-row{display:flex; align-items:center; gap:14px; margin-bottom:26px}
.eyebrow-row .ln{height:1px; width:42px; background:var(--accent-line)}
h1,h2,h3{margin:0; font-weight:500; letter-spacing:-.03em; text-wrap:balance}
.lead{color:var(--dim); text-wrap:pretty}

/* ── Hero ──────────────────────────────────────────── */
.hero{padding:188px 0 90px; position:relative; overflow:hidden}
.hero-grid{display:grid; grid-template-columns:1.05fr .95fr; gap:56px; align-items:center}
.hero h1{font-size:clamp(48px,6.4vw,92px); line-height:.95}
.hero .lead{font-size:21px; line-height:1.5; max-width:520px; margin:30px 0 38px}
.hero-cta{display:flex; gap:14px; flex-wrap:wrap}
.hero-tags{display:flex; gap:10px; margin-top:42px; flex-wrap:wrap}
.tag{display:inline-flex; align-items:center; gap:8px; padding:7px 14px; border-radius:999px;
  border:1px solid var(--line2); background:var(--surface);
  font-family:var(--mono); font-size:11px; text-transform:uppercase; letter-spacing:.12em; color:var(--dim)}
.tag .dot{width:5px; height:5px; border-radius:50%; background:var(--accent)}

/* glow blob behind hero */
.hero::before{content:""; position:absolute; top:-10%; right:-8%;
  width:620px; height:620px; border-radius:50%;
  background:radial-gradient(circle,rgba(95,179,161,.12),transparent 62%);
  pointer-events:none; filter:blur(8px)}

/* ── Phone mock ────────────────────────────────────── */
.phone{width:330px; height:690px; border-radius:42px; background:var(--bg);
  border:2px solid #2a2a30; box-shadow:0 50px 110px rgba(0,0,0,.6), 0 0 0 7px #16161b;
  margin:0 auto; overflow:hidden; display:flex; flex-direction:column; position:relative}
.phone .statusbar{height:34px; display:flex; align-items:center; justify-content:space-between;
  padding:0 18px; font-size:12px; color:var(--text); font-weight:500}
.phone .notch{position:absolute; left:50%; top:8px; transform:translateX(-50%);
  width:18px; height:18px; border-radius:50%; background:#000}
.phone .screen{flex:1; overflow:hidden; position:relative}
.phone .navpill{height:20px; display:flex; align-items:center; justify-content:center}
.phone .navpill i{width:108px; height:4px; border-radius:2px; background:var(--text); opacity:.5}

.pscreen{padding:18px 18px 0; display:flex; flex-direction:column; height:100%}
.ptop{display:flex; align-items:center; justify-content:space-between; padding-bottom:14px;
  border-bottom:1px solid var(--line)}
.ptop .l{display:flex; align-items:center; gap:9px}
.ptop .l img{width:24px; height:24px; border-radius:6px}
.ptop .l b{font-size:14px; font-weight:500}
.ptop .l span{font-family:var(--mono); font-size:9px; color:var(--accent);
  text-transform:uppercase; letter-spacing:.14em; display:block; margin-top:2px}
.cpill{display:inline-flex; align-items:center; gap:7px; padding:5px 11px 5px 7px;
  border:1px solid var(--line2); border-radius:999px; font-family:var(--mono);
  font-size:11px; color:var(--text)}
.cpill .o{width:16px; height:16px; border-radius:50%; background:var(--accent-bg);
  border:1px solid var(--accent-line); display:flex; align-items:center; justify-content:center}
.cpill .o i{width:5px; height:5px; border-radius:50%; background:var(--accent)}

.umsg{align-self:flex-end; max-width:80%; margin:16px 0 14px; padding:9px 13px;
  background:var(--surface); border:1px solid var(--line2);
  border-radius:13px 13px 4px 13px; font-size:12.5px; color:var(--text)}
.bevent{display:flex; align-items:center; gap:9px; margin-bottom:11px}
.bevent .ck{width:17px; height:17px; border-radius:50%; background:var(--accent-bg);
  border:1px solid var(--accent-line); display:flex; align-items:center; justify-content:center; flex:0 0 auto}
.bevent .ck svg{width:9px; height:9px}
.bevent span{font-size:12px; color:var(--dim)}
.readycard{margin-top:6px; padding:17px; background:var(--bg2);
  border:1px solid var(--accent-line); border-radius:16px; position:relative; overflow:hidden}
.readycard::before{content:""; position:absolute; top:0; left:0; right:0; height:1px;
  background:linear-gradient(90deg,transparent,var(--accent),transparent)}
.readycard .rt{display:flex; justify-content:space-between; align-items:center; margin-bottom:11px}
.readycard h5{margin:0; font-size:18px; font-weight:500; letter-spacing:-.02em}
.readycard p{margin:5px 0 13px; font-size:11.5px; color:var(--dim); line-height:1.45}
.openbtn{display:flex; align-items:center; justify-content:space-between;
  padding:9px 13px; border-radius:11px; background:var(--text); color:var(--bg);
  font-size:12.5px; font-weight:500}
.openbtn svg{width:13px; height:13px}

/* ── Trust strip ───────────────────────────────────── */
.strip{border-top:1px solid var(--line); border-bottom:1px solid var(--line); padding:30px 0}
.strip .row{display:flex; align-items:center; justify-content:space-between; gap:28px; flex-wrap:wrap}
.strip .item{display:flex; align-items:center; gap:11px; color:var(--dim);
  font-family:var(--mono); font-size:13px; text-transform:uppercase; letter-spacing:.1em}
.strip .item svg{width:19px; height:19px; stroke:var(--accent); fill:none; stroke-width:1.5}

/* ── Section header ────────────────────────────────── */
.sec-head{max-width:720px; margin-bottom:64px}
.sec-head h2{font-size:clamp(34px,4.4vw,58px); line-height:1.02}
.sec-head .lead{font-size:19px; margin-top:22px; max-width:600px}

/* ── Feature grid ──────────────────────────────────── */
.fgrid{display:grid; grid-template-columns:repeat(2,1fr); gap:20px}
.fcard{padding:38px; background:var(--surface); border:1px solid var(--line);
  border-radius:22px; position:relative; overflow:hidden; transition:.25s border-color,.25s transform}
.fcard:hover{border-color:var(--accent-line); transform:translateY(-3px)}
.fcard .ix{font-family:var(--mono); font-size:12px; color:var(--accent); letter-spacing:.16em}
.fcard h3{font-size:27px; margin:22px 0 12px; letter-spacing:-.02em}
.fcard p{margin:0; color:var(--dim); font-size:16px; line-height:1.55; text-wrap:pretty}
.fcard .gico{width:46px; height:46px; border-radius:12px; background:var(--bg);
  border:1px solid var(--line2); display:flex; align-items:center; justify-content:center}
.fcard .gico svg{width:22px; height:22px; stroke:var(--accent); fill:none; stroke-width:1.5}

/* ── Steps ─────────────────────────────────────────── */
.steps{display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--line);
  border-radius:22px; overflow:hidden}
.step{padding:38px 30px; border-right:1px solid var(--line); position:relative}
.step:last-child{border-right:none}
.step .n{font-family:var(--mono); font-size:13px; color:var(--accent); letter-spacing:.16em; margin-bottom:auto}
.step h4{font-size:21px; margin:22px 0 10px; font-weight:500; letter-spacing:-.02em}
.step p{margin:0; font-size:14.5px; color:var(--dim); line-height:1.5}

/* ── Showcase ──────────────────────────────────────── */
.shots{display:flex; gap:24px; justify-content:center; align-items:flex-end; flex-wrap:wrap}

/* ── FAQ ───────────────────────────────────────────── */
.faq{max-width:820px; margin:0 auto}
.qa{border-bottom:1px solid var(--line)}
.qa summary{list-style:none; cursor:pointer; padding:28px 0; display:flex;
  align-items:center; justify-content:space-between; gap:20px; font-size:20px;
  font-weight:500; letter-spacing:-.01em}
.qa summary::-webkit-details-marker{display:none}
.qa summary .pm{width:26px; height:26px; flex:0 0 auto; border:1px solid var(--line2);
  border-radius:50%; position:relative; transition:.2s}
.qa summary .pm::before,.qa summary .pm::after{content:""; position:absolute; left:50%; top:50%;
  width:11px; height:1.5px; background:var(--dim); transform:translate(-50%,-50%); transition:.2s}
.qa summary .pm::after{transform:translate(-50%,-50%) rotate(90deg)}
.qa[open] summary .pm{border-color:var(--accent-line)}
.qa[open] summary .pm::after{opacity:0}
.qa p{margin:0; padding:0 0 28px; color:var(--dim); font-size:16px; line-height:1.6; max-width:680px}

/* ── CTA band ──────────────────────────────────────── */
.ctaband{text-align:center; padding:130px 0; position:relative; overflow:hidden}
.ctaband::before{content:""; position:absolute; left:50%; top:50%; transform:translate(-50%,-50%);
  width:760px; height:520px; border-radius:50%;
  background:radial-gradient(circle,rgba(95,179,161,.13),transparent 62%); pointer-events:none}
.ctaband h2{font-size:clamp(40px,5.6vw,76px); line-height:.98; position:relative}
.ctaband .lead{font-size:20px; margin:26px auto 40px; max-width:520px; position:relative}
.ctaband .hero-cta{justify-content:center; position:relative}

/* waterline */
.waterline{width:100%; height:2px; background:linear-gradient(90deg,transparent,var(--accent),transparent); opacity:.7}

/* ── Footer ────────────────────────────────────────── */
footer{border-top:1px solid var(--line); padding:72px 0 44px}
.foot-grid{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; margin-bottom:56px}
.foot-brand .brand{margin-bottom:18px}
.foot-brand p{color:var(--mute); font-size:14px; max-width:260px; line-height:1.55; margin:0}
.foot-col h6{margin:0 0 18px; font-family:var(--mono); font-size:11px; color:var(--mute);
  text-transform:uppercase; letter-spacing:.16em; font-weight:500}
.foot-col a{display:block; color:var(--dim); font-size:14.5px; margin-bottom:13px; transition:color .15s}
.foot-col a:hover{color:var(--text)}
.foot-bottom{display:flex; align-items:center; justify-content:space-between; gap:20px;
  padding-top:32px; border-top:1px solid var(--line); flex-wrap:wrap}
.foot-bottom .cp{font-family:var(--mono); font-size:12px; color:var(--mute); letter-spacing:.08em}
.foot-bottom .soc{display:flex; gap:10px}
.foot-bottom .soc a{width:40px; height:40px; border:1px solid var(--line2); border-radius:11px;
  display:flex; align-items:center; justify-content:center; color:var(--dim); transition:.18s}
.foot-bottom .soc a:hover{border-color:var(--accent-line); color:var(--text)}
.foot-bottom .soc svg{width:17px; height:17px}

/* ── Reveal anim ───────────────────────────────────── */
/* Content is ALWAYS visible by default. The reveal is purely additive: JS adds
   .in, which replays a subtle fade-up keyframe. If JS/IO never runs, nothing is
   hidden — content simply shows with no animation. Cannot ever blank the page. */
.reveal{opacity:1; transform:none}
@keyframes revealUp{from{opacity:0; transform:translateY(22px)} to{opacity:1; transform:none}}
.js .reveal.in{animation:revealUp .7s cubic-bezier(.2,.7,.3,1) both}
@media (prefers-reduced-motion:reduce){.js .reveal.in{animation:none}}

/* ── Legal pages ───────────────────────────────────── */
.legal{padding:160px 0 100px; max-width:820px; margin:0 auto}
.legal .kicker{margin-bottom:18px; display:block}
.legal h1{font-size:clamp(40px,6vw,68px); line-height:1; margin-bottom:18px}
.legal .updated{font-family:var(--mono); font-size:12px; color:var(--mute);
  text-transform:uppercase; letter-spacing:.12em; margin-bottom:54px}
.legal h2{font-size:25px; margin:48px 0 16px; letter-spacing:-.02em}
.legal h3{font-size:18px; margin:30px 0 10px; color:var(--text); font-weight:500}
.legal p,.legal li{color:var(--dim); font-size:16px; line-height:1.7; text-wrap:pretty}
.legal p{margin:0 0 16px}
.legal ul{margin:0 0 16px; padding-left:22px}
.legal li{margin-bottom:9px}
.legal a{color:var(--accent); text-decoration:underline; text-underline-offset:3px}
.legal strong{color:var(--text); font-weight:500}
.legal .toc{padding:24px 28px; background:var(--surface); border:1px solid var(--line);
  border-radius:16px; margin-bottom:48px}
.legal .toc h6{margin:0 0 14px; font-family:var(--mono); font-size:11px; color:var(--mute);
  text-transform:uppercase; letter-spacing:.16em}
.legal .toc a{display:inline-block; margin:0 18px 8px 0; font-size:14px; text-decoration:none; color:var(--dim)}
.legal .toc a:hover{color:var(--accent)}

/* ── Responsive ────────────────────────────────────── */
@media (max-width:900px){
  .hero-grid{grid-template-columns:1fr; gap:48px}
  .hero-phone{order:-1}
  .fgrid{grid-template-columns:1fr}
  .steps{grid-template-columns:1fr 1fr}
  .step:nth-child(2n){border-right:none}
  .step{border-bottom:1px solid var(--line)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-links{display:none}
}
@media (max-width:560px){
  .wrap{padding:0 20px}
  .sec-pad{padding:84px 0}
  .steps{grid-template-columns:1fr}
  .step{border-right:none; border-bottom:1px solid var(--line)}
  .foot-grid{grid-template-columns:1fr 1fr}
  .nav-cta .btn-ghost{display:none}
}
