/*
Theme Name:  Boost4biz
Theme URI:   https://boost4biz.it
Author:      Boost4biz – Sergio De Carolis
Description: Tema Boost4biz v8. Brand Identity System: Verde #0F8060 primary, Arancione #F39422 accent, Navy #1D3D6B text/link. Tipografia Inter 400/500/600/700.
Version:     8.1.0
Requires at least: 6.0
Tested up to:      6.7
Requires PHP:      8.0
Text Domain: boost4biz
*/

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

/* ══════════════════════════════════════════
   BRAND IDENTITY SYSTEM — Boost4biz v8
   Verde #0F8060 → brand primario (software-friendly)
   Arancione #F39422 → accenti, CTA prenota, highlight
   Navy #1D3D6B → testo principale, heading, link hover
══════════════════════════════════════════ */
:root {
  /* ── COLORI BRAND (spec Boost4biz) ── */
  --primary:       #0F8060;   /* verde brand */
  --primary-dark:  #0A5C45;   /* hover / active */
  --primary-soft:  #E6F4EE;   /* superfici chiare */
  --primary-mid:   #7FC0A8;   /* bordi medi */

  --accent:        #F39422;   /* arancio accenti */
  --accent-dark:   #D47817;   /* hover accenti */
  --accent-mid:    #F8B15A;   /* tint gradienti / companion */
  --accent-soft:   #FEF3E4;   /* superfici chiare */

  --navy:          #1D3D6B;   /* testo principale */
  --navy-dark:     #0F2647;   /* testo forte / footer */
  --navy-soft:     #EEF2F8;   /* superfici chiare */
  --navy-mid:      #6B86AA;

  /* ── LEGACY ALIAS (compatibilità codice esistente) ── */
  --petrol:        var(--primary);
  --petrol-dark:   var(--primary-dark);
  --petrol-deeper: var(--primary-dark);
  --petrol-light:  var(--primary-soft);
  --petrol-mid:    var(--primary-mid);
  --petrol-soft:   var(--primary-mid);
  --petrol-pale:   var(--primary-soft);

  --arancio:       var(--accent);
  --arancio-dark:  var(--accent-dark);
  --arancio-light: var(--accent-soft);

  --oxford:        var(--navy);
  --oxford-dark:   var(--navy-dark);
  --oxford-mid:    var(--navy-mid);
  --oxford-light:  var(--navy-soft);

  --blu:           var(--navy);
  --blu-light:     var(--navy-soft);

  /* ── NEUTRI (spec) ── */
  --graphite:      #0F1721;
  --text-primary:  #0F1721;
  --text-secondary:#3D4754;
  --text-muted:    #7A8594;
  --border:        #D4D9E0;
  --slate:         #3D4754;
  --muted:         #3D4754;
  --cool-grey:     #7A8594;
  --fog:           #EDEFF2;
  --fog-dark:      #D4D9E0;
  --bg-white:      #FFFFFF;
  --bg-off:        #F7F9FB;

  /* ── FOOTER ── */
  /* Allineato a Brand Identity System · Navy primario #1D3D6B */
  --footer-bg:     var(--navy);          /* #1D3D6B */
  --footer-text:   rgba(255,255,255,.88); /* testo primario (link, desc) */
  --footer-sub:    rgba(255,255,255,.72); /* testo secondario (tagline, h4, copy, legal) */
  --footer-muted:  rgba(255,255,255,.56); /* testo/icona muted (svg, placeholder) */
  --footer-rule:   rgba(255,255,255,.14); /* divider sottili */
  --footer-ring:   rgba(255,255,255,.22); /* bordi social, focus */

  /* ── SEMANTIC ── */
  --coral:         #D32F2F;
  --coral-light:   #FDEDED;
  --success:       #0F8060;
  --error:         #D32F2F;
  --warning:       #F39422;

  /* ── TIPOGRAFIA (Inter, spec) ── */
  --font: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-heading: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --font-body:    'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
  --fw-normal:400; --fw-medium:500; --fw-semi:600; --fw-bold:700;

  /* scala 1.25, base 16 */
  --text-xs:12px; --text-sm:14px; --text-base:16px; --text-lg:18px;
  --text-xl:20px; --text-2xl:22px; --text-3xl:28px; --text-4xl:36px;

  /* ── SPACING ── */
  --s1:8px; --s2:16px; --s3:24px; --s4:32px;
  --s5:48px; --s6:64px; --s7:96px; --s8:120px;

  /* ── RADIUS (spec) ── */
  --r-xs:4px; --r-sm:6px; --r-md:8px; --r-lg:12px; --r-xl:20px; --r-full:9999px;

  /* ── SHADOW (spec, rgba(15,23,33)) ── */
  --sh-xs:   0 1px 2px rgba(15,23,33,.06);
  --sh-sm:   0 2px 8px rgba(15,23,33,.06);
  --sh-md:   0 4px 16px rgba(15,23,33,.08);
  --sh-lg:   0 8px 32px rgba(15,23,33,.10);
  --sh-hover:0 8px 28px rgba(15,23,33,.12);
  --sh-btn-petrol: 0 2px 8px rgba(15,128,96,.18);
  --sh-btn-arancio:0 2px 8px rgba(243,148,34,.22);

  --tr: .2s cubic-bezier(.4,0,.2,1);

  /* ── LAYOUT ── */
  --max-w:1200px; --pad-x:24px;
  --hdr-h:104px;   /* aumentato per logo 2x */
  --hdr-h-mob:88px;
  --topbar-h:46px;
}

/* RESET */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{font-size:var(--text-base);scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{font-family:var(--font);font-size:var(--text-base);font-weight:var(--fw-normal);line-height:1.6;color:var(--text-primary);background:var(--bg-white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.has-sticky-header{padding-top:0}
a{color:var(--primary);text-decoration:none;transition:color var(--tr)}
a:hover{color:var(--primary-dark)}
img,svg{max-width:100%;height:auto;display:block}
ul,ol{padding-left:1.5em} li{margin-bottom:.3em}
:focus-visible{outline:2px solid var(--primary);outline-offset:3px;border-radius:var(--r-sm)}

/* HEADINGS — Inter, navy, spec scale */
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);color:var(--navy);line-height:1.2;font-weight:var(--fw-bold);letter-spacing:-.02em}
h1{font-size:clamp(28px,4vw,36px);font-weight:var(--fw-bold);letter-spacing:-.02em}
h2{font-size:clamp(22px,3vw,28px);font-weight:var(--fw-semi);letter-spacing:-.02em}
h3{font-size:clamp(18px,2.2vw,22px);font-weight:var(--fw-semi);letter-spacing:-.01em}
h4{font-size:18px;font-weight:var(--fw-semi);letter-spacing:-.01em}
p{margin-bottom:1em;max-width:72ch;line-height:1.65;font-weight:var(--fw-normal);color:var(--text-secondary)}
p:last-child{margin-bottom:0}

/* Testi piccoli → oxford blue */
.section-label,.badge,.news-card__tag,.news-card__date,.bc-item,.form-label,.hero__micro,.hero__stat-lbl,.card-text,.step__text{color:var(--oxford)}

/* "4" accent — solo dove esplicitamente marcato */
.b4-accent{color:var(--arancio);font-weight:inherit}
/* Legacy .n4 rimossa — nessuna auto-colorazione */

/* LAYOUT */
.container{max-width:var(--max-w);margin:0 auto;padding:0 var(--pad-x)}
.section{padding:var(--s7) 0} .section-sm{padding:var(--s6) 0} .section-lg{padding:var(--s8) 0}
.bg-white{background:var(--bg-white)} .bg-off{background:var(--bg-off)}
.bg-green{background:var(--petrol-light)} .bg-petrol{background:var(--petrol)} .bg-dark{background:var(--footer-bg)}

.grid{display:grid;gap:var(--s3)}
.cols-2{grid-template-columns:repeat(2,1fr)} .cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)} .cols-5{grid-template-columns:repeat(5,1fr)}
.cols-6-4{grid-template-columns:6fr 4fr} .cols-7-5{grid-template-columns:7fr 5fr}
.cols-5-7{grid-template-columns:5fr 7fr}

.flex{display:flex;align-items:center} .flex-between{display:flex;align-items:center;justify-content:space-between}
.flex-center{display:flex;align-items:center;justify-content:center} .flex-col{display:flex;flex-direction:column}
.gap-1{gap:var(--s1)} .gap-2{gap:var(--s2)} .gap-3{gap:var(--s3)} .gap-4{gap:var(--s4)}
.wrap{flex-wrap:wrap} .text-center{text-align:center} .mx-auto{margin-left:auto;margin-right:auto}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}

/* LINEE DECORATIVE — progressione brand 01→04 */
.line-top-petrol,.line-top-cyan,.line-top-teal{border-top:3px solid var(--petrol)}
.line-top-verde{border-top:3px solid var(--primary-dark,#0A5C45)}
.line-top-arancio,.line-top-giallo{border-top:3px solid var(--arancio)}
.line-top-oxford,.line-top-navy{border-top:3px solid var(--oxford)}
.line-top-blu{border-top:3px solid var(--blu)}
.line-top-coral{border-top:3px solid var(--coral)}
.divider-color{height:2px;background:linear-gradient(90deg,var(--petrol),var(--petrol-soft),var(--arancio));border:none;border-radius:2px}
.divider-sm{height:1px;background:var(--fog);border:none;margin:0}

/* ══ BOTTONI v8 — Brand Identity System ═════════════
   Primary  = verde pieno, hover verde-dark
   Secondary (ghost-green) = transparent+verde, hover verde-soft
   Accent (Prenota) = arancio pieno, hover arancio-dark
   Su sfondo scuro = bianco
════════════════════════════════════════════════════ */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--font);font-size:var(--text-sm);font-weight:var(--fw-semi);letter-spacing:0;line-height:1;padding:12px 24px;border-radius:var(--r-md);border:1.5px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--tr);min-height:44px}

/* Secondary outline — "Scopri", nav, link secondari (ghost verde) */
.btn-green,.btn-secondary{background:transparent;color:var(--primary);border-color:var(--primary);box-shadow:none}
.btn-green:hover,.btn-secondary:hover{background:var(--primary-soft);color:var(--primary-dark);border-color:var(--primary-dark)}
.btn-green:active,.btn-secondary:active{transform:translateY(0)}

/* Primary — CTA primari verde pieno */
.btn-petrol,.btn-cta,.btn-primary,.btn-navy{background:var(--primary);color:#fff;border-color:var(--primary);box-shadow:var(--sh-btn-petrol)}
.btn-petrol:hover,.btn-cta:hover,.btn-primary:hover,.btn-navy:hover{background:var(--primary-dark);border-color:var(--primary-dark);color:#fff;box-shadow:var(--sh-md)}
.btn-petrol:active,.btn-cta:active,.btn-primary:active{transform:translateY(0)}

/* Accent — Prenota (arancio pieno + testo navy-dark per WCAG AA 6.53:1) */
.btn-prenota{background:var(--accent);color:var(--navy-dark);border-color:var(--accent);box-shadow:var(--sh-btn-arancio);font-weight:var(--fw-semi)}
.btn-prenota:hover{background:var(--accent-dark);color:var(--navy-dark);border-color:var(--accent-dark);box-shadow:var(--sh-md)}
.btn-prenota:active{transform:translateY(0);background:var(--accent-dark);color:var(--navy-dark)}

/* Bianco (su sfondi scuri) */
.btn-white,.btn-cta-inv{background:#fff;color:var(--primary);border-color:#fff;box-shadow:0 2px 8px rgba(0,0,0,.12)}
.btn-white:hover,.btn-cta-inv:hover{background:var(--primary-soft);color:var(--primary-dark);border-color:var(--primary-soft)}

/* Ghost — link testuale */
.btn-ghost{background:transparent;color:var(--primary);border:none;padding:0;font-weight:var(--fw-semi);font-size:var(--text-sm);box-shadow:none;min-height:auto}
.btn-ghost::after{content:' →';display:inline-block;transition:transform var(--tr)}
.btn-ghost:hover{color:var(--primary-dark)}
.btn-ghost:hover::after{transform:translateX(4px)}

/* Taglie */
.btn-sm{padding:8px 16px;font-size:var(--text-xs);min-height:36px}
.btn-lg{padding:16px 32px;font-size:var(--text-base);min-height:52px}

/* ══ BADGE / TAG ═════════════════════════ */
.badge{display:inline-flex;align-items:center;gap:5px;padding:4px 12px;border-radius:var(--r-full);font-size:var(--text-xs);font-weight:var(--fw-semi);letter-spacing:.4px;text-transform:uppercase}
.badge-petrol,.badge-cyan,.badge-verde,.badge-teal,.badge-celeste{background:var(--petrol-light);color:var(--petrol-deeper);border:1px solid var(--petrol-mid)}
.badge-arancio{background:var(--arancio-light);color:var(--navy-dark);border:1px solid rgba(243,148,34,.35)}
.badge-oxford,.badge-navy{background:var(--oxford-light);color:var(--oxford);border:1px solid rgba(29,61,107,.15)}
.badge-blu{background:var(--blu-light);color:var(--blu);border:1px solid rgba(29,61,107,.18)}
.badge-coral{background:var(--coral-light);color:var(--coral);border:1px solid rgba(192,64,94,.2)}
/* Badge "giallo/warning" → accent-soft bg + navy-dark text (WCAG AA 13.79:1) */
.badge-giallo{background:var(--accent-soft,#FEF3E4);color:var(--navy-dark,#0F2647);border:1px solid rgba(243,148,34,.35)}
/* Badge "purple" → rimappati su navy brand */
.badge-purple{background:var(--navy-soft,#EEF2F8);color:var(--navy,#1D3D6B);border:1px solid rgba(29,61,107,.22)}

/* Section label — oxford blue piccolo */
.section-label{display:inline-block;font-size:var(--text-xs);font-weight:var(--fw-semi);letter-spacing:1.5px;text-transform:uppercase;color:var(--oxford);margin-bottom:10px}

/* PLACEHOLDER IMMAGINI */
.img-ph{position:relative;background:var(--petrol-light);border:2px dashed var(--petrol-mid);border-radius:var(--r-lg);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:200px;overflow:hidden}
.img-ph__num{font-size:40px;font-weight:var(--fw-bold);color:var(--petrol);opacity:.25;line-height:1}
.img-ph__label{font-size:var(--text-xs);color:var(--oxford);text-align:center;padding:0 16px;line-height:1.4}

/* ══ CARD ════════════════════════════════ */
.card{background:var(--bg-white);border:1px solid var(--fog-dark);border-radius:var(--r-lg);padding:var(--s4);box-shadow:var(--sh-sm);transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr)}
.card:hover{transform:translateY(-4px);box-shadow:var(--sh-hover);border-color:var(--petrol)}
.card-icon{width:48px;height:48px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;margin-bottom:var(--s2)}
.card-icon-petrol,.card-icon-cyan,.card-icon-verde,.card-icon-teal,.card-icon-navy{background:var(--petrol-light);color:var(--petrol)}
.card-icon-oxford,.card-icon-blu{background:var(--oxford-light);color:var(--oxford)}
.card-icon-arancio{background:var(--arancio-light);color:var(--arancio-dark)}
.card-icon-coral{background:var(--coral-light);color:var(--coral)}
/* Titolo card → verde */
.card-title{font-size:var(--text-lg);font-weight:var(--fw-semi);color:var(--petrol);margin-bottom:10px;line-height:1.3;letter-spacing:-.01em}
/* Testo card → oxford (piccolo) */
.card-text{font-size:var(--text-sm);color:var(--oxford);line-height:1.65;margin-bottom:16px}
.card-stadio{display:block;color:inherit;text-decoration:none;height:100%}
.card-stadio:hover{color:inherit}

/* NEWS CARD */
.news-card{background:var(--bg-white);border:1px solid var(--fog-dark);border-radius:var(--r-lg);overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--sh-sm);transition:transform var(--tr),box-shadow var(--tr),border-color var(--tr)}
.news-card:hover{transform:translateY(-4px);box-shadow:var(--sh-hover);border-color:var(--petrol)}
.news-card__img{aspect-ratio:16/9;overflow:hidden;background:var(--petrol-light)}
.news-card__img img,.news-card__img svg{width:100%;height:100%;object-fit:cover;transition:transform .4s}
.news-card:hover .news-card__img img{transform:scale(1.04)}
.news-card__body{padding:var(--s3);flex:1;display:flex;flex-direction:column}
.news-card__tag{font-size:var(--text-xs);font-weight:var(--fw-semi);letter-spacing:.8px;text-transform:uppercase;color:var(--oxford);margin-bottom:8px;display:block}
.news-card__title{font-size:var(--text-base);font-weight:var(--fw-semi);color:var(--petrol);margin-bottom:8px;line-height:1.4;flex:1}
.news-card__title a{color:inherit;text-decoration:none}
.news-card__title a:hover{color:var(--arancio)}
.news-card__meta{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:12px;border-top:1px solid var(--fog)}
.news-card__date{font-size:var(--text-xs);color:var(--oxford)}

/* SECTION HEADER */
.section-hdr{margin-bottom:var(--s6)}
.section-hdr.center{text-align:center}
.section-hdr.center p{margin-left:auto;margin-right:auto}
.section-title{color:var(--petrol);margin-bottom:14px}
.section-sub{font-size:var(--text-lg);color:var(--slate);line-height:1.65;max-width:62ch;font-weight:var(--fw-normal)}

/* STEPS */
.steps{display:flex;flex-direction:column;gap:0}
.step{display:flex;gap:var(--s3);padding-bottom:var(--s5);position:relative}
.step:not(:last-child)::before{content:'';position:absolute;left:25px;top:54px;bottom:0;width:2px;background:linear-gradient(180deg,var(--petrol-mid),transparent)}
.step__num{flex-shrink:0;width:52px;height:52px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--text-lg);font-weight:var(--fw-bold);color:#fff;position:relative;z-index:1;box-shadow:var(--sh-md)}
.step-1 .step__num{background:linear-gradient(135deg,var(--petrol-soft),var(--petrol))}
.step-2 .step__num{background:linear-gradient(135deg,var(--petrol),var(--petrol-dark))}
.step-3 .step__num{background:linear-gradient(135deg,var(--petrol-dark),var(--oxford))}
.step-4 .step__num{background:linear-gradient(135deg,var(--oxford),var(--oxford-dark))}
.step-5 .step__num{background:linear-gradient(135deg,var(--arancio),var(--arancio-dark))}
.step__body{padding-top:12px}
.step__title{font-size:var(--text-lg);font-weight:var(--fw-semi);color:var(--petrol);margin-bottom:6px;letter-spacing:-.01em}
.step__text{font-size:var(--text-sm);color:var(--oxford)}
@media(min-width:769px){
  .steps-h{display:flex;gap:0;position:relative;padding-bottom:var(--s4)}
  .steps-h::before{content:'';position:absolute;top:26px;left:8%;right:8%;height:2px;background:linear-gradient(90deg,var(--petrol-soft),var(--petrol),var(--petrol-dark),var(--oxford));border-radius:2px}
  .steps-h .step{flex:1;flex-direction:column;text-align:center;padding:0 var(--s2) var(--s3);gap:var(--s2)}
  .steps-h .step::before{display:none}
  .steps-h .step__num{margin:0 auto}
  .steps-h .step__body{padding-top:0}
}

/* CTA BANNER — sfondo verde petrolio, testo sempre bianco */
.cta-banner{background:linear-gradient(135deg,var(--petrol) 0%,var(--petrol-dark) 60%,var(--oxford) 100%);padding:var(--s7) 0;text-align:center;position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 20% 50%,rgba(255,255,255,.06) 0%,transparent 60%);pointer-events:none}
.cta-banner .title{font-size:clamp(22px,3vw,36px);font-weight:var(--fw-bold);color:#fff;margin-bottom:16px;max-width:600px;margin-left:auto;margin-right:auto;position:relative;z-index:1;letter-spacing:-.02em}
.cta-banner .sub{font-size:var(--text-lg);color:rgba(255,255,255,.88);margin-bottom:32px;max-width:520px;margin-left:auto;margin-right:auto;font-weight:var(--fw-normal);position:relative;z-index:1}
.cta-banner .micro{font-size:var(--text-xs);color:rgba(255,255,255,.58);margin-top:14px;position:relative;z-index:1}

/* VALUE BAR */
.value-bar{background:var(--petrol-light);border-top:3px solid var(--petrol);border-bottom:3px solid var(--petrol);padding:var(--s5) 0;text-align:center}
.value-bar p{font-size:clamp(18px,2.5vw,24px);font-weight:var(--fw-semi);color:var(--petrol-deeper);max-width:820px;margin:0 auto;line-height:1.4}
.value-bar p strong{color:var(--petrol);font-weight:var(--fw-bold)}

/* PROBLEMA LIST */
.problem__list{list-style:none;padding:0;margin:var(--s3) 0;display:flex;flex-direction:column;gap:10px}
.problem__item{display:flex;align-items:flex-start;gap:12px;padding:12px 16px;background:#fff;border-radius:var(--r-md);border-left:3px solid var(--arancio);font-size:var(--text-base);line-height:1.55;color:var(--slate);box-shadow:var(--sh-xs);transition:box-shadow var(--tr)}
.problem__item:hover{box-shadow:var(--sh-sm)}
.problem__close{padding:18px var(--s3);background:var(--petrol-light);border-radius:var(--r-md);border-left:4px solid var(--petrol);margin-top:var(--s3)}
.problem__close strong{color:var(--petrol);font-size:15px;display:block;margin-bottom:6px}
.problem__close p{font-size:var(--text-sm);color:var(--oxford);margin:0}

/* HERO STATS */
.hero__stats{display:flex;gap:var(--s4);padding-top:var(--s3);border-top:1px solid var(--petrol-mid);margin-top:var(--s2)}
.hero__stat{text-align:center;min-width:80px}
.hero__stat-num{display:block;font-size:20px;font-weight:var(--fw-bold);color:var(--petrol);line-height:1;letter-spacing:-.02em}
.hero__stat-lbl{display:block;font-size:11px;font-weight:var(--fw-semi);letter-spacing:.5px;text-transform:uppercase;color:var(--oxford);margin-top:4px}

/* ACCORDION */
.accordion{border:1.5px solid var(--fog-dark);border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-xs)}
.accordion-item{border-bottom:1px solid var(--fog)}
.accordion-item:last-child{border-bottom:none}
.acc-trigger{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px var(--s3);background:transparent;border:none;text-align:left;cursor:pointer;font-family:var(--font);font-size:var(--text-base);font-weight:var(--fw-semi);color:var(--petrol);transition:background var(--tr),color var(--tr)}
.acc-trigger:hover{background:var(--petrol-light);color:var(--petrol-dark)}
.acc-trigger.open{background:var(--petrol-light);color:var(--petrol-dark);border-bottom:1px solid var(--petrol-mid)}
.acc-icon{flex-shrink:0;width:28px;height:28px;border-radius:50%;background:var(--petrol-light);color:var(--petrol);font-size:18px;display:flex;align-items:center;justify-content:center;line-height:1;transition:transform var(--tr),background var(--tr),color var(--tr)}
.acc-trigger.open .acc-icon{transform:rotate(45deg);background:var(--petrol);color:#fff}
.acc-body{max-height:0;overflow:hidden;transition:max-height .32s cubic-bezier(.4,0,.2,1)}
.acc-content{padding:0 var(--s3) var(--s3);font-size:var(--text-base);color:var(--oxford);line-height:1.75}

/* FORM */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:var(--text-xs);font-weight:var(--fw-semi);letter-spacing:.5px;text-transform:uppercase;color:var(--oxford);margin-bottom:6px}
.form-label .req{color:var(--error)}
.form-ctrl{width:100%;height:50px;padding:0 16px;border:1.5px solid var(--fog-dark);border-radius:var(--r-md);font-family:var(--font);font-size:var(--text-base);color:var(--slate);background:var(--bg-white);box-shadow:inset 0 2px 4px rgba(0,0,0,.04);transition:border-color var(--tr),box-shadow var(--tr);appearance:none}
textarea.form-ctrl{height:auto;min-height:120px;padding:14px 16px;resize:vertical}
.form-ctrl::placeholder{color:var(--cool-grey)}
.form-ctrl:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px rgba(15,128,96,.16)}
.form-ctrl.err{border-color:var(--error)}
.form-err{font-size:var(--text-xs);color:var(--error);margin-top:4px;display:none;font-weight:var(--fw-semi)}
.form-err.show{display:block}
.form-micro{font-size:var(--text-xs);color:var(--oxford);margin-top:8px}

/* BREADCRUMB */
.breadcrumb{padding:12px 0;border-bottom:1px solid var(--fog);background:var(--bg-off)}
.bc-list{display:flex;flex-wrap:wrap;gap:8px;list-style:none;padding:0;margin:0}
.bc-item{font-size:var(--text-xs);color:var(--oxford)}
.bc-item a{color:var(--oxford);transition:color var(--tr)}
.bc-item a:hover{color:var(--petrol)}
.bc-item+.bc-item::before{content:'/';margin-right:8px;color:var(--fog-dark)}
.bc-item.current{color:var(--petrol);font-weight:var(--fw-semi)}

/* TABELLA */
.cmp-table{width:100%;border-collapse:separate;border-spacing:0;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh-md)}
.cmp-table th{padding:14px var(--s3);font-size:var(--text-sm);font-weight:var(--fw-semi);text-align:left}
.cmp-table th.before{background:var(--coral-light,#FDEDED);color:var(--error);border-top:3px solid var(--error)}
.cmp-table th.after{background:var(--petrol-light);color:var(--petrol-deeper);border-top:3px solid var(--petrol)}
.cmp-table td{padding:13px var(--s3);font-size:var(--text-sm);border-bottom:1px solid var(--fog);vertical-align:top;color:var(--oxford)}
.cmp-table td.before{background:rgba(211,47,47,.03)}
.cmp-table td.after{background:var(--petrol-pale)}
.cmp-table tr:last-child td{border-bottom:none}

/* PAGINATION */
.pagination{display:flex;justify-content:center;gap:8px;padding-top:var(--s5)}
.page-numbers{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--r-md);border:1.5px solid var(--fog-dark);font-size:var(--text-sm);font-weight:var(--fw-semi);color:var(--oxford);text-decoration:none;box-shadow:var(--sh-xs);transition:all var(--tr)}
.page-numbers:hover,.page-numbers.current{background:var(--petrol);border-color:var(--petrol);color:#fff;box-shadow:var(--sh-btn-petrol)}
.page-numbers.dots{border:none;width:auto;box-shadow:none}

/* PROSE */
.prose p{font-size:var(--text-lg);line-height:1.8;color:var(--slate);margin-bottom:1.4em}
.prose h2{font-size:var(--text-3xl);color:var(--petrol);margin:2em 0 .8em;padding-bottom:.5em;border-bottom:2px solid var(--petrol-mid);font-weight:var(--fw-semi)}
.prose h3{font-size:var(--text-2xl);color:var(--petrol);margin:1.6em 0 .6em;font-weight:var(--fw-semi)}
.prose ul,.prose ol{padding-left:2em;margin-bottom:1.4em}
.prose li{font-size:var(--text-base);color:var(--oxford);margin-bottom:.4em;line-height:1.7}
.prose strong{color:var(--petrol);font-weight:var(--fw-semi)}
.prose blockquote{border-left:4px solid var(--petrol);padding:16px var(--s3);background:var(--petrol-light);border-radius:0 var(--r-md) var(--r-md) 0;margin:2em 0;font-style:italic}
.prose img{border-radius:var(--r-lg);margin:2em 0;box-shadow:var(--sh-md)}
.prose a{color:var(--petrol);text-decoration:underline}

/* KPI BOX */
.kpi-box{text-align:center;padding:var(--s3)}
.kpi-box .num{font-size:clamp(36px,5vw,52px);font-weight:var(--fw-bold);line-height:1;margin-bottom:6px;display:block;letter-spacing:-.03em;color:var(--petrol)}
.kpi-box .lbl{font-size:var(--text-sm);color:var(--oxford)}

/* Numeri stadio */
.stadio-n{font-size:56px;font-weight:var(--fw-bold);line-height:1;margin-bottom:8px;letter-spacing:-.04em;color:var(--petrol-mid)}
.stadio-1-n,.stadio-2-n,.stadio-3-n,.stadio-4-n{color:var(--petrol-mid)}

/* Skip link */
.skip-link{position:fixed;top:-100px;left:16px;z-index:9999;background:var(--petrol);color:#fff;padding:10px 18px;border-radius:0 0 var(--r-md) var(--r-md);font-size:var(--text-sm);font-weight:var(--fw-semi);box-shadow:var(--sh-md);transition:top .2s}
.skip-link:focus{top:0}

/* RESPONSIVE */
@media(max-width:1024px){.section{padding:72px 0}.cols-4{grid-template-columns:repeat(2,1fr)}.cols-5{grid-template-columns:repeat(2,1fr)}.cols-6-4,.cols-7-5,.cols-5-7{grid-template-columns:1fr}}
@media(max-width:768px){:root{--pad-x:20px;--hdr-h:var(--hdr-h-mob);--topbar-h:40px}html{font-size:15px}.section{padding:56px 0}.cols-2,.cols-3,.cols-4,.cols-5,.cols-6-4,.cols-7-5,.cols-5-7{grid-template-columns:1fr}.grid{gap:var(--s2)}.btn{padding:12px 22px}.btn-lg{padding:14px 28px;font-size:var(--text-base)}.cta-banner{padding:56px 0}h1{font-size:clamp(22px,6vw,30px)}h2{font-size:clamp(20px,5vw,24px)}.hero__stats{gap:var(--s2)}}
@media(max-width:480px){:root{--pad-x:16px;--hdr-h:var(--hdr-h-mob);--topbar-h:36px}.section{padding:48px 0}h1{font-size:clamp(22px,7vw,28px)}.btn{width:100%;justify-content:center}.btn.btn-ghost{width:auto}.card{padding:var(--s3)}}

/* ══ ALIAS RETROCOMPATIBILITÀ v8 ══════════════
   Mappatura variabili legacy → nuova palette.
   Garantisce che i template esistenti funzionino
   anche se referenziano token vecchi nei PHP.
   NOTA: --navy e --oxford sono definiti nel :root
   principale — non re-assegnarli qui.
══════════════════════════════════════════════ */
:root {
  /* Alias →primary (verde) */
  --cyan:          var(--primary);
  --cyan-dark:     var(--primary-dark);
  --cyan-darker:   var(--primary-dark);
  --cyan-light:    var(--primary-soft);
  --verde:         var(--primary);
  --verde-light:   var(--primary-soft);
  --teal:          var(--primary);
  --teal-dark:     var(--primary-dark);
  /* Alias →navy */
  --navy-hover:    var(--navy-dark);
  --navy-light:    var(--navy-soft);
  --sh-btn-navy:   var(--sh-btn-petrol);
  /* Alias →primary-soft */
  --green-light:   var(--primary-soft);
  --green-mid:     var(--primary-mid);
  --green-pale:    var(--primary-soft);
  /* Alias accent */
  --accent-warm:   var(--accent);
  /* Blu dati — mantenuto separato (navy-derived) */
  --blu-deep:      var(--navy);
  /* Giallo legacy → rimappato su accent brand (arancio) */
  --giallo:        var(--accent);
  --giallo-bg:     var(--accent-soft);
  --giallo-dark:   var(--accent-dark);
  /* Coral — errore/warning (allineato a spec) */
  --coral-bg:      var(--coral-light);
  /* Purple legacy → rimappato su navy brand */
  --purple:        var(--navy);
  --purple-light:  var(--navy-soft);
  /* Stadi card-icon aliases */
  --card-icon-blu:  var(--navy-soft);
  /* Footer */
  --blu-footer:    var(--footer-bg);
}

/* ══ DESIGN HARMONIZATION 2026 ═══════════════
   Regole condivise con tema Blog
══════════════════════════════════════════════ */
h1,
.hero__title,
.page-hero h1,
.arch-hdr h1 {
  color: var(--navy);
  line-height: 1.2;
}

.btn {
  min-height: 44px;
  border-radius: var(--r-md);
}

.btn:focus-visible,
.nav-link:focus-visible,
.card-stadio:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

.card,
.news-card,
.card-stadio,
.signal,
.stadio-grid-item,
.valore-item,
.prenota-block,
.sidebar-card,
.principio-card,
.fw-card,
.modulo-card {
  height: 100%;
  border-color: var(--fog-dark);
}

.card-title,
.news-card__title,
.fw-card__title,
.principio-card__title,
.step__title {
  color: var(--petrol);
}

.card-text,
.news-card__date,
.stadio-grid-item,
.signal,
.valore-sub,
.hero__micro,
.footer-links a,
.tl-text {
  color: var(--oxford);
}

.card-link-hint {
  font-size: 13px;
  font-weight: var(--fw-semi);
  color: var(--petrol);
}

.card-stadio:hover .card-link-hint {
  color: var(--arancio);
}

@media (max-width: 1024px) {
  .grid.cols-4,
  .fw-grid,
  .principi-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 768px) {
  .grid.cols-4,
  .fw-grid,
  .principi-grid,
  .grid.cols-3,
  .grid.cols-2 {
    grid-template-columns: 1fr;
  }

  .section,
  .section-sm,
  .section-lg {
    padding-top: 52px;
    padding-bottom: 52px;
  }
}

/* ══ SKIP LINK (accessibility) ═════════════ */
.skip-link:focus{top:0;outline:2px solid var(--primary);outline-offset:2px}

/* Uniforma hover dei bottoni nel contenuto pagina
   (Primary → primary-dark, Prenota → accent-dark; per i Gutenberg block
   e i submit HTML usiamo primary come default) */
main .wp-block-button__link,
.site-main .wp-block-button__link,
main button,
.site-main button,
main input[type="submit"],
.site-main input[type="submit"]{
  background:var(--primary);
  border:1.5px solid var(--primary);
  color:#fff;
  border-radius:var(--r-md);
  padding:12px 24px;
  font-family:var(--font);
  font-weight:var(--fw-semi);
  min-height:44px;
  box-shadow:var(--sh-btn-petrol);
  transition:all var(--tr);
}
main .wp-block-button__link:hover,
.site-main .wp-block-button__link:hover,
main button:hover,
.site-main button:hover,
main input[type="submit"]:hover,
.site-main input[type="submit"]:hover{
  background:var(--primary-dark);
  border-color:var(--primary-dark);
  color:#fff;
  box-shadow:var(--sh-md);
}

