/* ============================================================
   Apex Field Reports — "Field Steel" design system
   Shared across the marketing site. Direction A.
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Saira+Condensed:wght@500;600;700;800&family=IBM+Plex+Sans:wght@400;500;600&family=IBM+Plex+Mono:wght@400;500;600&display=swap');

:root{
  --bg:#15171b;
  --bg2:#1b1e23;
  --surface:#22262c;
  --surface2:#282d34;
  --line:#343a42;
  --line-soft:#2a2f36;
  --text:#eef0f2;
  --muted:#969da6;
  --muted2:#6f7780;
  --hi:#ffcc00;        /* high-vis caution yellow */
  --hi-dim:#a8850a;
  --hi-ink:#1a1500;    /* near-black for text on yellow */
  --steel:#7d8b99;
  --ok:#39c07a;
  --radius:4px;
  --maxw:1180px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--text);
  font-family:'IBM Plex Sans',system-ui,sans-serif;
  font-size:17px;line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 32px}
.wrap-wide{max-width:1320px;margin:0 auto;padding:0 32px}
.mono{font-family:'IBM Plex Mono',monospace}
.disp{font-family:'Saira Condensed',sans-serif;font-weight:700;line-height:0.95;letter-spacing:-0.01em}
a{color:inherit;text-decoration:none}

.eyebrow{
  font-family:'IBM Plex Mono',monospace;
  font-size:12.5px;font-weight:500;letter-spacing:0.18em;text-transform:uppercase;
  color:var(--hi);display:inline-flex;align-items:center;gap:10px;
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--hi);display:inline-block}
.eyebrow.center{justify-content:center}

/* hazard stripe */
.hazard{background-image:repeating-linear-gradient(135deg,var(--hi) 0 11px,#15171b 11px 22px);height:6px;width:100%}

/* ---------- buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  font-family:'IBM Plex Mono',monospace;font-weight:600;font-size:14px;
  letter-spacing:0.04em;text-transform:uppercase;
  padding:15px 26px;border-radius:var(--radius);border:1px solid transparent;cursor:pointer;
  transition:transform .12s ease, background .15s ease, box-shadow .15s ease, border-color .15s ease;
}
.btn-primary{background:var(--hi);color:var(--hi-ink);box-shadow:0 0 0 1px var(--hi), 0 8px 24px -10px rgba(255,204,0,.6)}
.btn-primary:hover{background:#ffd633;transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--text);border-color:var(--line)}
.btn-ghost:hover{border-color:var(--steel);background:var(--surface)}
.btn-lg{padding:18px 34px;font-size:15px}
.btn-sm{padding:11px 18px;font-size:12.5px}

/* ---------- nav ---------- */
/* Sticky bar stays at 70px so the page content below isn't shoved
   down — the brand tile is deliberately oversized and allowed to
   overflow the bar (overflow:visible on both the bar and the inner
   row). The drop shadow lets the tile read as a badge "hanging" off
   the nav into the hero area. */
header.nav{position:sticky;top:0;z-index:50;background:rgba(21,23,27,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line-soft);overflow:visible}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:70px;overflow:visible}
/* Brand tile: actual Apex Field Reports logo PNG on a high-vis yellow
   ground. Sized larger than the nav band so it visibly overhangs;
   raised z-index so the overhang renders above the page-hero. */
.logo{display:inline-flex;align-items:center;justify-content:center;padding:10px 18px;background:var(--hi);border-radius:8px;line-height:0;box-shadow:0 0 0 1px rgba(0,0,0,.18) inset, 0 14px 36px -16px rgba(0,0,0,.7);transition:filter .15s,transform .15s;position:relative;z-index:2}
.logo:hover{filter:brightness(1.05);transform:translateY(-1px)}
.logo img{display:block;height:90px;width:auto}
/* Even larger lockup in the footer brand block — no nav-band
   constraint there so it can breathe. */
.foot-brand .logo{padding:14px 22px}
.foot-brand .logo img{height:110px}
@media(max-width:560px){
    .logo{padding:8px 14px}
    .logo img{height:64px}
    .foot-brand .logo img{height:88px}
}
nav.links{display:flex;align-items:center;gap:30px}
nav.links a{font-size:14.5px;color:var(--muted);font-weight:500;transition:color .15s}
nav.links a:hover,nav.links a.active{color:var(--text)}
.nav-cta{display:flex;align-items:center;gap:18px}
.nav-cta .login{font-family:'IBM Plex Mono',monospace;font-size:13.5px;color:var(--muted)}
.nav-cta .login:hover{color:var(--text)}
@media(max-width:920px){nav.links{display:none}}

/* ---------- section base ---------- */
section.sec{padding:96px 0;border-bottom:1px solid var(--line-soft)}
section.sec.tight{padding:72px 0}
.sec-head{max-width:720px;margin-bottom:54px}
.sec-head.center{margin-left:auto;margin-right:auto;text-align:center}
.sec-head h2{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:clamp(34px,4vw,56px);line-height:0.98;text-transform:uppercase;letter-spacing:-0.01em;margin:18px 0 16px}
.sec-head p{font-size:18px;color:var(--muted);max-width:38em}
.sec-head.center p{margin-left:auto;margin-right:auto}

/* page hero (interior pages) */
.page-hero{position:relative;padding:78px 0 64px;border-bottom:1px solid var(--line-soft);overflow:hidden}
.page-hero::before{content:"";position:absolute;inset:0;z-index:0;background:radial-gradient(900px 460px at 75% -20%,rgba(255,204,0,.08),transparent 60%),linear-gradient(180deg,var(--bg2),var(--bg))}
.page-hero-grid{position:absolute;inset:0;z-index:0;opacity:.4;background-image:linear-gradient(var(--line-soft) 1px,transparent 1px),linear-gradient(90deg,var(--line-soft) 1px,transparent 1px);background-size:54px 54px;mask-image:radial-gradient(circle at 28% 10%,#000,transparent 75%)}
.page-hero .inner{position:relative;z-index:1;max-width:780px}
.page-hero h1{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:clamp(40px,5.4vw,76px);line-height:0.92;letter-spacing:-0.015em;text-transform:uppercase;margin:20px 0 20px}
.page-hero h1 .accent{color:var(--hi)}
.page-hero p.lead{font-size:19px;color:var(--muted);max-width:36em}
.hero-cta{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin-top:30px}
.hero-note{font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--muted2);margin-top:18px;display:flex;align-items:center;gap:8px}
.hero-note b{color:var(--steel);font-weight:500}
.dot{width:6px;height:6px;border-radius:50%;background:var(--hi);display:inline-block;flex:none}

/* ---------- placeholder + device ---------- */
.ph{position:relative;background:repeating-linear-gradient(135deg,#1f2329 0 14px,#23282f 14px 28px);border:1px solid var(--line);border-radius:var(--radius);display:grid;place-items:center;color:var(--muted2)}
.ph .ph-label{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.08em;text-transform:uppercase;background:var(--bg);padding:6px 12px;border:1px solid var(--line);border-radius:3px;text-align:center;max-width:80%}
.device{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:8px;padding:12px;box-shadow:0 40px 80px -40px rgba(0,0,0,.8)}
.device .bar{display:flex;align-items:center;gap:6px;padding:4px 4px 12px}
.device .bar i{width:9px;height:9px;border-radius:50%;background:var(--line);display:block}
.device .screen{border-radius:4px}

/* Real-image swap of a .ph placeholder. Same border/radius so the slot
   looks identical pre-swap-vs-post-swap; aspect-ratio comes from an
   inline style on the wrapper, so a 9/16 phone shot and an 8.5/11 PDF
   page can sit in the same grid.

   .shot defaults to object-fit:cover so a screenshot that doesn't
   perfectly match the slot ratio still fills the box without
   letterboxing. Use .shot.contain on PDF/page mockups where the
   whole document needs to be visible. */
.shot{position:relative;overflow:hidden;border:1px solid var(--line);border-radius:var(--radius);background:var(--bg2);display:block}
.shot img{display:block;width:100%;height:100%;object-fit:cover;cursor:zoom-in;transition:filter .15s}
.shot:hover img{filter:brightness(1.08)}
.shot.contain{background:#fff}
.shot.contain img{object-fit:contain}

/* ---------- lightbox (clickable screenshots) ----------
   Triggered by clicking any .shot img — the layout binds a single
   delegated handler so newly-added .shot blocks pick it up without
   per-page wiring. PDF/page mockups (.shot.contain) get a white
   inset in the modal so their content doesn't run into the backdrop. */
.lightbox{position:fixed;inset:0;background:rgba(0,0,0,.88);display:flex;align-items:center;justify-content:center;z-index:1000;cursor:zoom-out;padding:2.5rem}
.lightbox img{max-width:95vw;max-height:95vh;border-radius:6px;box-shadow:0 20px 60px rgba(0,0,0,.6);cursor:default}
.lightbox.lightbox-paper img{background:#fff;padding:24px 20px}
.lightbox-close{position:absolute;top:1rem;right:1rem;width:40px;height:40px;border:0;border-radius:50%;background:rgba(255,255,255,.12);color:#fff;font-size:1.6rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;padding:0}
.lightbox-close:hover{background:rgba(255,255,255,.24)}

/* ---------- generic cards ---------- */
.cardgrid{display:grid;gap:1px;background:var(--line-soft);border:1px solid var(--line-soft);border-radius:var(--radius);overflow:hidden}
.cardgrid.cols-3{grid-template-columns:repeat(3,1fr)}
.cardgrid.cols-2{grid-template-columns:repeat(2,1fr)}
.cell{background:var(--surface);padding:34px 30px 36px;transition:background .2s}
.cell:hover{background:var(--surface2)}
.cell .num{font-family:'IBM Plex Mono',monospace;font-size:12px;color:var(--hi);letter-spacing:0.1em}
.cell .ico{width:46px;height:46px;border:1px solid var(--line);border-radius:6px;display:grid;place-items:center;margin:18px 0 22px;background:var(--bg2)}
.cell .ico svg{width:24px;height:24px;stroke:var(--hi);fill:none;stroke-width:1.7}
.cell h3{font-family:'Saira Condensed',sans-serif;font-weight:700;font-size:24px;text-transform:uppercase;letter-spacing:0.01em;margin-bottom:11px}
.cell p{color:var(--muted);font-size:15.5px}
.cell-more{margin-top:16px;font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--hi);letter-spacing:0.04em;display:inline-flex;align-items:center;gap:7px;transition:gap .15s}
.cell:hover .cell-more{gap:11px}
@media(max-width:860px){.cardgrid.cols-3,.cardgrid.cols-2{grid-template-columns:1fr}}

/* checks list */
.checks{list-style:none;display:flex;flex-direction:column;gap:16px}
.checks li{display:flex;gap:14px;align-items:flex-start}
.checks .ck{flex:none;width:24px;height:24px;border-radius:4px;background:rgba(255,204,0,.14);border:1px solid var(--hi-dim);display:grid;place-items:center;margin-top:2px}
.checks .ck svg{width:14px;height:14px;stroke:var(--hi);fill:none;stroke-width:2.6}
.checks li b{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:18px;text-transform:uppercase;letter-spacing:0.01em;display:block;margin-bottom:2px}
.checks li span{color:var(--muted);font-size:15px}

/* ---------- trades / strip ---------- */
.strip{border-bottom:1px solid var(--line-soft);background:var(--bg2)}
.strip-inner{padding:28px 0;display:flex;align-items:center;gap:30px;flex-wrap:wrap;justify-content:center}
.strip .lbl{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.14em;text-transform:uppercase;color:var(--muted2)}
.trade{font-family:'Saira Condensed',sans-serif;font-weight:600;font-size:19px;text-transform:uppercase;color:var(--steel);letter-spacing:0.02em}

/* ---------- final CTA band ---------- */
.cta{position:relative;padding:104px 0;text-align:center;overflow:hidden;border-bottom:1px solid var(--line-soft)}
.cta::before{content:"";position:absolute;inset:0;background:radial-gradient(700px 400px at 50% 120%,rgba(255,204,0,.14),transparent 60%)}
.cta-inner{position:relative;z-index:1}
.cta h2{font-family:'Saira Condensed',sans-serif;font-weight:800;font-size:clamp(40px,5.5vw,76px);text-transform:uppercase;line-height:0.95;letter-spacing:-0.01em;margin-bottom:20px}
.cta p{color:var(--muted);font-size:19px;max-width:32em;margin:0 auto 34px}

/* ---------- footer ---------- */
footer.site{background:var(--bg2);border-top:1px solid var(--line-soft);padding:56px 0 40px}
.foot-top{display:flex;justify-content:space-between;gap:48px;flex-wrap:wrap;padding-bottom:36px;border-bottom:1px solid var(--line-soft)}
.foot-brand{max-width:320px}
.foot-brand p{color:var(--muted);font-size:14.5px;margin-top:16px}
.foot-social{display:flex;gap:12px;margin-top:20px}
.foot-social a{width:34px;height:34px;border:1px solid var(--line);border-radius:6px;display:grid;place-items:center;color:var(--muted);transition:all .15s}
.foot-social a:hover{color:var(--hi);border-color:var(--hi-dim)}
.foot-social svg{width:16px;height:16px;fill:currentColor}
.foot-cols{display:flex;gap:60px;flex-wrap:wrap}
.foot-col h4{font-family:'IBM Plex Mono',monospace;font-size:12px;letter-spacing:0.12em;text-transform:uppercase;color:var(--muted2);margin-bottom:16px}
.foot-col a{display:block;color:var(--muted);font-size:14.5px;margin-bottom:11px;transition:color .15s}
.foot-col a:hover{color:var(--text)}
.foot-bottom{padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;font-family:'IBM Plex Mono',monospace;font-size:12.5px;color:var(--muted2)}
.foot-bottom a{color:var(--muted2)}
.foot-bottom a:hover{color:var(--text)}

/* trades footer columns get tighter */
.foot-col.trades{columns:2;column-gap:40px}
.foot-col.trades a{margin-bottom:9px}
