/*
Theme Name: Andrea Oldano — L'Umano Selvatico v4
Version: 4.0
Text Domain: oldano
*/

@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,500;0,700;1,400;1,500&family=DM+Sans:wght@300;400;500&display=swap');

:root {
  --verde:        #2D5A27;
  --verde-scuro:  #1A3A16;
  --verde-m:      #3D7A35;
  --verde-chiaro: #EBF2E8;
  --verde-acc:    #9EC98A;
  --terra:        #AF4B2F;
  --terra-chiaro: #F5EAE6;
  --terra-scuro:  #7A3220;
  --crema:        #F7F4EE;
  --crema-scuro:  #EDE8DE;
  --antracite:    #2C2C2A;
  --grigio:       #6B6B68;
  --grigio-l:     #D5CFC4;
  --bianco:       #FFFFFF;
  --serif:        'Playfair Display', Georgia, serif;
  --sans:         'DM Sans', system-ui, sans-serif;
  --max:          1140px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:var(--sans);color:var(--antracite);background:var(--crema);-webkit-font-smoothing:antialiased;line-height:1.75;}
img{max-width:100%;height:auto;display:block;}
a{color:var(--verde);text-decoration:none;transition:color .2s;}
a:hover{color:var(--terra);}
ul{list-style:none;}
p{margin-bottom:1rem;}
h1,h2,h3,h4{font-family:var(--serif);font-weight:400;line-height:1.15;color:var(--verde-scuro);}
h1{font-size:clamp(2.4rem,5vw,3.8rem);}
h2{font-size:clamp(1.6rem,3vw,2.4rem);}
h3{font-size:1.25rem;}
.container{max-width:var(--max);margin:0 auto;padding:0 2rem;}
.label{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--grigio);font-family:var(--sans);font-weight:500;display:block;margin-bottom:1rem;}

/* BOTTONI */
.btn{display:inline-block;padding:.7rem 2rem;font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--sans);font-weight:500;cursor:pointer;transition:all .25s;border-radius:0;line-height:1;}
.btn-scuro{background:var(--antracite);color:var(--bianco);border:1.5px solid var(--antracite);}
.btn-scuro:hover{background:var(--verde-scuro);border-color:var(--verde-scuro);color:var(--bianco);}
.btn-outline{background:transparent;color:var(--antracite);border:1.5px solid var(--antracite);}
.btn-outline:hover{background:var(--antracite);color:var(--bianco);}
.btn-bianco{background:transparent;color:var(--bianco);border:1.5px solid rgba(255,255,255,.6);}
.btn-bianco:hover{background:rgba(255,255,255,.15);color:var(--bianco);}
.btn-terra{background:var(--terra);color:var(--bianco);border:1.5px solid var(--terra);}
.btn-terra:hover{background:var(--terra-scuro);border-color:var(--terra-scuro);color:var(--bianco);}

/* ── NAVBAR ─────────────────────────────────────────── */
/* Default: verde scuro — sempre leggibile, elegante, coerente con la palette */
#site-header{
  position:fixed;top:0;left:0;right:0;z-index:999;
  background:var(--verde-scuro);
  box-shadow:0 1px 24px rgba(0,0,0,.18);
  transition:background .4s,box-shadow .4s;
}
/* Sul hero: leggermente trasparente ma sempre scuro — mai invisibile */
#site-header.at-hero{
  background:rgba(26,58,22,.82);
  box-shadow:none;
  backdrop-filter:blur(8px);
  -webkit-backdrop-filter:blur(8px);
}
.nav-inner{
  display:flex;align-items:center;justify-content:space-between;
  padding:1rem 2rem;max-width:var(--max);margin:0 auto;
}
/* Logo — sempre bianco su sfondo verde */
.site-branding a{
  font-family:var(--serif);font-size:1rem;
  color:var(--bianco);letter-spacing:.02em;transition:color .3s;
}
.site-branding a em{font-style:italic;color:var(--verde-acc);}

/* Menu — sempre bianco su sfondo verde */
#primary-menu{display:flex;gap:2rem;}
#primary-menu li a{
  font-size:.73rem;color:rgba(255,255,255,.7);
  letter-spacing:.06em;text-transform:uppercase;font-weight:500;
  transition:color .2s;border-bottom:1.5px solid transparent;padding-bottom:2px;
}
#primary-menu li a:hover{color:var(--bianco);border-bottom-color:var(--verde-acc);}
#primary-menu li.current-menu-item a{color:var(--bianco);border-bottom-color:var(--terra);}

.menu-toggle{display:none;background:none;border:none;cursor:pointer;padding:.3rem;}
.menu-toggle span{display:block;width:22px;height:1.5px;background:rgba(255,255,255,.8);margin:5px 0;transition:all .3s;}

/* ── HERO ────────────────────────────────────────────── */
#hero{
  min-height:100vh;display:grid;
  grid-template-columns:1fr 1fr;
  position:relative;padding-top:60px;/* compensa navbar fissa */
}
.hero-left{
  background:var(--verde-scuro);
  padding:5rem 4rem 5rem;
  display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;overflow:hidden;min-height:calc(100vh - 60px);
}
.hero-left::after{
  content:'';position:absolute;bottom:-120px;right:-120px;
  width:400px;height:400px;border-radius:50%;
  border:1px solid rgba(255,255,255,.06);pointer-events:none;
}
.hero-foto{
  position:relative;overflow:hidden;
  background:var(--crema-scuro);min-height:calc(100vh - 60px);
}
.hero-foto img{width:100%;height:100%;object-fit:cover;object-position:center top;}
.hero-foto-placeholder{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;text-align:center;
  font-size:.75rem;color:var(--grigio);
}
.hero-eyebrow{
  font-size:.7rem;letter-spacing:.14em;text-transform:uppercase;
  color:rgba(255,255,255,.45);margin-bottom:1.5rem;
}
.hero-title{
  font-family:var(--serif);font-size:clamp(2.2rem,3.5vw,3.4rem);
  color:var(--bianco);line-height:1.1;font-weight:400;margin-bottom:1.2rem;
}
.hero-title em{color:var(--verde-acc);font-style:italic;}
.hero-sub{
  font-family:var(--serif);font-size:1rem;
  color:rgba(255,255,255,.6);font-style:italic;
  line-height:1.65;margin-bottom:2.5rem;max-width:400px;
}
.hero-scroll{
  position:absolute;bottom:2rem;left:25%;transform:translateX(-50%);
  display:flex;flex-direction:column;align-items:center;gap:.5rem;
  color:rgba(255,255,255,.35);font-size:.65rem;letter-spacing:.1em;
  text-transform:uppercase;cursor:pointer;
}
.hero-scroll-line{
  width:1px;height:40px;background:rgba(255,255,255,.25);
  animation:scrollpulse 2s ease-in-out infinite;
}
@keyframes scrollpulse{0%,100%{opacity:.3}50%{opacity:.9}}

/* ── IDENTIFICAZIONE ─────────────────────────────────── */
#identificazione{padding:7rem 2rem;background:var(--crema);}
.identificazione-inner{max-width:780px;margin:0 auto;text-align:center;}
#identificazione h2{font-size:clamp(1.8rem,3.5vw,2.8rem);color:var(--antracite);margin-bottom:1.5rem;font-weight:400;}
#identificazione h2 em{color:var(--terra);font-style:italic;}
#identificazione p{font-size:1.05rem;color:var(--grigio);line-height:1.85;margin-bottom:1.2rem;text-align:justify;}
.id-cta{margin-top:2.5rem;display:flex;gap:1rem;justify-content:center;flex-wrap:wrap;}

/* ── LEAD MAGNET ─────────────────────────────────────── */
#manifesto-band{background:var(--terra);padding:5rem 2rem;}
.lead-inner{max-width:680px;margin:0 auto;text-align:center;}
#manifesto-band .label{color:rgba(255,255,255,.5);}
#manifesto-band h2{color:var(--bianco);font-size:clamp(1.5rem,3vw,2rem);margin-bottom:.8rem;}
#manifesto-band p{color:rgba(255,255,255,.8);font-size:.95rem;line-height:1.7;margin-bottom:1.8rem;}
.lead-form{display:flex;gap:.8rem;justify-content:center;flex-wrap:wrap;}
.lead-input{padding:.7rem 1.2rem;border:1.5px solid rgba(255,255,255,.4);background:rgba(255,255,255,.12);color:var(--bianco);font-family:var(--sans);font-size:.9rem;width:280px;outline:none;border-radius:0;}
.lead-input::placeholder{color:rgba(255,255,255,.55);}
.lead-input:focus{border-color:rgba(255,255,255,.9);background:rgba(255,255,255,.2);}
.lead-nota{font-size:.72rem;color:rgba(255,255,255,.45);margin-top:1rem;}

/* ── TRE PERCORSI ────────────────────────────────────── */
#percorsi{background:var(--bianco);padding:7rem 2rem;}
.percorsi-header{text-align:center;margin-bottom:4rem;}
.percorsi-header h2{margin-bottom:.6rem;}
.percorsi-header p{color:var(--grigio);max-width:520px;margin:0 auto;font-size:.95rem;}
.percorsi-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  border-top:1px solid var(--grigio-l);border-left:1px solid var(--grigio-l);
}
.percorso{
  padding:3rem 2.5rem;
  border-right:1px solid var(--grigio-l);border-bottom:1px solid var(--grigio-l);
  transition:background .3s;
}
.percorso:hover{background:var(--crema);}
.percorso-num{font-family:var(--serif);font-size:3rem;color:var(--grigio-l);line-height:1;margin-bottom:1rem;}
.percorso h3{font-family:var(--serif);font-size:1.4rem;color:var(--antracite);margin-bottom:1rem;font-weight:400;}
.percorso p{font-size:.9rem;color:var(--grigio);line-height:1.7;margin-bottom:1.2rem;}
.percorso-tag{font-size:.7rem;letter-spacing:.08em;text-transform:uppercase;color:var(--terra);font-weight:500;}
.percorsi-cta{text-align:center;margin-top:3rem;}

/* ── BIO ─────────────────────────────────────────────── */
#bio{background:var(--crema-scuro);padding:7rem 2rem;}
.bio-grid{display:grid;grid-template-columns:1fr 1.4fr;gap:5rem;align-items:start;max-width:var(--max);margin:0 auto;}
.bio-foto-wrap{position:relative;}
.bio-foto-placeholder{aspect-ratio:3/4;background:var(--crema);border:.5px solid var(--grigio-l);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:2rem;font-size:.75rem;color:var(--grigio);}
.bio-tag{position:absolute;bottom:-1rem;right:-1rem;background:var(--terra);color:var(--bianco);padding:.5rem 1.2rem;font-size:.72rem;letter-spacing:.08em;text-transform:uppercase;font-family:var(--sans);font-weight:500;}
.bio-testo .label{margin-bottom:1.5rem;}
.bio-testo h2{margin-bottom:1.5rem;}
.bio-testo p{font-size:.95rem;line-height:1.85;color:var(--antracite);text-align:justify;}
.bio-credenziali{margin-top:2rem;display:flex;flex-direction:column;gap:.5rem;}
.bio-cred{font-size:.85rem;color:var(--grigio);display:flex;gap:.8rem;align-items:baseline;}
.bio-cred::before{content:'—';color:var(--terra);flex-shrink:0;}
.bio-cta{margin-top:2rem;display:flex;gap:1rem;flex-wrap:wrap;}

/* ── MANIFESTO SEZIONE ───────────────────────────────── */
#manifesto{background:var(--verde-scuro);padding:8rem 2rem;}
.manifesto-inner{max-width:860px;margin:0 auto;}
#manifesto .label{color:rgba(255,255,255,.35);border-bottom:.5px solid rgba(255,255,255,.1);padding-bottom:.6rem;margin-bottom:2rem;}
.manifesto-fulcro{font-family:var(--serif);font-size:clamp(2.4rem,5vw,4.2rem);color:var(--bianco);line-height:1.25;font-weight:400;font-style:italic;margin-bottom:2.5rem;letter-spacing:-.02em;}
.manifesto-fulcro strong{color:var(--verde-acc);font-weight:400;}
#manifesto > .manifesto-inner > p{color:rgba(255,255,255,.65);font-size:.95rem;line-height:1.8;margin-bottom:2rem;text-align:justify;}
.manifesto-cta{display:flex;gap:1rem;flex-wrap:wrap;}

/* ── LIBRI ───────────────────────────────────────────── */
#libri{background:var(--bianco);padding:7rem 2rem;}
.libri-header{text-align:center;margin-bottom:4rem;}
.libro-card{display:grid;grid-template-columns:200px 1fr;gap:4rem;align-items:start;max-width:900px;margin:0 auto 5rem;}
.libro-cover{aspect-ratio:2/3;background:var(--crema-scuro);border:.5px solid var(--grigio-l);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem;font-size:.7rem;color:var(--grigio);}
.libro-cover img{width:100%;height:100%;object-fit:cover;}
.libro-tag-small{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);font-weight:500;display:block;margin-bottom:.6rem;}
.libro-testo h3{font-family:var(--serif);font-size:1.8rem;color:var(--verde-scuro);margin-bottom:.3rem;font-weight:400;}
.libro-editore{font-size:.8rem;color:var(--grigio);margin-bottom:1.5rem;line-height:1.6;}
.libro-testo p{font-size:.95rem;line-height:1.85;text-align:justify;}
.libro-citazione{border-left:2px solid var(--terra);padding:.8rem 1.4rem;margin:1.5rem 0;font-family:var(--serif);font-size:1.05rem;font-style:italic;color:var(--antracite);line-height:1.6;}
.libro-per-chi{font-size:.85rem;color:var(--grigio);font-style:italic;margin-top:1.2rem;padding-top:1.2rem;border-top:.5px solid var(--grigio-l);}

/* ── RISULTATI ───────────────────────────────────────── */
#risultati{background:var(--crema);padding:7rem 2rem;}
.risultati-header{text-align:center;margin-bottom:4rem;}
.risultati-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;max-width:var(--max);margin:0 auto;}
.risultato-num{font-family:var(--serif);font-size:4rem;color:var(--grigio-l);line-height:1;margin-bottom:.8rem;}
.risultato-titolo{font-family:var(--serif);font-size:1.1rem;color:var(--antracite);margin-bottom:.8rem;}
.risultato-testo{font-size:.88rem;color:var(--grigio);line-height:1.7;text-align:justify;}

/* ── GALLERY ─────────────────────────────────────────── */
#gallery{display:grid;grid-template-columns:repeat(4,1fr);}
.gallery-cell{aspect-ratio:1;background:var(--crema-scuro);overflow:hidden;position:relative;}
.gallery-cell img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.gallery-cell:hover img{transform:scale(1.04);}
.gallery-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:1rem;font-size:.7rem;color:var(--grigio);border:.5px dashed var(--grigio-l);}

/* ── CTA FINALE ──────────────────────────────────────── */
#cta-finale{background:var(--crema-scuro);padding:7rem 2rem;text-align:center;}
#cta-finale h2{font-size:clamp(1.8rem,3.5vw,2.8rem);margin-bottom:.8rem;}
#cta-finale h2 em{color:var(--terra);font-style:italic;}
#cta-finale p{color:var(--grigio);max-width:500px;margin:0 auto 2rem;font-size:.95rem;line-height:1.7;}

/* ── PAGINE INTERNE ──────────────────────────────────── */
.page-hero{background:var(--antracite);padding:7rem 2rem 4rem;margin-top:60px;}
.page-hero .pill{display:inline-block;background:rgba(255,255,255,.1);color:rgba(255,255,255,.6);font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;padding:.3rem .9rem;margin-bottom:1.2rem;}
.page-hero h1{color:var(--bianco);margin-bottom:.8rem;}
.page-hero .hero-sub{font-family:var(--serif);font-size:1.05rem;color:rgba(255,255,255,.5);font-style:italic;max-width:560px;}
.page-content{padding:5rem 2rem;background:var(--bianco);}
.page-content-inner{max-width:760px;margin:0 auto;}
.page-content h2{margin:2.5rem 0 1rem;}
.page-content h3{margin:2rem 0 .6rem;font-size:1rem;color:var(--terra);font-family:var(--sans);font-weight:500;letter-spacing:.06em;text-transform:uppercase;}
.page-content p{font-size:.95rem;line-height:1.85;text-align:justify;}
.page-content ul li{font-size:.95rem;line-height:1.7;padding-left:1.2rem;position:relative;margin-bottom:.4rem;}
.page-content ul li::before{content:'—';position:absolute;left:0;color:var(--terra);}

/* Scheda chi sono */
.chisono-grid{display:grid;grid-template-columns:280px 1fr;gap:5rem;align-items:start;padding:5rem 2rem;max-width:var(--max);margin:0 auto;}
.scheda-cred{background:var(--crema);padding:2rem;border-top:2px solid var(--terra);}
.scheda-cred h3{font-family:var(--sans);font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);font-weight:500;margin:1.5rem 0 .4rem;padding-top:1rem;border-top:.5px solid var(--grigio-l);}
.scheda-cred h3:first-child{margin-top:0;border-top:none;padding-top:0;}
.scheda-cred p{font-size:.85rem;color:var(--antracite);line-height:1.7;margin-bottom:0;}

/* Principi manifesto */
.principi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5px;margin-top:2rem;background:var(--grigio-l);}
.principio{background:var(--bianco);padding:2rem;}
.principio-num{font-size:.68rem;letter-spacing:.1em;text-transform:uppercase;color:var(--terra);font-weight:500;margin-bottom:.5rem;font-family:var(--sans);}
.principio h3{font-family:var(--serif);font-size:1.05rem;color:var(--antracite);margin-bottom:.6rem;}
.principio p{font-size:.85rem;color:var(--grigio);line-height:1.6;margin-bottom:0;}

/* Formazione */
.formazione-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5px;}
.formazione-card{background:var(--bianco);padding:2.5rem 2rem;border-top:2px solid var(--terra);transition:background .2s;}
.formazione-card:hover{background:var(--crema);}
.formazione-card h3{font-family:var(--serif);font-size:1.3rem;color:var(--antracite);margin-bottom:1rem;font-weight:400;}
.formazione-card p{font-size:.88rem;color:var(--grigio);line-height:1.65;margin-bottom:1rem;text-align:justify;}
.formazione-formati{font-size:.75rem;color:var(--terra);font-style:italic;}

/* Contatti */
.contatti-block{display:grid;grid-template-columns:1fr 1fr;gap:5rem;padding:5rem 2rem;max-width:var(--max);margin:0 auto;}
.contatti-testo p{font-size:.95rem;line-height:1.85;text-align:justify;}
.contatti-testo ul li{font-size:.9rem;color:var(--antracite);padding:.3rem 0 .3rem 1.2rem;position:relative;}
.contatti-testo ul li::before{content:'→';position:absolute;left:0;color:var(--terra);}
.form-field{width:100%;padding:.8rem 1rem;border:.5px solid var(--grigio-l);background:var(--crema);font-family:var(--sans);font-size:.9rem;color:var(--antracite);outline:none;transition:border-color .2s;border-radius:0;margin-bottom:.8rem;}
.form-field:focus{border-color:var(--terra);}
textarea.form-field{min-height:130px;resize:vertical;}
.form-submit{background:var(--antracite);color:var(--bianco);border:none;padding:.75rem 2rem;font-family:var(--sans);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;font-weight:500;cursor:pointer;transition:background .2s;}
.form-submit:hover{background:var(--terra);}

/* ── FOOTER ──────────────────────────────────────────── */
#site-footer{background:var(--antracite);padding:4rem 2rem 2rem;}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:3rem;max-width:var(--max);margin:0 auto;padding-bottom:3rem;border-bottom:.5px solid rgba(255,255,255,.1);}
.footer-logo{font-family:var(--serif);font-size:1.1rem;color:rgba(255,255,255,.85);margin-bottom:.6rem;}
.footer-logo em{color:var(--terra);font-style:italic;}
.footer-tagline{font-size:.82rem;color:rgba(255,255,255,.4);line-height:1.6;}
.footer-nav h4{font-family:var(--sans);font-size:.68rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:1rem;}
.footer-nav ul{display:flex;flex-direction:column;gap:.5rem;}
.footer-nav ul li a{font-size:.85rem;color:rgba(255,255,255,.5);transition:color .2s;}
.footer-nav ul li a:hover{color:var(--terra);}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:1.5rem;max-width:var(--max);margin:0 auto;font-size:.75rem;color:rgba(255,255,255,.25);}
.footer-bottom a{color:rgba(255,255,255,.25);}
.footer-bottom a:hover{color:rgba(255,255,255,.5);}

/* ── RESPONSIVE ──────────────────────────────────────── */
@media(max-width:960px){
  #hero{grid-template-columns:1fr;min-height:auto;padding-top:60px;}
  .hero-left{padding:4rem 2rem 4rem;min-height:70vh;}
  .hero-foto{min-height:50vw;}
  .hero-scroll{left:50%;}
  .percorsi-grid{grid-template-columns:1fr;}
  .bio-grid,.risultati-grid{grid-template-columns:1fr;gap:2.5rem;}
  #gallery{grid-template-columns:repeat(2,1fr);}
  .libro-card{grid-template-columns:1fr;gap:2rem;}
  .chisono-grid,.contatti-block{grid-template-columns:1fr;gap:2rem;}
  .formazione-grid{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:640px){
  .nav-inner{padding:.8rem 1.2rem;}
  #primary-menu{
    display:none;flex-direction:column;
    position:fixed;top:0;left:0;right:0;bottom:0;
    background:var(--antracite);
    padding:5rem 2rem;gap:1.5rem;
    justify-content:center;z-index:997;
  }
  #primary-menu.open{display:flex;}
  #primary-menu li a{font-size:1.2rem;color:rgba(255,255,255,.85);}
  .menu-toggle{display:block;z-index:998;position:relative;}
  .footer-grid{grid-template-columns:1fr;gap:2rem;}
  .footer-bottom{flex-direction:column;gap:.5rem;text-align:center;}
}

/* ══ RESPONSIVE PAGINE INTERNE ══════════════════════════ */
@media (max-width: 768px) {

  /* Chi sono */
  .chisono-grid {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
    padding: 3rem 1.2rem !important;
  }

  /* Formazione — tre card in colonna */
  .formazione-grid {
    grid-template-columns: 1fr !important;
  }
  .formazione-card {
    padding: 1.5rem 1.2rem !important;
  }

  /* Formazione — card percorsi interni */
  .container > div[style*="grid-template-columns:1fr 2fr"] {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }

  /* Principi manifesto */
  .principi-grid {
    grid-template-columns: 1fr !important;
  }

  /* Contatti */
  .contatti-block {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
    padding: 3rem 1.2rem !important;
  }

  /* Libri pagina interna */
  .libro-detail-inner {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }

  /* Hero pagine interne */
  .page-hero {
    padding: 5rem 1.2rem 3rem !important;
    margin-top: 60px !important;
  }
  .page-hero h1 {
    font-size: clamp(1.8rem, 7vw, 2.8rem) !important;
  }

  /* Sezione Sabrina e griglie inline */
  div[style*="grid-template-columns:1fr 1fr"],
  div[style*="grid-template-columns:1fr 1.4fr"],
  div[style*="grid-template-columns:1fr 2fr"],
  div[style*="grid-template-columns:280px 1fr"],
  div[style*="grid-template-columns:260px 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 2rem !important;
  }

  /* Foto griglia formazione */
  div[style*="grid-template-columns:repeat(3,1fr)"] {
    grid-template-columns: 1fr !important;
  }

  /* Padding container generici */
  .page-content {
    padding: 3rem 1.2rem !important;
  }
  .page-content-inner {
    max-width: 100% !important;
  }

  /* Bottoni affiancati — vanno in colonna */
  .manifesto-cta,
  .id-cta,
  .bio-cta {
    flex-direction: column !important;
    align-items: flex-start !important;
  }

  /* Libro card pagina I Libri */
  .libro-card {
    grid-template-columns: 1fr !important;
    gap: 1.5rem !important;
  }

  /* Copertina libro — non sticky su mobile */
  div[style*="position:sticky"] {
    position: relative !important;
    top: auto !important;
  }

}