/* =========================================================================
   Pagina "Chi è Roberto Serra" — /chi-e-roberto-serra/
   Tutte le classi con prefisso .cs- per isolamento dal tema (niente collisioni).
   Brand kit: ink/blue/orange · Plus Jakarta Sans + Rubik. Voce FATTUALE.
   Escluso da WP Rocket minify/RUCSS (vedi functions.php).
   ========================================================================= */
.cs-page{
  --ink:#1C1F29;--ink2:#23262f;--blue:#0365FA;--deep:#023A93;--amber:#FA9329;
  --soft:#EDF4FF;--muted:#525C72;--line:#E6E9EE;
  font-family:"Rubik",system-ui,sans-serif;color:var(--ink2);line-height:1.65;
  background:#fff;overflow-x:clip;
}
.cs-page *{box-sizing:border-box}
.cs-page img{max-width:100%;display:block}
.cs-page a{color:inherit;text-decoration:none}
.cs-h1,.cs-h2,.cs-h3,.cs-pj,.cs-eye,.cs-kicker,.cs-stat,.cs-tl__y,.cs-num__n,.cs-btn{font-family:"Plus Jakarta Sans",sans-serif}

.cs-wrap{max-width:1080px;margin:0 auto;padding:0 26px}
.cs-eye{font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--amber)}
.cs-kicker{font-size:12.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--blue)}
.cs-sec{padding:74px 0}
.cs-sec--soft{background:var(--soft)}
.cs-sec--ink{background:var(--ink);color:#eef1f6}
.cs-sec__h{font-family:"Plus Jakarta Sans",sans-serif;font-size:clamp(25px,3.4vw,34px);font-weight:800;letter-spacing:-.02em;line-height:1.15;color:var(--ink)}
.cs-sec--ink .cs-sec__h{color:#fff}
.cs-sec__lead{font-size:17px;color:var(--muted);max-width:62ch;margin-top:12px}
.cs-sec--ink .cs-sec__lead{color:#aeb7c6}
.cs-center{text-align:center}
.cs-center .cs-sec__lead{margin-left:auto;margin-right:auto}

/* ---------- HERO ---------- */
.cs-hero{position:relative;overflow:hidden;background:
  radial-gradient(1100px 460px at 88% -8%, rgba(3,101,250,.10), transparent 60%),
  radial-gradient(700px 380px at 0% 110%, rgba(250,147,41,.08), transparent 55%),#fff}
.cs-hero__in{display:grid;grid-template-columns:1.15fr .85fr;gap:48px;align-items:center;padding:60px 0 54px}
.cs-hero__eye{display:flex;align-items:center;gap:10px;font-size:12.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.cs-hero__eye b{color:var(--ink)}
.cs-hero__dot{width:6px;height:6px;border-radius:50%;background:var(--amber)}
.cs-hero h1{font-family:"Plus Jakarta Sans",sans-serif;font-size:clamp(29px,4.3vw,48px);font-weight:800;letter-spacing:-.025em;line-height:1.08;margin:16px 0 18px;color:var(--ink)}
.cs-hero h1 .cs-hl{color:var(--blue)}
.cs-hero__sub{font-size:18px;color:var(--muted);max-width:54ch}
.cs-hero__cta{display:flex;gap:13px;flex-wrap:wrap;margin-top:26px}
.cs-btn{display:inline-flex;align-items:center;gap:9px;font-weight:700;font-size:15px;border-radius:11px;padding:14px 22px;transition:.18s;cursor:pointer;border:0}
.cs-btn--p{background:var(--blue);color:#fff;box-shadow:0 12px 26px -12px rgba(3,101,250,.7)}
.cs-btn--p:hover{background:var(--deep);color:#fff}
.cs-btn--g{background:#fff;color:var(--ink);border:1px solid var(--line)}
.cs-btn--g:hover{border-color:#c9d2e0}
/* .cs-page a{color:inherit} (0,1,1) batteva .cs-btn--* (0,1,0) → testo bottone ereditato.
   Rialzo la specificità così il colore del bottone vince sempre. */
.cs-page a.cs-btn--p,.cs-page .cs-btn--p{color:#fff}
.cs-page a.cs-btn--g,.cs-page .cs-btn--g{color:var(--ink)}
.cs-hero__media{position:relative}
.cs-hero__photo{position:relative;border-radius:20px;overflow:hidden;aspect-ratio:4/5;background:#dfe6f1;
  box-shadow:0 40px 80px -40px rgba(20,30,60,.5);border:1px solid #e7ecf3}
.cs-hero__photo img{width:100%;height:100%;object-fit:cover;object-position:center 18%}
.cs-hero__badge{position:absolute;left:-14px;bottom:22px;background:#fff;border:1px solid var(--line);
  border-radius:14px;padding:12px 15px;box-shadow:0 18px 40px -22px rgba(20,30,60,.4);display:flex;gap:11px;align-items:center}
.cs-hero__badge .cs-bn{font-family:"Plus Jakarta Sans";font-weight:800;font-size:20px;color:var(--ink);line-height:1}
.cs-hero__badge .cs-bt{font-size:11.5px;color:var(--muted);line-height:1.25}
.cs-cred{border-top:1px solid var(--line);background:rgba(255,255,255,.6)}
.cs-cred__in{display:flex;align-items:center;gap:10px 24px;flex-wrap:wrap;justify-content:center;padding:18px 26px;max-width:1080px;margin:0 auto}
.cs-cred__lab{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#97a0b2}
.cs-cred__i{font-family:"Plus Jakarta Sans";font-weight:700;font-size:13.5px;color:var(--ink);display:flex;align-items:center;gap:9px}
.cs-cred__i::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--blue)}

/* ---------- MEDIA STRIP ---------- */
.cs-media__top{text-align:center;margin-bottom:26px}
.cs-media__top .cs-h{font-family:"Plus Jakarta Sans";font-weight:800;font-size:15px;color:var(--ink)}
.cs-media__top .cs-s{font-size:13.5px;color:var(--muted);margin-top:4px}
.cs-mq{overflow:hidden;background:var(--ink);border-radius:18px;padding:24px 0;max-width:920px;margin:0 auto}
.cs-mq__t{display:flex;align-items:center;width:max-content;animation:cs-mq 28s linear infinite}
.cs-mq:hover .cs-mq__t{animation-play-state:paused}
.cs-mq .cs-l{flex:0 0 auto;display:flex;align-items:center;justify-content:center;padding:0 34px}
.cs-mq .cs-l img{height:38px;width:auto}
@keyframes cs-mq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- CAROSELLO VIDEO orizzontale (Senato · TEDx · …) ---------- */
.cs-vcar{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:none;margin-top:30px;padding-bottom:4px}
.cs-vcar::-webkit-scrollbar{display:none}
.cs-vslide{flex:0 0 87%;scroll-snap-align:center}
.cs-vslide .cs-video{border-radius:16px;overflow:hidden;border:1px solid rgba(255,255,255,.10)}
.cs-vcar__hint{color:#8b94a6;font-size:13px;font-family:"Plus Jakarta Sans",sans-serif;font-weight:600}
.cs-vcar-foot{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-top:14px}
.cs-scrollnav{display:none;gap:10px}
.cs-arrow{width:44px;height:44px;border-radius:50%;border:1px solid rgba(255,255,255,.28);background:rgba(255,255,255,.06);color:#fff;font-size:24px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .18s,border-color .18s;font-family:"Plus Jakarta Sans",sans-serif}
.cs-arrow:hover{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.45)}
@media(min-width:880px){ .cs-vslide{flex-basis:66%} .cs-scrollnav{display:flex} .cs-vcar__hint{display:none} }

/* ---------- BLOG / SEO Confidential ---------- */
.cs-experts{margin:24px 0 22px}
.cs-experts__lab{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#97a0b2}
.cs-experts__row{display:flex;flex-wrap:wrap;gap:10px;margin-top:13px}
.cs-exp{font-family:"Plus Jakarta Sans",sans-serif;font-weight:600;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:999px;padding:8px 15px}
.cs-exp--more{color:var(--muted);background:transparent;border-style:dashed}

/* ---------- ANCHOR Senato/TEDx + VIDEO FACADE ---------- */
.cs-anchor__grid{display:grid;grid-template-columns:1.4fr 1fr;gap:24px;margin-top:32px}
.cs-vcard{position:relative;border-radius:16px;overflow:hidden;background:#0c0f16;border:1px solid rgba(255,255,255,.08);display:block}
.cs-video{position:relative;aspect-ratio:16/9;background:#11151f;cursor:pointer}
.cs-video img{width:100%;height:100%;object-fit:cover;opacity:.92}
.cs-video iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.cs-play{position:absolute;inset:0;display:flex;align-items:center;justify-content:center}
.cs-play span{width:62px;height:62px;border-radius:50%;background:rgba(255,255,255,.94);display:flex;align-items:center;justify-content:center;box-shadow:0 10px 30px rgba(0,0,0,.4);transition:.18s}
.cs-video:hover .cs-play span{transform:scale(1.07)}
.cs-play svg{width:22px;height:22px;fill:var(--ink);margin-left:3px}
.cs-vcard__cap{padding:15px 18px}
.cs-vcard__cap .cs-k{font-family:"Plus Jakarta Sans";font-weight:700;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber)}
.cs-vcard__cap .cs-t{color:#fff;font-weight:600;margin-top:6px;font-size:15.5px;line-height:1.35}
.cs-tedx{display:flex;flex-direction:column;justify-content:center;gap:8px;padding:26px;background:linear-gradient(160deg,#1a1f2b,#0c0f16);border:1px solid rgba(255,255,255,.08);border-radius:16px}
.cs-tedx .cs-red{font-family:"Plus Jakarta Sans";font-weight:800;font-size:27px;letter-spacing:-.02em;color:#fff}
.cs-tedx .cs-red b{color:#eb0028}
.cs-tedx .cs-tt{color:#fff;font-size:17px;font-weight:600;line-height:1.3}
.cs-tedx .cs-yy{color:#9aa3b2;font-size:13.5px}

/* ---------- NUMERI ---------- */
.cs-nums{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:30px}
.cs-num{background:#fff;border:1px solid var(--line);border-radius:16px;padding:26px 18px;text-align:center}
.cs-num__n{font-family:"Plus Jakarta Sans";font-weight:800;font-size:clamp(28px,4vw,40px);color:var(--ink);letter-spacing:-.02em;line-height:1}
.cs-num__n .cs-u{color:var(--blue)}
.cs-num__t{font-size:13.5px;color:var(--muted);margin-top:9px;line-height:1.4}
.cs-nums__note{text-align:center;font-size:12px;color:#9aa3b2;margin-top:16px}

/* ---------- STORIA + TIMELINE ---------- */
.cs-story{display:grid;grid-template-columns:1fr 1fr;gap:44px;align-items:start}
.cs-story__txt p{font-size:16.5px;color:var(--muted);margin-top:14px}
.cs-pledge{margin-top:22px;border-left:4px solid var(--amber);background:#fff;border-radius:0 12px 12px 0;
  padding:16px 18px;box-shadow:0 16px 34px -26px rgba(20,30,60,.4)}
.cs-pledge .cs-k{font-family:"Plus Jakarta Sans";font-weight:800;font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--amber)}
.cs-pledge .cs-t{font-family:"Plus Jakarta Sans";color:var(--ink);font-weight:600;font-size:17px;margin-top:7px;line-height:1.4}
.cs-tl{position:relative;padding-left:26px}
.cs-tl::before{content:"";position:absolute;left:6px;top:6px;bottom:6px;width:2px;background:linear-gradient(var(--blue),var(--amber))}
.cs-tl__i{position:relative;padding:0 0 20px 0}
.cs-tl__i::before{content:"";position:absolute;left:-26px;top:4px;width:11px;height:11px;border-radius:50%;background:#fff;border:3px solid var(--blue)}
.cs-tl__y{font-weight:800;font-size:13px;color:var(--blue);letter-spacing:.04em}
.cs-tl__t{font-size:15px;color:var(--ink2);margin-top:2px}
.cs-tl__t b{color:var(--ink);font-weight:600}

/* ---------- DIGITAL TALKS (editoriale, senza foto) ---------- */
.cs-dt{display:grid;grid-template-columns:1.05fr .95fr;gap:40px;align-items:center}
.cs-dt__chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}
.cs-dt__chip{font-size:13px;font-weight:600;color:#dfe6f4;border:1px solid rgba(255,255,255,.18);border-radius:999px;padding:7px 14px}
.cs-dt__panel{background:#0c0f16;border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:24px 28px}
.cs-dt__row{display:flex;align-items:baseline;gap:12px;padding:14px 0;border-bottom:1px solid rgba(255,255,255,.08)}
.cs-dt__row:last-child{border-bottom:0}
.cs-dt__row .cs-d{font-family:"Plus Jakarta Sans";font-weight:800;color:var(--amber);font-size:13px;flex:0 0 auto;width:90px}
.cs-dt__row .cs-x{color:#cfd6e2;font-size:14.5px}
.cs-dt__cta{margin-top:20px}

/* Shorts dei Digital Talks (verticali, scorrevoli) */
.cs-shorts-wrap{margin-top:42px}
.cs-shorts-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:14px}
.cs-shorts-lab{font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:#9aa3b2}
.cs-shorts{display:flex;gap:16px;overflow-x:auto;scroll-snap-type:x proximity;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding-bottom:4px}
.cs-shorts::-webkit-scrollbar{display:none}
.cs-short{flex:0 0 190px;scroll-snap-align:start}
.cs-video--short{aspect-ratio:9/16;border-radius:14px;overflow:hidden;border:1px solid rgba(255,255,255,.10)}
.cs-video--short .cs-play span{width:48px;height:48px}
.cs-short__cap{margin-top:10px}
.cs-short__n{font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;color:#fff;font-size:14px;line-height:1.25}
.cs-short__r{color:#9aa3b2;font-size:12.5px;margin-top:2px}
.cs-short--all{flex:0 0 190px;scroll-snap-align:start;display:flex;align-items:center;justify-content:center;aspect-ratio:9/16;border-radius:14px;border:1px dashed rgba(255,255,255,.28);background:rgba(255,255,255,.04);color:#dfe6f4;transition:background .18s}
.cs-short--all:hover{background:rgba(255,255,255,.09)}
.cs-short--all__in{display:flex;flex-direction:column;gap:11px;align-items:center;text-align:center;font-family:"Plus Jakarta Sans",sans-serif;font-weight:700;font-size:14px;padding:0 16px}
.cs-short--all__ic{width:46px;height:46px;border-radius:50%;border:2px solid rgba(255,255,255,.45);display:flex;align-items:center;justify-content:center;font-size:14px}
@media(max-width:520px){.cs-short,.cs-short--all{flex-basis:152px}}

/* ---------- PALCHI ---------- */
.cs-stages{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px}
.cs-stage{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px 18px;display:flex;flex-direction:column;gap:3px}
.cs-stage .cs-y{font-family:"Plus Jakarta Sans";font-weight:800;font-size:12px;color:var(--blue)}
.cs-stage .cs-n{font-weight:600;color:var(--ink);font-size:15px}
.cs-stage .cs-p{font-size:12.5px;color:var(--muted)}

/* ---------- LIBRI (copertine reali) ---------- */
.cs-books{display:grid;grid-template-columns:repeat(5,1fr);gap:22px;margin-top:30px;align-items:start}
.cs-book{margin:0}
.cs-book img{width:100%;height:auto;display:block;border-radius:8px;box-shadow:0 20px 38px -20px rgba(20,30,60,.55);transition:transform .2s}
.cs-book:hover img{transform:translateY(-4px)}
.cs-book__cap{font-family:"Plus Jakarta Sans",sans-serif;font-weight:600;font-size:11px;color:var(--muted);text-align:center;margin-top:9px;letter-spacing:.02em}
.cs-books__note{text-align:center;font-size:13.5px;color:var(--muted);margin-top:22px}

/* ---------- VIDEO FEEDBACK ---------- */
.cs-fb{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:30px}
.cs-fb__c{border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 18px 40px -28px rgba(20,30,60,.35);text-align:left}
.cs-fb__m{padding:14px 16px}
.cs-fb__m .cs-n{font-family:"Plus Jakarta Sans";font-weight:700;color:var(--ink);font-size:15px}
.cs-fb__m .cs-r{font-size:12.5px;color:var(--muted);margin-top:2px;line-height:1.35}

/* ---------- MANIFESTO (perché lo faccio) ---------- */
.cs-manifesto{background:linear-gradient(135deg,var(--blue),var(--deep));text-align:center}
.cs-manifesto__eye{display:block;font-family:"Plus Jakarta Sans",sans-serif;font-weight:800;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:#bcd3ff}
.cs-manifesto__t{font-family:"Plus Jakarta Sans",sans-serif;color:#fff;font-weight:700;font-size:clamp(21px,2.7vw,31px);line-height:1.34;letter-spacing:-.01em;max-width:820px;margin:16px auto 0}

/* ---------- CTA FINALE ---------- */
.cs-final{background:radial-gradient(800px 360px at 50% -20%,rgba(3,101,250,.25),transparent 60%),var(--ink);text-align:center}
.cs-final h2{color:#fff;font-family:"Plus Jakarta Sans";font-size:clamp(26px,3.6vw,38px);font-weight:800;letter-spacing:-.02em}
.cs-final p{color:#aeb7c6;font-size:17px;max-width:56ch;margin:14px auto 0}
.cs-final .cs-btn--p{margin-top:26px}
.cs-final .cs-rea{display:flex;gap:8px;justify-content:center;align-items:center;color:#8b94a6;font-size:13px;margin-top:16px}

/* ---------- REVEAL on scroll ---------- */
.cs-rev{opacity:0;transform:translateY(16px);transition:opacity .6s ease,transform .6s ease}
.cs-rev.cs-in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){.cs-rev{opacity:1;transform:none;transition:none}}

/* ---------- RESPONSIVE ---------- */
@media (max-width:880px){
  .cs-hero__in{grid-template-columns:1fr;gap:28px;padding:42px 0 36px}
  .cs-hero__media{order:-1;max-width:330px}
  .cs-anchor__grid,.cs-story,.cs-dt{grid-template-columns:1fr;gap:22px}
  .cs-nums{grid-template-columns:repeat(2,1fr)}
  .cs-stages{grid-template-columns:1fr 1fr}
  .cs-books{grid-template-columns:repeat(3,1fr)}
  .cs-fb{grid-template-columns:1fr 1fr}
}
@media (max-width:520px){
  .cs-sec{padding:50px 0}
  .cs-nums,.cs-stages,.cs-fb{grid-template-columns:1fr 1fr}
  .cs-books{grid-template-columns:repeat(3,1fr)}
  .cs-hero h1{font-size:29px}
}
