/* =========================================================
   Allevi Sposo — Landing page
   Identità: neutra (bianco/crema + nero) con accento caldo taupe.
   Tipografia: Inter (titoli + corpo), Oswald solo per il logo.
   ========================================================= */
:root{
  --ink:#1a1714;        /* testo / nero caldo */
  --black:#141210;      /* bottoni, footer, bande scure */
  --paper:#ffffff;
  --cream:#f5f1ea;      /* sezioni alternate */
  --cream-2:#efe9df;
  --accent:#a98c74;     /* taupe caldo */
  --accent-dark:#85694f;/* taupe per testo su chiaro */
  --line:#e7e0d5;
  --muted:#7a736a;
  --shadow:0 22px 60px -28px rgba(26,23,20,.34);
  --radius:14px;
  --maxw:1140px;
  --sans:"Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  --display:"Oswald", "Inter", sans-serif;
}

*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:86px}
body{
  margin:0;
  font-family:var(--sans);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block}
a{color:inherit}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 clamp(18px,4vw,34px)}
.section{padding:clamp(58px,8vw,112px) 0}
.center{text-align:center}

h1,h2,h3{font-family:var(--sans);font-weight:600;line-height:1.14;letter-spacing:-.02em;margin:0}
h1{font-size:clamp(2.1rem,5vw,3.6rem);font-weight:600}
h2{font-size:clamp(1.7rem,3.3vw,2.6rem)}
h3{font-size:1.22rem;font-weight:600}
em{font-style:italic;color:var(--accent-dark);font-weight:500}
p{margin:0 0 1rem}

.eyebrow{
  font-family:var(--sans);text-transform:uppercase;letter-spacing:.22em;
  font-size:.74rem;font-weight:600;color:var(--accent-dark);margin:0 0 .7rem
}
.eyebrow.light{color:var(--accent)}

/* ---------- Skip link / a11y ---------- */
.skip-link{
  position:absolute;left:-999px;top:0;background:var(--black);color:#fff;
  padding:12px 18px;z-index:200;border-radius:0 0 8px 0
}
.skip-link:focus{left:0}
:focus-visible{outline:3px solid var(--accent);outline-offset:2px}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  font-family:var(--sans);font-weight:600;font-size:1rem;text-decoration:none;
  padding:.9rem 1.6rem;border-radius:999px;border:1.5px solid transparent;
  cursor:pointer;transition:transform .15s ease, box-shadow .2s ease, background .2s ease, color .2s ease;
  white-space:nowrap;letter-spacing:.01em
}
.btn:hover{transform:translateY(-2px)}
.btn-primary{background:var(--black);color:#fff;box-shadow:0 14px 30px -16px rgba(20,18,16,.85)}
.btn-primary:hover{background:var(--accent-dark)}
.btn-outline{background:transparent;border-color:var(--ink);color:var(--ink)}
.btn-outline:hover{background:var(--ink);color:#fff}
.btn-lg{padding:1.05rem 2.1rem;font-size:1.06rem}
.btn-sm{padding:.55rem 1.1rem;font-size:.9rem}
.btn-block{width:100%}

/* ---------- Header ---------- */
.site-header{
  position:sticky;top:0;z-index:100;background:rgba(255,255,255,.9);
  backdrop-filter:blur(10px);border-bottom:1px solid var(--line)
}
.header-inner{display:flex;align-items:center;justify-content:space-between;height:72px}
.brand{display:flex;align-items:center;text-decoration:none}
.brand-logo{height:34px;width:auto;mix-blend-mode:multiply}
.header-actions{display:flex;align-items:center;gap:1.1rem}
.header-phone{display:inline-flex;align-items:center;gap:.4rem;text-decoration:none;color:var(--ink);font-weight:600;font-size:.95rem}
.header-phone:hover{color:var(--accent-dark)}

/* ---------- Hero ---------- */
.hero{background:linear-gradient(180deg,var(--cream),#fff);overflow:hidden}
.hero-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(28px,5vw,68px);align-items:center;padding-block:clamp(40px,6vw,88px)}
.pre-headline{display:inline-block;background:#fff;border:1px solid var(--line);color:var(--ink);font-weight:500;font-size:.8rem;letter-spacing:.04em;padding:.4rem .95rem;border-radius:999px;margin-bottom:1.2rem}
.hero-sub{font-size:1.12rem;color:#43403a;max-width:36ch}
.hero-bullets{list-style:none;padding:0;margin:1.4rem 0 1.9rem;display:grid;gap:.6rem}
.hero-bullets li{position:relative;padding-left:1.8rem;font-weight:400}
.hero-bullets li::before{content:"—";position:absolute;left:0;top:0;color:var(--accent-dark);font-weight:700}
.hero-cta{display:flex;flex-direction:column;gap:1.1rem;align-items:flex-start}
.hero-rating{display:flex;align-items:center;gap:.55rem;font-size:.95rem;color:var(--muted)}
.stars{color:var(--accent);letter-spacing:2px}
.hero-media{position:relative;margin:0}
.hero-media img{width:100%;height:auto;border-radius:var(--radius);box-shadow:var(--shadow);object-fit:cover;aspect-ratio:4/5}
.hero-badge{position:absolute;left:-14px;bottom:26px;background:#fff;color:var(--ink);padding:.85rem 1.15rem;border-radius:10px;box-shadow:var(--shadow);font-size:.82rem;display:flex;flex-direction:column;line-height:1.25;border:1px solid var(--line)}
.hero-badge-title{font-family:var(--display);text-transform:uppercase;letter-spacing:.06em;font-size:1.05rem;color:var(--ink)}
/* fallback se manca un'immagine */
.img-fallback img{display:none}
.img-fallback{background:var(--cream-2);border-radius:var(--radius);min-height:420px;display:grid;place-items:center}
.img-fallback::after{content:"ALLEVI SPOSO";font-family:var(--display);letter-spacing:.18em;color:var(--accent-dark);opacity:.7}

/* ---------- Trust bar ---------- */
.trustbar{background:var(--cream);border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.trustbar-inner{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;padding:1.6rem 0;text-align:center}
.trust-item{display:flex;flex-direction:column;gap:.15rem}
.trust-item strong{font-family:var(--display);font-weight:500;text-transform:uppercase;letter-spacing:.04em;font-size:1.25rem;color:var(--ink)}
.trust-item span{font-size:.84rem;color:var(--muted)}

/* ---------- Benefits ---------- */
.benefits-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.4rem}
.benefit{background:#fff;border:1px solid var(--line);border-radius:var(--radius);padding:1.9rem}
.benefit-icon{width:52px;height:52px;border-radius:50%;display:grid;place-items:center;background:var(--cream);border:1px solid var(--line);font-size:1.4rem;color:var(--accent-dark);margin-bottom:1rem}
.benefit h3{margin-bottom:.5rem}
.benefit p{color:#4a463f;margin:0}

/* ---------- Mechanism ---------- */
.mechanism{background:var(--cream)}
.mechanism-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(28px,5vw,68px);align-items:center}
.mechanism-media img{border-radius:var(--radius);box-shadow:var(--shadow);aspect-ratio:4/3;object-fit:cover;width:100%}
.mechanism-media.img-fallback{min-height:360px}
.mechanism-quote{font-family:var(--sans);font-size:1.4rem;font-style:italic;font-weight:500;color:var(--ink);border-left:2px solid var(--accent);padding-left:1.1rem;margin-top:1.6rem;line-height:1.4}

/* ---------- Catalog preview ---------- */
.preview-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.2rem;margin:2.4rem 0}
.preview-card{border:1px solid var(--line);border-radius:var(--radius);padding:1.6rem;background:#fff}
.preview-n{font-family:var(--display);font-weight:500;font-size:1.5rem;color:var(--accent-dark)}
.preview-card h3{margin:.5rem 0 .4rem;font-size:1.12rem}
.preview-card p{color:var(--muted);margin:0;font-size:.95rem}

/* ---------- How it works ---------- */
.steps{list-style:none;padding:0;margin:2.4rem 0 0;display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
.step{position:relative;padding:1.9rem;border-radius:var(--radius);background:var(--cream);border:1px solid var(--line)}
.step-n{display:grid;place-items:center;width:46px;height:46px;border-radius:50%;background:var(--black);color:#fff;font-family:var(--display);font-weight:500;font-size:1.25rem;margin-bottom:.9rem}
.step h3{margin-bottom:.4rem}
.step p{margin:0;color:#4a463f}

/* ---------- Reviews ---------- */
.reviews{background:var(--black);color:#f3efe8}
.reviews .eyebrow{color:var(--accent)}
.reviews h2{color:#fff}
.reviews .rate{font-family:var(--display);font-weight:500;font-size:1.1rem;color:var(--accent);margin-left:.5rem}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem;margin-top:2.4rem}
.review{background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);border-radius:var(--radius);padding:1.7rem;margin:0}
.review .stars{font-size:1.05rem}
.review p{font-family:var(--sans);font-size:1.08rem;font-style:italic;margin:.7rem 0 1rem;color:#efeae2}
.review cite{font-style:normal;font-size:.88rem;color:#b8b2a8}

/* ---------- Catalog / form (banda full-bleed con foto) ---------- */
.catalog{position:relative;color:#fff;background:var(--black)}
.catalog::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(120deg, rgba(20,18,16,.92), rgba(20,18,16,.66)),
             var(--catalog-bg, none) center/cover no-repeat;
}
.catalog .container{position:relative;z-index:1}
.catalog-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:center}
.catalog-list{list-style:none;padding:0;margin:1.3rem 0;display:grid;gap:.5rem;color:#e7e2da}
.catalog-store{color:var(--accent);font-size:.95rem}
.catalog-form-wrap{background:#fff;color:var(--ink);border-radius:var(--radius);padding:clamp(20px,3vw,34px);box-shadow:var(--shadow)}
.form-title{margin-bottom:1rem}
.lead-form{display:grid;gap:.9rem}
.lead-form label{display:grid;gap:.35rem;font-weight:600;font-size:.9rem}
.lead-form input[type=text],.lead-form input[type=email],.lead-form input[type=tel]{
  font:inherit;padding:.82rem .9rem;border:1px solid var(--line);border-radius:9px;width:100%;background:#fff
}
.lead-form input:focus{border-color:var(--accent);outline:none}
.consent{display:flex;align-items:flex-start;gap:.5rem;font-weight:400;font-size:.84rem;color:var(--muted)}
.consent input{margin-top:.2rem}
.consent a{color:var(--accent-dark)}
.form-note{font-size:.78rem;color:var(--muted);margin:.4rem 0 0}

/* ---------- Store ---------- */
.store-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,56px);align-items:stretch}
.store-address{font-size:1.05rem}
.store-info{list-style:none;padding:0;margin:1rem 0;display:grid;gap:.4rem}
.store-info a{color:var(--accent-dark);text-decoration:none;font-weight:600}
.hours{border-collapse:collapse;margin:1rem 0;width:100%;max-width:380px}
.hours th,.hours td{text-align:left;padding:.5rem .6rem;border-bottom:1px solid var(--line);font-weight:500}
.hours th{color:var(--ink);font-weight:600}
.store-note{color:var(--muted);font-size:.9rem}
.store-map{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow);min-height:360px;border:1px solid var(--line)}
.store-map iframe{width:100%;height:100%;min-height:360px;border:0;display:block}

/* ---------- FAQ ---------- */
.faq-list{margin-top:2.2rem;max-width:800px}
.faq-list details{border-bottom:1px solid var(--line);padding:.4rem 0}
.faq-list summary{cursor:pointer;font-weight:600;padding:.85rem 0;list-style:none;font-size:1.05rem;display:flex;justify-content:space-between;gap:1rem}
.faq-list summary::after{content:"+";color:var(--accent-dark);font-size:1.3rem;line-height:1}
.faq-list details[open] summary::after{content:"–"}
.faq-list details p{color:#4a463f;margin:0 0 .9rem}

/* ---------- Final CTA (banda foto) ---------- */
.final-cta{position:relative;padding:clamp(64px,9vw,108px) 0;text-align:center;color:#fff;background:var(--black)}
.final-cta::before{
  content:"";position:absolute;inset:0;z-index:0;
  background:linear-gradient(rgba(20,18,16,.72), rgba(20,18,16,.72)),
             var(--final-bg, none) center/cover no-repeat;
}
.final-cta .container{position:relative;z-index:1}
.final-cta h2{color:#fff}
.final-cta p{color:#e7e2da;margin-bottom:1.7rem}

/* ---------- Footer (chiaro) ---------- */
.site-footer{background:var(--cream);color:#4a463f;font-size:.92rem;border-top:1px solid var(--line)}
.footer-inner{display:grid;grid-template-columns:2fr 1fr 1fr;gap:2rem;padding:3rem 0 1.6rem}
.footer-logo{height:30px;width:auto;margin-bottom:.7rem;mix-blend-mode:multiply}
.footer-brand p{margin:.4rem 0 0;color:var(--muted)}
.footer-group{color:var(--muted)}
.footer-col a{color:#4a463f;text-decoration:none}
.footer-col a:hover{color:var(--accent-dark)}
.footer-col p{margin:0 0 .5rem}
.footer-legal{border-top:1px solid var(--line);padding:1.3rem 0;color:var(--muted);font-size:.82rem}

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta{
  display:none;position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:90;
  text-align:center;background:var(--black);color:#fff;font-weight:600;
  text-decoration:none;padding:1rem;border-radius:999px;
  box-shadow:0 14px 32px -12px rgba(20,18,16,.9)
}

/* ---------- Cookie banner ---------- */
.cookie-banner{
  position:fixed;left:12px;right:12px;bottom:calc(12px + env(safe-area-inset-bottom));z-index:150;background:#fff;
  border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);
  padding:1rem 1.2rem;display:flex;align-items:center;gap:1.2rem;flex-wrap:wrap;justify-content:space-between
}
.cookie-banner[hidden]{display:none}
.cookie-text p{margin:0;font-size:.88rem;color:#4a463f;max-width:60ch}
.cookie-text a{color:var(--accent-dark)}
.cookie-actions{display:flex;gap:.6rem}

/* ---------- Responsive ---------- */
@media (max-width:900px){
  .hero-grid,.mechanism-grid,.catalog-grid,.store-grid{grid-template-columns:1fr}
  .hero-grid{gap:clamp(22px,5vw,36px)}
  .hero-copy{max-width:680px}
  .hero-media{max-width:520px}
  .mechanism-media{max-width:520px}
  .benefits-grid,.preview-grid,.steps,.reviews-grid{grid-template-columns:1fr 1fr}
  .trustbar-inner{grid-template-columns:1fr 1fr;gap:1.2rem}
  .footer-inner{grid-template-columns:1fr 1fr}
}
@media (max-width:600px){
  html{scroll-padding-top:72px}
  .container{padding-inline:18px}
  .section{padding:48px 0}
  h1{font-size:clamp(2rem,10vw,2.45rem);line-height:1.05}
  h2{font-size:clamp(1.55rem,7vw,2rem)}
  .btn{white-space:normal;text-align:center}
  .site-header{background:rgba(255,255,255,.94)}
  .header-inner{height:64px}
  .brand-logo{height:30px}
  .header-actions{gap:.6rem}
  .header-phone span{display:none}
  .header-phone{width:42px;height:42px;justify-content:center;border:1px solid var(--line);border-radius:50%;background:#fff}
  .header-actions .btn{padding:.55rem .85rem;font-size:.84rem;min-height:42px;max-width:158px;line-height:1.15}
  .hero{background:linear-gradient(180deg,var(--cream) 0%,#fff 88%)}
  .hero-grid{padding-block:24px 36px;gap:22px}
  .hero-copy{display:flex;flex-direction:column}
  .pre-headline{font-size:.72rem;line-height:1.25;letter-spacing:.02em;padding:.35rem .72rem;margin-bottom:.75rem;max-width:100%}
  .hero-sub{font-size:1rem;line-height:1.46;max-width:none;margin-top:.65rem;margin-bottom:.45rem}
  .hero-bullets{order:5;gap:.42rem;margin:.9rem 0 0}
  .hero-bullets li{padding-left:1.25rem;font-size:.93rem;line-height:1.42}
  .hero-cta{order:4;gap:.65rem;align-items:stretch}
  .hero-cta .btn{width:100%;min-height:54px;padding:.9rem 1rem;font-size:1rem;line-height:1.18}
  .hero-rating{gap:.45rem;align-items:flex-start;font-size:.82rem;line-height:1.35}
  .stars{letter-spacing:1px;line-height:1.35}
  .hero-media{max-width:none;margin-top:.15rem}
  .hero-media img{aspect-ratio:16/10;max-height:240px;object-position:center 30%;border-radius:12px}
  .hero-badge{left:10px;bottom:10px;padding:.58rem .78rem;border-radius:8px;font-size:.72rem}
  .hero-badge-title{font-size:.9rem}
  .trustbar-inner{padding:1rem 0;gap:.75rem}
  .trust-item strong{font-size:1rem}
  .trust-item span{font-size:.76rem;line-height:1.25}
  .benefits-grid,.preview-grid,.steps,.reviews-grid{gap:.9rem;margin-top:1.45rem}
  .benefit,.preview-card,.step,.review{padding:1.2rem;border-radius:12px}
  .benefit-icon{width:44px;height:44px;margin-bottom:.8rem}
  .catalog-grid{gap:1.4rem}
  .catalog-list{margin:1rem 0;gap:.45rem}
  .catalog-form-wrap{padding:18px;border-radius:12px}
  .lead-form{gap:.8rem}
  .lead-form input[type=text],.lead-form input[type=email],.lead-form input[type=tel]{min-height:48px;padding:.78rem .85rem}
  .lead-form .btn{min-height:52px}
  .store-map,.store-map iframe{min-height:300px}
  .benefits-grid,.preview-grid,.steps,.reviews-grid,.footer-inner{grid-template-columns:1fr}
  .sticky-cta{display:block}
  body.cookie-visible .sticky-cta,
  body.hero-visible .sticky-cta{display:none}
  .cookie-banner{flex-direction:column;align-items:stretch;gap:.55rem;padding:.68rem;border-radius:12px}
  .cookie-text p{font-size:.76rem;line-height:1.28}
  .cookie-actions{justify-content:stretch;gap:.5rem}
  .cookie-actions .btn{flex:1;min-height:36px;padding:.45rem .55rem;font-size:.78rem}
  body{padding-bottom:calc(84px + env(safe-area-inset-bottom))}
  body.cookie-visible{padding-bottom:0}
}

@media (max-width:360px){
  .container{padding-inline:16px}
  .header-actions .btn{max-width:128px;font-size:.8rem}
  h1{font-size:1.95rem}
  .hero-grid{padding-block:20px 32px}
  .hero-media img{max-height:205px}
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  .btn:hover{transform:none}
}

/* =========================================================
   Pagina contenuti riservati (/grazie)
   ========================================================= */
.reserved-hero{background:linear-gradient(180deg,var(--cream),#fff);padding-bottom:clamp(32px,5vw,56px)}
.reserved-lead{max-width:60ch;margin:1rem auto 0;color:#43403a;font-size:1.1rem}

.reserved-block{padding-top:clamp(28px,4vw,44px);padding-bottom:clamp(28px,4vw,44px)}
.reserved-catalog{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;
  border:1px solid var(--line);border-radius:var(--radius);background:var(--cream);
  padding:clamp(20px,3vw,32px)}
.reserved-catalog-icon{flex:0 0 auto;width:68px;height:68px;border-radius:50%;display:grid;
  place-items:center;background:#fff;border:1px solid var(--line);color:var(--accent-dark)}
.reserved-catalog-text{flex:1 1 220px}
.reserved-catalog-text h2{font-size:1.5rem}
.reserved-catalog-text p{margin:.3rem 0 0;color:var(--muted)}
.reserved-catalog .btn{flex:0 0 auto}

.reserved-vouchers{background:var(--cream);padding-top:clamp(40px,6vw,72px)}
.vouchers-total{font-family:var(--display);font-weight:500;color:var(--accent-dark);font-size:1.1rem;margin-left:.4rem}
.vouchers-intro{max-width:62ch;margin:.9rem auto 0;color:#43403a}
.vouchers-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin:2.2rem 0 1.4rem}
.voucher{margin:0;background:#fff;border:1px solid var(--line);border-radius:var(--radius);
  padding:.9rem;box-shadow:var(--shadow)}
.voucher img{border-radius:8px;width:100%;height:auto}
.voucher figcaption{margin-top:.7rem;font-size:.9rem;color:var(--muted);text-align:center}
.voucher-rules{max-width:74ch;margin:1rem auto 0;font-size:.9rem;color:#4a463f;
  background:#fff;border:1px solid var(--line);border-left:3px solid var(--accent);
  border-radius:10px;padding:1rem 1.2rem}
.vouchers-actions{display:flex;gap:.7rem;justify-content:center;flex-wrap:wrap;margin-top:1.8rem}

.reserved-next-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(28px,5vw,56px);align-items:center}
.reserved-next-cta{display:flex;gap:.7rem;flex-wrap:wrap;margin-top:1.2rem}
.reserved-store{background:var(--cream);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(20px,3vw,28px)}

@media (max-width:760px){
  .vouchers-grid,.reserved-next-grid{grid-template-columns:1fr}
  .reserved-catalog{flex-direction:column;align-items:flex-start;text-align:left}
  .reserved-catalog .btn{width:100%}
}

/* ---------- Stampa: solo i buoni + regolamento ---------- */
@media print{
  .no-print{display:none !important}
  body{background:#fff;padding:0}
  main, .section{padding:0 !important;margin:0 !important}
  body * {visibility:hidden}
  .print-area, .print-area *{visibility:visible}
  .print-area{position:absolute;left:0;top:0;width:100%}
  .vouchers-grid{grid-template-columns:1fr;gap:14px;margin:0}
  .voucher{box-shadow:none;border:1px solid #ccc;break-inside:avoid;page-break-inside:avoid}
  .voucher-rules{border:1px solid #ccc}
}
