/* ============================================================
   Winnita — foglio di stile (archetipo TABLOID-REFINED)
   inchiostro su carta · Oswald display + Bitter testo
   angoli vivi · plinto inverso · divisori spessi · accento elettrico
   Prefisso unico: ypm-
   ============================================================ */

:root{
  /* superfici (neutrale calda, carta da quotidiano) */
  --ypm-bg:#f3efe6;
  --ypm-surface:#fbf8f1;
  --ypm-surface-2:#e7e1d4;
  --ypm-ink:#15130e;
  --ypm-ink-2:#403b32;
  --ypm-ink-3:#726c60;
  --ypm-hairline:color-mix(in srgb, var(--ypm-ink) 16%, transparent);
  --ypm-hairline-2:color-mix(in srgb, var(--ypm-ink) 30%, transparent);
  --ypm-accent:#0f5bff;
  --ypm-accent-ink:#ffffff;
  --ypm-accent-soft:color-mix(in srgb, var(--ypm-accent) 12%, transparent);
  --ypm-inverse:#15130e;
  --ypm-inverse-ink:#f6f2e9;

  /* tipo-scala modulare (ratio 1.25) */
  --ypm-step--1:.8rem;
  --ypm-step-0:1rem;
  --ypm-step-1:1.25rem;
  --ypm-step-2:1.5625rem;
  --ypm-step-3:1.953rem;
  --ypm-step-4:2.441rem;
  --ypm-step-5:3.052rem;
  --ypm-step-6:3.815rem;

  /* ritmo (denso) */
  --ypm-wrap:1257px;
  --ypm-pad:clamp(16px,4vw,32px);
  --ypm-sec:clamp(26px,3.4vw,46px);
  --ypm-gap:14px;
  --ypm-r:0px; /* angoli vivi da archetipo */
}

*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}

html{overflow-x:clip}
body{
  margin:0;
  background:var(--ypm-bg);
  color:var(--ypm-ink);
  font-family:Bitter,Georgia,"Times New Roman",serif;
  font-size:16px;
  line-height:1.62;
  font-feature-settings:"liga" 1,"kern" 1;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}

h1,h2,h3,h4,h5,h6{
  font-family:Oswald,"Arial Narrow",system-ui,sans-serif;
  font-weight:700;
  line-height:1.06;
  letter-spacing:-.01em;
  margin:0 0 .4em;
  text-wrap:balance;
  color:var(--ypm-ink);
}
h1{font-size:clamp(2.1rem,5.2vw,var(--ypm-step-6));text-transform:uppercase;letter-spacing:-.02em}
h2{font-size:clamp(1.6rem,3.4vw,var(--ypm-step-4));text-transform:uppercase}
h3{font-size:var(--ypm-step-2)}
h4{font-size:var(--ypm-step-1)}
p{margin:0 0 1em;text-wrap:pretty}
a{color:var(--ypm-accent);text-underline-offset:2px;text-decoration-thickness:1px}
a:hover{color:color-mix(in srgb,var(--ypm-accent) 78%,var(--ypm-ink))}
strong{font-weight:600}
img{max-width:100%;height:auto;display:block}

:focus-visible{outline:2px solid var(--ypm-accent);outline-offset:2px}
::selection{background:color-mix(in srgb,var(--ypm-accent) 26%,transparent);color:var(--ypm-ink)}
::-moz-selection{background:color-mix(in srgb,var(--ypm-accent) 26%,transparent);color:var(--ypm-ink)}

/* ---------- contenitore ---------- */
.ypm-wrap{width:100%;max-width:var(--ypm-wrap);margin-inline:auto;padding-inline:var(--ypm-pad)}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.ypm-head{
  position:sticky;top:0;z-index:50;
  background:var(--ypm-surface);
  border-bottom:3px solid var(--ypm-ink);
}
.ypm-head__bar{display:flex;align-items:center;justify-content:space-between;gap:16px;min-height:62px}
.ypm-brand{display:inline-flex;align-items:center;gap:10px;text-decoration:none;color:var(--ypm-ink)}
.ypm-brand__mark{
  width:34px;height:34px;flex:0 0 34px;background:var(--ypm-ink);color:var(--ypm-accent-ink);
  display:grid;place-items:center;font-family:Oswald,sans-serif;font-weight:700;font-size:1.15rem;
}
.ypm-brand__name{font-family:Oswald,sans-serif;font-weight:700;font-size:1.45rem;text-transform:uppercase;letter-spacing:.02em;line-height:1}
.ypm-brand__name small{display:block;font-family:Bitter,serif;font-weight:400;font-size:.56rem;letter-spacing:.18em;color:var(--ypm-ink-3);text-transform:uppercase}

.ypm-nav{display:flex;align-items:center;gap:2px;flex-wrap:wrap;justify-content:flex-end}
.ypm-nav a{
  font-family:Oswald,sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.03em;
  font-size:.82rem;color:var(--ypm-ink-2);text-decoration:none;padding:8px 9px;
  border-bottom:2px solid transparent;transition:color .14s ease,border-color .14s ease;
}
.ypm-nav a:hover{color:var(--ypm-ink)}
.ypm-nav a[aria-current="page"]{color:var(--ypm-ink);border-bottom-color:var(--ypm-accent)}
.ypm-geo{
  font-family:Oswald,sans-serif;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ypm-ink-3);border:1px solid var(--ypm-hairline-2);padding:5px 8px;white-space:nowrap;
}

/* burger */
.ypm-burger{display:none;align-items:center;justify-content:center;width:48px;height:48px;background:var(--ypm-ink);color:var(--ypm-inverse-ink);border:0;cursor:pointer}
.ypm-burger svg{width:24px;height:24px}
@media (max-width:900px){
  .ypm-burger{display:inline-flex}
  .ypm-nav,.ypm-geo{display:none}
}

/* overlay mobile fullscreen */
.ypm-drawer{position:fixed;inset:0;z-index:60;background:var(--ypm-inverse);color:var(--ypm-inverse-ink);display:none;flex-direction:column;padding:24px}
.ypm-drawer.is-open{display:flex}
.ypm-drawer__top{display:flex;justify-content:flex-end}
.ypm-drawer__close{width:52px;height:52px;background:transparent;border:1px solid color-mix(in srgb,var(--ypm-inverse-ink) 40%,transparent);color:var(--ypm-inverse-ink);cursor:pointer;display:grid;place-items:center}
.ypm-drawer__close svg{width:26px;height:26px}
.ypm-drawer nav{display:flex;flex-direction:column;justify-content:center;gap:6px;flex:1;text-align:center}
.ypm-drawer nav a{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.02em;font-size:clamp(1.5rem,7vw,2.2rem);color:var(--ypm-inverse-ink);text-decoration:none;padding:6px 0}
.ypm-drawer nav a:hover{color:var(--ypm-accent)}

/* ============================================================
   RUBRICA LATERALE + STANDFIRST (firma archetipo)
   ============================================================ */
.ypm-rubric{
  display:inline-block;font-family:Oswald,sans-serif;font-weight:600;text-transform:uppercase;
  letter-spacing:.16em;font-size:.72rem;color:var(--ypm-accent-ink);background:var(--ypm-ink);
  padding:5px 10px;margin-bottom:12px;
}
.ypm-standfirst{font-size:clamp(1.05rem,2vw,1.3rem);line-height:1.5;color:var(--ypm-ink-2);font-weight:400;max-width:none}

/* ============================================================
   HERO (desktop: una colonna centrata; mobile: img→H1→CTA→lead)
   ============================================================ */
.ypm-hero{padding-block:var(--ypm-sec);border-bottom:3px solid var(--ypm-ink);position:relative;background:linear-gradient(180deg,color-mix(in srgb,var(--ypm-accent) 7%,transparent),transparent 60%)}
.ypm-hero__inner{display:flex;flex-direction:column;align-items:center;text-align:center;gap:var(--ypm-gap)}
.ypm-hero__kicker{display:block;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.16em;font-size:.78rem;color:var(--ypm-accent);font-weight:600}
.ypm-hero h1{margin:0;max-width:18ch}
.ypm-hero__verdict{font-family:Oswald,sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.02em;font-size:clamp(1rem,2.4vw,1.35rem);color:var(--ypm-ink-2);margin:0}
.ypm-hero__lead{max-width:52ch;color:var(--ypm-ink-2);margin:0}
.ypm-hero__media{position:relative;width:100%;max-width:440px;margin-inline:auto}
.ypm-hero__media::before{content:"";position:absolute;inset:-8% -6%;background:radial-gradient(closest-side,color-mix(in srgb,var(--ypm-accent) 24%,transparent),transparent 72%);filter:blur(26px);z-index:0}
.ypm-hero-img{position:relative;z-index:1;width:100%;aspect-ratio:1/1;object-fit:cover;border:3px solid var(--ypm-ink);box-shadow:14px 14px 0 -2px color-mix(in srgb,var(--ypm-accent) 70%,var(--ypm-ink))}
.ypm-hero__cta{display:flex;justify-content:center;width:100%}

/* ordine hero — DOM = ordine mobile (H1 -> CTA -> img -> verdetto -> lead -> fatti);
   desktop riordina con CSS (H1 -> verdetto -> lead -> img -> CTA -> fatti) */
.ypm-hero--cta{margin-block:2px}
@media (max-width:640px){
  .ypm-hero-img{max-height:none}
}
@media (min-width:900px){
  /* ДЕСКТОП: 2 колонки — текст слева, картинка справа (а не высокая центр-стопка) */
  .ypm-hero__inner{
    display:grid;
    grid-template-columns:minmax(0,1.12fr) minmax(0,.88fr);
    column-gap:clamp(28px,4vw,52px);
    row-gap:12px;
    align-items:start;
    text-align:left;
  }
  .ypm-hero--kicker{grid-column:1;align-self:end}
  .ypm-hero--h1{grid-column:1}
  .ypm-hero--verdict{grid-column:1}
  .ypm-hero--lead{grid-column:1}
  .ypm-hero--cta{grid-column:1;justify-content:flex-start;width:auto;margin-top:6px}
  .ypm-hero--media{grid-column:2;grid-row:1 / span 5;align-self:center;justify-self:center;max-width:380px;margin:0}
  .ypm-hero--facts{grid-column:1 / -1;margin-top:8px}
  .ypm-hero h1{max-width:none}
  .ypm-hero__lead{max-width:50ch}
  .ypm-hero-img{max-height:none;width:100%}
}

/* striscia fatti hero */
.ypm-facts{display:grid;grid-template-columns:repeat(auto-fit,minmax(0,1fr));gap:1px;background:var(--ypm-hairline-2);border:1px solid var(--ypm-hairline-2);width:100%;margin-top:6px}
.ypm-facts__c{background:var(--ypm-surface);padding:10px 14px;text-align:left;min-width:0}
.ypm-facts__k{display:block;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.1em;font-size:.64rem;color:var(--ypm-ink-3)}
.ypm-facts__v{font-family:Oswald,sans-serif;font-weight:600;font-size:1.02rem;color:var(--ypm-ink);font-variant-numeric:tabular-nums lining-nums}

/* ============================================================
   CTA
   ============================================================ */
.ypm-cta{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  font-family:Oswald,sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.04em;
  font-size:1rem;line-height:1;padding:15px 26px;min-height:50px;text-decoration:none;cursor:pointer;
  border:0;transition:background-color .14s ease,border-color .14s ease,transform .12s ease,color .14s ease;
}
.ypm-cta__i{flex:0 0 auto;transition:transform .14s ease}
.ypm-cta--solid{background:var(--ypm-accent);color:var(--ypm-accent-ink);border-bottom:3px solid var(--ypm-ink)}
.ypm-cta--solid:hover{background:color-mix(in srgb,var(--ypm-accent) 86%,var(--ypm-ink));color:var(--ypm-accent-ink)}
.ypm-cta--ghost{background:transparent;color:var(--ypm-ink);border:2px solid var(--ypm-ink)}
.ypm-cta--ghost:hover{background:var(--ypm-ink);color:var(--ypm-inverse-ink)}
.ypm-cta:hover .ypm-cta__i{transform:translateX(3px)}
.ypm-cta:active{transform:translateY(1px)}
.ypm-ctarow{display:flex;justify-content:center;margin:var(--ypm-gap) 0 calc(var(--ypm-gap) + 6px)}

/* ============================================================
   BREADCRUMBS
   ============================================================ */
.ypm-crumbs{border-bottom:1px solid var(--ypm-hairline);background:var(--ypm-surface)}
.ypm-crumbs ol{display:flex;flex-wrap:wrap;gap:6px;align-items:center;list-style:none;margin:0;padding:10px 0;font-family:Oswald,sans-serif;font-size:.76rem;text-transform:uppercase;letter-spacing:.06em}
.ypm-crumbs li{display:inline-flex;align-items:center;gap:6px;color:var(--ypm-ink-3)}
.ypm-crumbs li::after{content:"›";color:var(--ypm-hairline-2)}
.ypm-crumbs li:last-child::after{content:""}
.ypm-crumbs a{color:var(--ypm-ink-2);text-decoration:none}
.ypm-crumbs a:hover{color:var(--ypm-accent)}
.ypm-crumbs li[aria-current]{color:var(--ypm-ink)}

/* ============================================================
   BYLINE
   ============================================================ */
.ypm-byline{background:var(--ypm-surface);border-bottom:1px solid var(--ypm-hairline)}
.ypm-byline__row{display:flex;align-items:center;gap:12px;padding:12px 0;flex-wrap:wrap}
.ypm-byline__ph{width:46px;height:46px;flex:0 0 46px;object-fit:cover;border:2px solid var(--ypm-ink);border-radius:0}
.ypm-byline__txt{font-size:.86rem;line-height:1.4;color:var(--ypm-ink-3)}
.ypm-byline__txt a{font-weight:600;text-decoration:none}
.ypm-byline__txt a:hover{text-decoration:underline}
.ypm-byline__name{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.02em;color:var(--ypm-ink)}
.ypm-byline__date{font-variant-numeric:tabular-nums}

/* ============================================================
   CORPO / PROSA  (una colonna, bordo sinistro unico, larghezza .wrap)
   ============================================================ */
.ypm-main{padding-block:var(--ypm-sec)}
.ypm-prose{max-width:none}
.ypm-prose>*+*{margin-top:.2rem}
.ypm-prose p,.ypm-prose ul,.ypm-prose ol,.ypm-prose table,.ypm-prose .ypm-figure{max-width:none}
.ypm-prose h2{margin-top:1.4em}
.ypm-prose h3{margin-top:1.1em}
.ypm-prose a:not(.ypm-cta){color:var(--ypm-accent);font-weight:600}
.ypm-prose a:not(.ypm-cta):hover{color:color-mix(in srgb,var(--ypm-accent) 75%,var(--ypm-ink))}

/* numero di sezione + titolo (firma tabloid) */
.ypm-sectit{display:flex;align-items:baseline;gap:12px;border-top:3px solid var(--ypm-ink);padding-top:10px;margin-top:1.6em}
.ypm-sectit__n{font-family:Oswald,sans-serif;font-weight:700;font-size:1rem;color:var(--ypm-accent);font-variant-numeric:tabular-nums}
.ypm-sectit h2{margin:0}

/* liste con freccia accento, rientro sospeso */
.ypm-prose ul{list-style:none;padding-left:0;margin:0 0 1em}
.ypm-prose ul li{position:relative;padding-left:1.5em;margin-bottom:.4em}
.ypm-prose ul li::before{content:"›";position:absolute;left:0;top:-.02em;color:var(--ypm-accent);font-family:Oswald,sans-serif;font-weight:700;font-size:1.15em}
.ypm-prose ol{padding-left:1.3em;margin:0 0 1em}
.ypm-prose ol li{margin-bottom:.4em}

/* callout / nota */
.ypm-note{background:var(--ypm-surface-2);border-left:5px solid var(--ypm-accent);padding:14px 18px;margin:1.2em 0}
.ypm-note p:last-child{margin-bottom:0}
.ypm-note strong{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-size:.9rem}

/* figure contenuto: centrata, cap in px */
.ypm-figure{width:min(72%,760px);margin:1.4rem auto;border:2px solid var(--ypm-ink)}
.ypm-figure img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block}
.ypm-figure figcaption{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:.7rem;color:var(--ypm-ink-3);padding:7px 10px;border-top:2px solid var(--ypm-ink);background:var(--ypm-surface)}

/* ============================================================
   TABELLE (premium, hairline orizzontali, no card)
   ============================================================ */
.ypm-tablewrap{overflow-x:auto;margin:1.2em 0;border:1px solid var(--ypm-hairline-2)}
table{width:100%;border-collapse:collapse;font-size:.92rem;background:var(--ypm-surface)}
table caption{caption-side:top;text-align:left;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem;color:var(--ypm-ink-3);padding:0 0 8px}
thead th{background:var(--ypm-surface-2);font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.03em;font-size:.78rem;color:var(--ypm-ink)}
th,td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--ypm-hairline);vertical-align:top;font-variant-numeric:tabular-nums lining-nums}
tbody tr:last-child td{border-bottom:0}
tbody tr:hover td{background:color-mix(in srgb,var(--ypm-accent) 6%,transparent)}
td:first-child,th:first-child{font-weight:600}
table td:not(:first-child),table th:not(:first-child){white-space:nowrap}
/* sicurezza anti-scroll su mobile: la tabella scorre come blocco */
@media (max-width:640px){
  .ypm-prose table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
  .ypm-tablewrap table{display:table;width:100%}
}

/* ============================================================
   FAQ / DETAILS (carta con cornice, marcatore +)
   ============================================================ */
details{border:1px solid var(--ypm-hairline-2);background:var(--ypm-surface);margin:0 0 8px;padding:0}
details+details{margin-top:8px}
summary{list-style:none;cursor:pointer;padding:14px 46px 14px 16px;position:relative;font-family:Oswald,sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.02em;font-size:.96rem;color:var(--ypm-ink)}
summary::-webkit-details-marker{display:none}
summary::after{content:"+";position:absolute;right:16px;top:50%;transform:translateY(-50%);color:var(--ypm-accent);font-family:Oswald,sans-serif;font-weight:700;font-size:1.4rem;line-height:1}
details[open] summary::after{content:"–"}
details[open] summary{border-bottom:1px solid var(--ypm-hairline)}
details .ypm-faq__a{padding:12px 16px 16px}
details .ypm-faq__a p:last-child{margin-bottom:0}

/* TOC details flottante in apertura */
.ypm-toc{border:2px solid var(--ypm-ink);background:var(--ypm-surface);margin:0 0 1.4em}
.ypm-toc>summary{border-bottom:0}
.ypm-toc[open]>summary{border-bottom:2px solid var(--ypm-ink)}
.ypm-toc ol{margin:0;padding:12px 16px 14px 32px;columns:2;column-gap:28px}
.ypm-toc li{margin-bottom:5px}
.ypm-toc a{text-decoration:none;color:var(--ypm-ink-2)}
.ypm-toc a:hover{color:var(--ypm-accent)}
@media (max-width:640px){.ypm-toc ol{columns:1}}

/* ============================================================
   VALUTAZIONE PER CRITERI (mini-barre)
   ============================================================ */
.ypm-rating{border:2px solid var(--ypm-ink);background:var(--ypm-surface);padding:16px 18px;margin:1.2em 0}
.ypm-rating__top{display:flex;align-items:baseline;justify-content:space-between;gap:12px;border-bottom:2px solid var(--ypm-ink);padding-bottom:10px;margin-bottom:12px}
.ypm-rating__score{font-family:Oswald,sans-serif;font-weight:700;font-size:2.6rem;line-height:1;color:var(--ypm-ink);font-variant-numeric:tabular-nums}
.ypm-rating__score span{font-size:1rem;color:var(--ypm-ink-3)}
.ypm-rating__label{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;color:var(--ypm-ink-3)}
.ypm-crit{display:grid;gap:9px}
.ypm-crit__row{display:grid;grid-template-columns:minmax(0,1fr) 46px;align-items:center;gap:10px}
.ypm-crit__name{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.02em;font-size:.82rem;color:var(--ypm-ink-2)}
.ypm-crit__bar{grid-column:1/-1;height:7px;background:var(--ypm-surface-2);position:relative;border:1px solid var(--ypm-hairline)}
.ypm-crit__bar i{position:absolute;inset:0 auto 0 0;background:var(--ypm-accent);display:block}
.ypm-crit__num{text-align:right;font-family:Oswald,sans-serif;font-weight:600;font-variant-numeric:tabular-nums;color:var(--ypm-ink)}

/* pro / contro */
.ypm-proscons{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin:1.2em 0}
.ypm-pc{border:2px solid var(--ypm-ink);background:var(--ypm-surface);padding:14px 16px}
.ypm-pc h3{font-size:1.05rem;margin-bottom:.5em;text-transform:uppercase}
.ypm-pc ul{list-style:none;padding:0;margin:0}
.ypm-pc li{position:relative;padding-left:1.6em;margin-bottom:.45em;font-size:.92rem}
.ypm-pc--pro li::before{content:"+";position:absolute;left:0;color:var(--ypm-accent);font-family:Oswald,sans-serif;font-weight:700}
.ypm-pc--con li::before{content:"–";position:absolute;left:0;color:var(--ypm-ink-3);font-family:Oswald,sans-serif;font-weight:700}
@media (max-width:640px){.ypm-proscons{grid-template-columns:1fr}}

/* ============================================================
   BLOCCO GIOCHI POPOLARI (compatto, molte colonne)
   ============================================================ */
.ypm-slots{padding-block:var(--ypm-sec);border-top:3px solid var(--ypm-ink);border-bottom:3px solid var(--ypm-ink);background:var(--ypm-surface)}
.ypm-slots__head{display:flex;align-items:baseline;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.ypm-slots__head h2{margin:0}
.ypm-slots__all{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-size:.82rem;text-decoration:none}
.ypm-slotgrid{display:grid;grid-template-columns:repeat(6,minmax(0,1fr));gap:10px}
.ypm-slot{display:block;text-decoration:none;color:inherit;border:1px solid var(--ypm-hairline-2);background:var(--ypm-bg);transition:transform .12s ease,border-color .14s ease}
.ypm-slot:hover{transform:translateY(-3px);border-color:var(--ypm-accent)}
.ypm-slot img{width:100%;aspect-ratio:1/1;object-fit:cover;display:block}
.ypm-slot__name{display:block;font-family:Oswald,sans-serif;font-weight:500;text-transform:uppercase;letter-spacing:.01em;font-size:.7rem;color:var(--ypm-ink-2);padding:6px 7px;line-height:1.15;border-top:1px solid var(--ypm-hairline)}
@media (max-width:980px){.ypm-slotgrid{grid-template-columns:repeat(4,minmax(0,1fr))}}
@media (max-width:560px){.ypm-slotgrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:7px}}

/* ============================================================
   CARD AUTORE (fine articolo)
   ============================================================ */
.ypm-author{display:flex;gap:18px;border:2px solid var(--ypm-ink);background:var(--ypm-surface);padding:20px 22px;margin:1.6em auto;max-width:820px}
.ypm-author__photo{width:104px;height:104px;flex:0 0 104px;object-fit:cover;border:2px solid var(--ypm-ink);aspect-ratio:1/1}
.ypm-prose img.ypm-author__photo{width:104px;aspect-ratio:1/1}
.ypm-author__body{min-width:0}
.ypm-author__role{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.06em;font-size:.72rem;color:var(--ypm-accent);margin:0 0 2px}
.ypm-author__name{font-family:Oswald,sans-serif;font-weight:700;text-transform:uppercase;font-size:1.3rem;margin:0 0 6px}
.ypm-author__name a{color:var(--ypm-ink);text-decoration:none}
.ypm-author__name a:hover{color:var(--ypm-accent)}
.ypm-author__bio{font-size:.92rem;color:var(--ypm-ink-2);margin:0 0 8px}
.ypm-author__more{font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.04em;font-size:.78rem;text-decoration:none}
@media (max-width:560px){.ypm-author{flex-direction:column}.ypm-author__photo{width:88px;height:88px;flex-basis:88px}}

/* ritratto pagina autore */
.ypm-prose img.ypm-portrait{width:220px;aspect-ratio:3/4;object-fit:cover;border:3px solid var(--ypm-ink);float:left;margin:0 22px 12px 0}
@media (max-width:560px){.ypm-prose img.ypm-portrait{float:none;margin:0 0 14px}}

/* disclaimer 18+ */
.ypm-age{display:inline-flex;align-items:center;gap:8px;border:2px solid var(--ypm-ink);padding:4px 9px;font-family:Oswald,sans-serif;font-weight:700;font-size:.8rem}
.ypm-disclaimer{border-top:3px solid var(--ypm-ink);margin-top:var(--ypm-sec);padding-top:14px;font-size:.84rem;color:var(--ypm-ink-3)}

/* ============================================================
   FOOTER
   ============================================================ */
.ypm-foot{background:var(--ypm-inverse);color:var(--ypm-inverse-ink);margin-top:var(--ypm-sec)}
.ypm-foot__rg{background:var(--ypm-accent);color:var(--ypm-accent-ink);padding:12px 0}
.ypm-foot__rg .ypm-wrap{display:flex;align-items:center;gap:14px;flex-wrap:wrap;font-family:Oswald,sans-serif;text-transform:uppercase;letter-spacing:.03em;font-size:.84rem}
.ypm-foot__rg strong{font-weight:700}
.ypm-foot__main{padding-block:28px}
.ypm-foot__cols{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:24px}
.ypm-foot h3{color:var(--ypm-inverse-ink);text-transform:uppercase;font-size:.9rem;letter-spacing:.04em;border-bottom:1px solid color-mix(in srgb,var(--ypm-inverse-ink) 26%,transparent);padding-bottom:6px;margin-bottom:10px;line-height:1.06}
.ypm-foot ul{list-style:none;margin:0;padding:0}
.ypm-foot li{margin-bottom:6px}
.ypm-foot a{color:color-mix(in srgb,var(--ypm-inverse-ink) 82%,transparent);text-decoration:none;font-size:.9rem}
.ypm-foot a:hover{color:var(--ypm-accent-ink);text-decoration:underline}
.ypm-foot__brand{font-family:Oswald,sans-serif;font-weight:700;text-transform:uppercase;font-size:1.4rem;margin-bottom:8px}
.ypm-foot__bio{font-size:.86rem;color:color-mix(in srgb,var(--ypm-inverse-ink) 70%,transparent);line-height:1.55}
.ypm-foot__bottom{border-top:1px solid color-mix(in srgb,var(--ypm-inverse-ink) 22%,transparent);padding-block:16px;font-size:.78rem;color:color-mix(in srgb,var(--ypm-inverse-ink) 62%,transparent)}
.ypm-foot__bottom .ypm-wrap{display:flex;justify-content:space-between;gap:12px;flex-wrap:wrap}
@media (max-width:780px){.ypm-foot__cols{grid-template-columns:1fr}}

/* utility ritmo */
.ypm-stack>*+*{margin-top:var(--ypm-gap)}
.ypm-flow>*+*{margin-top:.7em}
.ypm-center{text-align:center}
.ypm-mt{margin-top:var(--ypm-sec)}

/* stagger longread: piccoli scarti orizzontali per ritmo */
@media (min-width:1000px){
  .ypm-step-a{margin-left:0}
  .ypm-step-b{margin-left:4%}
  .ypm-step-c{margin-left:2%}
}

@media (prefers-reduced-motion:reduce){
  *{transition:none !important}
}
