/* =====================================================================
   Lemo IPTV — Shared Design System  (css/styles.css)
   LIGHT theme · Deep Teal #0F766E · Amber #F59E0B
   Fonts: Space Grotesk (display) + Inter (body)
   Mobile-first · Vanilla HTML+CSS · Lighthouse-mobile friendly
   Single source of truth — every page links this file. Do not invent tokens.
   ===================================================================== */

/* ---------- 1. Design Tokens ---------- */
:root{
  /* Brand */
  --teal:#0F766E;
  --teal-600:#0D6B63;
  --teal-700:#0B5A54;
  --teal-50:#F0FDFA;
  --teal-100:#CCFBF1;
  --teal-ring:rgba(15,118,110,.28);
  --amber:#F59E0B;
  --amber-600:#D97706;
  --amber-50:#FFFBEB;
  --amber-100:#FEF3C7;

  /* Neutrals */
  --white:#FFFFFF;
  --surface:#F8FAFC;       /* alt section bg */
  --tint:#F0FDFA;          /* teal-tinted alt bg */
  --cloud:#F1F5F9;
  --line:#E2E8F0;          /* hairline borders */
  --line-strong:#CBD5E1;
  --ink:#0F172A;           /* primary text */
  --ink-2:#334155;         /* secondary */
  --muted:#64748B;         /* tertiary */
  --muted-2:#94A3B8;

  /* Feedback */
  --success:#059669;
  --danger:#DC2626;

  /* Type families — EXACTLY 2 */
  --f-display:"Space Grotesk","Inter",system-ui,sans-serif;
  --f-body:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;

  /* Type scale (fluid, mobile-first) */
  --fs-hero:clamp(2.25rem,1.4rem + 3.6vw,3.75rem);
  --fs-h2:clamp(1.75rem,1.2rem + 2.2vw,2.5rem);
  --fs-h3:clamp(1.25rem,1.05rem + .9vw,1.5rem);
  --fs-lead:clamp(1.0625rem,1rem + .3vw,1.25rem);
  --fs-body:clamp(1rem,.97rem + .15vw,1.0625rem);
  --fs-small:.875rem;
  --fs-xs:.8125rem;
  --lh-tight:1.08;
  --lh-snug:1.3;
  --lh-body:1.65;

  /* Spacing scale */
  --s1:.25rem; --s2:.5rem; --s3:.75rem; --s4:1rem; --s5:1.5rem;
  --s6:2rem;  --s7:3rem;   --s8:4rem;   --s9:5rem; --s10:7.5rem;

  /* Radii */
  --r-sm:8px; --r-md:12px; --r-lg:16px; --r-xl:24px; --r-pill:999px;

  /* Shadows */
  --sh-1:0 1px 2px rgba(15,23,42,.06),0 1px 3px rgba(15,23,42,.04);
  --sh-2:0 6px 16px rgba(15,23,42,.08),0 2px 6px rgba(15,23,42,.05);
  --sh-3:0 18px 40px -12px rgba(15,23,42,.18),0 6px 14px rgba(15,23,42,.06);
  --sh-pop:0 0 0 4px var(--teal-50),0 22px 50px -14px rgba(15,118,110,.32);

  /* Layout */
  --container:1200px;
  --container-narrow:780px;
  --gutter:clamp(1.25rem,4vw,2rem);
  --section-y:clamp(4rem,8vw,7.5rem);
  --header-h:68px;

  /* Motion */
  --ease:cubic-bezier(.4,0,.2,1);
  --t-fast:.15s var(--ease);
  --t:.25s var(--ease);

  color-scheme:light;
}

/* ---------- 2. Reset / Base ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:calc(var(--header-h) + 16px)}
body{
  font-family:var(--f-body);
  font-size:var(--fs-body);
  line-height:var(--lh-body);
  color:var(--ink);
  background:var(--white);
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:var(--teal);text-decoration:none;transition:color var(--t-fast)}
a:hover{color:var(--teal-700)}
ul,ol{list-style:none}
button{font:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font:inherit;color:inherit}
:focus-visible{outline:3px solid var(--teal-ring);outline-offset:2px;border-radius:6px}
hr{border:0;border-top:1px solid var(--line);margin:var(--s6) 0}

/* ---------- 3. Typography ---------- */
h1,h2,h3,h4{font-family:var(--f-display);font-weight:700;line-height:var(--lh-tight);letter-spacing:-.02em;color:var(--ink)}
h1{font-size:var(--fs-hero)}
h2{font-size:var(--fs-h2)}
h3{font-size:var(--fs-h3)}
p{max-width:70ch}
strong{font-weight:600;color:var(--ink)}
small{font-size:var(--fs-small)}
.lead{font-size:var(--fs-lead);color:var(--ink-2);line-height:1.55}
.muted{color:var(--muted)}
.center{text-align:center}
.measure{max-width:65ch}
.measure-narrow{max-width:52ch}

/* ---------- 4. Layout helpers ---------- */
.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter)}
.container--narrow{max-width:var(--container-narrow)}
.section{padding-block:var(--section-y)}
.section--alt{background:var(--surface)}
.section--tint{background:linear-gradient(180deg,var(--teal-50),var(--white))}
.stack{display:flex;flex-direction:column;gap:var(--s4)}
.stack-lg{gap:var(--s6)}
.cluster{display:flex;flex-wrap:wrap;gap:var(--s3);align-items:center}
.cluster--center{justify-content:center}
.grid{display:grid;gap:var(--s5)}

/* Section heading block */
.section-head{max-width:62ch;margin-bottom:var(--s7)}
.section-head--center{margin-inline:auto;text-align:center}
.section-head--center .lead{margin-inline:auto}
.eyebrow{
  display:inline-flex;align-items:center;gap:.5rem;
  font-family:var(--f-display);font-weight:600;font-size:var(--fs-xs);
  letter-spacing:.12em;text-transform:uppercase;color:var(--teal);
  margin-bottom:var(--s3);
}
.eyebrow::before{content:"";width:22px;height:2px;background:var(--amber);border-radius:2px}

/* ---------- 5. Buttons ---------- */
.btn{
  --bg:var(--ink);--fg:var(--white);
  display:inline-flex;align-items:center;justify-content:center;gap:.55rem;
  font-family:var(--f-display);font-weight:600;font-size:.96875rem;
  line-height:1;padding:.95rem 1.4rem;border-radius:var(--r-md);
  background:var(--bg);color:var(--fg);border:1px solid transparent;
  transition:transform var(--t-fast),box-shadow var(--t-fast),background var(--t-fast),color var(--t-fast);
  min-height:48px;text-align:center;
}
.btn:hover{transform:translateY(-1px);color:var(--fg)}
.btn:active{transform:translateY(0)}
.btn--primary{--bg:var(--teal);box-shadow:var(--sh-2)}
.btn--primary:hover{--bg:var(--teal-600);box-shadow:var(--sh-3)}
.btn--amber{--bg:var(--amber);color:#3a2600}
.btn--amber:hover{--bg:var(--amber-600);color:#fff}
.btn--secondary{--bg:var(--white);--fg:var(--ink);border-color:var(--line-strong)}
.btn--secondary:hover{border-color:var(--teal);color:var(--teal);--bg:var(--white)}
.btn--ghost{--bg:transparent;--fg:var(--teal)}
.btn--ghost:hover{--bg:var(--teal-50);color:var(--teal-700)}
.btn--lg{padding:1.1rem 1.75rem;font-size:1.03125rem;min-height:54px}
.btn--block{width:100%}
.btn-row{display:flex;flex-wrap:wrap;gap:var(--s3);align-items:center}
.btn .arrow{transition:transform var(--t-fast)}
.btn:hover .arrow{transform:translateX(3px)}
.link-arrow{display:inline-flex;gap:.4rem;align-items:center;min-height:44px;font-weight:600;color:var(--teal);font-family:var(--f-display)}
.link-arrow:hover{color:var(--teal-700)}

/* ---------- 6. Chips / pills / badges ---------- */
.pill{
  display:inline-flex;align-items:center;gap:.5rem;
  font-size:var(--fs-small);font-weight:600;
  padding:.45rem .85rem;border-radius:var(--r-pill);
  background:var(--teal-50);color:var(--teal-700);border:1px solid var(--teal-100);
}
.pill svg{width:16px;height:16px;flex:none}
.badge{
  display:inline-flex;align-items:center;gap:.4rem;
  font-size:var(--fs-xs);font-weight:600;text-transform:uppercase;letter-spacing:.06em;
  padding:.35rem .7rem;border-radius:var(--r-pill);
  background:var(--amber-100);color:var(--amber-600);
}

/* ---------- 7. Header / nav (persistent) ---------- */
.site-header{
  position:sticky;top:0;z-index:60;
  background:rgba(255,255,255,.86);
  backdrop-filter:saturate(160%) blur(10px);
  border-bottom:1px solid var(--line);
}
.site-header__inner{
  max-width:var(--container);margin-inline:auto;padding-inline:var(--gutter);
  height:var(--header-h);display:flex;align-items:center;gap:var(--s5);justify-content:space-between;
}
.logo{display:inline-flex;align-items:center;gap:.55rem;font-family:var(--f-display);font-weight:700;font-size:1.1875rem;color:var(--ink);letter-spacing:-.02em;min-height:44px}
.logo__mark{width:30px;height:30px;border-radius:9px;background:linear-gradient(145deg,var(--teal),var(--teal-600));display:grid;place-items:center;color:#fff;flex:none;box-shadow:var(--sh-1)}
.logo__mark svg{width:18px;height:18px}
.logo b{color:var(--teal)}
.nav{display:flex;align-items:center;gap:.25rem}
.nav__list{display:flex;align-items:center;gap:.15rem}
.nav__link{display:inline-flex;align-items:center;min-height:44px;padding:.55rem .8rem;border-radius:var(--r-sm);font-size:.9375rem;font-weight:500;color:var(--ink-2)}
.nav__link:hover{background:var(--surface);color:var(--teal)}
.nav__link[aria-current="page"]{color:var(--teal);font-weight:600}
.header__cta{display:inline-flex;align-items:center;gap:var(--s3)}
.header__cta .btn{min-height:44px;padding:.7rem 1.1rem}
.nav-toggle{display:none;width:44px;height:44px;flex-shrink:0;align-items:center;justify-content:center;border-radius:10px;color:var(--ink)}
.nav-toggle svg{width:24px;height:24px}
/* Mobile nav drawer */
@media (max-width:900px){
  .nav{position:fixed;inset:var(--header-h) 0 auto 0;background:var(--white);border-bottom:1px solid var(--line);padding:var(--s4) var(--gutter) var(--s6);transform:translateY(-130%);transition:transform var(--t);box-shadow:var(--sh-2);max-height:calc(100vh - var(--header-h));overflow:auto}
  .nav[data-open="true"]{transform:translateY(0)}
  .nav__list{flex-direction:column;align-items:stretch;gap:.25rem;background:var(--white)}
  .nav__link{padding:.85rem .5rem;font-size:1rem;border-radius:10px}
  .nav-toggle{display:inline-flex}
  .header__cta .btn--secondary{display:none}
}

/* ---------- 8. Hero ---------- */
.hero{position:relative;background:
   radial-gradient(1200px 480px at 85% -10%,var(--teal-50),transparent 60%),
   linear-gradient(180deg,#fff,var(--surface));overflow:hidden}
.hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:var(--s8);align-items:center;padding-block:clamp(2.5rem,6vw,5.5rem)}
.hero__title{margin-bottom:var(--s5)}
.hero__title .hl{color:var(--teal);position:relative;white-space:nowrap}
.hero__lead{font-size:var(--fs-lead);color:var(--ink-2);max-width:54ch;margin-bottom:var(--s6)}
.hero__actions{margin-bottom:var(--s6)}
.trust-pills{display:flex;flex-wrap:wrap;gap:var(--s2) var(--s3)}
.trust-pill{display:inline-flex;align-items:center;gap:.5rem;font-size:.9rem;font-weight:600;color:var(--ink-2)}
.trust-pill svg{width:20px;height:20px;color:var(--teal);flex:none}
.hero__media{position:relative}
.hero__media .frame{position:relative;border-radius:var(--r-xl);overflow:hidden;background:var(--cloud);box-shadow:var(--sh-3);border:1px solid var(--line)}
.hero__media img{width:100%;aspect-ratio:16/10;object-fit:cover}
.hero__media .float{position:absolute;left:-14px;bottom:-14px;background:var(--white);border:1px solid var(--line);box-shadow:var(--sh-2);border-radius:var(--r-lg);padding:.7rem .9rem;display:flex;align-items:center;gap:.6rem;font-weight:600;font-size:.9rem}
.hero__media .float .dot{width:10px;height:10px;border-radius:50%;background:var(--success);box-shadow:0 0 0 4px rgba(5,150,105,.18)}
.hero__media .float small{display:block;color:var(--muted);font-weight:500;font-size:.78rem}
@media (max-width:900px){
  .hero__inner{grid-template-columns:1fr;gap:var(--s7)}
  .hero__media{order:-1;max-width:520px}
}

/* ---------- 9. Events ticker [DATA SHELL] ---------- */
.events-ticker{background:var(--ink);color:#fff;border-block:1px solid var(--ink)}
.events-ticker__label{display:none}
.events-ticker__viewport{contain:paint;mask-image:linear-gradient(90deg,transparent,#000 6%,#000 94%,transparent)}
.events-ticker__track{display:flex;gap:0;width:max-content;animation:ticker 38s linear infinite}
.events-ticker:hover .events-ticker__track{animation-play-state:paused}
.event-pill{display:inline-flex;align-items:center;gap:.7rem;padding:.85rem 1.4rem;border-right:1px solid rgba(255,255,255,.08);white-space:nowrap}
.event-pill__time{font-family:var(--f-display);font-weight:700;font-size:.72rem;letter-spacing:.08em;color:var(--amber);text-transform:uppercase}
.event-pill__match{font-weight:600;font-size:.9rem;color:#E2E8F0}
.event-pill__league{color:var(--muted-2);font-size:.78rem;font-weight:500}
.live-dot{width:8px;height:8px;border-radius:50%;background:#22C55E;flex:none;box-shadow:0 0 0 0 rgba(34,197,94,.7);animation:pulse 1.6s infinite}
@keyframes ticker{to{transform:translateX(-50%)}}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(34,197,94,.5)}70%{box-shadow:0 0 0 7px rgba(34,197,94,0)}100%{box-shadow:0 0 0 0 rgba(34,197,94,0)}}
@media (prefers-reduced-motion:reduce){
  .events-ticker__track{animation:none;flex-wrap:wrap;justify-content:center;width:100%}
  .live-dot{animation:none}
}

/* ---------- 10. Feature grid ---------- */
.features{grid-template-columns:repeat(3,1fr);gap:var(--s5)}
.feature{position:relative;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--sh-1);transition:transform var(--t),box-shadow var(--t),border-color var(--t)}
.feature::before{content:"";position:absolute;left:0;top:0;height:3px;width:46px;background:var(--teal);border-radius:0 0 3px 0}
.feature:hover{transform:translateY(-4px);box-shadow:var(--sh-2);border-color:var(--teal-100)}
.feature__icon{width:46px;height:46px;border-radius:12px;background:var(--teal-50);color:var(--teal);display:grid;place-items:center;margin-bottom:var(--s4)}
.feature__icon svg{width:24px;height:24px}
.feature__title{font-size:1.125rem;margin-bottom:var(--s2)}
.feature__text{color:var(--ink-2);font-size:.96875rem;line-height:1.6}
@media (max-width:900px){.features{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.features{grid-template-columns:1fr}}

/* ---------- 11. Sports / split feature ---------- */
.split{grid-template-columns:1fr 1fr;gap:var(--s8);align-items:center}
.split__media .frame{border-radius:var(--r-xl);overflow:hidden;border:1px solid var(--line);box-shadow:var(--sh-2);background:var(--cloud)}
.split__media img{width:100%;aspect-ratio:3/2;object-fit:cover}
.split__copy h2{margin-bottom:var(--s5)}
.split__copy p{color:var(--ink-2);margin-bottom:var(--s4)}
.split__copy p+p{margin-top:-.5rem}
.checklist{display:grid;gap:var(--s3);margin-top:var(--s5)}
.checklist li{display:flex;gap:.65rem;align-items:flex-start;font-weight:500;color:var(--ink-2)}
.checklist svg{width:22px;height:22px;color:var(--teal);flex:none;margin-top:1px}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:var(--s6)}}

/* ---------- 12. Pricing [DATA SHELL] ---------- */
.pricing{scroll-margin-top:90px}
#pricing-tabs{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:var(--s7)}
.conn-tab{font-family:var(--f-display);font-weight:600;font-size:.9375rem;color:var(--ink-2);background:var(--white);border:1px solid var(--line-strong);padding:.7rem 1.1rem;border-radius:var(--r-pill);transition:all var(--t-fast);min-height:48px;display:inline-flex;align-items:center;gap:.4rem}
.conn-tab:hover{border-color:var(--teal);color:var(--teal)}
.conn-tab.active{background:var(--teal);border-color:var(--teal);color:#fff;box-shadow:var(--sh-2)}
#pricing-grid{grid-template-columns:repeat(4,1fr);gap:var(--s5);align-items:stretch}
.plan{position:relative;display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--sh-1);transition:transform var(--t),box-shadow var(--t)}
.plan:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.plan--popular{border:2px solid var(--teal);box-shadow:var(--sh-pop)}
.plan__badge{position:absolute;top:-13px;left:50%;transform:translateX(-50%);background:var(--amber);color:#3a2600;font-family:var(--f-display);font-weight:700;font-size:.72rem;letter-spacing:.06em;text-transform:uppercase;padding:.35rem .8rem;border-radius:var(--r-pill);box-shadow:var(--sh-1);white-space:nowrap}
.plan__duration{font-family:var(--f-display);font-weight:600;color:var(--muted);font-size:.95rem;text-transform:uppercase;letter-spacing:.06em;margin-bottom:var(--s3)}
.plan__price{font-family:var(--f-display);font-weight:700;font-size:clamp(2.25rem,5vw,2.85rem);line-height:1;color:var(--ink);display:flex;align-items:baseline;gap:.15rem}
.plan__price .currency{font-size:1.4rem;font-weight:600;color:var(--muted)}
.plan__per{color:var(--muted);font-size:.9rem;font-weight:500;margin-top:.4rem;margin-bottom:var(--s5)}
.plan__features{display:grid;gap:.6rem;margin-bottom:var(--s6);flex:1}
.plan__features li{display:flex;gap:.55rem;align-items:flex-start;font-size:.90625rem;color:var(--ink-2);line-height:1.45}
.plan__features svg{width:18px;height:18px;color:var(--success);flex:none;margin-top:2px}
.plan__cta{margin-top:auto}
.pricing__foot{margin-top:var(--s7);text-align:center;color:var(--muted);font-size:.9rem}
.pricing__foot .link-arrow{justify-content:center}
@media (max-width:980px){#pricing-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:520px){#pricing-grid{grid-template-columns:1fr}}

/* ---------- 13. Comparison table [DATA SHELL] ---------- */
.comparison{margin-top:var(--s6)}
.table-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-1);-webkit-overflow-scrolling:touch}
.comparison__table{width:100%;border-collapse:collapse;min-width:680px;background:var(--white)}
.comparison__table th,.comparison__table td{padding:var(--s4) var(--s5);text-align:center;border-bottom:1px solid var(--line);font-size:.9375rem;vertical-align:middle}
.comparison__table thead th{background:var(--surface);font-family:var(--f-display);font-weight:600;color:var(--ink-2);font-size:.9rem;white-space:nowrap}
.comparison__table tbody th{text-align:left;font-weight:600;color:var(--ink);background:var(--white)}
.comparison__table tbody tr:hover td{background:var(--teal-50)}
.comparison__brand-col{color:var(--teal);font-weight:700}
.comparison__table .icon-yes{color:var(--success)}
.comparison__table .icon-no{color:var(--muted-2)}
.comparison__table svg{width:20px;height:20px;vertical-align:middle}
.comparison__table .price{font-weight:700;color:var(--ink)}
/* highlight the "us" column */
.comparison__table thead .us{background:var(--teal);color:#fff}
.comparison__table tbody .us{background:var(--teal-50);font-weight:600}
.comparison__note{margin-top:var(--s4);font-size:.85rem;color:var(--muted);text-align:center}

/* ---------- 14. Social proof ---------- */
.proof{display:grid;grid-template-columns:1.1fr 1fr;gap:var(--s8);align-items:center}
.proof>*{min-width:0}
.rating{display:inline-flex;align-items:center;gap:.6rem;margin-bottom:var(--s4)}
.rating__stars{display:inline-flex;gap:2px;color:var(--amber)}
.rating__stars svg{width:20px;height:20px}
.rating b{font-family:var(--f-display);font-size:1.1rem}
.badges{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--s4);min-width:0}
.badge-card{display:flex;align-items:center;gap:.7rem;background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s4) var(--s5);box-shadow:var(--sh-1);font-weight:600;font-size:.9375rem;min-width:0;overflow-wrap:anywhere}
.badge-card svg{width:24px;height:24px;color:var(--teal);flex:none}
@media (max-width:900px){.proof{grid-template-columns:1fr;gap:var(--s6)}.badges{grid-template-columns:1fr 1fr}}

/* ---------- 15. Forms [DATA SHELL] ---------- */
.form-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s7);box-shadow:var(--sh-2);max-width:640px}
.form-card--center{margin-inline:auto}
.form{display:grid;gap:var(--s4)}
.form__row{display:grid;grid-template-columns:1fr 1fr;gap:var(--s4)}
.field{display:grid;gap:.4rem}
.field__label{font-weight:600;font-size:.9rem;color:var(--ink-2)}
.field__label .req{color:var(--danger)}
.input,.select,textarea.input{
  width:100%;padding:.85rem .95rem;border:1px solid var(--line-strong);border-radius:var(--r-sm);
  background:var(--white);font-size:1rem;min-height:48px;transition:border-color var(--t-fast),box-shadow var(--t-fast);
}
textarea.input{min-height:130px;resize:vertical;line-height:1.5}
.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--teal);box-shadow:0 0 0 4px var(--teal-ring)}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2364748B' stroke-width='2.2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .85rem center;padding-right:2.5rem}
.form__msg{display:none;border-radius:var(--r-sm);padding:.9rem 1rem;font-weight:600;font-size:.9375rem}
.form__msg--ok{display:block;background:var(--teal-50);color:var(--teal-700);border:1px solid var(--teal-100)}
.form__hint{font-size:.82rem;color:var(--muted)}
@media (max-width:520px){.form__row{grid-template-columns:1fr}}

/* ---------- 16. FAQ ---------- */
.faq{display:grid;gap:var(--s3);max-width:780px}
.faq--center{margin-inline:auto}
.faq__item{background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--sh-1);overflow:hidden}
.faq__item summary{list-style:none;cursor:pointer;padding:var(--s5);font-family:var(--f-display);font-weight:600;font-size:1.03125rem;color:var(--ink);display:flex;justify-content:space-between;gap:1rem;align-items:center;min-height:48px}
.faq__item summary::-webkit-details-marker{display:none}
.faq__item summary .chev{flex:none;width:22px;height:22px;color:var(--teal);transition:transform var(--t)}
.faq__item[open] summary .chev{transform:rotate(45deg)}
.faq__item__a{padding:0 var(--s5) var(--s5);color:var(--ink-2);line-height:1.65;max-width:none}
.faq__item__a a{font-weight:600}

/* ---------- 17. CTA banner ---------- */
.cta-banner{position:relative;background:linear-gradient(135deg,var(--teal),var(--teal-600));border-radius:var(--r-xl);padding:clamp(2.25rem,5vw,3.5rem);text-align:center;color:#fff;overflow:hidden;box-shadow:var(--sh-3)}
.cta-banner::after{content:"";position:absolute;inset:0;background:radial-gradient(600px 300px at 80% 0%,rgba(245,158,11,.35),transparent 60%);pointer-events:none}
.cta-banner h2{color:#fff;margin-bottom:var(--s4);position:relative}
.cta-banner p{color:rgba(255,255,255,.9);margin-inline:auto;max-width:55ch;margin-bottom:var(--s6);position:relative}
.cta-banner .btn-row{justify-content:center;position:relative}
.cta-banner .btn--secondary{background:rgba(255,255,255,.12);border-color:rgba(255,255,255,.4);color:#fff}
.cta-banner .btn--secondary:hover{background:rgba(255,255,255,.22);color:#fff;border-color:#fff}

/* ---------- 18. Footer ---------- */
.site-footer{background:var(--ink);color:#CBD5E1;padding-block:var(--s8) var(--s6);margin-top:var(--section-y)}
.site-footer a{color:#CBD5E1}
.site-footer a:hover{color:#fff}
.footer__grid{display:grid;grid-template-columns:1.4fr repeat(3,1fr);gap:var(--s7);margin-bottom:var(--s7)}
.footer__brand .logo{color:#fff;margin-bottom:var(--s4)}
.footer__about{color:#94A3B8;font-size:.9375rem;max-width:34ch;margin-bottom:var(--s5)}
.footer__col h4{color:#fff;font-size:.9rem;text-transform:uppercase;letter-spacing:.08em;margin-bottom:var(--s4);font-family:var(--f-display)}
.footer__col ul{display:grid;gap:.6rem}
.footer__col a{font-size:.9375rem}
.footer__bottom{border-top:1px solid rgba(255,255,255,.12);padding-top:var(--s5);display:flex;flex-wrap:wrap;justify-content:space-between;gap:var(--s3);font-size:.85rem;color:#94A3B8}
.footer__legal{display:flex;flex-wrap:wrap;gap:var(--s4)}
@media (max-width:760px){.footer__grid{grid-template-columns:1fr 1fr;gap:var(--s6)}.footer__brand{grid-column:1/-1}}
@media (max-width:480px){.footer__grid{grid-template-columns:1fr}.footer__bottom{flex-direction:column;align-items:flex-start}}

/* ---------- 19. Sticky mobile CTA bar (persistent) ---------- */
.mobile-bar{position:fixed;left:0;right:0;bottom:0;z-index:55;display:none;gap:.6rem;padding:.6rem max(var(--gutter),env(safe-area-inset-right));padding-left:max(var(--gutter),env(safe-area-inset-left));background:rgba(255,255,255,.95);backdrop-filter:blur(10px);border-top:1px solid var(--line);box-shadow:0 -6px 18px rgba(15,23,42,.08)}
.mobile-bar .btn{flex:1;min-height:52px}
@media (max-width:760px){.mobile-bar{display:flex}body{padding-bottom:76px}}

/* ---------- 20. Breadcrumbs ---------- */
.breadcrumbs{font-size:.85rem;color:var(--muted);padding:var(--s4) 0}
.breadcrumbs ol{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}
.breadcrumbs li{display:inline-flex;align-items:center;gap:.5rem}
.breadcrumbs li:not(:last-child)::after{content:"/";color:var(--muted-2)}
.breadcrumbs a{color:var(--muted)}
.breadcrumbs a:hover{color:var(--teal)}
.breadcrumbs [aria-current="page"]{color:var(--ink-2);font-weight:600}

/* ---------- 21. Page hero (inner pages) ---------- */
.page-hero{background:radial-gradient(900px 360px at 85% -20%,var(--teal-50),transparent 60%),linear-gradient(180deg,#fff,var(--surface));border-bottom:1px solid var(--line);padding-block:clamp(2rem,4vw,3.5rem) clamp(2.5rem,5vw,4rem)}
.page-hero__inner{max-width:62ch}
.page-hero h1{margin-bottom:var(--s4)}
.page-hero .lead{color:var(--ink-2)}

/* ---------- 22. Channel categories ---------- */
.channels{grid-template-columns:repeat(2,1fr);gap:var(--s5)}
.channel-cat{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--sh-1)}
.channel-cat__head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin-bottom:var(--s4);flex-wrap:wrap}
.channel-cat__title{font-size:1.25rem;display:flex;align-items:center;gap:.6rem}
.channel-cat__title svg{width:24px;height:24px;color:var(--teal)}
.channel-cat__count{font-family:var(--f-display);font-weight:700;color:var(--teal);font-size:.95rem;background:var(--teal-50);padding:.3rem .7rem;border-radius:var(--r-pill)}
.channel-cat__brands{display:flex;flex-wrap:wrap;gap:.45rem}
.channel-cat__brands .tag{font-size:.82rem;font-weight:600;color:var(--ink-2);background:var(--surface);border:1px solid var(--line);padding:.3rem .65rem;border-radius:var(--r-pill)}
.channel-cat__note{margin-top:var(--s4);color:var(--muted);font-size:.9rem}
@media (max-width:760px){.channels{grid-template-columns:1fr}}

/* ---------- 23. Setup steps ---------- */
.steps{display:grid;gap:var(--s6)}
.device{background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);padding:var(--s6);box-shadow:var(--sh-1)}
.device__head{display:flex;align-items:center;gap:.8rem;margin-bottom:var(--s5)}
.device__icon{width:42px;height:42px;border-radius:11px;background:var(--teal-50);color:var(--teal);display:grid;place-items:center}
.device__icon svg{width:24px;height:24px}
.device__title{font-size:1.2rem}
.step-list{counter-reset:step;display:grid;gap:var(--s3)}
.step-list li{counter-increment:step;position:relative;padding-left:2.7rem;font-size:.96875rem;color:var(--ink-2);line-height:1.55;min-height:44px;display:flex;align-items:center}
.step-list li::before{content:counter(step);position:absolute;left:0;top:0;width:2rem;height:2rem;border-radius:50%;background:var(--teal);color:#fff;font-family:var(--f-display);font-weight:700;font-size:.85rem;display:grid;place-items:center}
.app-grid{grid-template-columns:repeat(4,1fr);gap:var(--s4)}
.app-card{background:var(--white);border:1px solid var(--line);border-radius:var(--r-md);padding:var(--s5);box-shadow:var(--sh-1);text-align:center}
.app-card__name{font-family:var(--f-display);font-weight:600;margin-bottom:.2rem}
.app-card__tag{color:var(--teal);font-size:.82rem;font-weight:600}
@media (max-width:900px){.app-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:480px){.app-grid{grid-template-columns:1fr}}

/* ---------- 24. Blog list / post ---------- */
.blog-grid{grid-template-columns:repeat(3,1fr);gap:var(--s6)}
.post-card{display:flex;flex-direction:column;background:var(--white);border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-1);transition:transform var(--t),box-shadow var(--t)}
.post-card:hover{transform:translateY(-4px);box-shadow:var(--sh-2)}
.post-card__media{aspect-ratio:16/9;background:var(--cloud);overflow:hidden}
.post-card__media img{width:100%;height:100%;object-fit:cover}
.post-card__body{padding:var(--s5);display:flex;flex-direction:column;gap:var(--s3);flex:1}
.post-card__cat{font-size:.78rem;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--amber-600)}
.post-card__title{font-size:1.125rem;line-height:1.3}
.post-card__title a{color:var(--ink)}
.post-card__title a:hover{color:var(--teal)}
.post-card__excerpt{color:var(--muted);font-size:.9375rem;flex:1}
.post-card__meta{font-size:.82rem;color:var(--muted-2);display:flex;gap:.6rem;align-items:center}
@media (max-width:900px){.blog-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.blog-grid{grid-template-columns:1fr}}

/* Article prose (blog posts + legal) */
.article{display:grid;grid-template-columns:1fr;gap:0}
.article__head{max-width:760px;margin-bottom:var(--s7)}
.article__meta{display:flex;flex-wrap:wrap;gap:.8rem;align-items:center;color:var(--muted);font-size:.875rem;margin-bottom:var(--s5)}
.article__meta .badge{background:var(--teal-50);color:var(--teal)}
.prose{max-width:760px;font-size:1.03125rem;line-height:1.75;color:var(--ink-2)}
.prose>*+*{margin-top:var(--s5)}
.prose h2{font-size:var(--fs-h3);margin-top:var(--s7);color:var(--ink)}
.prose h3{font-size:1.1875rem;margin-top:var(--s6);color:var(--ink)}
.prose p{max-width:none}
.prose ul, .prose ol{padding-left:1.3rem;display:grid;gap:.6rem}
.prose ul li{list-style:disc}
.prose ol li{list-style:decimal}
.prose a{font-weight:600;color:var(--teal);text-decoration:underline;text-underline-offset:2px}
.prose strong{color:var(--ink)}
.prose blockquote{border-left:4px solid var(--teal);background:var(--teal-50);padding:var(--s4) var(--s5);border-radius:0 var(--r-md) var(--r-md) 0;font-style:normal;color:var(--ink-2)}
.prose code{background:var(--surface);padding:.15rem .4rem;border-radius:6px;font-size:.9em;font-family:ui-monospace,SFMono-Regular,Menlo,monospace}
.prose img{border-radius:var(--r-md);border:1px solid var(--line);margin-top:var(--s5)}
.legal{max-width:780px}
.legal h1{margin-bottom:var(--s5)}
.legal .lead{color:var(--ink-2);margin-bottom:var(--s7)}
.legal h2{font-size:1.25rem;margin-top:var(--s7);margin-bottom:var(--s3)}
.legal p{color:var(--ink-2);margin-bottom:var(--s4)}
.legal ul{display:grid;gap:.5rem;margin-bottom:var(--s4);padding-left:1.2rem}
.legal li{list-style:disc;color:var(--ink-2)}

/* ---------- 25. Utilities ---------- */
.hide-mobile{}
.show-mobile{display:none}
.text-center{text-align:center}
.mt-0{margin-top:0}
.gap-sm{gap:var(--s3)}
.divider{height:1px;background:var(--line);border:0;margin-block:var(--s7)}
.note{font-size:.85rem;color:var(--muted)}
@media (max-width:760px){.hide-mobile{display:none!important}.show-mobile{display:revert}}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.skip-link{position:absolute;left:var(--s4);top:-60px;background:var(--teal);color:#fff;padding:.7rem 1rem;border-radius:0 0 8px 8px;z-index:100;transition:top var(--t-fast);font-weight:600}
.skip-link:focus{top:0;color:#fff}
