/* ──────────────────────────────────────────────────────────────────
   Cook Impact Software — corporate site v2
   Bright, happy, high-craft.  Sky-blue + orange, geometric display
   type, an "impact ripple" motif.  Deliberately distinct from both
   Hawser (dark/teal) and generic centered-column SaaS templates.

   NOTE on the old bug: v1 put class="wrap" directly on <section>, and
   .wrap's horizontal-only padding overrode the section's vertical
   padding (class > tag specificity), crushing the page.  v2 separates
   them: <section class="section"><div class="wrap">…</div></section>.
   ────────────────────────────────────────────────────────────────── */

:root {
  --blue-700:#0B6CB3;
  --blue-600:#0B86D0;
  --blue-500:#0EA5E9;   /* primary */
  --blue-400:#38BDF8;
  --blue-300:#7DD3FC;
  --blue-100:#E0F2FE;
  --orange-600:#EA6A0C;
  --orange-500:#F97316;  /* CTA */
  --orange-400:#FB923C;
  --sun:#FBBF24;         /* a happy spark in the gradient */

  --paper:#F4FAFF;       /* soft sky tint */
  --surface:#FFFFFF;
  --ink:#0C3553;         /* deep blue, strong contrast on light */
  --ink-2:#456178;       /* muted blue-gray (>=4.5:1 on paper) */
  --muted:#6E8AA0;
  --line:#D8EBF8;
  --line-2:#E9F4FC;

  --grad: linear-gradient(120deg, var(--blue-500) 0%, var(--blue-400) 35%, var(--orange-500) 100%);
  --grad-soft: linear-gradient(120deg, rgba(14,165,233,0.14), rgba(249,115,22,0.14));

  --shadow-sm: 0 2px 8px rgba(12,53,83,0.06);
  --shadow-md: 0 14px 36px rgba(11,108,179,0.12);
  --shadow-blue: 0 18px 44px rgba(14,165,233,0.22);
  --shadow-orange: 0 18px 44px rgba(249,115,22,0.20);

  --radius: 18px;
  --radius-lg: 26px;
  --maxw: 1120px;
  --ease: cubic-bezier(0.22, 1, 0.36, 1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: 'Work Sans', -apple-system, BlinkMacSystemFont, sans-serif;
  color: var(--ink);
  line-height: 1.65;
  background:
    radial-gradient(1100px 520px at 78% -8%, var(--blue-100), transparent 60%),
    radial-gradient(900px 480px at 0% 8%, #FFF1E6, transparent 55%),
    var(--paper);
  background-attachment: fixed;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* ── Type ───────────────────────────────────────────────────────── */
.display { font-family:'Outfit', sans-serif; font-weight:700; line-height:1.05; letter-spacing:-1px; }
h1.display{ font-size: clamp(42px, 6.4vw, 76px); margin:0 0 22px; }
h2.display{ font-size: clamp(30px, 4.2vw, 46px); margin:0 0 18px; }
h3.display{ font-size:22px; margin:0 0 8px; font-weight:600; letter-spacing:-0.4px; }
.grad-text{
  background: var(--grad); -webkit-background-clip:text; background-clip:text;
  -webkit-text-fill-color:transparent; color:transparent;
}
.lede{ font-size:clamp(17px,2.1vw,21px); color:var(--ink-2); max-width:600px; margin:0 0 34px; }
.eyebrow{
  display:inline-flex; align-items:center; gap:8px;
  text-transform:uppercase; letter-spacing:2px; font-size:11px; font-weight:700;
  color:var(--blue-600); margin:0 0 18px;
}
.eyebrow::before{ content:""; width:22px; height:2px; border-radius:2px; background:var(--grad); }

/* ── Layout ─────────────────────────────────────────────────────── */
.wrap{ max-width:var(--maxw); margin:0 auto; padding:0 24px; }
.section{ padding: clamp(40px, 5vw, 68px) 0; }
.section.tight{ padding: clamp(26px, 3vw, 40px) 0; }
.section.hero{ padding-top: clamp(28px, 4vw, 52px); }

/* ── Floating pill nav ──────────────────────────────────────────── */
.nav{ position:sticky; top:0; z-index:50; padding:14px 0; }
.nav-inner{
  /* ~2/3 of the viewport, genuinely centered.  (The off-center bug was
     a margin:0 auto immediately overridden by margin-left/right:16px.)
     Capped so it doesn't sprawl on ultrawide; goes full-width with
     gutters on smaller screens via the media queries below. */
  width: min(66vw, 1320px); margin:0 auto; padding:10px 14px 10px 18px;
  display:flex; align-items:center; justify-content:space-between;
  background:rgba(255,255,255,0.82);
  backdrop-filter:saturate(180%) blur(14px); -webkit-backdrop-filter:saturate(180%) blur(14px);
  border:1px solid var(--line); border-radius:999px; box-shadow:var(--shadow-sm);
}
@media (max-width:1024px){ .nav-inner{ width:auto; margin:0 16px; } }
.wordmark{ display:flex; align-items:center; gap:11px; text-decoration:none; color:var(--ink); }
.wordmark svg{ width:30px; height:30px; flex:none; display:block; }
.wordmark .wm-text{ font-family:'Outfit',sans-serif; font-weight:700; font-size:16px; letter-spacing:-0.3px; }
.wordmark .wm-text .light{ color:var(--muted); font-weight:500; }
.nav-links{ display:flex; align-items:center; gap:6px; }
.nav-links a{
  text-decoration:none; color:var(--ink-2); font-size:14.5px; font-weight:600;
  padding:8px 14px; border-radius:999px; transition:color .2s var(--ease), background .2s var(--ease);
}
.nav-links a:hover{ color:var(--ink); background:var(--line-2); }
.nav-links a.active{ color:var(--blue-600); background:var(--blue-100); }
.nav-links .nav-cta{ color:#fff; background:var(--orange-500); }
.nav-links .nav-cta:hover{ color:#fff; background:var(--orange-600); }
@media (max-width:620px){
  .nav-links a{ padding:7px 10px; font-size:13.5px; }
  .nav-links a.hide-sm{ display:none; }
  .nav-inner{ margin:0 10px; }
}

/* ── Buttons ────────────────────────────────────────────────────── */
.btn{
  display:inline-flex; align-items:center; gap:9px; text-decoration:none;
  font-family:'Outfit',sans-serif; font-weight:600; font-size:15.5px;
  padding:13px 24px; border-radius:14px; cursor:pointer;
  transition:transform .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease);
}
.btn svg{ width:18px; height:18px; transition:transform .2s var(--ease); }
.btn-primary{ background:var(--orange-500); color:#fff; box-shadow:var(--shadow-orange); }
.btn-primary:hover{ background:var(--orange-600); transform:translateY(-2px); }
.btn-primary:hover svg{ transform:translateX(3px); }
.btn-ghost{ background:#fff; color:var(--ink); border:1.5px solid var(--line); }
.btn-ghost:hover{ border-color:var(--blue-400); transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-row{ display:flex; flex-wrap:wrap; gap:14px; }

/* ── Hero ───────────────────────────────────────────────────────── */
.hero{ position:relative; }
.hero-grid{ display:grid; grid-template-columns:1fr; gap:48px; align-items:center; }
@media (min-width:900px){ .hero-grid{ grid-template-columns:1.15fr 0.85fr; gap:32px; } }

/* sonar ripple art (the logo motif, alive) */
.ripple-art{ position:relative; width:min(360px,80vw); aspect-ratio:1; margin:0 auto; }
.ripple-art .ring{
  position:absolute; inset:0; margin:auto; width:100%; height:100%;
  border-radius:50%; border:2px solid var(--blue-400); opacity:0;
  animation:sonar 3.6s var(--ease) infinite;
}
.ripple-art .ring:nth-child(2){ animation-delay:1.2s; border-color:var(--blue-300); }
.ripple-art .ring:nth-child(3){ animation-delay:2.4s; border-color:var(--orange-400); }
.ripple-art .core{
  position:absolute; inset:0; margin:auto; width:34%; height:34%; border-radius:50%;
  background:var(--grad); box-shadow:var(--shadow-blue);
}
.ripple-art .core::after{
  content:""; position:absolute; inset:22%; border-radius:50%;
  background:rgba(255,255,255,0.22);
}
@keyframes sonar{
  0%{ transform:scale(0.28); opacity:0; }
  15%{ opacity:1; }
  100%{ transform:scale(1); opacity:0; }
}

/* ── Cards / products ───────────────────────────────────────────── */
.grid{ display:grid; grid-template-columns:1fr; gap:22px; }
@media (min-width:760px){ .grid.cols-2{ grid-template-columns:1fr 1fr; } .grid.cols-3{ grid-template-columns:repeat(3,1fr); } }

.product-card{
  display:flex; flex-direction:column; text-decoration:none; color:inherit;
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:32px; box-shadow:var(--shadow-sm); position:relative; overflow:hidden;
  transition:transform .25s var(--ease), box-shadow .25s var(--ease), border-color .25s var(--ease);
}
.product-card::before{
  content:""; position:absolute; left:0; top:0; height:5px; width:100%;
  background:var(--grad); transform:scaleX(0); transform-origin:left; transition:transform .3s var(--ease);
}
.product-card:hover{ transform:translateY(-5px); box-shadow:var(--shadow-blue); border-color:transparent; }
.product-card:hover::before{ transform:scaleX(1); }
.product-card .tag{
  align-self:flex-start; font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase;
  color:var(--blue-700); background:var(--blue-100); padding:5px 11px; border-radius:999px; margin-bottom:18px;
}
.product-card p{ color:var(--ink-2); font-size:15.5px; margin:0 0 22px; }
.product-card .go{ display:inline-flex; align-items:center; gap:7px; color:var(--orange-500); font-family:'Outfit',sans-serif; font-weight:600; font-size:15px; margin-top:auto; }
.product-card .go svg{ width:17px; height:17px; transition:transform .2s var(--ease); }
.product-card:hover .go svg{ transform:translateX(4px); }
.product-card.soon{ background:var(--line-2); border-style:dashed; box-shadow:none; }
.product-card.soon:hover{ transform:none; box-shadow:none; border-color:var(--line); }
.product-card.soon:hover::before{ transform:scaleX(0); }

/* ── Principles / feature with icon ─────────────────────────────── */
.feature .ic{
  width:52px; height:52px; border-radius:15px; display:grid; place-items:center;
  background:var(--grad-soft); margin-bottom:16px;
}
.feature .ic svg{ width:26px; height:26px; stroke:var(--blue-600); }
.feature h3{ font-family:'Outfit',sans-serif; font-size:18px; font-weight:600; margin:0 0 6px; letter-spacing:-0.3px; }
.feature p{ color:var(--ink-2); font-size:15px; margin:0; }

/* ── Big gradient CTA band ──────────────────────────────────────── */
.cta-band{
  position:relative; overflow:hidden; border-radius:var(--radius-lg);
  background:var(--grad); color:#fff; padding:clamp(40px,6vw,68px); text-align:center;
  box-shadow:var(--shadow-blue);
}
.cta-band h2{ color:#fff; margin:0 0 14px; }
.cta-band p{ color:rgba(255,255,255,0.92); max-width:520px; margin:0 auto 28px; font-size:17px; }
.cta-band .btn-primary{ background:#fff; color:var(--orange-600); box-shadow:0 10px 30px rgba(0,0,0,0.18); }
.cta-band .btn-primary:hover{ background:#fff; color:var(--orange-600); }

/* ── Prose (about/contact) ──────────────────────────────────────── */
.prose{ max-width:640px; }
.prose p{ color:var(--ink-2); font-size:17px; margin:0 0 18px; }
.prose p strong{ color:var(--ink); font-weight:600; }
.prose a{ color:var(--blue-600); font-weight:600; }

.card{ background:var(--surface); border:1px solid var(--line); border-radius:var(--radius); padding:30px; box-shadow:var(--shadow-sm); }

/* ── Pricing ────────────────────────────────────────────────────── */
.price-card{
  background:var(--surface); border:1px solid var(--line); border-radius:var(--radius-lg);
  padding:clamp(28px,4vw,40px); box-shadow:var(--shadow-md);
  max-width:440px; position:relative; overflow:hidden;
}
.price-card::before{
  content:""; position:absolute; left:0; top:0; height:5px; width:100%; background:var(--grad);
}
.price-card .plan{
  font-family:'Outfit',sans-serif; font-weight:600; font-size:14px; letter-spacing:.4px;
  text-transform:uppercase; color:var(--blue-700);
}
.price-card .price{
  display:flex; align-items:baseline; gap:7px; margin:8px 0 2px;
  font-family:'Outfit',sans-serif; font-weight:700; letter-spacing:-1.5px; color:var(--ink);
}
.price-card .price .amount{ font-size:clamp(46px,7vw,60px); line-height:1; }
.price-card .price .per{ font-size:18px; color:var(--muted); font-weight:500; letter-spacing:0; }
.price-card .trial{
  display:inline-block; margin:16px 0 6px; font-size:12.5px; font-weight:700; letter-spacing:.5px;
  text-transform:uppercase; color:var(--blue-700); background:var(--blue-100);
  padding:6px 13px; border-radius:999px;
}
.feature-list{ list-style:none; padding:0; margin:22px 0 26px; display:grid; gap:13px; }
.feature-list li{ display:flex; gap:11px; align-items:flex-start; color:var(--ink-2); font-size:15.5px; }
.feature-list li svg{ width:20px; height:20px; flex:none; stroke:var(--blue-500); margin-top:2px; }
.fineprint{ color:var(--muted); font-size:13.5px; margin-top:16px; line-height:1.6; }
.fineprint a{ color:var(--blue-600); font-weight:600; }

/* ── Legal / long-form ──────────────────────────────────────────── */
.legal{ max-width:760px; }
.legal .updated{ color:var(--muted); font-size:14px; margin:-8px 0 30px; }
.legal h2{
  font-family:'Outfit',sans-serif; font-size:22px; font-weight:600; letter-spacing:-0.3px;
  color:var(--ink); margin:36px 0 12px;
}
.legal h3{
  font-family:'Outfit',sans-serif; font-size:16px; font-weight:600;
  color:var(--ink); margin:24px 0 8px;
}
.legal p{ color:var(--ink-2); font-size:16px; margin:0 0 16px; }
.legal ul{ color:var(--ink-2); font-size:16px; margin:0 0 16px; padding-left:22px; }
.legal li{ margin:0 0 9px; }
.legal a{ color:var(--blue-600); font-weight:600; }
.legal strong{ color:var(--ink); font-weight:600; }

/* ── Footer ─────────────────────────────────────────────────────── */
footer{ margin-top:24px; border-top:1px solid var(--line); }
.foot-inner{
  max-width:var(--maxw); margin:0 auto; padding:40px 24px;
  display:flex; justify-content:space-between; flex-wrap:wrap; gap:18px; align-items:center;
  color:var(--muted); font-size:14px;
}
.foot-inner a{ color:var(--ink-2); text-decoration:none; font-weight:500; }
.foot-inner a:hover{ color:var(--blue-600); }
.foot-links{ display:flex; gap:22px; flex-wrap:wrap; }

/* ── Scroll reveal ──────────────────────────────────────────────── */
.reveal{ opacity:0; transform:translateY(22px); transition:opacity .6s var(--ease), transform .6s var(--ease); }
.reveal.in{ opacity:1; transform:none; }

/* ── A11y / motion ──────────────────────────────────────────────── */
:focus-visible{ outline:3px solid var(--blue-400); outline-offset:2px; border-radius:6px; }
@media (prefers-reduced-motion: reduce){
  *{ animation:none !important; transition:none !important; scroll-behavior:auto !important; }
  .reveal{ opacity:1; transform:none; }
  .ripple-art .ring{ opacity:.5; transform:scale(1); }
}
