/* ==== Dragonfly theme (blues + teals, high contrast) ==== */
:root{
  --bg-900:#0b1220;      /* midnight navy */
  --bg-800:#0f1a2b;
  --panel:#0f1f36;       /* deep slate */
  --line:#20324f;        /* soft border */
  --text-100:#e9f7fb;    /* ice */
  --text-300:#b8d8e3;    /* muted */
  --muted:#8fb3c0;

  --brand:#6fd2f2;       /* cyan primary */
  --brand-2:#86e0d8;     /* teal secondary */
  --brand-3:#c9f3ff;     /* light highlight */
  
  --accent:#7dd3fc; /* light sky - keeping for compatibility */
  --accent-2:#60a5fa; /* blue - keeping for compatibility */
  --ok:#34d399;
  --radius:16px;
  --shadow:0 12px 30px rgba(0,0,0,.25);
}
*{box-sizing:border-box}
html, body {
  margin:0;padding:0;
  background:
    radial-gradient(1200px 600px at 18% -10%, rgba(111,210,242,.10), transparent 60%),
    radial-gradient(900px 500px  at 85% 0%,   rgba(134,224,216,.08), transparent 55%),
    var(--bg-900);
  color: var(--text-100);
  font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;
}
a{color:var(--accent)}
.container{max-width:1100px;margin:0 auto;padding:0 20px}
.section{padding:72px 0}
.section--alt{background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(255,255,255,0));}
.row{display:flex;align-items:center;justify-content:space-between;gap:16px}
.two{display:grid;grid-template-columns:1.2fr .8fr;gap:24px}
.grid{display:grid;gap:20px}
.grid-3{grid-template-columns:repeat(3,1fr)}
.card{background:var(--panel);border:1px solid rgba(255,255,255,.06);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow)}
.pillrow{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}
.pill{background:#0a1627;border:1px solid rgba(255,255,255,.06);padding:6px 10px;border-radius:999px;font-size:.85rem}
.dim{color:var(--ink-dim)}
.sm{font-size:.9rem}
.hidden{display:none}
h1,h2,h3{line-height:1.15;margin:0 0 12px}
h1{font-size:clamp(32px,5vw,56px);letter-spacing:-.02em}
h2{font-size:clamp(24px,3.5vw,34px)}
h3{font-size:clamp(18px,2.5vw,22px)}
.lead{font-size:clamp(16px,2.2vw,18px);color:var(--ink-dim)}
.nav{position:sticky;top:0;background:rgba(7,17,31,.8);backdrop-filter:blur(6px);border-bottom:1px solid rgba(255,255,255,.06);z-index:20}
.brand{display:flex;align-items:center;gap:10px;font-weight:700}
.links a{margin-left:18px;text-decoration:none;color:var(--ink)}
.links a:hover{color:var(--accent)}
.btn{display:inline-block;padding:12px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);text-decoration:none;color:var(--ink)}
.btn--sm{padding:8px 12px;font-size:.9rem}
.btn--primary{background:linear-gradient(135deg,var(--accent),var(--accent-2));border:none;color:#07111f;font-weight:600}
.hero{position:relative;padding:90px 0 40px;border-bottom:1px solid rgba(255,255,255,.06)}
.hero .cta{margin:22px 0;display:flex;gap:12px;flex-wrap:wrap}
.hero-badges{display:flex;gap:10px;flex-wrap:wrap;margin-top:6px}
.badge{background:#0a1627;border:1px solid rgba(255,255,255,.06);padding:6px 10px;border-radius:999px;color:var(--ink-dim);font-size:.85rem}
.accent{background:linear-gradient(135deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.glow{position:absolute;inset:auto -20% -40% -20%;height:320px;filter:blur(70px);background:radial-gradient(50% 50% at 50% 50%, rgba(96,165,250,.35), rgba(125,211,252,.15) 60%, rgba(0,0,0,0) 70%)}

.checklist{padding-left:18px}
.checklist li{margin:8px 0}
.steps{padding-left:18px}
.steps li{margin:8px 0}
.form label{display:block;margin-bottom:10px}
.form input,.form textarea,.form select{width:100%;margin-top:6px;padding:12px;border-radius:10px;border:1px solid rgba(255,255,255,.12);background:#0b1729;color:var(--ink)}
.form input:focus,.form textarea:focus,.form select:focus{outline:2px solid var(--accent)}
.footer{border-top:1px solid rgba(255,255,255,.06);padding:20px 0;color:var(--ink-dim)}

@media (max-width: 920px){
  .two{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .links{display:none}
}

/* Blog helpers */
.prose p { line-height: 1.7; margin: 14px 0; }
.post h2 a { text-decoration: none; color: var(--ink); }
.post h2 a:hover { color: var(--accent); }

/* --- Blog: Prose typography & components --- */
:root{
  --warn:#f59e0b;
  --danger:#ef4444;
  --muted:#0b1729;
}
.prose{
  max-width: 850px;
  margin: 0 auto;
  line-height: 1.75;
  font-size: 1.05rem;
}
.prose h1,.prose h2,.prose h3{letter-spacing:-.01em}
.prose h1{font-size:clamp(28px,4.5vw,46px);margin:8px 0 6px}
.prose h2{font-size:clamp(22px,3.2vw,30px);margin:28px 0 10px}
.prose h3{font-size:clamp(18px,2.6vw,22px);margin:18px 0 6px}
.prose p{margin:12px 0}
.prose .lead{color:var(--ink-dim);font-size:1.1rem;margin-top:8px}
.prose a{color:var(--accent);text-decoration:underline}
.prose hr{border:0;border-top:1px solid rgba(255,255,255,.08);margin:26px 0}
.prose blockquote{
  margin:18px 0;
  padding:14px 16px;
  background:var(--muted);
  border-left:4px solid var(--accent-2);
  border-radius:10px;
  color:var(--ink);
}
.prose figure{margin:18px 0}
.prose figcaption{color:var(--ink-dim);font-size:.9rem;margin-top:6px}

.prose .eyebrow{
  display:inline-block;
  font-size:.8rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:var(--ink-dim);
  margin-bottom:6px;
}

.callout{
  border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,0));
  padding:14px 16px;
  border-radius:12px;
  margin:16px 0;
}
.callout strong{display:block;margin-bottom:6px}
.callout.tip{border-left:4px solid var(--ok)}
.callout.warn{border-left:4px solid var(--warn)}
.callout.info{border-left:4px solid var(--accent-2)}

.mode-grid{display:grid;gap:16px;grid-template-columns:repeat(3,1fr)}
@media (max-width:920px){.mode-grid{grid-template-columns:1fr}}

.mode{
  background:var(--panel);
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:18px;
  box-shadow:var(--shadow);
}
.mode h3{margin-bottom:6px}
.mode ul{padding-left:18px;margin:10px 0}
.mode li{margin:6px 0}

.kicker{
  background:#0a1627;
  color:var(--ink-dim);
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.06);
  font-size:.85rem;
}
.meta{color:var(--ink-dim);font-size:.95rem;margin:6px 0 18px}

.faq details{
  background:var(--panel);
  border:1px solid rgba(255,255,255,.08);
  border-radius:12px;
  padding:12px 14px;
  margin:10px 0;
}
.faq summary{cursor:pointer;font-weight:600}

/* Blog readability polish */
.prose {
  /* keep paragraphs a consistent measure */
  max-width: 70ch;           /* ~70 characters per line */
}

/* fully-justify body text */
.prose p,
.prose li {
  text-align: justify;
  text-justify: inter-word;  /* better spacing between words */
  hyphens: auto;             /* enable hyphenation */
  -webkit-hyphens: auto;     /* Safari */
  line-height: 1.7;
}

/* don't justify headings or special blocks */
.prose h1,
.prose h2,
.prose h3,
.prose .lead,
.prose blockquote,
.prose .callout {
  text-align: start;
  hyphens: manual;
}

/* nicer heading breaks */
.prose h1, .prose h2, .prose h3 { text-wrap: balance; }

/* on small screens, drop justification to avoid odd spacing */
@media (max-width: 520px) {
  .prose p,
  .prose li {
    text-align: start;
  }
}

/* 1) Justify only top-level article paragraphs (not nested sections) */
.prose > p,
.prose > ul > li {
  text-align: justify;
  text-justify: inter-word;
  hyphens: auto;
  line-height: 1.7;
}

/* 2) In the "privacy modes" cards, use ragged-right and no hyphenation */
.mode-grid .mode p,
.mode-grid .mode li {
  text-align: start;      /* left align */
  text-justify: auto;
  hyphens: none;          /* stop auto hyphenation */
  word-break: normal;
  overflow-wrap: break-word; /* only break very long words/urls if needed */
  line-height: 1.65;
}

/* optional: make the cards breathe a bit more */
.mode-grid .mode { padding: 20px 22px; }

/* headings stay balanced and never justified */
.prose h1, .prose h2, .prose h3 { text-wrap: balance; }
.prose .lead, .callout, .faq summary { text-align: start; hyphens: manual; }

/* Disable italics site-wide unless explicitly re-enabled */
em, i { font-style: normal; }

/* Keep hero and body text crisp */
.lead, .sublead, .prose p { font-style: normal; }

/* Links and focus */
a{ color:var(--brand); text-decoration:none }
a:hover{ color:var(--brand-3); text-decoration:underline }
:focus-visible{ outline:2px solid var(--brand-2); outline-offset:2px }

/* Cards */
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow:0 12px 30px rgba(0,0,0,.25);
  padding:22px;
}

/* Chips (the small tags under the hero) */
.chip{
  display:inline-block;
  background:rgba(111,210,242,.10);
  border:1px solid rgba(111,210,242,.35);
  color:var(--brand-3);
  border-radius:999px;
  padding:6px 10px;
  font-size:13px;
}

/* Optional hero accent on the brand name */
.brand{
  background:linear-gradient(90deg,var(--brand),var(--brand-2));
  -webkit-background-clip:text; background-clip:text;
  color:transparent;
}

/* Grid helper for the footer section with forms/cards */
.grid-2 { display:grid; gap:18px }
@media (min-width: 900px){
  .grid-2{ grid-template-columns: 1.1fr 1.2fr } /* left form, right cards */
}

/* Compact variants for the right column */
.card--compact{ padding:18px }
.card--tight   { padding:16px }

/* Lists in cards */
ul.tight > li { margin:6px 0 }

/* Blog mode cards keep clean lines */
.mode p, .mode li { hyphens:none; word-break:normal }

/* ===== Equal-height layout for form + right column ===== */
.beta-grid{
  display:grid;
  gap:24px;
  align-items:stretch; /* both columns same row height */
}
@media (min-width: 980px){
  .beta-grid{ grid-template-columns: 1.55fr 1fr; }
}

/* Left column: ensure the form card stretches to full row height */
.beta-left > .card{ height:100%; }

/* Right column becomes a vertical stack that fills the same height */
.beta-right{
  display:flex;
  flex-direction:column;
  gap:14px;
  height:100%;
  position:static; /* override any sticky from earlier */
}

/* Card styling (keeps your dragonfly palette) */
.beta-right .card{
  position:relative;
  background: linear-gradient(180deg, rgba(111,210,242,.06), rgba(134,224,216,.04)) , var(--panel);
  border:1px solid var(--line);
  border-radius:14px;
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
  padding:18px;
}

/* Contact card typography */
.contact-card h3{ margin:0 0 6px; font-size:18px; letter-spacing:.2px; }
.contact-card .email{
  margin:6px 0 6px;
  font-weight:600;
  font-size:16px;
}
.contact-card .org{
  margin:2px 0 0;
  color: rgba(255,255,255,.88);   /* visible (not muted) */
  font-size:13.5px;
  letter-spacing:.35px;
  text-transform:uppercase;
}

/* Developers card fills the remaining space so its bottom aligns with the form */
.dev-card{ flex:1; display:flex; flex-direction:column; }
.dev-card h3{ margin:0 0 8px; font-size:18px; }
.dev-card ul.tight{ margin:6px 0 0 18px; }
.dev-card ul.tight li{ margin:6px 0; }
.dev-card .more{ margin-top:auto; } /* pushes the 'Read:' line to the bottom */

/* No accidental italics anywhere */
em, i { font-style: normal; }

/* === Dragonfly palette (site-wide overrides) === */
:root{
  /* Raw palette */
  --df-yg: #C5D040;           /* bright yellow-green (body) */
  --df-eye-blue: #96B4C4;     /* eye blue-gray */
  --df-eye-pink: #E0C0CC;     /* eye pink iridescence */
  --df-deep: #1E3B5D;         /* deep blue (legs/body) */
  --df-black: #191919;        /* detail contrast */
  --df-white: #FFFFFF;        /* droplets highlight */
  --df-hair: #F3F3E8;         /* pale fuzz */

  /* App tokens (built from palette) */
  --bg: radial-gradient(1200px 600px at 15% -10%, rgba(224,192,204,.18) 0%, rgba(150,180,196,.10) 25%, transparent 55%),
        radial-gradient(1200px 800px at 95% 15%, rgba(197,208,64,.10) 0%, transparent 55%),
        linear-gradient(180deg, #0B1421, #0A0F17 55%, #0A0E15);
  --text: #E8F1F6;
  --muted: rgba(232,241,246,.72);

  --link: #A7C1D0;            /* eye blue */
  --link-hover: #E0C0CC;      /* pink tint */
  --accent: #C5D040;          /* yellow-green */
  --accent-ink: #111;

  --panel: rgba(30,59,93,.35);         /* deep-blue glass */
  --panel-strong: rgba(30,59,93,.55);
  --line: rgba(255,255,255,.08);       /* soft border */
  --ring: rgba(197,208,64,.55);        /* focus ring */
  --glow: 0 0 0 3px rgba(197,208,64,.25), 0 4px 18px rgba(150,180,196,.25);
}

/* Base */
html, body{ background: var(--bg); color: var(--text); }
i, em { font-style: normal; }  /* no accidental italics */

/* Headings get a subtle accent underline */
h1, h2, h3{ letter-spacing:.2px; }
h1::after, h2::after{
  content:""; display:block; width:64px; height:3px;
  background: linear-gradient(90deg, var(--accent), rgba(197,208,64,0));
  border-radius:2px; margin-top:10px;
}

/* Links with soft iridescence */
a{ color: var(--link); text-decoration: none; }
a:hover{ color: var(--link-hover); text-decoration: underline; }

/* Cards */
.card{
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 14px;
  box-shadow: 0 10px 26px rgba(0,0,0,.25);
}

/* Buttons */
.button, .btn, .btn-primary{
  background: linear-gradient(180deg, rgba(30,59,93,.85), rgba(30,59,93,.65));
  border: 1px solid var(--line);
  color: #EAF2F6; padding: 10px 16px; border-radius: 12px; font-weight: 600;
}
.button:hover, .btn:hover, .btn-primary:hover{
  border-color: var(--accent); box-shadow: var(--glow); transform: translateY(-1px);
}
.button:focus, .btn:focus, .btn-primary:focus{ outline: none; box-shadow: var(--glow); }

/* Pills / badges */
.badge, .pill{
  background: linear-gradient(180deg, rgba(150,180,196,.18), rgba(150,180,196,.10));
  border: 1px solid var(--line);
  color: var(--text); border-radius: 999px; padding:6px 10px; font-size:12px;
}

/* Callouts */
.callout.info{
  background: linear-gradient(180deg, rgba(150,180,196,.18), rgba(150,180,196,.08));
  border-left: 3px solid var(--link);
}
.callout.tip{
  background: linear-gradient(180deg, rgba(197,208,64,.14), rgba(197,208,64,.06));
  border-left: 3px solid var(--accent);
}

/* Inputs */
input, select, textarea{
  background: var(--panel-strong); color: var(--text);
  border: 1px solid var(--line); border-radius: 12px;
}
input:focus, select:focus, textarea:focus{
  outline: none; border-color: var(--accent); box-shadow: var(--glow);
}

/* Contact + Developers from earlier step, colored to palette */
.contact-card h3, .dev-card h3{ margin:0 0 8px; font-size:18px; }
.contact-card .email a{ color: var(--text); }
.contact-card .email a:hover{ color: var(--accent); }
.contact-card .org{ color: var(--muted); letter-spacing:.35px; text-transform:uppercase; font-size:13.5px; }

/* Layout alignment with the form */
.beta-grid{ display:grid; gap:24px; align-items:stretch; }
@media (min-width:980px){ .beta-grid{ grid-template-columns:1.55fr 1fr; } }
.beta-left>.card{ height:100%; }
.beta-right{ display:flex; flex-direction:column; gap:14px; height:100%; }
.dev-card{ flex:1; display:flex; flex-direction:column; }
.dev-card ul{ margin:6px 0 0 18px; }
.dev-card .more{ margin-top:auto; }

/* Footer links */
footer a{ color: var(--link); }
footer a:hover{ color: var(--link-hover); }

/* two-column grid with equal heights */
.beta-grid{
  display:grid;
  grid-template-columns: 1.65fr 1fr;   /* left wider than right */
  gap:24px;
  align-items:stretch;                 /* both columns share the same row height */
}

/* left card fills the row height */
.beta-left > .card{ height:100%; display:flex; flex-direction:column; }
.beta-left .actions{ margin-top:auto; }  /* keep button at bottom */

/* right rail matches left height and stacks two cards */
.beta-right{
  display:flex;
  flex-direction:column;
  height:100%;
  gap:14px;
}

/* contact is fixed height; dev grows to fill remainder */
.contact-card{ flex:0 0 auto; margin:0; }
.dev-card{
  flex:1 1 auto;                       /* stretch to bottom */
  display:flex; flex-direction:column;
}
.dev-card .more{ margin-top:auto; }     /* pin "Read" to the bottom */

/* small visual tweaks so it looks tight */
.card h3{ margin:0 0 8px; }
.card .email{ font-weight:600; margin:4px 0 2px; }
.card .org{
  opacity:.9; letter-spacing:.35px; text-transform:uppercase;
  font-size:13.5px; margin:0;
}
ul.tight{ margin:8px 0 0; padding-left:18px; }
ul.tight li{ margin:6px 0; }

/* responsive: stack on small screens */
@media (max-width: 900px){
  .beta-grid{ grid-template-columns: 1fr; }
  .beta-right{ height:auto; }
  .dev-card{ flex:0 0 auto; }
}

/* ===== Dragonfly polish (add to end of styles.css) ===== */

/* Palette */
:root{
  --deep-blue: #1E3B5D;          /* legs / contrast */
  --bg-950:  #0F1822;            /* page background */
  --surface-800:#102536;         /* card bg */
  --surface-700:#133149;         /* card bg (lighter) */
  --text-100:#EAF2F8;            /* primary text */
  --muted-400:#9BB0BE;           /* blue-gray eye tone */
  --iris:#96B4C4;                /* eye blue */
  --iris-pink:#E0C0CC;           /* faint pink sheen */
  --accent:#C5D040;              /* bright yellow-green */
  --hair:#F3F3E8;                /* pale yellow hairs */
  --ink:#191919;                 /* near black for shadows */

  --radius-xl: 18px;
  --radius-lg: 14px;
  --radius-md: 12px;
  --space-1: 8px;
  --space-2: 12px;
  --space-3: 16px;
  --space-4: 20px;
  --space-5: 24px;
  --space-6: 28px;
}

/* Subtle "droplet" + deep blue background */
body{
  background:
    radial-gradient(1200px 600px at 20% -10%, color-mix(in oklab, var(--iris) 20%, transparent) 0%, transparent 60%),
    radial-gradient(900px 480px at 80% -15%, color-mix(in oklab, var(--iris-pink) 14%, transparent) 0%, transparent 70%),
    linear-gradient(180deg, rgba(10,16,24,0.9), rgba(6,10,16,0.96));
  color: var(--text-100);
}

/* Containers */
.container{ max-width: 1080px; padding: 0 20px; margin: 0 auto; }

/* Headings rhythm */
h1,h2,h3{ letter-spacing: 0.2px; }
h1{ margin-bottom: var(--space-3); }
.lede{ color: var(--muted-400); }

/* Grid that keeps left form and right rail aligned */
.form-grid{
  display: grid;
  grid-template-columns: 1.18fr 0.82fr;   /* nice visual balance */
  gap: 28px;
  align-items: start;
}
@media (max-width: 980px){
  .form-grid{ grid-template-columns: 1fr; }
}

/* Cards */
.card{
  background: linear-gradient(180deg, color-mix(in oklab, var(--surface-700) 88%, transparent), var(--surface-800));
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: var(--radius-xl);
  padding: 18px;
  box-shadow:
    0 1px 0 rgba(255,255,255,0.04) inset,
    0 8px 30px rgba(0,0,0,0.25);
}
.card h3{ margin: 2px 0 12px; }

/* Make columns equal height */
.form-card, .rail{ height: 100%; }
.rail{ display: flex; flex-direction: column; gap: 16px; }

/* Inputs */
input, select, textarea{
  width: 100%;
  background: #0E2333;
  color: var(--text-100);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 12px 14px;
  outline: none;
  transition: box-shadow .15s ease, border-color .15s ease;
}
input::placeholder, textarea::placeholder{ color: color-mix(in oklab, var(--muted-400) 60%, transparent); }
input:focus, select:focus, textarea:focus{
  border-color: color-mix(in oklab, var(--accent) 60%, white 0%);
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--accent) 32%, transparent);
}

/* Button */
.button, button, .btn{
  display: inline-flex; align-items: center; justify-content: center;
  gap: 10px; padding: 12px 16px; border-radius: 14px;
  background: color-mix(in oklab, var(--deep-blue) 76%, black 10%);
  color: white; border: 1px solid rgba(255,255,255,0.08);
  box-shadow: 0 8px 22px rgba(0,0,0,0.35);
  text-decoration: none; font-weight: 600;
}
.button:hover, button:hover{ filter: brightness(1.05); }
.button:focus-visible{ outline: none; box-shadow: 0 0 0 3px color-mix(in oklab, var(--accent) 40%, transparent); }

/* Tiny reassurance under the button */
.form-footnote{ margin-top: 8px; font-size: 13px; color: var(--muted-400); }

/* Links */
a{ color: color-mix(in oklab, var(--iris) 85%, white 0%); text-decoration: none; }
a:hover{ text-decoration: underline; text-underline-offset: 3px; }

/* Contact / dev accents */
.contact .headline{ color: color-mix(in oklab, var(--accent) 80%, white 10%); font-weight: 700; }
.kicker{ font-size: 12px; letter-spacing: .12em; text-transform: uppercase; color: var(--hair); }

/* Bullet polish */
.card ul{ margin: 8px 0 0; padding-left: 22px; }
.card li{ margin: 6px 0; }

/* --- Home polish (hero, nav, labels, grid, CTA) --- */

/* make top nav links always readable on the gradient */
.site-nav a {
  color: #9eb4c4;           /* blue-gray from the dragonfly eye */
  opacity: 0.95;
}
.site-nav a:hover { opacity: 1; text-decoration: underline; }

/* softer, controlled wrap for the big headline */
.hero-title {
  max-width: 18ch;          /* natural two-line wrap on laptops */
  line-height: 1.06;
}

/* give the subhead some breathing room */
.hero-sub {
  margin-top: 10px;
  margin-bottom: 18px;
}

/* label chips should look like labels, not buttons */
.tags { margin-bottom: 18px; }
.tag {
  pointer-events: none;
  cursor: default;
  opacity: 0.85;
}

/* align Our vision + v0 card cleanly */
.two-col {
  display: grid;
  grid-template-columns: 1fr minmax(340px, 420px);
  gap: 32px;
  align-items: start;        /* lock card tops to the heading */
}

/* consistent bullet look (no trailing periods needed) */
.prose ul li { list-style: disc; }
.prose ul li::marker { color: var(--accent, #C5D040); }

/* simple primary CTA */
.btn { display: inline-block; padding: 10px 16px; border-radius: 10px; font-weight: 600; }
.btn.primary {
  background: #1E3B5D;      /* deep blue from the legs */
  color: #E6F0F6;           /* soft light for contrast */
  box-shadow: 0 6px 14px rgba(30,59,93,.25);
}
.btn.primary:hover { transform: translateY(-1px); }

/* --- Simpler, smaller hero --- */
.hero { padding-top: 32px; padding-bottom: 24px; }

.hero h1 {
  font-weight: 750;
  letter-spacing: -0.02em;
  line-height: 1.15;
  /* responsive but modest */
  font-size: clamp(32px, 6vw, 56px);
  margin: 0 0 12px 0;
}

.hero .lead {
  font-size: clamp(14px, 1.6vw, 18px);
  line-height: 1.6;
  opacity: 0.9;
  max-width: 60ch;
  margin: 0 0 14px 0;
}

.badges { display: flex; gap: 8px; flex-wrap: wrap; }
.chip { background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.08);
        padding: 6px 10px; border-radius: 999px; font-size: 12px; }

/* HBUK link highlight */
:root { --hbuk: #C5D040; }           /* dragonfly yellow-green */
a.hbuk-link{
  color: var(--hbuk);
  font-weight: 700;
  text-decoration: underline;
  text-decoration-color: rgba(197,208,64,.6);
  text-underline-offset: 2px;
  text-decoration-thickness: 2px;
}
a.hbuk-link:hover{ text-decoration-color: currentColor; filter: brightness(1.08); }
