/* Sourcing Captain — sub1.jettseo.pro
   Design tokens, layout primitives, and section variants */

:root{
  --ink:#0c1322;
  --ink-2:#243049;
  --muted:#5a657c;
  --line:#e6e9f1;
  --bg:#ffffff;
  --bg-soft:#f5f7fb;
  --bg-deep:#0c1322;
  --brand:#0a5cd6;
  --brand-2:#0e7be0;
  --accent:#ff7a18;
  --good:#1aa56b;
  --shadow:0 12px 40px rgba(12,19,34,.08);
  --radius:14px;
  --radius-lg:22px;
  --max:1180px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font:16px/1.65 -apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  color:var(--ink);
  background:var(--bg);
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}
h1,h2,h3,h4{font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;color:var(--ink);line-height:1.18;letter-spacing:-.01em;margin:0 0 .5em}
h1{font-size:clamp(2rem,4.4vw,3.4rem);font-weight:800;letter-spacing:-.02em}
h2{font-size:clamp(1.55rem,2.6vw,2.2rem);font-weight:800}
h3{font-size:1.25rem;font-weight:700}
p{margin:0 0 1em}
ul{margin:0 0 1em;padding-left:1.2em}
.container{max-width:var(--max);margin:0 auto;padding:0 24px}

/* ---------- Header ---------- */
.site-header{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:inline-flex;align-items:center;gap:10px;font-weight:800;color:var(--ink);text-decoration:none;font-size:1.1rem}
.brand-mark{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border-radius:9px;background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff;font-weight:900;font-size:.9rem;letter-spacing:.5px}
.primary-nav{display:flex;gap:22px;align-items:center}
.primary-nav a{color:var(--ink-2);font-weight:600;font-size:.95rem}
.primary-nav a:hover{color:var(--brand);text-decoration:none}
.btn{display:inline-block;padding:.75em 1.4em;border-radius:10px;font-weight:700;text-decoration:none;transition:transform .15s ease,box-shadow .15s ease;font-size:.95rem}
.btn-cta{background:linear-gradient(135deg,var(--brand),var(--brand-2));color:#fff!important;box-shadow:0 6px 20px rgba(10,92,214,.28)}
.btn-cta:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(10,92,214,.36);text-decoration:none}
.btn-ghost{background:transparent;border:2px solid #fff;color:#fff!important}
.btn-ghost:hover{background:#fff;color:var(--brand)!important}

/* ---------- Hero variants ---------- */
.hero{position:relative;color:#fff;overflow:hidden}
.hero .container{position:relative;z-index:2}
.hero h1{color:#fff}
.hero .lede{font-size:1.18rem;max-width:640px;color:rgba(255,255,255,.9);margin-bottom:1.6em}
.hero .meta{display:flex;gap:24px;flex-wrap:wrap;margin-top:24px;color:rgba(255,255,255,.85);font-size:.95rem}
.hero .meta strong{color:#fff}
.hero-actions{display:flex;gap:12px;flex-wrap:wrap}

/* hero variant A — full bleed image right */
.hero-a{padding:80px 0;background:linear-gradient(120deg,#0a1d3d 0%,#0c2c5c 60%,#0e3f7a 100%)}
.hero-a .grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.hero-a .visual{border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);aspect-ratio:5/4;background-position:center;background-size:cover}

/* hero variant B — centered with stat strip */
.hero-b{padding:96px 0 72px;background:radial-gradient(ellipse at top,#15315f 0%,#0a1428 70%)}
.hero-b .center{max-width:840px;margin:0 auto;text-align:center}
.hero-b .center .lede{margin:0 auto 2em}
.hero-b .stats{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:54px}
.hero-b .stat{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12);padding:22px;border-radius:14px;text-align:center}
.hero-b .stat b{display:block;font-size:1.7rem;color:#fff}
.hero-b .stat span{font-size:.85rem;color:rgba(255,255,255,.7)}

/* hero variant C — diagonal split */
.hero-c{padding:88px 0;background:linear-gradient(95deg,#0a1d3d 50%,#0c4ea8 50%)}
.hero-c .grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center}
.hero-c .visual{border-radius:24px;overflow:hidden;aspect-ratio:4/3;background-size:cover;background-position:center;border:6px solid rgba(255,255,255,.1)}

/* hero variant D — tape over image, animated */
.hero-d{padding:0;min-height:540px;display:flex;align-items:center;background-size:cover;background-position:center;position:relative}
.hero-d::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,rgba(7,15,30,.92) 0%,rgba(7,15,30,.55) 60%,rgba(7,15,30,.2) 100%);z-index:1}
.hero-d .container{padding:90px 24px}
.hero-d .pill{display:inline-block;padding:.4em 1em;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.25);border-radius:99px;font-size:.78rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;margin-bottom:1em;color:#fff}

/* hero variant E — minimal, copy first */
.hero-e{padding:96px 0;background:#0a1322;border-bottom:1px solid #1a2440}
.hero-e .grid{display:grid;grid-template-columns:1.4fr 1fr;gap:60px;align-items:end}
.hero-e .visual{border-radius:16px;overflow:hidden;aspect-ratio:1/1;background-size:cover;background-position:center}

/* hero variant F — animated gradient with ticker */
.hero-f{padding:90px 0;background:linear-gradient(135deg,#0a1d3d,#1d3a6a,#0a5cd6,#0a1d3d);background-size:300% 300%;animation:gradient-shift 14s ease infinite}
@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.hero-f .center{max-width:880px}
.hero-f .ticker{margin-top:42px;display:flex;gap:32px;flex-wrap:wrap;color:rgba(255,255,255,.8);font-size:.9rem}
.hero-f .ticker span::before{content:"•";margin-right:10px;color:var(--accent)}

/* ---------- Section utilities ---------- */
.section{padding:84px 0}
.section-tight{padding:64px 0}
.section-soft{background:var(--bg-soft)}
.section-dark{background:var(--bg-deep);color:#fff}
.section-dark h2{color:#fff}
.section-dark .muted{color:rgba(255,255,255,.7)}
.eyebrow{display:inline-block;font-size:.78rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--brand);margin-bottom:.6em}
.eyebrow.on-dark{color:#7eb7ff}
.lede{font-size:1.1rem;color:var(--muted);max-width:680px}

/* ---------- What is / why need (text-rich) ---------- */
.text-block .grid-2{display:grid;grid-template-columns:1.05fr .95fr;gap:60px;align-items:start}
.text-block .grid-2 .body{font-size:1.05rem;color:var(--ink-2)}
.text-block .visual{border-radius:var(--radius-lg);overflow:hidden;aspect-ratio:5/4;background-size:cover;background-position:center;box-shadow:var(--shadow)}
.text-block .grid-rev{grid-template-columns:.95fr 1.05fr}
.text-block .grid-rev .visual{order:-1}

/* "Why need" callout variant */
.why-block{background:linear-gradient(135deg,#f6f9ff,#eef3ff);border-radius:var(--radius-lg);padding:54px;border:1px solid #dde6fa}
.why-block h2{color:var(--ink)}
.why-block .body{max-width:780px;font-size:1.05rem;color:var(--ink-2)}

/* "Why need" alt — dark band */
.why-band{background:#0a1322;color:#fff;padding:72px 0;border-top:4px solid var(--accent)}
.why-band h2{color:#fff}
.why-band p{color:rgba(255,255,255,.85);max-width:780px}

/* ---------- Process variants ---------- */
.process .steps-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:18px;counter-reset:step}
.process .step{counter-increment:step;background:#fff;border:1px solid var(--line);border-radius:14px;padding:24px;position:relative}
.process .step::before{content:counter(step,decimal-leading-zero);font-size:1.6rem;font-weight:900;color:var(--brand);display:block;margin-bottom:.4em}
.process .step h3{font-size:1.05rem;margin-bottom:.4em}
.process .step p{font-size:.95rem;color:var(--muted);margin:0}

/* process variant — vertical timeline */
.process-timeline{position:relative;max-width:780px;margin:0 auto;padding-left:38px}
.process-timeline::before{content:"";position:absolute;left:14px;top:8px;bottom:8px;width:3px;background:linear-gradient(180deg,var(--brand),var(--accent))}
.process-timeline .step{counter-increment:step;position:relative;padding:18px 0 32px 24px}
.process-timeline .step::before{content:counter(step);position:absolute;left:-38px;top:14px;width:32px;height:32px;background:var(--brand);color:#fff;font-weight:900;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.95rem}
.process-timeline .step h3{font-size:1.1rem;margin-bottom:.3em}
.process-timeline .step p{margin:0;color:var(--muted)}

/* process variant — pill chevrons */
.process-flow{display:flex;flex-wrap:wrap;gap:14px;counter-reset:step}
.process-flow .step{counter-increment:step;flex:1 1 220px;background:#fff;border-left:4px solid var(--accent);padding:20px 22px;border-radius:8px;box-shadow:0 4px 18px rgba(12,19,34,.06)}
.process-flow .step::before{content:"Step " counter(step);display:block;font-size:.75rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--accent);margin-bottom:.4em}

/* ---------- Deliverables variants ---------- */
.deliverables-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.deliverables-cards .card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:24px;transition:transform .15s ease,box-shadow .15s ease}
.deliverables-cards .card:hover{transform:translateY(-2px);box-shadow:var(--shadow)}
.deliverables-cards .card .ic{width:42px;height:42px;border-radius:10px;background:linear-gradient(135deg,var(--brand),var(--brand-2));display:flex;align-items:center;justify-content:center;color:#fff;font-weight:900;margin-bottom:14px}
.deliverables-cards .card h3{font-size:1rem;margin-bottom:.3em}
.deliverables-cards .card p{font-size:.92rem;color:var(--muted);margin:0}

.deliverables-list{display:grid;grid-template-columns:1fr 1fr;gap:0;background:#fff;border:1px solid var(--line);border-radius:14px;overflow:hidden}
.deliverables-list .row{padding:22px 26px;border-bottom:1px solid var(--line);border-right:1px solid var(--line)}
.deliverables-list .row:nth-child(2n){border-right:none}
.deliverables-list .row h3{font-size:1rem;margin-bottom:.25em;color:var(--brand)}
.deliverables-list .row p{font-size:.93rem;color:var(--muted);margin:0}

/* ---------- FAQ variants ---------- */
.faq{max-width:820px;margin:0 auto}
.faq details{background:#fff;border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin-bottom:14px}
.faq details[open]{box-shadow:var(--shadow)}
.faq summary{cursor:pointer;font-weight:700;color:var(--ink);font-size:1.02rem;list-style:none;display:flex;justify-content:space-between;align-items:center}
.faq summary::after{content:"+";font-size:1.4rem;color:var(--brand);font-weight:900}
.faq details[open] summary::after{content:"–"}
.faq details p{margin-top:.8em;color:var(--ink-2)}

.faq-flat{max-width:880px;margin:0 auto}
.faq-flat .qa{padding:24px 0;border-bottom:1px solid var(--line)}
.faq-flat .qa h3{font-size:1.1rem;color:var(--ink);margin-bottom:.5em}
.faq-flat .qa p{margin:0;color:var(--ink-2)}

/* ---------- Related ---------- */
.related-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px}
.related-grid a{display:block;text-decoration:none;color:var(--ink);border:1px solid var(--line);border-radius:14px;overflow:hidden;background:#fff;transition:transform .15s ease,box-shadow .15s ease}
.related-grid a:hover{transform:translateY(-3px);box-shadow:var(--shadow);text-decoration:none}
.related-grid .img{aspect-ratio:16/10;background-size:cover;background-position:center}
.related-grid .body{padding:18px 20px}
.related-grid h3{font-size:1.05rem;margin:0 0 .25em}
.related-grid p{font-size:.88rem;color:var(--muted);margin:0}

/* ---------- Contact form ---------- */
.contact-block{background:linear-gradient(135deg,#0a1d3d,#0a5cd6);color:#fff;border-radius:var(--radius-lg);padding:60px;display:grid;grid-template-columns:1fr 1.1fr;gap:48px;align-items:center}
.contact-block h2{color:#fff}
.contact-block p{color:rgba(255,255,255,.85);max-width:420px}
.contact-block form{display:grid;gap:14px}
.contact-block .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.contact-block input,.contact-block textarea,.contact-block select{
  padding:14px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.18);
  background:rgba(255,255,255,.08);color:#fff;font:inherit;width:100%
}
.contact-block input::placeholder,.contact-block textarea::placeholder{color:rgba(255,255,255,.55)}
.contact-block textarea{min-height:120px;resize:vertical}
.contact-block button{
  background:var(--accent);color:#fff;border:none;padding:14px 26px;border-radius:10px;font-weight:800;font-size:1rem;cursor:pointer;letter-spacing:.02em
}
.contact-block button:hover{filter:brightness(1.08)}
.contact-block .trust{display:flex;gap:18px;flex-wrap:wrap;margin-top:18px;font-size:.85rem;color:rgba(255,255,255,.8)}
.contact-block .trust span::before{content:"✓ ";color:var(--accent);font-weight:900}

/* ---------- Footer ---------- */
.site-footer{background:#070d1c;color:#cbd3e2;padding:64px 0 28px;margin-top:40px}
.site-footer h4{color:#fff;font-size:.95rem;margin-bottom:1em}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1fr;gap:36px}
.footer-grid ul{list-style:none;padding:0;margin:0}
.footer-grid li{margin-bottom:.5em}
.footer-grid a{color:#9ba6bf}
.footer-grid a:hover{color:#fff}
.brand-light{color:#fff}
.brand-light .brand-text{color:#fff}
.muted{color:#8a92a8}
.footer-bottom{display:flex;justify-content:space-between;flex-wrap:wrap;gap:16px;margin-top:42px;padding-top:24px;border-top:1px solid #182037;color:#8a92a8;font-size:.85rem}

/* ---------- Hub / Home grids ---------- */
.cat-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:22px}
.cat-card{display:block;background:#fff;border:1px solid var(--line);border-radius:16px;overflow:hidden;text-decoration:none;color:var(--ink);transition:transform .18s ease,box-shadow .18s ease}
.cat-card:hover{transform:translateY(-4px);box-shadow:var(--shadow);text-decoration:none}
.cat-card .img{aspect-ratio:16/10;background-size:cover;background-position:center;background-color:#0a1d3d}
.cat-card .body{padding:22px 24px}
.cat-card h3{font-size:1.15rem;margin-bottom:.3em}
.cat-card p{font-size:.92rem;color:var(--muted);margin:0 0 .8em}
.cat-card .more{font-size:.85rem;font-weight:700;color:var(--brand)}

/* ---------- Page header (hub) ---------- */
.page-head{background:linear-gradient(120deg,#0a1d3d 0%,#0c2c5c 100%);color:#fff;padding:84px 0 70px}
.page-head h1{color:#fff;max-width:760px}
.page-head .lede{color:rgba(255,255,255,.85);max-width:720px;font-size:1.15rem}
.crumbs{font-size:.85rem;color:rgba(255,255,255,.65);margin-bottom:1.5em}
.crumbs a{color:rgba(255,255,255,.85)}

/* ---------- Responsive ---------- */
@media (max-width: 900px){
  .hero-a .grid,.hero-c .grid,.hero-e .grid,.text-block .grid-2,.contact-block,.footer-grid{grid-template-columns:1fr;gap:36px}
  .text-block .grid-rev .visual{order:0}
  .hero-b .stats{grid-template-columns:repeat(2,1fr)}
  .deliverables-list{grid-template-columns:1fr}
  .deliverables-list .row{border-right:none}
  .primary-nav{gap:14px;font-size:.85rem}
  .primary-nav a:not(.btn){display:none}
  .contact-block{padding:36px}
  .why-block{padding:36px}
  .section{padding:60px 0}
  .footer-bottom{flex-direction:column}
}
