/* =====================================================================
   TOP100 — « Leaderboard / Classifica »
   Magazine delle classifiche italiane. Design system bespoke (anti-footprint).
   Display: Archivo (700-900, uppercase) · Testo: Hanken Grotesk.
   Accent rosso #E63031 + inchiostro · oro/argento/bronzo per il podio.
   ===================================================================== */

@font-face{font-family:'Archivo';src:url('../fonts/archivo.woff2') format('woff2');font-weight:600 900;font-style:normal;font-display:swap}
@font-face{font-family:'Hanken Grotesk';src:url('../fonts/hanken.woff2') format('woff2');font-weight:400 800;font-style:normal;font-display:swap}

:root{
  --c-ink:#15151a;          /* inchiostro / fondi scuri */
  --c-ink-2:#0e0e12;
  --c-rosso:#e63031; --c-rosso-d:#c41f20;
  --c-gold:#d99e17; --c-silver:#9aa1aa; --c-bronze:#bd7a45;
  --c-paper:#faf9f6;        /* fondo caldo */
  --c-card:#ffffff;
  --c-muted:#6c6c76;
  --c-line:#eae6dd;         /* filetti caldi */
  --c-border:#e4dfd4;

  --font-display:'Archivo','Arial Narrow',system-ui,sans-serif;
  --font-ui:'Hanken Grotesk',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --font-read:'Hanken Grotesk',system-ui,sans-serif;

  --step--2:clamp(.72rem,.69rem + .15vw,.8rem);
  --step--1:clamp(.84rem,.8rem + .2vw,.95rem);
  --step-0:clamp(1rem,.96rem + .2vw,1.1rem);
  --step-1:clamp(1.2rem,1.08rem + .5vw,1.45rem);
  --step-2:clamp(1.5rem,1.25rem + 1.1vw,2.1rem);
  --step-3:clamp(2rem,1.55rem + 2vw,3rem);
  --step-4:clamp(2.6rem,1.9rem + 3.2vw,4.4rem);
  --step-5:clamp(3rem,1.9rem + 5vw,6rem);

  --sp-1:.25rem; --sp-2:.5rem; --sp-3:1rem; --sp-4:1.5rem; --sp-5:2rem; --sp-6:3rem; --sp-7:4.5rem;
  --wrap:1240px; --wrap-read:720px;
  --radius:14px; --radius-sm:9px;
  --shadow:0 1px 2px rgba(21,21,26,.05),0 8px 22px rgba(21,21,26,.06);
  --shadow-lg:0 12px 26px rgba(21,21,26,.1),0 28px 64px rgba(21,21,26,.14);
  --header-h:66px;
  --ease:cubic-bezier(.22,1,.36,1);
  --grain:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

html{scroll-behavior:smooth}
body{
  margin:0;background:var(--c-paper);color:var(--c-ink);
  font-family:var(--font-ui);font-size:var(--step-0);line-height:1.65;
  font-weight:420;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
body::before{content:"";position:fixed;inset:0;z-index:9999;pointer-events:none;background:var(--grain);background-size:170px;opacity:.02;mix-blend-mode:multiply}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.04;letter-spacing:-.01em;margin:0}
a{color:inherit;text-decoration:none}
::selection{background:var(--c-rosso);color:#fff}

.ff-wrap{max-width:var(--wrap);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.2rem)}
.ff-skip{position:absolute;left:-9999px}
.ff-skip:focus{left:1rem;top:1rem;background:#fff;padding:.6rem 1rem;z-index:1000;border-radius:8px;box-shadow:var(--shadow)}

/* Barra di avanzamento lettura (single) */
.ff-progress{position:fixed;top:0;left:0;height:3px;width:0;background:var(--c-rosso);z-index:200;transition:width .1s linear}

/* Kicker / etichetta categoria */
.ff-kicker{display:inline-block;font-family:var(--font-ui);font-weight:800;font-size:var(--step--2);letter-spacing:.16em;text-transform:uppercase;color:var(--c-rosso-d)}

/* Bottoni */
.ff-btn{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;font-size:var(--step--1);background:var(--c-rosso);color:#fff;padding:.8rem 1.5rem;border-radius:999px;transition:transform .25s var(--ease),background .25s}
.ff-btn:hover{background:var(--c-ink);color:#fff;transform:translateY(-2px)}
.ff-btn--ghost{background:transparent;color:var(--c-ink);border:1.5px solid var(--c-ink)}
.ff-btn--ghost:hover{background:var(--c-ink);color:#fff}

/* ---------- Header ---------- */
.ff-header{position:sticky;top:0;z-index:100;background:rgba(250,249,246,.88);backdrop-filter:saturate(1.4) blur(12px);border-bottom:2px solid var(--c-ink)}
.ff-header__bar{display:flex;align-items:center;gap:var(--sp-4);min-height:var(--header-h);flex-wrap:wrap}
.ff-logo{flex:0 0 auto;display:flex;align-items:center}
.ff-logo img{max-height:42px;width:auto}
.ff-logo__text{font-family:var(--font-display);font-weight:900;font-size:1.55rem;letter-spacing:-.03em;text-transform:uppercase;color:var(--c-ink);display:inline-flex;align-items:center;gap:.12em}
.ff-logo__text::before{content:"";display:inline-block;width:.34em;height:1em;background:var(--c-rosso);transform:skewX(-10deg)}
.ff-nav{margin-left:auto}
.ff-nav ul{list-style:none;display:flex;gap:var(--sp-1);align-items:center;flex-wrap:wrap;margin:0;padding:0}
.ff-nav a{position:relative;display:block;padding:.5rem .8rem;font-family:var(--font-ui);font-weight:600;font-size:var(--step--1);color:var(--c-ink)}
.ff-nav a::after{content:"";position:absolute;left:.8rem;right:.8rem;bottom:.28rem;height:2px;background:var(--c-rosso);transform:scaleX(0);transform-origin:left;transition:transform .3s var(--ease)}
.ff-nav a:hover::after,.ff-nav .current-menu-item>a::after{transform:scaleX(1)}
.ff-search{flex:0 0 auto}
.ff-search form{display:flex;align-items:center;border:1.5px solid var(--c-border);border-radius:999px;background:#fff;transition:box-shadow .25s,border-color .25s}
.ff-search form:focus-within{border-color:var(--c-ink);box-shadow:0 0 0 3px rgba(230,48,49,.13)}
.ff-search input{border:0;background:transparent;padding:.5rem .9rem;width:130px;font:inherit;font-size:var(--step--1)}
.ff-search input:focus{outline:none}
.ff-search button{border:0;background:transparent;padding:.5rem .8rem;cursor:pointer;color:var(--c-muted);font-size:1rem}
.ff-burger{display:none;border:0;background:transparent;font-size:1.5rem;cursor:pointer;color:var(--c-ink);padding:.3rem}
@media(max-width:860px){
  .ff-burger{display:block;margin-left:auto;order:3}
  .ff-search{order:4;flex:1 1 auto}
  .ff-search input{width:100%}
  .ff-nav{order:5;flex-basis:100%;margin-left:0;display:none}
  .ff-nav.is-open{display:block;padding-bottom:.6rem}
  .ff-nav ul{flex-direction:column;align-items:stretch;gap:0}
  .ff-nav a{padding:.85rem .4rem;border-bottom:1px solid var(--c-line)}
  .ff-nav a::after{display:none}
}

/* ---------- Cover generata (articolo senza immagine) ---------- */
.ff-cover{position:relative;width:100%;height:100%;display:flex;align-items:flex-end;padding:1.3rem;overflow:hidden;isolation:isolate;background:linear-gradient(150deg,var(--accent,#e63031) 0%,#15151a 125%)}
.ff-cover::after{content:"";position:absolute;inset:0;z-index:1;background:var(--grain);background-size:150px;opacity:.22;mix-blend-mode:overlay;pointer-events:none}
.ff-cover__label{position:relative;z-index:2;font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:clamp(1rem,.9rem + 1vw,1.5rem);line-height:1.04;color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.22);max-width:92%;letter-spacing:-.01em}
.ff-cover__label::before{content:"";display:block;width:30px;height:3px;background:rgba(255,255,255,.85);margin-bottom:.55rem}

/* ---------- Hero « Classifiche d'Italia » ---------- */
.ff-hero-band{margin-block:var(--sp-5) var(--sp-4);padding:clamp(1.4rem,3vw,2.4rem) 0 var(--sp-4);border-bottom:2px solid var(--c-ink)}
.ff-hero-band__kicker{display:flex;align-items:center;gap:.7rem;color:var(--c-rosso-d);font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.18em;font-size:var(--step--2)}
.ff-hero-band__kicker::before{content:"";width:26px;height:3px;background:var(--c-rosso)}
.ff-hero-band h1{font-size:var(--step-5);text-transform:uppercase;margin-top:.3rem;max-width:16ch}
.ff-hero-band h1 em{font-style:normal;color:var(--c-rosso)}
.ff-hero-band p{font-family:var(--font-ui);color:var(--c-muted);font-size:var(--step-1);max-width:54ch;margin:.9rem 0 0;font-weight:460}

/* ---------- Sezioni ---------- */
.ff-section-head{display:flex;align-items:baseline;justify-content:space-between;gap:1rem;margin:var(--sp-7) 0 var(--sp-5);padding-bottom:.7rem;border-bottom:2px solid var(--c-ink)}
.ff-section-head h2{font-size:var(--step-2);text-transform:uppercase}
.ff-section-head a{font-family:var(--font-display);font-size:var(--step--1);font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--c-rosso-d)}

/* ---------- Podio (top 3) ---------- */
.ff-podium{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1rem,2.4vw,1.8rem);align-items:end;margin-top:var(--sp-5)}
.ff-podium__item{position:relative;display:flex;flex-direction:column;background:var(--c-card);border:1.5px solid var(--c-border);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.ff-podium__item:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.ff-podium__item--1{order:2;border-color:var(--c-gold)}
.ff-podium__item--2{order:1}
.ff-podium__item--3{order:3}
.ff-podium__rank{position:absolute;top:0;left:0;z-index:3;font-family:var(--font-display);font-weight:900;font-size:2.4rem;line-height:1;color:#fff;background:var(--c-ink);width:1.7em;height:1.6em;display:flex;align-items:center;justify-content:center;border-bottom-right-radius:var(--radius)}
.ff-podium__item--1 .ff-podium__rank{background:var(--c-gold)}
.ff-podium__item--2 .ff-podium__rank{background:var(--c-silver)}
.ff-podium__item--3 .ff-podium__rank{background:var(--c-bronze)}
.ff-podium__medal{position:absolute;top:.5rem;right:.6rem;z-index:3;font-size:1.5rem;filter:drop-shadow(0 2px 3px rgba(0,0,0,.25))}
.ff-podium__media{display:block;aspect-ratio:16/10;overflow:hidden;background:var(--c-ink)}
.ff-podium__item--1 .ff-podium__media{aspect-ratio:16/12}
.ff-podium__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ff-podium__item:hover .ff-podium__media img{transform:scale(1.05)}
.ff-podium__body{padding:1.1rem 1.2rem 1.3rem;display:flex;flex-direction:column;gap:.5rem;flex:1}
.ff-podium__title{font-size:var(--step-1);line-height:1.12}
.ff-podium__item--1 .ff-podium__title{font-size:var(--step-2)}
.ff-podium__title a:hover{color:var(--c-rosso)}
.ff-podium__meta{font-family:var(--font-ui);margin-top:auto;display:flex;gap:.5rem;align-items:center;color:var(--c-muted);font-size:var(--step--2);text-transform:uppercase;letter-spacing:.06em}
@media(max-width:760px){
  .ff-podium{grid-template-columns:1fr;gap:1rem}
  .ff-podium__item--1,.ff-podium__item--2,.ff-podium__item--3{order:initial}
  .ff-podium__media,.ff-podium__item--1 .ff-podium__media{aspect-ratio:16/9}
}

/* ---------- Classifica (lista numerata) ---------- */
.ff-classifica{list-style:none;margin:var(--sp-5) 0 0;padding:0}
.ff-cl-row{display:grid;grid-template-columns:auto 132px 1fr;gap:clamp(1rem,2.2vw,1.6rem);align-items:center;padding:1.1rem 0;border-top:1px solid var(--c-border)}
.ff-cl-row:hover .ff-cl-title{color:var(--c-rosso)}
.ff-cl-num{font-family:var(--font-display);font-weight:900;font-size:clamp(2.2rem,1.5rem + 3vw,3.6rem);line-height:1;color:transparent;-webkit-text-stroke:2px var(--c-ink);min-width:1.6ch;text-align:center;transition:color .25s,-webkit-text-stroke-color .25s}
.ff-cl-row:hover .ff-cl-num{color:var(--c-rosso);-webkit-text-stroke-color:var(--c-rosso)}
.ff-cl-media{display:block;aspect-ratio:16/10;border-radius:var(--radius-sm);overflow:hidden;background:var(--c-ink);box-shadow:var(--shadow)}
.ff-cl-media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ff-cl-row:hover .ff-cl-media img{transform:scale(1.06)}
.ff-cl-body{display:flex;flex-direction:column;gap:.4rem;min-width:0}
.ff-cl-title{font-size:var(--step-1);line-height:1.16;transition:color .25s}
.ff-cl-excerpt{font-family:var(--font-ui);color:var(--c-muted);font-size:var(--step--1);line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ff-cl-meta{font-family:var(--font-ui);display:flex;gap:.55rem;align-items:center;color:var(--c-muted);font-size:var(--step--2);text-transform:uppercase;letter-spacing:.06em}
.ff-cl-meta .dot{width:3px;height:3px;border-radius:50%;background:var(--c-muted)}
@media(max-width:620px){
  .ff-cl-row{grid-template-columns:auto 1fr;gap:1rem}
  .ff-cl-media{display:none}
  .ff-cl-excerpt{-webkit-line-clamp:3}
}

/* ---------- Griglia di schede (archivio, correlati) ---------- */
.ff-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:clamp(1.4rem,3vw,2.2rem)}
.ff-card{position:relative;display:flex;flex-direction:column;background:transparent}
.ff-card__media{position:relative;display:block;aspect-ratio:16/10;border-radius:var(--radius-sm);overflow:hidden;background:var(--c-line);box-shadow:var(--shadow)}
.ff-card__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ff-card:hover .ff-card__media img,.ff-card:hover .ff-card__media .ff-cover{transform:scale(1.04)}
.ff-rankbadge{position:absolute;top:0;left:0;z-index:2;font-family:var(--font-display);font-weight:900;font-size:1.3rem;color:#fff;background:var(--c-ink);min-width:2.1em;height:2.1em;display:flex;align-items:center;justify-content:center;border-bottom-right-radius:var(--radius-sm)}
.ff-card__body{padding-top:1rem;display:flex;flex-direction:column;gap:.5rem}
.ff-card__title{font-size:var(--step-1);line-height:1.18}
.ff-card__title a{background-image:linear-gradient(var(--c-rosso),var(--c-rosso));background-size:0 2px;background-repeat:no-repeat;background-position:0 100%;transition:background-size .35s var(--ease);padding-bottom:1px}
.ff-card:hover .ff-card__title a{background-size:100% 2px}
.ff-card__excerpt{font-family:var(--font-ui);color:var(--c-muted);font-size:var(--step--1);line-height:1.6}
.ff-card__meta{font-family:var(--font-ui);display:flex;gap:.6rem;align-items:center;color:var(--c-muted);font-size:var(--step--2);text-transform:uppercase;letter-spacing:.06em}
.ff-card__meta .dot{width:3px;height:3px;border-radius:50%;background:var(--c-muted)}

/* ---------- Paginazione ---------- */
.ff-pagination{margin:var(--sp-7) 0;display:flex;justify-content:center}
.ff-pagination .page-numbers{list-style:none;display:flex;gap:.4rem;flex-wrap:wrap;padding:0;margin:0}
.ff-pagination a,.ff-pagination span{font-family:var(--font-display);font-weight:700;display:flex;min-width:44px;height:44px;align-items:center;justify-content:center;padding:0 .6rem;border-radius:10px;border:1.5px solid var(--c-border);background:#fff;color:var(--c-ink);transition:.2s}
.ff-pagination a:hover{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.ff-pagination .current{background:var(--c-rosso);color:#fff;border-color:var(--c-rosso)}

/* ---------- Layout principale ---------- */
.ff-layout{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:clamp(2rem,4vw,3.6rem);margin-block:var(--sp-5)}
@media(max-width:980px){.ff-layout{grid-template-columns:1fr}}
.ff-sidebar{display:flex;flex-direction:column;gap:var(--sp-5)}
.ff-widget{background:#fff;border:1.5px solid var(--c-border);border-radius:var(--radius);padding:var(--sp-4)}
.ff-widget__title{font-family:var(--font-display);font-weight:800;text-transform:uppercase;font-size:var(--step--1);letter-spacing:.1em;color:var(--c-ink);margin:0 0 var(--sp-3);display:flex;align-items:center;gap:.5rem}
.ff-widget__title::before{content:"";width:18px;height:3px;background:var(--c-rosso)}
.ff-pills{display:flex;flex-wrap:wrap;gap:.5rem;list-style:none;margin:0;padding:0}
.ff-pills a{display:inline-block;padding:.4rem .85rem;border-radius:999px;background:var(--c-paper);border:1.5px solid var(--c-border);font-family:var(--font-ui);font-size:var(--step--1);font-weight:600;color:var(--c-ink);transition:.2s}
.ff-pills a:hover{background:var(--c-ink);color:#fff;border-color:var(--c-ink)}
.ff-rank{list-style:none;margin:0;padding:0}
.ff-rank li{display:flex;gap:.9rem;align-items:flex-start;padding:.8rem 0;border-top:1px solid var(--c-line)}
.ff-rank li:first-child{border-top:0;padding-top:0}
.ff-rank__num{font-family:var(--font-display);font-weight:900;font-size:1.6rem;line-height:1;color:var(--c-rosso);flex:0 0 auto;width:1.4em;text-align:center}
.ff-rank li:nth-child(1) .ff-rank__num{color:var(--c-gold)}
.ff-rank li:nth-child(2) .ff-rank__num{color:var(--c-silver)}
.ff-rank li:nth-child(3) .ff-rank__num{color:var(--c-bronze)}
.ff-rank__title{font-family:var(--font-ui);font-weight:600;font-size:var(--step--1);line-height:1.3;color:var(--c-ink)}
.ff-rank__title:hover{color:var(--c-rosso)}
.ff-rank__date{display:block;font-size:var(--step--2);color:var(--c-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:.2rem}
.ff-newsletter{background:var(--c-ink);border-color:var(--c-ink);color:#fff}
.ff-newsletter .ff-widget__title{color:#fff}
.ff-newsletter p{font-family:var(--font-ui);font-size:var(--step--1);color:rgba(255,255,255,.78);margin:.2rem 0 var(--sp-3)}
.ff-newsletter form{display:flex;flex-direction:column;gap:.5rem}
.ff-newsletter input{border:0;border-radius:8px;padding:.7rem .9rem;font-size:var(--step--1)}
.ff-newsletter button{border:0;border-radius:8px;background:var(--c-rosso);color:#fff;font-family:var(--font-display);font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:.7rem;cursor:pointer;transition:.2s}
.ff-newsletter button:hover{background:#fff;color:var(--c-ink)}

/* ---------- Articolo ---------- */
.ff-single{max-width:var(--wrap-read);margin-inline:auto}
.ff-breadcrumb{font-family:var(--font-ui);font-size:var(--step--2);color:var(--c-muted);margin-block:var(--sp-5) var(--sp-3);text-transform:uppercase;letter-spacing:.05em}
.ff-breadcrumb a:hover{color:var(--c-rosso)}
.ff-article__header{margin-bottom:var(--sp-4)}
.ff-article__title{font-size:var(--step-3);text-transform:uppercase;margin:.5rem 0 .6rem}
.ff-article__lead{font-family:var(--font-ui);font-size:var(--step-1);line-height:1.55;color:var(--c-muted);font-weight:460}
.ff-article__meta{font-family:var(--font-ui);display:flex;gap:1rem;flex-wrap:wrap;color:var(--c-muted);font-size:var(--step--1);margin-top:var(--sp-3);padding-top:var(--sp-3);border-top:1px solid var(--c-line)}
.ff-article__featured{margin:var(--sp-4) 0;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.ff-article__featured img{width:100%;height:auto}

.ff-prose{font-family:var(--font-read);font-size:1.12rem;line-height:1.78;color:#22222a}
.ff-prose>*+*{margin-top:1.2em}
.ff-prose h2{font-size:var(--step-2);text-transform:uppercase;margin-top:1.8em;padding-left:.7rem;border-left:5px solid var(--c-rosso);line-height:1.1}
.ff-prose h3{font-size:var(--step-1);margin-top:1.5em}
.ff-prose a{color:var(--c-rosso-d);text-decoration:underline;text-underline-offset:2px}
.ff-prose ul,.ff-prose ol{padding-left:1.3em}
.ff-prose li{margin-top:.5em}
.ff-prose ol{list-style:none;counter-reset:p;padding-left:0}
.ff-prose ol>li{counter-increment:p;position:relative;padding-left:2.6rem;margin-top:1em}
.ff-prose ol>li::before{content:counter(p);position:absolute;left:0;top:.05em;font-family:var(--font-display);font-weight:900;font-size:1.1rem;color:#fff;background:var(--c-rosso);width:1.8rem;height:1.8rem;display:flex;align-items:center;justify-content:center;border-radius:7px}
.ff-prose blockquote{margin:1.4em 0;padding:.4em 0 .4em 1.3rem;border-left:4px solid var(--c-ink);font-style:italic;color:var(--c-ink)}
.ff-prose img{border-radius:var(--radius-sm);box-shadow:var(--shadow)}
.ff-prose figure{margin:1.4em 0}

.ff-tags{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:var(--sp-5)}
.ff-tags a{font-family:var(--font-ui);font-size:var(--step--2);padding:.35rem .8rem;border-radius:999px;background:var(--c-paper);border:1px solid var(--c-border);color:var(--c-muted);text-transform:uppercase;letter-spacing:.05em}
.ff-tags a:hover{background:var(--c-ink);color:#fff}

.ff-author{display:flex;gap:1.1rem;align-items:flex-start;max-width:var(--wrap-read);margin:var(--sp-6) auto 0;padding:var(--sp-4);background:#fff;border:1.5px solid var(--c-border);border-radius:var(--radius)}
.ff-author img{border-radius:50%;flex:0 0 auto}
.ff-author strong{font-family:var(--font-display);text-transform:uppercase;letter-spacing:.02em}
.ff-author p{font-family:var(--font-ui);color:var(--c-muted);font-size:var(--step--1);margin:.3rem 0 0}

.ff-related{max-width:var(--wrap);margin:var(--sp-7) auto 0}

/* ---------- Pubblicità ---------- */
.ff-ad{display:flex;justify-content:center;margin-block:var(--sp-5)}
.ff-ad__slot:empty{display:none}

/* ---------- Footer ---------- */
.ff-footer{background:var(--c-ink-2);color:#fff;margin-top:var(--sp-7);padding-block:var(--sp-6) var(--sp-4)}
.ff-footer__top{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:var(--sp-5)}
@media(max-width:760px){.ff-footer__top{grid-template-columns:1fr 1fr}}
.ff-footer h3{font-family:var(--font-display);text-transform:uppercase;font-size:var(--step--1);letter-spacing:.1em;color:#fff;margin:0 0 var(--sp-3)}
.ff-footer ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:.5rem}
.ff-footer a:hover{color:var(--c-rosso)}
.ff-footer__brand .ff-logo__text{color:#fff}
.ff-footer__brand p{font-family:var(--font-ui);color:rgba(255,255,255,.7);font-size:var(--step--1);margin:.8rem 0 0;max-width:42ch}
.ff-footer li{font-size:var(--step--1)}
.ff-social{display:flex;gap:.5rem}
.ff-social a{display:flex;width:38px;height:38px;align-items:center;justify-content:center;border-radius:9px;background:rgba(255,255,255,.08);font-family:var(--font-display);font-weight:700;font-size:.85rem;text-transform:uppercase;transition:.2s}
.ff-social a:hover{background:var(--c-rosso);color:#fff}
.ff-footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:1rem;flex-wrap:wrap;margin-top:var(--sp-5);padding-top:var(--sp-4);border-top:1px solid rgba(255,255,255,.12);font-family:var(--font-ui);font-size:var(--step--2);color:rgba(255,255,255,.6)}
.ff-footer__menu{display:flex;gap:1rem;list-style:none;margin:0;padding:0}

/* ---------- Back to top ---------- */
.ff-backtop{position:fixed;right:1.2rem;bottom:1.2rem;z-index:120;width:46px;height:46px;border:0;border-radius:12px;background:var(--c-ink);color:#fff;font-size:1.3rem;cursor:pointer;opacity:0;transform:translateY(12px);transition:.3s var(--ease)}
.ff-backtop.is-visible{opacity:1;transform:none}
.ff-backtop:hover{background:var(--c-rosso)}

/* ---------- Vuoto ---------- */
.ff-empty{text-align:center;padding:var(--sp-6) 0}
.ff-empty h2{font-size:var(--step-2);text-transform:uppercase}

/* ---------- Reveal allo scroll ----------
   Hidden state SEULEMENT si JS présent (.ff-js ajouté par funny.js).
   Sans JS / Safari sans IntersectionObserver → tout reste visible. */
.ff-js .ff-reveal{opacity:0;transform:translateY(18px);transition:opacity .6s var(--ease),transform .6s var(--ease)}
.ff-js .ff-reveal.is-in{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){
  .ff-js .ff-reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
  *{animation-duration:.001ms!important;transition-duration:.001ms!important}
}
