/* =============================================================================
   style.css — shared template (фабрика, mobile-first)
   -----------------------------------------------------------------------------
   - Цвета приходят из brand.config.js через theme.js (CSS custom properties).
     Здесь заданы fallback-значения, чтобы шаблон выглядел корректно даже без JS.
   - Шкала отступов: 4/8/12/16/24/32/48/64 (через --sp-*).
   - Шрифты: системный serif для заголовков (editorial, быстрый, без загрузки),
     системный sans для текста. НЕ Inter, НЕ фиолетовый градиент.
   ========================================================================== */

/* ---------- Tokens / fallback ------------------------------------------------ */
:root {
  /* цвета (fallback; перекрываются theme.js) */
  --c-primario: #0e3a36;  --c-primario-scuro: #0a2925; --c-primario-chiaro: #155049;
  --c-accento: #c9a25a;   --c-accento-scuro: #a8843f;
  --c-n900: #1c1a17; --c-n700: #403b34; --c-n500: #6f6759;
  --c-n300: #cfc8bb; --c-n100: #f4f1ea; --c-n050: #faf8f3; --c-bianco: #fff;
  --c-success: #2f7d4f; --c-warning: #b4791f; --c-danger: #a8392f;

  /* -------------------------------------------------------------------------
     СЕМАНТИЧЕСКИЕ ТОКЕНЫ (WCAG AA в КАЖДОЙ теме).
     В тёмных темах нейтралы инвертированы в brand.config.js: --c-n900 светлый,
     --c-bianco = тёмная поверхность. Поэтому:
       • текст/заголовки/текст-на-поверхностях выводим из --c-n900/--c-n700
         (в тёмной теме = светлые; в светлой _template = тёмные) — корректно везде;
       • текст НА тёмном бренд-цвете (header/hero/footer/thead/cta) = --c-on-primary,
         он ВСЕГДА светлый (раньше тут стоял --c-bianco, который в тёмных темах стал
         тёмной поверхностью → «тёмное на тёмном»);
       • ссылки = --c-link: на тёмных темах = яркий акцент (проходит AA),
         на светлом _template акцент-золото НЕ проходит AA на белом → theme.js
         подставляет тёмный fallback. Здесь заданы fallback-значения под светлую тему.
     theme.js перезаписывает эти токены под конкретный бренд (см. applyColors). ----- */
  --c-text: var(--c-n900);              /* основной текст */
  --c-text-muted: var(--c-n700);        /* вторичный текст (section-intro, .lead) */
  --c-heading: var(--c-n900);           /* заголовки h1-h4, caption, FAQ summary */
  --c-on-surface: var(--c-n900);        /* текст на карточках/таблицах/.note/.related */
  --c-on-surface-muted: var(--c-n700);  /* приглушённый текст на поверхностях */
  --c-on-primary: #ffffff;              /* текст на тёмном бренд-цвете (всегда светлый) */
  --c-on-primary-muted: #d7dde8;        /* приглушённый текст на тёмном бренд-цвете */
  --c-on-accent: var(--c-primario-scuro);/* текст на ярком акцент-фоне (кнопки) */
  --c-link: #0a5c52;                    /* ссылка (fallback светлой темы; dark-темы → акцент) */
  --c-link-hover: #073f38;              /* hover ссылки (fallback светлой темы) */

  /* шкала отступов */
  --sp-1: 4px;  --sp-2: 8px;  --sp-3: 12px; --sp-4: 16px;
  --sp-6: 24px; --sp-8: 32px; --sp-12: 48px; --sp-16: 64px;

  /* типографика */
  --font-head: Georgia, "Times New Roman", "Iowan Old Style", serif;
  --font-body: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
  --fs-xs: 0.8125rem; --fs-sm: 0.9375rem; --fs-base: 1.0625rem;
  --fs-lg: 1.25rem;  --fs-xl: 1.5rem;  --fs-2xl: 2rem; --fs-3xl: 2.5rem;

  /* радиусы и тени (мягкие, не «glass») */
  --r-sm: 6px; --r-md: 10px; --r-lg: 16px;
  --sh-1: 0 1px 2px rgba(28,26,23,.06), 0 1px 3px rgba(28,26,23,.08);
  --sh-2: 0 4px 12px rgba(28,26,23,.08), 0 2px 4px rgba(28,26,23,.05);
  --maxw: 1080px;
}

/* ---------- Reset minimo ----------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; overflow-x: hidden; }
body {
  margin: 0;
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--c-text);
  background: var(--c-n050);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;            /* niente scroll orizzontale (guard a 360px) */
  overflow-wrap: break-word;     /* URL/parole lunghe non sfondano il layout */
  word-break: break-word;
}
img, svg, video, iframe { max-width: 100%; height: auto; display: block; }
/* figli di grid/flex non devono forzare overflow (min-width:auto default) */
.grid > *, .cta-row > *, .app-stores > *, .footer-grid > * { min-width: 0; }
a { color: var(--c-link); text-decoration: underline; text-underline-offset: 2px; }
a:hover { color: var(--c-link-hover); }
:focus-visible { outline: 3px solid var(--c-accento); outline-offset: 2px; border-radius: 3px; }

h1, h2, h3, h4 { font-family: var(--font-head); line-height: 1.2; color: var(--c-heading); margin: 0 0 var(--sp-4); font-weight: 700; }
h1 { font-size: var(--fs-2xl); letter-spacing: -.01em; }
h2 { font-size: var(--fs-xl); margin-top: var(--sp-12); }
h3 { font-size: var(--fs-lg); margin-top: var(--sp-8); }
p { margin: 0 0 var(--sp-4); max-width: 70ch; }
ul, ol { margin: 0 0 var(--sp-4); padding-left: var(--sp-6); }
li { margin-bottom: var(--sp-2); }

/* ---------- Layout ----------------------------------------------------------- */
.wrap { width: 100%; max-width: var(--maxw); margin-inline: auto; padding-inline: var(--sp-4); }
.section { padding-block: var(--sp-8); }
.section--alt { background: var(--c-bianco); border-block: 1px solid var(--c-n100); }
.skip-link {
  position: absolute; left: -9999px; top: 0; background: var(--c-accento);
  color: var(--c-on-accent); padding: var(--sp-2) var(--sp-4); z-index: 100; border-radius: 0 0 var(--r-sm) 0;
}
.skip-link:focus { left: 0; }

/* ---------- Header ----------------------------------------------------------- */
.site-header {
  background: var(--c-primario); color: var(--c-on-primary);
  position: sticky; top: 0; z-index: 50; box-shadow: var(--sh-1);
}
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); min-height: 60px; }
.brand-mark { display: flex; align-items: center; gap: var(--sp-3); }
.brand-mark img { height: 34px; width: auto; }
.brand-mark .brand-name { font-family: var(--font-head); font-weight: 700; font-size: var(--fs-lg); color: var(--c-on-primary); text-decoration: none; }
.header-cta {
  display: inline-flex; align-items: center; justify-content: center;
  min-height: 44px; background: var(--c-accento); color: var(--c-on-accent);
  font-weight: 700; text-decoration: none; padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-sm); font-size: var(--fs-sm); white-space: nowrap;
}
.header-cta:hover { background: var(--c-accento-scuro); color: var(--c-on-accent); }

/* nav principale (header) — collassabile su mobile, orizzontale su desktop */
.site-nav { margin-left: auto; }
.site-nav ul { list-style: none; display: flex; flex-wrap: wrap; gap: var(--sp-1) var(--sp-4); margin: 0; padding: 0; }
.site-nav a { display: inline-flex; align-items: center; min-height: 44px; color: var(--c-on-primary); text-decoration: none; font-size: var(--fs-sm); font-weight: 600; white-space: nowrap; opacity: .92; }
.site-nav a:hover, .site-nav a[aria-current="page"] { color: var(--c-accento); opacity: 1; }
.site-header .wrap { flex-wrap: wrap; }
@media (max-width: 859px) {
  .site-nav { order: 3; width: 100%; border-top: 1px solid rgba(255,255,255,.12); padding-top: var(--sp-2); margin-top: var(--sp-2); margin-left: 0; }
  .site-nav ul { gap: 0 var(--sp-4); font-size: var(--fs-sm); }
  .site-nav a { min-height: 44px; }
}

/* ---------- Badge 18+ globale ------------------------------------------------ */
.age-strip {
  background: var(--c-primario-scuro); color: var(--c-on-primary-muted);
  font-size: var(--fs-xs); text-align: center; padding: var(--sp-1) var(--sp-3);
}
.age-strip strong { color: var(--c-on-primary); }

/* ---------- Hero ------------------------------------------------------------- */
.hero {
  background: linear-gradient(180deg, var(--c-primario) 0%, var(--c-primario-scuro) 100%);
  color: var(--c-on-primary); padding-block: var(--sp-12) var(--sp-8);
}
.hero h1 { color: var(--c-on-primary); font-size: var(--fs-2xl); margin-bottom: var(--sp-3); }
.hero .hero-logo { background: #ffffff; border-radius: var(--r-md); padding: var(--sp-3) var(--sp-4); display: inline-block; margin-bottom: var(--sp-6); box-shadow: var(--sh-2); }
.hero .hero-logo img { height: 44px; }
.hero-bonus {
  display: inline-block; background: rgba(255,255,255,.10); border: 1px solid var(--c-accento);
  color: var(--c-accento); font-weight: 700; padding: var(--sp-2) var(--sp-4);
  border-radius: var(--r-sm); margin-bottom: var(--sp-4); font-size: var(--fs-sm);
}
.hero-lede { color: var(--c-on-primary-muted); font-size: var(--fs-base); max-width: 60ch; }

/* rating stelle */
.rating { display: flex; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-6); flex-wrap: wrap; }
.stelle { display: inline-flex; gap: 2px; font-size: var(--fs-lg); line-height: 1; }
.stella { color: rgba(255,255,255,.30); }
.stella.is-full { color: var(--c-accento); }
.stella.is-half { background: linear-gradient(90deg, var(--c-accento) 50%, rgba(255,255,255,.30) 50%); -webkit-background-clip: text; background-clip: text; color: transparent; }
.rating-num { font-weight: 700; font-size: var(--fs-lg); color: var(--c-on-primary); }
.rating-count { color: var(--c-on-primary-muted); font-size: var(--fs-sm); }

/* CTA cluster */
.cta-row { display: flex; flex-direction: column; gap: var(--sp-3); margin-top: var(--sp-6); }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  min-height: 48px; font-weight: 700; text-decoration: none; padding: var(--sp-4) var(--sp-6);
  border-radius: var(--r-sm); font-size: var(--fs-base); border: 2px solid transparent;
  transition: transform .08s ease, background .15s ease; text-align: center;
}
.btn:active { transform: translateY(1px); }
.btn--primary { background: var(--c-accento); color: var(--c-on-accent); }
.btn--primary:hover { background: var(--c-accento-scuro); color: var(--c-on-accent); }
.btn--ghost { background: transparent; color: var(--c-on-primary); border-color: rgba(255,255,255,.5); }
.btn--ghost:hover { background: rgba(255,255,255,.10); color: var(--c-on-primary); }
.btn--block { width: 100%; }

/* ---------- Disclaimer «scopo informativo» ---------------------------------- */
.disclaimer {
  background: var(--c-n100); border-left: 4px solid var(--c-warning);
  padding: var(--sp-3) var(--sp-4); font-size: var(--fs-sm); color: var(--c-on-surface-muted);
  border-radius: 0 var(--r-sm) var(--r-sm) 0; margin-block: var(--sp-6);
}
.disclaimer strong { color: var(--c-on-surface); }

/* ---------- Breadcrumb ------------------------------------------------------- */
.breadcrumb { font-size: var(--fs-sm); padding-block: var(--sp-3); }
.breadcrumb ol { list-style: none; display: flex; flex-wrap: wrap; gap: var(--sp-2); margin: 0; padding: 0; }
.breadcrumb a { color: var(--c-link); }
.breadcrumb a:hover { color: var(--c-link-hover); }
.breadcrumb li::after { content: "›"; margin-left: var(--sp-2); color: var(--c-n500); }
.breadcrumb li:last-child::after { content: ""; }
.breadcrumb [aria-current] { color: var(--c-n500); }

/* ---------- Tables ----------------------------------------------------------- */
.table-scroll { overflow-x: auto; -webkit-overflow-scrolling: touch; margin-bottom: var(--sp-6); border-radius: var(--r-md); box-shadow: var(--sh-1); max-width: 100%; }
table { width: 100%; border-collapse: collapse; background: var(--c-bianco); font-size: var(--fs-sm); color: var(--c-on-surface); }
.table-scroll table { min-width: 520px; }   /* mantiene leggibili le colonne; scrolla dentro il contenitore */
caption { text-align: left; font-weight: 700; color: var(--c-heading); padding: var(--sp-3) var(--sp-4); font-family: var(--font-head); }
th, td { text-align: left; padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--c-n100); color: var(--c-on-surface); }
thead th { background: var(--c-primario); color: var(--c-on-primary); font-weight: 600; }
tbody th { font-weight: 600; color: var(--c-on-surface); background: var(--c-n050); }
tbody tr:last-child th, tbody tr:last-child td { border-bottom: none; }
tbody tr:hover td, tbody tr:hover th { background: var(--c-n100); }

/* «quadro generale» — двухколоночная key/value */
.quadro th { width: 42%; }

/* ---------- Cards / griglie -------------------------------------------------- */
.grid { display: grid; gap: var(--sp-4); }
.grid--cards { grid-template-columns: 1fr; }
.card {
  background: var(--c-bianco); color: var(--c-on-surface); border-radius: var(--r-md); padding: var(--sp-6);
  box-shadow: var(--sh-1); border: 1px solid var(--c-n100);
}
.card h3 { margin-top: 0; }
.card--game { display: flex; flex-direction: column; gap: var(--sp-2); }
.card--game .thumb { aspect-ratio: 16/10; background: var(--c-n100); border-radius: var(--r-sm); display: grid; place-items: center; color: var(--c-on-surface-muted); font-size: var(--fs-sm); overflow: hidden; }
.card--game .meta { font-size: var(--fs-xs); color: var(--c-on-surface-muted); }
.card--game .rtp { font-weight: 700; color: var(--c-success); }

/* ---------- Game tiles: segnaposto stilizzati (CSS/SVG, niente foto) -------- */
/* Plitke tematiche al posto del testo "Immagine ...": gradiente navy+lime,
   griglia sottile e iniziale del titolo. Coerenti col tema, niente foto inventate. */
.tile {
  position: relative;
  aspect-ratio: 16/10;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 1px solid var(--c-n300);
  background:
    radial-gradient(110% 80% at 85% -10%, rgba(58,208,122,.30), rgba(58,208,122,0) 55%),
    linear-gradient(150deg, var(--c-primario-chiaro), var(--c-primario) 60%, var(--c-primario-scuro));
}
.tile::before {
  content: "";
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  opacity: .6;
}
.tile__mark {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 64px; height: 64px;
  border-radius: 16px;
  background: rgba(16,42,77,.7);
  border: 1.5px solid var(--c-accento);
  display: grid; place-items: center;
  font-family: var(--font-head);
  font-size: 1.9rem; font-weight: 700;
  color: var(--c-accento);
  box-shadow: 0 6px 18px rgba(0,0,0,.35);
}
.tile__tag {
  position: absolute;
  left: var(--sp-3); bottom: var(--sp-3);
  font-size: var(--fs-xs); font-weight: 700;
  letter-spacing: .04em; text-transform: uppercase;
  color: #eef2f8;            /* tile = sempre navy scuro -> testo chiaro fisso */
  background: rgba(7,21,41,.65);
  padding: 2px 8px; border-radius: 999px;
  backdrop-filter: blur(2px);
}
.tile--live .tile__mark { font-size: 1.5rem; }

/* ---------- Chips (providers/payments quick) -------------------------------- */
.chips { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: var(--sp-2); }
.chip {
  background: var(--c-n100); color: var(--c-on-surface-muted); font-size: var(--fs-sm);
  padding: var(--sp-1) var(--sp-3); border-radius: 999px; border: 1px solid var(--c-n300);
}

/* ---------- Vantaggi (pro/contro style) ------------------------------------- */
.vantaggi { list-style: none; padding: 0; }
.vantaggi li { display: flex; gap: var(--sp-3); align-items: flex-start; margin-bottom: var(--sp-3); }
.vantaggi li::before { content: "✓"; color: var(--c-success); font-weight: 700; flex: none; }

/* ---------- Sicurezza / trust box ------------------------------------------- */
.trust-box { display: flex; align-items: center; gap: var(--sp-4); background: var(--c-bianco); border: 1px solid var(--c-n100); border-radius: var(--r-md); padding: var(--sp-6); box-shadow: var(--sh-1); }
.trust-box .badge-adm { flex: none; width: 72px; height: 72px; border-radius: var(--r-md); background: var(--c-primario); color: var(--c-accento); display: grid; place-items: center; font-family: var(--font-head); font-weight: 700; text-align: center; font-size: var(--fs-sm); line-height: 1.1; }

/* ---------- FAQ (accordion, <details>) -------------------------------------- */
.faq details {
  background: var(--c-bianco); border: 1px solid var(--c-n100); border-radius: var(--r-md);
  margin-bottom: var(--sp-3); box-shadow: var(--sh-1); overflow: hidden;
}
.faq summary {
  cursor: pointer; list-style: none; padding: var(--sp-4) var(--sp-6);
  min-height: 44px; box-sizing: border-box;
  font-weight: 700; color: var(--c-heading); font-family: var(--font-head);
  display: flex; justify-content: space-between; align-items: center; gap: var(--sp-4);
}
.faq summary::-webkit-details-marker { display: none; }
.faq summary::after { content: "+"; font-size: var(--fs-xl); color: var(--c-accento); flex: none; transition: transform .15s; }
.faq details[open] summary::after { content: "−"; }
.faq summary:hover { background: var(--c-n050); }
.faq .faq-body { padding: 0 var(--sp-6) var(--sp-4); color: var(--c-on-surface-muted); }
.faq .faq-body p { margin: 0; }

/* ---------- App section ------------------------------------------------------ */
.app-row { display: grid; gap: var(--sp-6); }
.app-stores { display: flex; gap: var(--sp-3); flex-wrap: wrap; }
.app-store-btn { display: inline-flex; align-items: center; min-height: 44px; background: var(--c-primario); color: var(--c-on-primary); padding: var(--sp-3) var(--sp-4); border-radius: var(--r-sm); text-decoration: none; font-size: var(--fs-sm); font-weight: 600; }
.app-store-btn:hover { background: var(--c-primario-scuro); color: var(--c-on-primary); }

/* ---------- Final CTA band -------------------------------------------------- */
.cta-band { background: linear-gradient(180deg, var(--c-primario-chiaro), var(--c-primario)); color: var(--c-on-primary); text-align: center; border-radius: var(--r-lg); padding: var(--sp-8) var(--sp-6); }
.cta-band h2 { color: var(--c-on-primary); margin-top: 0; }
.cta-band p { color: var(--c-on-primary-muted); margin-inline: auto; }

/* ---------- Footer ----------------------------------------------------------- */
.site-footer { background: var(--c-primario-scuro); color: var(--c-on-primary-muted); padding-block: var(--sp-12) var(--sp-8); margin-top: var(--sp-16); font-size: var(--fs-sm); }
.site-footer a { color: var(--c-on-primary-muted); text-underline-offset: 2px; }
.site-footer a:hover { color: var(--c-accento); }
.footer-grid { display: grid; gap: var(--sp-8); margin-bottom: var(--sp-8); }
.footer-grid h4 { color: var(--c-on-primary); font-size: var(--fs-base); margin-bottom: var(--sp-3); }
.footer-grid ul { list-style: none; padding: 0; margin: 0; }
.footer-grid li { margin-bottom: var(--sp-1); }
.footer-grid a { display: inline-block; padding-block: var(--sp-1); }
.footer-legal { border-top: 1px solid rgba(255,255,255,.12); padding-top: var(--sp-6); font-size: var(--fs-xs); line-height: 1.7; color: var(--c-on-primary-muted); }
.footer-legal .rg-logos { display: flex; flex-wrap: wrap; gap: var(--sp-3); align-items: center; margin-bottom: var(--sp-4); }
.footer-legal .rg-logos span { border: 1px solid rgba(255,255,255,.30); border-radius: var(--r-sm); padding: var(--sp-1) var(--sp-3); color: var(--c-on-primary-muted); font-weight: 700; font-size: var(--fs-xs); }
.footer-legal .age18 { color: var(--c-on-primary); border-color: var(--c-accento); }

/* ---------- Article (pagine di contenuto interne) --------------------------- */
.article { padding-block: var(--sp-8); }
.article .lead { font-size: var(--fs-lg); color: var(--c-text-muted); max-width: 70ch; }
.article h2 { border-bottom: 1px solid var(--c-n100); padding-bottom: var(--sp-2); }
.note {
  background: var(--c-n100); border-left: 4px solid var(--c-accento);
  padding: var(--sp-3) var(--sp-4); font-size: var(--fs-sm); color: var(--c-on-surface-muted);
  border-radius: 0 var(--r-sm) var(--r-sm) 0; margin-block: var(--sp-6); max-width: 70ch;
}
.note strong { color: var(--c-on-surface); }
.steps { counter-reset: step; list-style: none; padding-left: 0; }
.steps li { position: relative; padding-left: calc(var(--sp-8) + var(--sp-2)); margin-bottom: var(--sp-4); }
.steps li::before {
  counter-increment: step; content: counter(step);
  position: absolute; left: 0; top: 0; width: 32px; height: 32px;
  background: var(--c-primario); color: var(--c-accento); border-radius: 999px;
  display: grid; place-items: center; font-weight: 700; font-family: var(--font-head);
}
.related { background: var(--c-bianco); border: 1px solid var(--c-n100); border-radius: var(--r-md); padding: var(--sp-6); box-shadow: var(--sh-1); margin-top: var(--sp-8); }
.related h2 { margin-top: 0; border: none; padding: 0; }
.related ul { list-style: none; padding: 0; margin: 0; display: grid; gap: var(--sp-2); }
.related a { color: var(--c-link); display: inline-block; padding-block: var(--sp-1); }
.related a:hover { color: var(--c-link-hover); }
@media (min-width: 600px) { .related ul { grid-template-columns: repeat(2, 1fr); } }
.article-footer { margin-top: var(--sp-12); padding-top: var(--sp-6); border-top: 1px solid var(--c-n100); font-size: var(--fs-sm); color: var(--c-text-muted); font-style: italic; }
.section-intro { color: var(--c-text-muted); }

/* ---------- Author / E-E-A-T byline ----------------------------------------- */
.byline { display: flex; align-items: center; gap: var(--sp-3); font-size: var(--fs-sm); color: var(--c-text-muted); margin-bottom: var(--sp-6); }
.byline .avatar { width: 40px; height: 40px; border-radius: 999px; background: var(--c-primario); color: var(--c-accento); display: grid; place-items: center; font-weight: 700; flex: none; }
.byline strong { color: var(--c-text); }
.byline .verified { color: var(--c-success); font-weight: 600; }

/* =============================================================================
   Breakpoints (mobile-first -> enhance) — 360 / 480 / 768 / 1024 / 1280
   Base (senza media query) = stato 360px: tutto in colonna singola, CTA full-width,
   testo >=16px, nessun overflow orizzontale.
   ========================================================================== */

/* --- 360px (molto stretto): compatta padding e titoli, niente overflow ----- */
@media (max-width: 359.98px) {
  .wrap { padding-inline: var(--sp-3); }
  :root { --fs-2xl: 1.625rem; --fs-3xl: 1.75rem; }
  .hero { padding-block: var(--sp-8) var(--sp-6); }
  .btn { padding-inline: var(--sp-4); }
}

/* --- >=480px: titoli un filo piu' grandi, hero piu' arioso ----------------- */
@media (min-width: 480px) {
  :root { --fs-2xl: 2.125rem; }
  .cta-row { flex-direction: row; flex-wrap: wrap; }
  .btn--block { width: auto; }
  .grid--cards { grid-template-columns: repeat(2, 1fr); }
}

/* --- >=768px (tablet): griglie a 2-3 colonne, nav orizzontale -------------- */
@media (min-width: 768px) {
  :root { --fs-2xl: 2.375rem; --fs-xl: 1.6875rem; }
  .grid--cards { grid-template-columns: repeat(2, 1fr); }
  .footer-grid { grid-template-columns: 1.6fr 1fr 1fr; }
  .app-row { grid-template-columns: 1fr 1fr; align-items: center; }
  .hero h1 { font-size: var(--fs-2xl); }
}

/* --- >=1024px (desktop): layout pieno --------------------------------------- */
@media (min-width: 1024px) {
  :root { --fs-2xl: 2.5rem; --fs-xl: 1.75rem; }
  .grid--cards { grid-template-columns: repeat(3, 1fr); }
  .footer-grid { grid-template-columns: 2fr 1fr 1fr; }
  .hero h1 { font-size: var(--fs-3xl); }
}

/* --- >=1280px (wide): respiro extra (container gia' a max 1080px) ----------- */
@media (min-width: 1280px) {
  .section { padding-block: var(--sp-12); }
}

/* ---------- Riduzione movimento ---------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  * { scroll-behavior: auto !important; transition: none !important; }
}

/* ---------- Print ------------------------------------------------------------ */
@media print {
  .site-header, .cta-row, .cta-band, .header-cta { display: none; }
  body { background: #fff; }
}
