/* ==========================================================================
   TROVIK AI — styles.css
   Archetype: 05 Mouse-Reactive Gradient, adapted — dark cool background +
   electric cyan / neon orange (brand) instead of the catalog's default
   green/pink. Signature effect: cursor-reactive gradient mesh.
   Sections:
   1. Reset & base
   2. Tokens (custom properties)
   3. Typography
   4. Layout / containers
   5. Navigation
   6. Buttons & utilities
   7. Reveal-on-scroll (defensive)
   8. Hero + mouse-gradient mesh
   9. Visual mockup cards (hero)
   10. Manifesto / section heads / mini grid / casos
   11. Product rows (accordion, productos.html)
   12. Pricing cards + shine-border (precios.html)
   13. Proceso + FAQ (contacto.html)
   14. CTA band
   15. Footer
   16. Cookie consent banner
   17. Legal pages (prose)
   18. Responsive breakpoints
   ========================================================================== */

/* 1. Reset & base ---------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; scroll-padding-top: 88px; background: #06070a; }
body, h1, h2, h3, p, ul, ol, dl, dd, figure, blockquote { margin: 0; }
ul, ol { padding: 0; list-style: none; }
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; }
table { border-collapse: collapse; width: 100%; }
::selection { background: #00e5ff; color: #03191d; }

/* 2. Tokens ----------------------------------------------------------------- */
:root{
  /* palette — dark cool + neon cyan/orange (brand: circuit "T" monogram) */
  --bg:        #06070a;
  --bg-1:      #0b0e15;
  --bg-2:      #11151e;
  --bg-3:      #181d29;
  --ink:       #eef2f6;
  --ink-soft:  #aab3c0;
  --ink-mute:  #6b7480;
  --accent:    #00e5ff;   /* electric cyan — primary */
  --accent-ink:#03191d;   /* text on accent */
  --accent-2:  #ff7a33;   /* neon orange — secondary, used sparingly */
  --violet:    #7c5cff;   /* gradient-mesh stop only */
  --line:      rgba(238,242,246,0.10);
  --line-strong: rgba(238,242,246,0.20);
  --glow-cyan:   rgba(0,229,255,0.32);
  --glow-orange: rgba(255,122,51,0.28);
  --radius:    18px;
  --ease-out:  cubic-bezier(.16,1,.3,1);
  --ease-soft: cubic-bezier(.22,1,.36,1);
  --font-display: 'Space Grotesk', ui-sans-serif, system-ui, sans-serif;
  --font-body:    'Inter', ui-sans-serif, system-ui, sans-serif;
  --font-mono:    'JetBrains Mono', ui-monospace, SFMono-Regular, monospace;
  --mx: 50%;
  --my: 35%;
}

/* 3. Typography --------------------------------------------------------------- */
body{
  background: var(--bg);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}
h1, h2, h3 { font-family: var(--font-display); font-weight: 600; letter-spacing: -0.01em; color: var(--ink); }
h1 em, h2 em, h3 em { font-style: normal; color: var(--accent); }
.kicker{
  font-family: var(--font-mono); font-size: .78rem; letter-spacing: .12em; text-transform: uppercase;
  color: var(--accent); display: inline-flex; align-items: center; gap: .55em;
}
.kicker::before{ content:""; width:6px; height:6px; border-radius:50%; background: var(--accent); box-shadow: 0 0 8px var(--glow-cyan); flex-shrink:0; }
a:focus-visible, button:focus-visible, summary:focus-visible { outline: 2px solid var(--accent); outline-offset: 3px; border-radius: 4px; }

/* 4. Layout / containers ----------------------------------------------------- */
.wrap{ max-width: 1180px; margin: 0 auto; padding-inline: 24px; }
.skip-link{ position:absolute; left:-9999px; top:0; background: var(--accent); color: var(--accent-ink); padding:.6rem 1rem; z-index:1000; border-radius: 0 0 8px 0; }
.skip-link:focus{ left:0; top:0; }

/* 5. Navigation ---------------------------------------------------------------- */
.nav{
  position: fixed; top: 0; inset-inline: 0; z-index: 100;
  border-bottom: 1px solid transparent;
  transition: background-color .4s var(--ease-out), border-color .4s var(--ease-out), backdrop-filter .4s var(--ease-out);
}
.nav.is-scrolled{
  background: rgba(6,7,10,0.82);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-color: var(--line);
}
.nav-inner{ display:flex; align-items:center; gap:1.5rem; padding-block:1rem; }
.brand{ display:inline-flex; align-items:center; gap:.65rem; font-family: var(--font-display); font-weight:600; font-size:1.05rem; }
.brand-mark{ width:34px; height:34px; flex-shrink:0; }
.nav-links{ display:none; align-items:center; gap:1.9rem; margin-inline:auto; font-size:.92rem; }
@media (min-width:860px){ .nav-links{ display:flex; } }
.nav-link{ position:relative; padding:.3rem 0; color: var(--ink-soft); transition: color .3s; }
.nav-link::after{
  content:""; position:absolute; left:0; right:0; bottom:-2px; height:1px; background: var(--accent);
  transform: scaleX(0); transform-origin: right; transition: transform .4s var(--ease-soft);
}
.nav-link:hover{ color: var(--ink); }
.nav-link:hover::after{ transform: scaleX(1); transform-origin: left; }
.nav-link[aria-current="page"]{ color: var(--ink); }
.nav-link[aria-current="page"]::after{ transform: scaleX(1); background: var(--accent); }
.nav-cta{ display:none; }
@media (min-width:860px){ .nav-cta{ display:inline-flex; } }
.nav-toggle{ display:inline-flex; flex-direction:column; gap:5px; padding:.4rem; margin-left:auto; }
@media (min-width:860px){ .nav-toggle{ display:none; } }
.nav-toggle span{ width:20px; height:2px; background: var(--ink); transition: transform .3s, opacity .3s; }
.nav-toggle[aria-expanded="true"] span:nth-child(1){ transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2){ opacity:0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3){ transform: translateY(-7px) rotate(-45deg); }
.nav-links-mobile{
  position: fixed; inset: 64px 0 0 0; z-index: 99; background: var(--bg-1);
  transform: translateY(-8px); opacity:0; pointer-events:none;
  transition: opacity .3s, transform .3s;
  display:flex; flex-direction:column; padding: 2rem 1.5rem; gap: 1.4rem;
}
.nav-links-mobile.is-open{ opacity:1; pointer-events:auto; transform: translateY(0); }
.nav-links-mobile a{ font-size:1.2rem; font-family: var(--font-display); color: var(--ink-soft); }
.nav-links-mobile a[aria-current="page"]{ color: var(--accent); }
@media (min-width:860px){ .nav-links-mobile{ display:none; } }

/* 6. Buttons & utilities -------------------------------------------------------- */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5em;
  padding: .85rem 1.5rem; border-radius: 999px; font-weight:600; font-size:.95rem;
  transition: transform .35s var(--ease-soft), box-shadow .35s var(--ease-soft), border-color .3s, color .3s;
}
.btn-cta{ background: var(--accent); color: var(--accent-ink); box-shadow: 0 0 0 1px rgba(0,229,255,.4), 0 18px 40px -16px var(--glow-cyan); }
.btn-cta:hover{ transform: translateY(-2px); box-shadow: 0 0 0 1px rgba(0,229,255,.6), 0 24px 48px -16px var(--glow-cyan); }
.btn-ghost{ border: 1px solid var(--line-strong); color: var(--ink); }
.btn-ghost:hover{ border-color: var(--accent); color: var(--accent); }
.btn-lg{ padding: 1rem 1.9rem; font-size: 1rem; }
.btn-card{ width:100%; border: 1px solid var(--line-strong); color: var(--ink); margin-top:auto; }
.btn-card:hover{ border-color: var(--accent); color: var(--accent); }

/* 7. Reveal-on-scroll (defensive — visible by default, JS opts in) ------------- */
.reveal{ opacity:1; transform:none; }
html.js-ready .reveal{ opacity:0; transform: translateY(28px); transition: opacity .8s var(--ease-soft), transform .8s var(--ease-soft); }
html.js-ready .reveal.is-visible{ opacity:1; transform:none; }

/* 8. Hero + mouse-gradient mesh -------------------------------------------------- */
.mesh-mouse{ position:absolute; inset:0; z-index:0; overflow:hidden; pointer-events:none; }
.mesh-mouse::before{
  content:""; position:absolute; inset:-20%;
  background:
    radial-gradient(circle 520px at var(--mx) var(--my), rgba(0,229,255,.30), transparent 60%),
    radial-gradient(circle 620px at calc(var(--mx) + 14%) calc(var(--my) - 12%), rgba(124,92,255,.20), transparent 60%),
    radial-gradient(circle 560px at calc(var(--mx) - 16%) calc(var(--my) + 14%), rgba(255,122,51,.18), transparent 60%);
  filter: blur(60px) saturate(130%);
}
.hero, .page-hero{ position:relative; isolation:isolate; overflow:hidden; }
.hero{ padding-top:9.5rem; padding-bottom:5rem; }
.page-hero{ padding-top:9rem; padding-bottom:4rem; }
.hero .wrap, .page-hero .wrap{ position:relative; z-index:1; }
.page-hero h1{ font-size: clamp(2.1rem, 4.4vw, 3.2rem); margin-top:1rem; max-width:20ch; }
.page-hero p{ margin-top:1rem; color: var(--ink-soft); max-width:54ch; font-size:1.05rem; }
.hero-grid{ display:grid; gap:3rem; }
@media (min-width:980px){ .hero-grid{ grid-template-columns: 1.1fr .9fr; align-items:center; } }
.hero-title{ font-size: clamp(2.3rem, 5vw, 3.6rem); line-height:1.08; margin-top:1.1rem; max-width:19ch; }
.hero-sub{ margin-top:1.2rem; color: var(--ink-soft); font-size:1.08rem; max-width:46ch; }
.hero-actions{ display:flex; flex-wrap:wrap; gap:1rem; margin-top:2rem; }
.stat-strip{ display:flex; gap:2.2rem; margin-top:3rem; flex-wrap:wrap; }
.stat dt{ font-family: var(--font-mono); font-size:1.5rem; color: var(--accent); }
.stat dd{ font-size:.85rem; color: var(--ink-mute); margin-top:.2rem; max-width:16ch; }

/* 9. Visual mockup cards (hero) -------------------------------------------------- */
.hero-visual{ position:relative; display:grid; gap:1rem; }
.visual-card{ background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding: 1.2rem; animation: floatY 7s ease-in-out infinite; }
.visual-card--crm{ animation-delay: .4s; }
.visual-card--portal{ animation-delay: .8s; }
@keyframes floatY{ 0%, 100% { transform: translateY(0); } 50% { transform: translateY(-10px); } }
.visual-label{ font-family: var(--font-mono); font-size:.72rem; letter-spacing:.06em; text-transform:uppercase; color: var(--ink-mute); margin-bottom:.7rem; }
.chat-bubble{ font-size:.82rem; padding:.55rem .8rem; border-radius:10px; margin-bottom:.5rem; max-width:90%; }
.chat-bubble--in{ background: var(--bg-3); color: var(--ink-soft); }
.chat-bubble--out{ background: rgba(0,229,255,.12); color: var(--accent); border: 1px solid rgba(0,229,255,.25); }
.bars{ display:flex; align-items:flex-end; gap:.4rem; height:60px; }
.bars span{ flex:1; background: linear-gradient(180deg, var(--accent), var(--violet)); height: var(--h); border-radius: 3px 3px 0 0; opacity:.85; }
.visual-foot{ font-size:.78rem; color: var(--ink-mute); margin-top:.6rem; }
.ring{ --p: 82; width:64px; height:64px; border-radius:50%; display:grid; place-items:center; background: conic-gradient(var(--accent) calc(var(--p)*1%), var(--bg-3) 0); margin:0 auto; }
.ring span{ background: var(--bg-2); width:46px; height:46px; border-radius:50%; display:grid; place-items:center; font-family: var(--font-mono); font-size:.78rem; }

/* 10. Manifesto / section heads / mini grid / casos ------------------------------ */
.manifesto{ padding-block:5rem; border-top: 1px solid var(--line); }
.manifesto-grid{ display:grid; gap:1.5rem; max-width:900px; }
.manifesto h2{ font-size: clamp(1.7rem, 3vw, 2.3rem); }
.manifesto-text{ color: var(--ink-soft); font-size:1.08rem; max-width:60ch; }

.section-head{ margin-bottom:2.6rem; }
.section-head h2{ font-size: clamp(1.8rem, 3.4vw, 2.5rem); margin-top:.8rem; max-width:24ch; }
section + section{ border-top: 1px solid var(--line); }
section{ padding-block: 5rem; }

.mini-grid{ display:grid; gap:1.2rem; }
@media (min-width:760px){ .mini-grid{ grid-template-columns: repeat(3, 1fr); } }
.mini-card{ background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding:1.6rem; transition: border-color .3s, transform .3s; }
.mini-card:hover{ border-color: var(--accent); transform: translateY(-4px); }
.mini-icon{ width:38px; height:38px; color: var(--accent); margin-bottom:1rem; }
.mini-card h3{ font-size:1.1rem; margin-bottom:.5rem; }
.mini-card p{ color: var(--ink-soft); font-size:.92rem; }
.mini-card .mini-link{ display:inline-flex; align-items:center; gap:.4em; margin-top:1rem; color: var(--accent); font-size:.88rem; font-weight:600; }
.services-teaser{ margin-top:1.8rem; text-align:center; font-size:.95rem; }
.services-teaser a{ color: var(--accent); font-weight:600; }
.services-teaser a:hover{ text-decoration: underline; }
@media (min-width:760px){ .mini-grid--services{ grid-template-columns: repeat(2, 1fr); } }

.case-grid{ display:grid; gap:1.2rem; }
@media (min-width:760px){ .case-grid{ grid-template-columns: repeat(3, 1fr); } }
.case{ background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding:1.5rem; }
.case-tag{ font-family: var(--font-mono); font-size:.74rem; color: var(--accent-2); text-transform:uppercase; letter-spacing:.05em; margin-bottom:.7rem; }
.case p:not(.case-tag){ color: var(--ink-soft); font-size:.92rem; }

/* 11. Product rows (accordion, productos.html) ----------------------------------- */
.product-list{ border-top: 1px solid var(--line); }
.product-row{ border-bottom: 1px solid var(--line); }
.product-row summary{ list-style:none; cursor:pointer; display:flex; align-items:center; gap:1.2rem; padding: 1.6rem 0; }
.product-row summary::-webkit-details-marker{ display:none; }
.row-index{ font-family: var(--font-mono); color: var(--ink-mute); font-size:.9rem; width:2.4ch; flex-shrink:0; }
.row-icon{ width:30px; height:30px; color: var(--accent); flex-shrink:0; }
.row-title{ font-family: var(--font-display); font-size:1.25rem; flex:1; }
.row-price{ font-family: var(--font-mono); font-size:.85rem; color: var(--accent-2); white-space:nowrap; }
.row-chevron{ width:18px; height:18px; color: var(--ink-mute); transition: transform .3s var(--ease-soft); flex-shrink:0; }
.product-row[open] .row-chevron{ transform: rotate(180deg); }
.product-row[open] summary{ padding-bottom:1rem; }
.row-body{ padding-bottom:2.4rem; display:grid; gap:1.5rem; }
@media (min-width:760px){ .row-body{ grid-template-columns: 1.3fr .9fr; } }
.row-body p{ color: var(--ink-soft); }
.feat-list{ display:grid; gap:.6rem; align-content:start; }
.feat-list li{ position:relative; padding-left:1.3rem; color: var(--ink-soft); font-size:.92rem; }
.feat-list li::before{ content:""; position:absolute; left:0; top:.55em; width:6px; height:6px; border-radius:50%; background: var(--accent); }

/* 12. Pricing cards + shine-border (precios.html) -------------------------------- */
.price-grid{ display:grid; gap:1.4rem; }
@media (min-width:760px){ .price-grid{ grid-template-columns: repeat(3, 1fr); align-items:start; } }
.price-card{ background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding:1.8rem; display:flex; flex-direction:column; height:100%; }
@media (min-width:760px){ .price-card--wide{ grid-column: span 3; } }
.price-card h3{ font-size:1.2rem; margin-bottom:.8rem; }
.price-big{ font-family: var(--font-display); font-size:2.2rem; color: var(--accent); }
.price-big span{ font-size:1rem; color: var(--ink-mute); font-family: var(--font-body); font-weight:400; }
.price-sub{ color: var(--ink-soft); font-size:.9rem; margin-top:.3rem; }
.price-desc{ color: var(--ink-soft); font-size:.92rem; margin-top:1rem; }
.price-note{ margin-top:2.4rem; color: var(--ink-mute); font-size:.85rem; text-align:center; }
.price-table{ margin-top:1.2rem; font-size:.92rem; }
.price-table th, .price-table td{ padding:.6rem .5rem; border-bottom:1px solid var(--line); text-align:left; }
.price-table thead th{ color: var(--ink-mute); font-weight:500; font-size:.78rem; text-transform:uppercase; letter-spacing:.04em; font-family: var(--font-mono); }
.price-table td, .price-table th[scope="row"]{ color: var(--ink-soft); }

/* Shine border — vanilla-CSS recreation of the 21st.dev "shadcnspace/shine-border"
   community component, adapted: rotating conic-gradient ring in the two brand
   accents (cyan + orange) instead of React/Tailwind. Degrades gracefully to a
   static two-tone ring on browsers without @property support. */
@property --shine-angle{ syntax: "<angle>"; inherits:false; initial-value:0deg; }
.shine-card{ position:relative; border-radius: calc(var(--radius) + 2px); padding:2px; isolation:isolate; }
.shine-card::before{
  content:""; position:absolute; inset:0; z-index:0; border-radius:inherit;
  background: conic-gradient(from var(--shine-angle), transparent 0deg, var(--accent) 60deg, var(--accent-2) 130deg, transparent 200deg, transparent 360deg);
  animation: shineRotate 3.2s linear infinite;
}
@keyframes shineRotate{ to { --shine-angle: 360deg; } }
.shine-card .price-card{ position:relative; z-index:1; }
.plan-badge{
  position:absolute; top:-.9rem; left:1.6rem; z-index:2;
  background: var(--accent-2); color:#1a0c02; font-family: var(--font-mono); font-size:.72rem;
  text-transform:uppercase; letter-spacing:.06em; padding:.35rem .8rem; border-radius:999px;
}

/* 13. Proceso + FAQ (contacto.html) ---------------------------------------------- */
.steps{ display:grid; gap:1.2rem; margin-top:2.2rem; }
@media (min-width:760px){ .steps{ grid-template-columns: repeat(3, 1fr); } }
.step{ background: var(--bg-2); border: 1px solid var(--line); border-radius: var(--radius); padding:1.6rem; }
.step-num{ font-family: var(--font-mono); color: var(--accent); font-size:1.3rem; }
.step h3{ margin-top:.8rem; font-size:1.05rem; }
.step p{ margin-top:.5rem; color: var(--ink-soft); font-size:.9rem; }

.faq-list{ border-top: 1px solid var(--line); margin-top: 2.2rem; }
.faq-item{ border-bottom: 1px solid var(--line); }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; justify-content:space-between; align-items:center; gap:1rem; padding:1.3rem 0; font-weight:600; }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-icon{ width:18px; height:18px; flex-shrink:0; position:relative; }
.faq-icon::before, .faq-icon::after{ content:""; position:absolute; background: var(--ink-mute); transition: transform .3s; }
.faq-icon::before{ width:100%; height:1px; top:50%; left:0; }
.faq-icon::after{ width:1px; height:100%; left:50%; top:0; }
.faq-item[open] .faq-icon::after{ transform: scaleY(0); }
.faq-item p{ padding-bottom:1.4rem; color: var(--ink-soft); }

/* 14. CTA band --------------------------------------------------------------------- */
.cta-band{ position:relative; isolation:isolate; overflow:hidden; padding-block:6rem; border-top: 1px solid var(--line); text-align:center; }
.cta-band .wrap{ position:relative; z-index:1; }
.cta-band h2{ font-size: clamp(1.8rem, 3.6vw, 2.6rem); max-width:24ch; margin:0 auto 1rem; }
.cta-band p{ color: var(--ink-soft); max-width:46ch; margin:0 auto 2rem; }
.cta-band .hero-actions{ justify-content:center; }

/* 15. Footer ------------------------------------------------------------------------ */
.site-footer{ border-top: 1px solid var(--line); padding-block: 3.5rem 2rem; }
.footer-grid{ display:grid; gap:2rem; }
@media (min-width:760px){ .footer-grid{ grid-template-columns: 1.2fr 1fr 1fr; } }
.footer-brand p{ color: var(--ink-mute); font-size:.88rem; margin-top:.8rem; max-width:28ch; }
.footer-nav{ display:flex; flex-direction:column; gap:.6rem; font-size:.92rem; }
.footer-nav a:hover{ color: var(--accent); }
.footer-contact{ display:flex; flex-direction:column; gap:.6rem; font-size:.92rem; }
.footer-contact a:hover{ color: var(--accent); }
.footer-legal{ margin-top:2.5rem; padding-top:1.5rem; border-top: 1px solid var(--line); color: var(--ink-mute); font-size:.82rem; display:flex; flex-wrap:wrap; gap:1rem 1.6rem; align-items:center; justify-content:space-between; }
.footer-legal-links{ display:flex; gap:1.2rem; flex-wrap:wrap; }
.footer-legal-links a{ color: var(--ink-mute); }
.footer-legal-links a:hover{ color: var(--accent); }

/* Contact form (contacto.html) -------------------------------------------------------- */
.contact-form{ display:grid; gap:1.4rem; max-width:640px; margin-top:2.2rem; }
.form-row{ display:grid; gap:.5rem; }
.form-row label{ font-size:.88rem; color: var(--ink-soft); font-weight:600; }
.form-row input,
.form-row select,
.form-row textarea{
  background: var(--bg-2); border: 1px solid var(--line-strong); border-radius: 10px;
  padding: .8rem 1rem; color: var(--ink); font-family: var(--font-body); font-size: .95rem;
  transition: border-color .3s;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus{ outline:none; border-color: var(--accent); }
.form-row textarea{ resize: vertical; min-height: 120px; }
.contact-form .btn{ justify-self:start; }
.form-note{ font-size:.82rem; color: var(--ink-mute); margin-top:-.4rem; }
.form-status{ font-size:.9rem; color: var(--accent); margin-top:-.4rem; }
.form-status.is-error{ color: var(--accent-2); }
.contact-form button[disabled]{ opacity:.6; cursor:not-allowed; }
.visually-hidden-field{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }

/* 16. Cookie consent banner ----------------------------------------------------------- */
.cookie-banner{
  position: fixed; left:0; right:0; bottom:0; z-index: 90;
  padding: 1.1rem 1.2rem; background: rgba(8,10,16,0.97);
  border-top: 1px solid rgba(0,229,255,0.18);
  backdrop-filter: blur(10px) saturate(140%); -webkit-backdrop-filter: blur(10px) saturate(140%);
  transform: translateY(100%); transition: transform .45s var(--ease-soft);
}
.cookie-banner.is-visible{ transform: translateY(0); }
.cookie-banner-inner{
  max-width: 1180px; margin:0 auto; display:flex; flex-wrap:wrap;
  align-items:center; gap:1rem 1.8rem; justify-content:space-between;
}
.cookie-banner p{ margin:0; font-size:.88rem; color: var(--ink-soft); max-width:72ch; }
.cookie-banner a{ color: var(--accent); }
.cookie-banner a:hover{ text-decoration: underline; }
.cookie-banner-actions{ flex-shrink:0; }
.btn-sm{ padding:.6rem 1.3rem; font-size:.88rem; }

/* 17. Legal pages (prose) ------------------------------------------------------------- */
.legal-content{ max-width: 74ch; margin-top:1rem; }
.legal-content h2{ font-size:1.3rem; margin-top:2.4rem; margin-bottom:.8rem; }
.legal-content h2:first-child{ margin-top:0; }
.legal-content p{ color: var(--ink-soft); margin-top:.9rem; }
.legal-content ul{ margin-top:.9rem; display:grid; gap:.5rem; }
.legal-content li{ position:relative; padding-left:1.3rem; color: var(--ink-soft); font-size:.95rem; }
.legal-content li::before{ content:""; position:absolute; left:0; top:.6em; width:5px; height:5px; border-radius:50%; background: var(--accent); }
.legal-content .placeholder{ color: var(--accent-2); font-weight:600; }
.legal-updated{ color: var(--ink-mute); font-size:.85rem; margin-top:1.5rem; }

/* 18. Responsive breakpoints --------------------------------------------------------- */
@media (max-width: 540px){
  .wrap{ padding-inline: 18px; }
  section{ padding-block: 3.6rem; }
  .stat-strip{ gap: 1.4rem; }
  .hero, .page-hero{ padding-top: 7.2rem; }
}
@media (max-width: 720px){
  .hero-actions, .cta-band .hero-actions{ flex-direction: column; align-items:stretch; }
  .hero-actions .btn, .cta-band .hero-actions .btn{ width:100%; }
}
