/*
Theme Name:  Boost4Biz
Theme URI:   https://boost4biz.it
Author:      Boost4Biz – Sergio De Carolis
Description: Tema Boost4Biz v7. Verde Petrolio #006D5B brand, Oxford Blue #002147 payoff, Arancione #F28C28 accenti. Header +20%. Nessuna auto-colorazione "4".
Version:     8.0.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=Poppins:wght@400;500;600;700&display=swap');

/* ══════════════════════════════════════════
   PALETTE v7 — Regole cromatiche precise
   Verde Petrolio #006D5B → brand principale
   Arancione Caldo #F28C28 → accenti, CTA prenota, testi medi su bianco
   Oxford Blue #002147 → payoff, testi piccoli, governance
══════════════════════════════════════════ */
:root {
  --petrol:        #006D5B;
  --petrol-dark:   #005247;
  --petrol-deeper: #003D35;
  --petrol-light:  #E6F2EF;
  --petrol-mid:    #B3D6CF;
  --petrol-soft:   #4DA090;
  --petrol-pale:   #F0F8F6;

  --arancio:       #F28C28;
  --arancio-dark:  #D4740E;
  --arancio-light: #FEF3E6;

  --oxford:        #002147;
  --oxford-dark:   #001530;
  --oxford-mid:    #1A3A5C;
  --oxford-light:  #EEF2F8;

  --blu:           #1E7A92;
  --blu-light:     #EBF8FC;

  --graphite:      #1A1A1A;
  --slate:         #2D3748;
  --muted:         #4A5568;
  --cool-grey:     #718096;
  --fog:           #E2E8F0;
  --fog-dark:      #CBD5E0;
  --bg-white:      #FFFFFF;
  --bg-off:        #F7FAFC;

  --footer-bg:     #001530;
  --footer-text:   rgba(255,255,255,.82);
  --footer-muted:  rgba(255,255,255,.48);

  --coral:         #C0405E;
  --coral-light:   #FFF0F4;

  --success:  #006D5B;
  --error:    #C53030;

  --font: 'Poppins', sans-serif;
  --fw-normal:400; --fw-medium:500; --fw-semi:600; --fw-bold:700;

  --text-xs:12px; --text-sm:14px; --text-base:16px; --text-lg:18px;
  --text-xl:20px; --text-2xl:24px; --text-3xl:30px; --text-4xl:36px;

  --s1:8px; --s2:16px; --s3:24px; --s4:32px;
  --s5:48px; --s6:64px; --s7:96px; --s8:120px;

  --r-sm:4px; --r-md:8px; --r-lg:12px; --r-xl:20px; --r-full:9999px;

  --sh-xs:   0 1px 3px rgba(0,0,0,.07);
  --sh-sm:   0 2px 8px rgba(0,0,0,.08);
  --sh-md:   0 4px 16px rgba(0,0,0,.09);
  --sh-lg:   0 8px 32px rgba(0,0,0,.11);
  --sh-hover:0 8px 28px rgba(0,0,0,.14);
  --sh-btn-petrol: 0 3px 12px rgba(0,109,91,.28);
  --sh-btn-arancio:0 3px 12px rgba(242,140,40,.28);

  --tr: .2s cubic-bezier(.4,0,.2,1);

  --max-w:1200px; --pad-x:24px;
  --hdr-h:86px;    /* +20% */
  --topbar-h:46px; /* +20% */
}

/* 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.65;color:var(--slate);background:var(--bg-white);-webkit-font-smoothing:antialiased;overflow-x:hidden}
body.has-sticky-header{padding-top:calc(var(--topbar-h) + var(--hdr-h))}
a{color:var(--petrol);text-decoration:none;transition:color var(--tr)}
a:hover{color:var(--arancio)}
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(--petrol);outline-offset:3px;border-radius:var(--r-sm)}

/* HEADINGS — verde petrolio uniforme, nessuna variazione in frase */
h1,h2,h3,h4,h5,h6{font-family:var(--font);color:var(--petrol);line-height:1.25;font-weight:var(--fw-bold);letter-spacing:-.02em}
h1{font-size:clamp(26px,4vw,44px);letter-spacing:-.03em}
h2{font-size:clamp(22px,3vw,34px);font-weight:var(--fw-semi)}
h3{font-size:clamp(18px,2.4vw,24px);font-weight:var(--fw-semi)}
h4{font-size:17px;font-weight:var(--fw-semi)}
p{margin-bottom:1em;max-width:72ch;line-height:1.7;font-weight:var(--fw-normal)}
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 */
.line-top-petrol,.line-top-cyan,.line-top-verde,.line-top-teal{border-top:3px solid var(--petrol)}
.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 v7 ═════════════════════════════
   Verde petrolio = testo/bordo, hover → arancio
   Prenota = testo arancio, hover → pieno arancio
   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:.01em;line-height:1;padding:14px 30px;border-radius:var(--r-md);border:2px solid transparent;cursor:pointer;text-decoration:none;white-space:nowrap;transition:all var(--tr);box-shadow:var(--sh-xs)}

/* Verde outline — "Scopri stadio", nav, link secondari */
.btn-green,.btn-secondary{background:transparent;color:var(--petrol);border-color:var(--petrol)}
.btn-green:hover,.btn-secondary:hover{background:var(--arancio);color:#fff;border-color:var(--arancio);box-shadow:var(--sh-btn-arancio);transform:translateY(-2px)}
.btn-green:active,.btn-secondary:active{transform:translateY(0)}

/* Verde pieno — CTA primari */
.btn-petrol,.btn-cta,.btn-primary,.btn-navy{background:var(--petrol);color:#fff;border-color:var(--petrol);box-shadow:var(--sh-btn-petrol)}
.btn-petrol:hover,.btn-cta:hover,.btn-primary:hover,.btn-navy:hover{background:var(--arancio);border-color:var(--arancio);color:#fff;box-shadow:var(--sh-btn-arancio);transform:translateY(-2px)}
.btn-petrol:active,.btn-cta:active,.btn-primary:active{transform:translateY(0)}

/* Prenota — testo arancio, hover pieno arancio */
.btn-prenota{background:transparent;color:var(--arancio);border-color:var(--arancio)}
.btn-prenota:hover{background:var(--arancio);color:#fff;border-color:var(--arancio);box-shadow:var(--sh-btn-arancio);transform:translateY(-2px)}
.btn-prenota:active{transform:translateY(0);background:var(--arancio-dark)}

/* Bianco (su sfondi scuri) */
.btn-white,.btn-cta-inv{background:#fff;color:var(--petrol);border-color:rgba(255,255,255,.8);box-shadow:0 3px 12px rgba(0,0,0,.18)}
.btn-white:hover,.btn-cta-inv:hover{background:var(--arancio-light);color:var(--arancio-dark);transform:translateY(-2px)}

/* Ghost */
.btn-ghost{background:transparent;color:var(--petrol);border:none;padding:0;font-weight:var(--fw-semi);font-size:var(--text-sm);box-shadow:none}
.btn-ghost::after{content:' →';display:inline-block;transition:transform var(--tr)}
.btn-ghost:hover{color:var(--arancio)}
.btn-ghost:hover::after{transform:translateX(4px)}

/* Taglie */
.btn-sm{padding:10px 20px;font-size:var(--text-xs)}
.btn-lg{padding:17px 40px;font-size:var(--text-lg)}

/* ══ 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(--arancio-dark);border:1px solid rgba(242,140,40,.25)}
.badge-oxford,.badge-navy{background:var(--oxford-light);color:var(--oxford);border:1px solid rgba(0,33,71,.15)}
.badge-blu{background:var(--blu-light);color:var(--blu);border:1px solid #C0E0EC}
.badge-coral{background:var(--coral-light);color:var(--coral);border:1px solid rgba(192,64,94,.2)}
.badge-giallo{background:#FEF9E7;color:#8B6914;border:1px solid #F0DF90}
.badge-purple{background:#F0EBFF;color:#5B2FC9;border:1px solid #D0C0F8}

/* 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(--petrol);box-shadow:0 0 0 3px rgba(0,109,91,.12)}
.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:#FEF2F2;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:#FFFAFA}
.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:72px;--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:13px 26px}.btn-lg{padding:16px 32px;font-size:var(--text-base)}.cta-banner{padding:56px 0}h1{font-size:clamp(24px,6vw,34px)}h2{font-size:clamp(20px,5vw,28px)}.hero__stats{gap:var(--s2)}}
@media(max-width:480px){:root{--pad-x:16px;--hdr-h:66px;--topbar-h:36px}.section{padding:48px 0}h1{font-size:clamp(22px,7vw,30px)}.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
══════════════════════════════════════════════ */
:root {
  /* Alias →petrol */
  --cyan:          var(--petrol);
  --cyan-dark:     var(--petrol);
  --cyan-darker:   var(--petrol);
  --cyan-light:    var(--petrol-light);
  --verde:         var(--petrol);
  --verde-light:   var(--petrol-light);
  --teal:          var(--petrol-soft);
  --teal-dark:     var(--petrol-dark);
  /* Alias →oxford */
  --navy:          var(--oxford);
  --navy-hover:    var(--oxford-dark);
  --navy-light:    var(--oxford-light);
  --sh-btn-navy:   var(--sh-btn-petrol);
  /* Alias →petrol-light */
  --green-light:   var(--petrol-light);
  --green-mid:     var(--petrol-mid);
  --green-pale:    var(--petrol-pale);
  /* Alias accent */
  --accent-warm:   var(--arancio);
  /* Blu dati — mantenuto separato */
  --blu:           #1E7A92;
  --blu-light:     #EBF8FC;
  --blu-deep:      #1E7A92;
  /* Giallo — solo decorativo */
  --giallo:        #D4A017;
  --giallo-bg:     #FEF9E7;
  --giallo-dark:   #8B6914;
  /* Coral — Chi Sono */
  --coral:         #C0405E;
  --coral-light:   #FFF0F4;
  --coral-bg:      #F8D7E7;
  /* Purple */
  --purple:        #6B3FD4;
  --purple-light:  #F0EBFF;
  /* Stadi card-icon aliases */
  --card-icon-blu:  var(--oxford-light);
  /* BG */
  --bg-off:        var(--bg-off, #F7FAFC);
  --cool-grey:     #718096;
  /* Footer */
  --blu-footer:    var(--footer-bg);
}
