:root{
  /* Palette brand: navy + rame del logo, crema per i testi */
  --bg:#151e39; /* blu navy del logo (misurato dai pixel) */
  --panel:#17213c;
  --panel2:#141d36;
  --text:#f4efea;
  --muted:#c5c0c9;
  --line:rgba(244,239,234,.12);
  --gold:#c8896a;   /* rame del logo (bottoni, accenti) */
  --gold2:#e7c3ab;  /* rame chiaro (titoletti, link) */

  --radius:18px;
  --shadow:0 18px 50px rgba(0,0,0,.40);
  --max:1120px;
  --pad:22px;
  --font: "Mulish", ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Helvetica, Arial;
  --display: "Cormorant", Georgia, "Times New Roman", serif;
}

*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth;scroll-padding-top:84px}
html,body{margin:0;padding:0}
body{
  font-family:var(--font);
  color:var(--text);
  /* Sfondo come il logo: navy con texture tipo pelle (estratta dal logo stesso).
     La texture NON si ripiega su se stessa (niente "repeat"): copre lo schermo
     una volta sola e resta fissa allo scroll -> nessuna linea di giunzione. */
  background:
    radial-gradient(1200px 600px at 20% -10%, rgba(200,137,106,.14), transparent 60%),
    radial-gradient(1000px 600px at 80% 10%, rgba(231,195,171,.08), transparent 55%),
    url("assets/bg-texture.jpg");
  background-color: var(--bg);
  background-repeat: no-repeat;
  background-position: center top, center top, center center;
  background-size: auto, auto, cover;
  background-attachment: scroll, scroll, fixed;
  line-height:1.5;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
h1,h2,h3{overflow-wrap:break-word;font-family:var(--display);font-weight:600;letter-spacing:.005em}

/* ===== Cursore personalizzato: freccia rame con bordo (solo dispositivi con mouse) ===== */
@media (hover:hover) and (pointer:fine){
  html, body{ cursor: url("assets/cursor.png") 3 3, auto; }
  a, button, .btn, label, summary, [role="button"],
  input[type="submit"], input[type="button"],
  input[type="checkbox"], input[type="radio"]{
    cursor: url("assets/cursor-link.png") 3 3, pointer;
  }
  input[type="text"], input[type="email"], input[type="tel"],
  input[type="search"], input[type="password"], input[type="number"],
  textarea{ cursor: text; }
}

a{color:inherit;text-decoration:none}
.container{max-width:var(--max);margin:0 auto;padding:0 var(--pad)}
.section{padding:78px 0}
/* Niente velatura sulle sezioni alternate: lo sfondo resta continuo, senza linee di stacco */
.section--alt{background: transparent}
.maxw{max-width:720px}

.skip-link{
  position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{left:20px;top:20px;width:auto;height:auto;padding:10px 14px;background:#fff;color:#000;border-radius:10px}

.header{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(21,30,57,.80);
  border-bottom:1px solid var(--line);
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px var(--pad)}
.brand{display:flex;align-items:center;gap:12px;min-width:260px}
.brand__logo{width:44px;height:44px;object-fit:contain}
.brand__name{font-weight:700}
.brand__role{font-size:13px;color:var(--muted)}

.nav{display:flex;gap:22px;align-items:center}
.nav a{font-size:14px;color:var(--muted);white-space:nowrap}
.nav a:hover{color:var(--text)}

.burger{
  display:none;flex-direction:column;gap:5px;
  background:transparent;border:0;cursor:pointer;padding:10px;border-radius:12px;
}
.burger span{display:block;width:24px;height:2px;background:var(--text);opacity:.85}

.mobile-menu{
  border-top:1px solid var(--line);
  padding:12px var(--pad) 18px;
  display:grid;gap:10px;
}
/* Rispetta l'attributo hidden: il menu resta chiuso finché non si tocca il burger */
.mobile-menu[hidden]{display:none}
.mobile-menu a{padding:10px 12px;border-radius:12px;background:var(--panel)}
.mobile-menu .btn{justify-content:center}

.hero{padding:56px 0 28px}
.hero__inner{display:grid;grid-template-columns: 1fr 1.05fr;gap:28px;align-items:center}
.kicker,.eyebrow{color:var(--gold2);font-size:12.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:600;font-family:var(--font)}
.eyebrow{display:inline-flex;align-items:center;gap:10px;margin-bottom:8px}
.eyebrow::before{content:"";width:22px;height:1px;background:linear-gradient(90deg,var(--gold),transparent)}
h1{font-size:56px;line-height:1.12;margin:14px 0 20px;font-weight:600}
.lead{font-size:18px;color:var(--muted);max-width:620px}

.hero__cta{display:flex;gap:12px;flex-wrap:wrap;margin:18px 0 18px}

.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 20px;border-radius:12px;font-family:var(--font);
  background: var(--gold);
  color:#14100b;font-weight:700;letter-spacing:.01em;border:1px solid rgba(231,195,171,.5);
  box-shadow: 0 8px 22px rgba(200,137,106,.18);
  transition: transform .22s ease, box-shadow .22s ease, background .22s ease;
}
.btn:hover{background:var(--gold2);transform:translateY(-1px);box-shadow:0 12px 28px rgba(200,137,106,.28)}
.btn:active{transform:translateY(0)}
.btn--ghost{
  background:transparent;color:var(--text);
  border:1px solid rgba(200,137,106,.40);
  box-shadow:none;
}
.btn--ghost:hover{background:rgba(200,137,106,.08);border-color:rgba(200,137,106,.7)}
.btn--small{padding:10px 16px;border-radius:11px;font-size:14px}

.trust{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:18px}
.trust__item{
  padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:var(--panel);
  box-shadow:0 6px 16px rgba(0,0,0,.25); /* leggermente in primo piano */
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.trust__item:hover{
  transform:translateY(-4px) scale(1.015);
  border-color:rgba(200,137,106,.45);
  box-shadow:0 16px 36px rgba(0,0,0,.45), 0 0 22px rgba(200,137,106,.20);
}
.trust__title{font-weight:700}
.trust__text{font-size:13px;color:var(--muted)}

.hero__media{display:flex;justify-content:flex-end}
.portrait{
  width:min(580px, 100%);aspect-ratio: 4/5;border-radius:26px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.04);
  overflow:hidden;box-shadow: var(--shadow);
}
.portrait img{width:100%;height:100%;object-fit:cover}

.grid2{display:grid;grid-template-columns: 1fr 1fr;gap:18px;align-items:start}
.cards3{display:grid;grid-template-columns: repeat(3,1fr);gap:14px;margin-top:18px}

.card{
  border-radius: var(--radius);
  border:1px solid var(--line);
  background: var(--panel); /* opaca: non lascia vedere la texture sotto */
  padding:22px;
  box-shadow:0 8px 20px rgba(0,0,0,.28); /* in primo piano già a riposo */
  transition: transform .25s ease, border-color .25s ease, background .25s ease, box-shadow .25s ease;
}
/* hover: la card "esce dallo schermo" con alone rame attorno al contorno */
.card:hover{
  transform:translateY(-5px) scale(1.018);
  border-color:rgba(200,137,106,.5);
  background:#1b2547;
  box-shadow:0 22px 46px rgba(0,0,0,.5), 0 0 26px rgba(200,137,106,.22);
}
.card--highlight{
  background: linear-gradient(180deg, rgba(200,137,106,.18), rgba(200,137,106,0)) var(--panel);
  border-color: rgba(200,137,106,.35);
}
h2{font-size:38px;margin:0 0 16px;line-height:1.16;font-weight:600}
h3{font-size:21px;margin:0 0 10px;font-weight:600;letter-spacing:.01em;line-height:1.2}
.muted{color:var(--muted)}
.small{font-size:12px}
.note{font-size:13px;color:var(--muted);border-left:3px solid rgba(200,137,106,.6);padding-left:12px;margin-top:14px}

.ticks{padding-left:18px;margin:12px 0 0}
.ticks li{margin:8px 0}
.steps{padding-left:18px}
.steps li{margin:10px 0}

.form{display:grid;gap:12px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:6px}
.field input,.field textarea{
  width:100%;border-radius:14px;border:1px solid rgba(255,255,255,.16);
  background: var(--panel2); /* opaco, niente texture in trasparenza */
  color:var(--text);padding:12px 12px;outline:none;
}
.field input:focus,.field textarea:focus{border-color: rgba(200,137,106,.7)}
.contact-actions{display:flex;flex-direction:column;gap:10px;margin-top:14px}
.link{color:var(--gold2);text-decoration:underline}

.consent{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--muted);cursor:pointer}
.consent input{margin-top:2px;width:18px;height:18px;flex:0 0 auto;accent-color:var(--gold)}
.consent a{color:var(--gold2);text-decoration:underline}

.footer{border-top:1px solid var(--line);padding:26px 0;margin-top:26px}
.footer__inner{display:grid;gap:12px}
.footer__links{display:flex;gap:14px;flex-wrap:wrap}
.footer__links a{color:var(--muted)}
.footer__links a:hover{color:var(--text)}

/* ===== TABLET (fino a 920px): menu a hamburger, layout a 1-2 colonne ===== */
@media (max-width: 920px){
  .nav{display:none}
  .burger{display:flex}
  .hero__inner{grid-template-columns: 1fr;gap:22px}
  .hero__media{justify-content:flex-start}
  .portrait{width:min(520px, 100%)}
  .grid2{grid-template-columns: 1fr}
  .cards3{grid-template-columns: repeat(2,1fr)}   /* tablet: 2 colonne */
  h1{font-size:46px}
  h2{font-size:32px}
  .section{padding:64px 0}
}

/* ===== TELEFONO / APP (fino a 600px): tutto in colonna singola ===== */
@media (max-width: 600px){
  :root{--pad:16px}
  .trust{grid-template-columns:1fr}
  .cards3{grid-template-columns: 1fr}
  .brand{min-width:0}
  .brand__role{font-size:12px}
  h1{font-size:38px}
  h2{font-size:28px}
  .lead{font-size:16px}
  .section{padding:48px 0}
  .hero{padding:32px 0 18px}
  .hero__cta .btn{width:100%}                      /* pulsanti a tutta larghezza, comodi al tocco */
}

/* ===== DESKTOP GRANDE (oltre 1200px): leggero respiro in più ===== */
@media (min-width: 1200px){
  h1{font-size:62px}
}

/* ===== Placeholder immagini (rimuovere quando arrivano le foto vere) ===== */
.ph{
  position:relative;width:100%;height:100%;
  background:
    repeating-linear-gradient(135deg, rgba(200,137,106,.10) 0 2px, transparent 2px 11px),
    linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.015));
  display:flex;align-items:center;justify-content:center;
}
.ph span{
  font-family: ui-monospace, "SF Mono", Menlo, Consolas, monospace;
  font-size:12px;letter-spacing:.05em;color:var(--muted);
  border:1px solid var(--line);border-radius:999px;padding:7px 14px;
  background:rgba(11,15,22,.5);backdrop-filter:blur(4px);
}
.brand__logo.ph{border-radius:12px}
.brand__logo.ph span{padding:0;border:0;background:none;font-size:10px;color:var(--gold2)}

/* ===== Scroll reveal discreto (solo se JS attivo: senza JS il contenuto resta visibile) ===== */
.js .reveal{opacity:0;transform:translateY(16px);transition:opacity .7s ease, transform .7s ease}
.js .reveal.is-in{opacity:1;transform:none}
@media (prefers-reduced-motion: reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
}

/* ===== Cursore: ripple al click ===== */
.click-ripple{
  position:fixed;left:0;top:0;border-radius:50%;
  pointer-events:none;z-index:9991;
  border:1.5px solid rgba(231,195,171,.6);
  box-shadow:0 0 12px rgba(200,137,106,.25) inset;
  transform:translate(-50%,-50%) scale(0);
  animation:rippleAnim .65s ease-out forwards;
  mix-blend-mode:screen;
}
@keyframes rippleAnim{
  0%{opacity:.65;transform:translate(-50%,-50%) scale(.1)}
  100%{opacity:0;transform:translate(-50%,-50%) scale(1)}
}

/* niente effetti su touch o se l'utente preferisce meno animazioni */
@media (hover:none),(prefers-reduced-motion:reduce){
  .click-ripple{display:none}
}

/* ===== Volti in trasparenza nello sfondo dell'hero ===== */
.hero{position:relative;overflow:hidden}
.face-bg{position:absolute;pointer-events:none;opacity:.14;z-index:0}
.face-bg img{width:100%;height:100%;object-fit:cover}
.face-bg--tl{top:-40px;left:-60px;width:340px;height:420px;
  -webkit-mask-image:radial-gradient(75% 75% at 35% 30%, #000 35%, transparent 75%);
  mask-image:radial-gradient(75% 75% at 35% 30%, #000 35%, transparent 75%);}
.face-bg--br{bottom:-60px;right:-60px;width:380px;height:460px;
  -webkit-mask-image:radial-gradient(75% 75% at 65% 70%, #000 35%, transparent 75%);
  mask-image:radial-gradient(75% 75% at 65% 70%, #000 35%, transparent 75%);}
.hero__inner{position:relative;z-index:1}

/* ===== Ritratto con logo + firma in basso a destra ===== */
.portrait{position:relative;margin:0}
.portrait__sign{
  position:absolute;right:12px;bottom:12px;
  display:flex;align-items:center;gap:9px;
  background:rgba(21,30,57,.78);backdrop-filter:blur(6px);
  border:1px solid rgba(200,137,106,.35);
  border-radius:999px;padding:7px 14px 7px 8px;
}
.portrait__sign img{width:30px;height:30px}
.portrait__sign span{
  font-family:var(--display);font-style:italic;font-weight:600;
  font-size:15px;color:var(--gold2);white-space:nowrap;
}
.hero__motto{
  margin:14px 4px 0;text-align:center;
  font-family:var(--display);font-style:italic;font-weight:600;
  font-size:17px;letter-spacing:.06em;color:var(--gold2);
}

/* ===== Emblema bronzo al centro della sezione focus viso ===== */
.focus-emblem{display:block;width:190px;margin:30px auto 14px;border-radius:50%;
  transition:transform .3s ease, filter .3s ease;
  filter:drop-shadow(0 0 26px rgba(200,137,106,.22));}
.focus-emblem img{width:100%;display:block}
.focus-emblem:hover{transform:scale(1.05);filter:drop-shadow(0 0 38px rgba(200,137,106,.4))}

/* ===== Coppia volti invecchiamento (focus viso) ===== */
.aging-pair{display:grid;grid-template-columns:repeat(2,minmax(0,340px));gap:18px;justify-content:center;margin:26px 0 8px}
.aging-pair__item{
  border-radius:var(--radius);overflow:hidden;border:1px solid var(--line);
  box-shadow:0 10px 26px rgba(0,0,0,.35);
  transition:transform .25s ease, border-color .25s ease, box-shadow .25s ease;
}
.aging-pair__item img{width:100%;height:100%;object-fit:cover;aspect-ratio:4/5}
.aging-pair__item:hover{
  transform:translateY(-5px) scale(1.015);
  border-color:rgba(200,137,106,.5);
  box-shadow:0 22px 46px rgba(0,0,0,.5), 0 0 26px rgba(200,137,106,.22);
}

/* ===== Griglia 4 sedi ===== */
.cards4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:18px}
@media (max-width:920px){.cards4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.cards4{grid-template-columns:1fr}}

/* ===== Recensioni ===== */
.review__text{font-style:italic;color:var(--text)}
.review__author{color:var(--gold2);font-weight:700;font-size:14px;margin-bottom:0}

/* ===== Prima/Dopo con dissolvenza al passaggio del mouse ===== */
.ba-card{
  position:relative;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);box-shadow:0 10px 26px rgba(0,0,0,.35);
  aspect-ratio:4/5;
}
.ba-card img{
  position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  transition:opacity .9s ease; /* dissolvenza fluida, non un cambio netto */
}
.ba-card img.ba-after{opacity:0}
.ba-card:hover img.ba-after{opacity:1}
.ba-card:hover img.ba-before{opacity:0}
.ba-card .ba-label{
  position:absolute;left:14px;bottom:14px;z-index:2;
  font-size:12px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  background:rgba(21,30,57,.8);border:1px solid rgba(200,137,106,.4);
  color:var(--gold2);border-radius:999px;padding:6px 14px;
  transition:opacity .9s ease;
}
.ba-card .ba-label--after{opacity:0}
.ba-card:hover .ba-label--after{opacity:1}
.ba-card:hover .ba-label--before{opacity:0}
.ba-grid{display:grid;grid-template-columns:repeat(2,minmax(0,340px));gap:18px;justify-content:center;margin-top:22px}
@media (max-width:600px){.ba-grid,.aging-pair{grid-template-columns:1fr}}

/* ===== Mappa volto cliccabile (pagina viso) ===== */
.face-map{position:relative;max-width:640px;margin:0 auto}
.face-map>img{width:100%;border-radius:var(--radius);border:1px solid var(--line);box-shadow:var(--shadow)}
.face-map__dot{
  position:absolute;transform:translate(0,-50%); /* ancorato a sinistra, niente sovrapposizioni */
  display:flex;align-items:center;gap:7px;
  background:rgba(21,30,57,.85);border:1px solid rgba(200,137,106,.55);
  color:var(--text);border-radius:999px;padding:4px 11px 4px 5px;
  font-size:12px;font-weight:700;cursor:pointer;white-space:nowrap;
  transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.face-map__dot::before{
  content:"+";display:flex;align-items:center;justify-content:center;
  width:18px;height:18px;border-radius:50%;
  background:var(--gold);color:#14100b;font-weight:800;
}
.face-map__dot:hover{
  transform:translate(0,-50%) scale(1.07);
  border-color:var(--gold2);
  box-shadow:0 0 18px rgba(200,137,106,.35);
}

/* ===== Pagine interne ===== */
.page-hero{padding:64px 0 30px}
.page-hero .eyebrow{margin-bottom:4px}
.zone-card{scroll-margin-top:96px}
.zone-card .ph-box{
  display:flex;align-items:center;justify-content:center;text-align:center;
  border:1px dashed rgba(200,137,106,.4);border-radius:14px;
  color:var(--muted);font-size:13px;min-height:200px;padding:16px;
  background:var(--panel2);
}
.option-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin:20px 0 8px}
.option-cards--2{grid-template-columns:repeat(2,1fr)}
.option-cards a.card{display:block}
.option-cards h3{margin-bottom:6px}
@media (max-width:600px){.option-cards,.option-cards--2{grid-template-columns:1fr}}
