/* Sgillano — Scuola d'italiano Hannover. Magazin-Stil, handgeschrieben. */
:root{
  --inchiostro:#2a1f1a; --crema:#fbf4ea; --sabbia:#f3e4d3; --linea:#e6d0b9;
  --terra:#c0492f; --terrascuro:#8a2f1c; --oliva:#6f7a45;
  --display:"Playfair Display",Georgia,serif;
  --testo:"Work Sans",system-ui,-apple-system,sans-serif;
  --raggio:14px; --largo:1140px;
  --ombra:0 2px 6px rgba(42,31,26,.06),0 14px 40px rgba(42,31,26,.08);
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--crema);color:var(--inchiostro);
  font-family:var(--testo);font-size:17px;line-height:1.66;-webkit-font-smoothing:antialiased}
img{max-width:100%;height:auto;display:block}
a{color:var(--terrascuro)}
h1,h2,h3{font-family:var(--display);font-weight:600;line-height:1.12;margin:0 0 .4em}
h1{font-size:clamp(2.3rem,6vw,4rem);font-weight:700}
h2{font-size:clamp(1.7rem,3.6vw,2.6rem)}
h3{font-size:1.3rem;font-weight:600}
p{margin:0 0 1rem}
.guscio{width:100%;max-width:var(--largo);margin-inline:auto;padding-inline:clamp(1.1rem,4vw,2.2rem)}
.fascia{padding-block:clamp(3rem,7vw,5.5rem)}
.fascia--crema{background:var(--sabbia)}
.occhiello{font-family:var(--testo);font-weight:600;font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--oliva);margin:0 0 1rem}
.sommario{font-size:1.18rem;color:color-mix(in srgb,var(--inchiostro) 80%,transparent)}
.tenue{color:color-mix(in srgb,var(--inchiostro) 60%,transparent)}

/* bottoni */
.bottone{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--testo);font-weight:600;font-size:1rem;
  border-radius:999px;padding:.8rem 1.7rem;border:1.5px solid transparent;cursor:pointer;text-decoration:none;transition:.15s}
.bottone--pieno{background:var(--terra);color:var(--crema)}
.bottone--pieno:hover{background:var(--terrascuro);transform:translateY(-2px)}
.bottone--filo{background:transparent;color:var(--inchiostro);border-color:var(--inchiostro)}
.bottone--filo:hover{background:var(--inchiostro);color:var(--crema)}

/* testata */
.testata{position:sticky;top:0;z-index:50;background:color-mix(in srgb,var(--crema) 86%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-bottom:1px solid var(--linea)}
.barra{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding-block:1rem}
.marchio{display:flex;flex-direction:column;line-height:1;color:var(--inchiostro);text-decoration:none}
.marchio b{font-family:var(--display);font-weight:700;font-size:1.55rem}
.marchio i{font-style:italic;font-family:var(--display);font-size:.78rem;color:var(--oliva)}
.leva{display:inline-flex;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:.4rem}
.leva span{width:24px;height:2px;background:var(--inchiostro);border-radius:2px}
.navi{list-style:none;display:none;margin:0;padding:0}
.navevoce{display:block;text-decoration:none;color:var(--inchiostro);font-weight:500;padding:.55rem 0;border-bottom:1px solid var(--linea)}
.navevoce.attiva,.navevoce:hover{color:var(--terrascuro)}
.barra.aperto .navi{display:block;position:absolute;left:0;right:0;top:100%;background:var(--crema);border-bottom:1px solid var(--linea);padding:.4rem clamp(1.1rem,4vw,2.2rem) 1rem}
.barra .navi-cta{display:none}

/* apertura / hero — asimmetrico */
.apertura{padding-block:clamp(2rem,5vw,3.5rem)}
.apertura__griglia{display:grid;gap:clamp(1.5rem,4vw,2.5rem);align-items:center}
.apertura__foto{position:relative}
.apertura__foto img{width:100%;border-radius:var(--raggio);box-shadow:var(--ombra)}
.apertura__foto::before{content:"";position:absolute;inset:14px -14px -14px 14px;border:2px solid var(--terra);border-radius:var(--raggio);z-index:-1}
.apertura__atti{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:1.6rem}

/* offerte — schede magazine */
.offerte{display:grid;gap:clamp(1rem,3vw,1.6rem);margin-top:2.2rem}
.scheda{background:var(--crema);border:1px solid var(--linea);border-radius:var(--raggio);padding:1.6rem;position:relative;transition:.18s}
.fascia--crema .scheda{background:var(--crema)}
.scheda:hover{transform:translateY(-3px);box-shadow:var(--ombra);border-color:color-mix(in srgb,var(--terra) 45%,var(--linea))}
.scheda__n{font-family:var(--display);font-style:italic;font-size:1.6rem;color:var(--terra)}
.scheda h3{margin:.3rem 0 .4rem}
.scheda p{margin:0;font-size:.96rem;color:color-mix(in srgb,var(--inchiostro) 76%,transparent)}

/* passi — process */
.passi{display:grid;gap:1.2rem;margin-top:2.2rem;counter-reset:p}
.passo{background:var(--crema);border:1px solid var(--linea);border-radius:var(--raggio);padding:1.5rem;border-top:4px solid var(--oliva)}
.passo::before{counter-increment:p;content:"0" counter(p);font-family:var(--display);font-style:italic;font-size:1.3rem;color:var(--oliva)}
.passo h3{margin:.3rem 0}
.passo p{margin:0;font-size:.95rem;color:color-mix(in srgb,var(--inchiostro) 76%,transparent)}

/* voci — testimonials */
.voci{display:grid;gap:1.2rem;margin-top:2.2rem}
.voce{background:var(--crema);border:1px solid var(--linea);border-radius:var(--raggio);padding:1.7rem}
.voce blockquote{margin:0;font-family:var(--display);font-style:italic;font-size:1.2rem;line-height:1.4}
.voce cite{display:block;margin-top:1rem;font-style:normal;font-size:.86rem;color:var(--oliva)}
.voce cite b{color:var(--inchiostro);font-family:var(--testo)}

/* domande — faq */
.domande{margin-top:1.6rem;max-width:760px}
.domande details{border-bottom:1px solid var(--linea);padding:1.1rem 0}
.domande summary{cursor:pointer;list-style:none;display:flex;justify-content:space-between;gap:1rem;font-family:var(--display);font-size:1.2rem}
.domande summary::-webkit-details-marker{display:none}
.domande summary::after{content:"+";color:var(--terra)}
.domande details[open] summary::after{content:"\2013"}
.domande details p{margin:.7rem 0 0;color:color-mix(in srgb,var(--inchiostro) 78%,transparent)}

/* invito — cta */
.invito{background:var(--terra);color:var(--crema);border-radius:var(--raggio);padding:clamp(2rem,5vw,3.2rem);text-align:center}
.invito h2{color:var(--crema)}
.invito p{color:color-mix(in srgb,#fff 84%,transparent);max-width:46ch;margin-inline:auto}
.invito .bottone--pieno{background:var(--crema);color:var(--terrascuro)}
.invito .bottone--pieno:hover{background:var(--inchiostro);color:var(--crema)}

/* testata-pagina + briciole */
.testata-pagina{padding-block:clamp(1.8rem,4vw,2.6rem)}
.briciole{font-size:.82rem;color:var(--oliva)}
.briciole a{color:inherit;text-decoration:none}
.guida{font-size:1.15rem;color:color-mix(in srgb,var(--inchiostro) 80%,transparent);max-width:60ch}

/* dettaglio (corsi) */
.dettaglio{display:grid;gap:1rem;padding-block:1.8rem;border-bottom:1px solid var(--linea)}
.dettaglio:last-child{border-bottom:0}
.dettaglio__n{font-family:var(--display);font-style:italic;font-size:1.8rem;color:var(--terra)}
.dettaglio .occhiello{color:var(--terrascuro);margin-bottom:.4rem}

/* listino — pricing */
.listino{display:grid;gap:1.2rem;margin-top:2.2rem}
.piano{background:var(--crema);border:1px solid var(--linea);border-radius:var(--raggio);padding:1.8rem;display:flex;flex-direction:column}
.piano--clou{border-color:var(--terra);box-shadow:var(--ombra)}
.piano__prezzo{font-family:var(--display);font-size:2.3rem;margin:.3rem 0}
.piano__prezzo small{font-family:var(--testo);font-size:.85rem;color:var(--tenue);color:color-mix(in srgb,var(--inchiostro) 60%,transparent)}
.etichetta{align-self:flex-start;font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;background:color-mix(in srgb,var(--oliva) 20%,var(--crema));color:var(--oliva);padding:.25rem .6rem;border-radius:999px;margin-bottom:.5rem}
.piano ul{list-style:none;margin:1rem 0 1.4rem;padding:0;display:grid;gap:.5rem}
.piano li{position:relative;padding-left:1.4rem;font-size:.94rem}
.piano li::before{content:"\2022";position:absolute;left:0;color:var(--terra);font-size:1.2rem;line-height:1}
.piano .bottone{margin-top:auto}
.tabella{width:100%;border-collapse:collapse;margin-top:1rem;border:1px solid var(--linea);border-radius:var(--raggio);overflow:hidden}
.tabella th,.tabella td{text-align:left;padding:.85rem 1.1rem;border-bottom:1px solid var(--linea)}
.tabella th{background:var(--sabbia);font-weight:600}
.tabella td:last-child,.tabella th:last-child{text-align:right;white-space:nowrap}
.tabella tr:last-child td{border-bottom:0}
.minuto{font-size:.8rem;color:color-mix(in srgb,var(--inchiostro) 56%,transparent);margin-top:1rem}

/* cifre — stats */
.cifre{display:grid;gap:1.2rem;margin-top:2.2rem}
.cifra{text-align:center;background:var(--crema);border:1px solid var(--linea);border-radius:var(--raggio);padding:1.5rem}
.cifra b{display:block;font-family:var(--display);font-size:2rem;color:var(--terrascuro)}
.cifra span{font-size:.9rem;color:var(--oliva)}

/* about */
.ritratto{display:grid;gap:2rem;align-items:start}
.ritratto img{width:100%;border-radius:var(--raggio);box-shadow:var(--ombra)}
.ritratto figcaption{font-size:.86rem;color:var(--oliva);margin-top:.6rem}
.racconto{max-width:62ch}.racconto p{font-size:1.05rem}

/* contatto */
.contatto{display:grid;gap:2rem}
.contatto-lista{list-style:none;margin:0;padding:0;display:grid;gap:1.1rem}
.contatto-lista li{display:grid;gap:.15rem}
.contatto-lista .k{font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--oliva)}
.contatto-lista a{color:var(--inchiostro);text-decoration:none}
.campo{margin-bottom:1.1rem}
.coppia{display:grid;gap:1.1rem}
label{display:block;font-weight:500;font-size:.88rem;margin-bottom:.35rem}
input,textarea{width:100%;font:inherit;font-size:1rem;color:var(--inchiostro);background:var(--crema);border:1.5px solid var(--linea);border-radius:10px;padding:.7rem .85rem}
input:focus,textarea:focus{outline:none;border-color:var(--terra);box-shadow:0 0 0 3px color-mix(in srgb,var(--terra) 20%,transparent)}
textarea{min-height:130px;resize:vertical}
.consenso{display:flex;gap:.6rem;align-items:flex-start;font-size:.9rem}
.consenso input{width:auto;margin-top:.25rem}
.avviso{padding:.9rem 1.1rem;border-radius:10px;font-size:.95rem;margin-top:1rem;border:1px solid var(--linea)}
.avviso--ok{background:color-mix(in srgb,var(--oliva) 18%,var(--crema));border-color:var(--oliva)}
.avviso--bad{background:color-mix(in srgb,#b3392b 12%,var(--crema));border-color:#b3392b}
.nascosto{display:none}

/* prosa */
.prosa{max-width:70ch}
.prosa h2{margin-top:2.2rem}.prosa h3{margin-top:1.6rem;font-size:1.1rem}
.prosa ul{padding-left:1.2rem}.prosa li{margin-bottom:.4rem}
.prosa address{font-style:normal}

/* piede */
.piede{background:var(--inchiostro);color:color-mix(in srgb,var(--crema) 86%,transparent);padding-block:clamp(2.5rem,5vw,3.5rem) 1.5rem;margin-top:clamp(3rem,6vw,5rem)}
.piede__griglia{display:grid;gap:1.8rem}
.piede h4{color:var(--crema);font-family:var(--display);margin:0 0 .7rem}
.piede a{color:color-mix(in srgb,var(--crema) 86%,transparent);text-decoration:none}
.piede a:hover{color:var(--crema)}
.piede ul{list-style:none;margin:0;padding:0;display:grid;gap:.45rem;font-size:.94rem}
.piede__marchio{font-family:var(--display);font-weight:700;font-size:1.4rem;color:var(--crema)}
.piede__base{margin-top:1.8rem;padding-top:1.1rem;border-top:1px solid color-mix(in srgb,var(--crema) 18%,transparent);font-size:.8rem;color:color-mix(in srgb,var(--crema) 60%,transparent);display:flex;flex-wrap:wrap;gap:.4rem 1.4rem;justify-content:space-between}

/* cookie */
.banner-cookie{position:fixed;left:1rem;right:1rem;bottom:1rem;z-index:80;max-width:540px;margin-inline:auto;background:var(--inchiostro);color:var(--crema);border-radius:var(--raggio);padding:1.2rem 1.3rem;box-shadow:0 14px 40px rgba(0,0,0,.25);transform:translateY(160%);transition:transform .4s ease;visibility:hidden}
.banner-cookie.su{transform:translateY(0);visibility:visible}
.banner-cookie p{margin:0 0 .9rem;font-size:.9rem;color:color-mix(in srgb,var(--crema) 86%,transparent)}
.banner-cookie a{color:var(--crema)}
.banner-cookie__atti{display:flex;flex-wrap:wrap;gap:.6rem}
.banner-cookie .bottone{padding:.55rem 1.1rem;font-size:.88rem}
.banner-cookie .bottone--filo{color:var(--crema);border-color:color-mix(in srgb,var(--crema) 45%,transparent)}
.banner-cookie .bottone--filo:hover{background:var(--crema);color:var(--inchiostro)}
.banner-cookie .bottone--pieno{background:var(--crema);color:var(--inchiostro)}

@media(min-width:780px){
  .leva{display:none}
  .navi{display:flex !important;position:static !important;gap:1.7rem;border:0 !important;padding:0 !important;background:transparent !important}
  .navevoce{border:0;padding:0}
  .barra .navi-cta{display:inline-flex}
  .apertura__griglia{grid-template-columns:1.1fr .9fr}
  .offerte{grid-template-columns:repeat(3,1fr)}
  .passi{grid-template-columns:repeat(2,1fr)}
  .voci{grid-template-columns:repeat(3,1fr)}
  .listino{grid-template-columns:repeat(3,1fr)}
  .cifre{grid-template-columns:repeat(4,1fr)}
  .ritratto{grid-template-columns:300px 1fr;gap:3rem}
  .contatto{grid-template-columns:.85fr 1.15fr}
  .piede__griglia{grid-template-columns:1.5fr 1fr 1fr 1fr}
  .coppia{grid-template-columns:1fr 1fr}
}
@media(min-width:1024px){.passi{grid-template-columns:repeat(4,1fr)}}
@media(prefers-reduced-motion:reduce){*{transition:none!important;scroll-behavior:auto}}
