/* ═══════════════════════════════════════════════════════════════
   CardioRoma — shared stylesheet
   Dark warm editorial design system
   ═══════════════════════════════════════════════════════════════ */

:root{
  --bg:        #1A1410;
  --bg-2:      #221A14;
  --bg-3:      #2A1F18;
  --gold:      #D4A574;
  --gold-dim:  #b88c5d;
  --wine:      #9B3247;
  --text:      #F5F1EA;
  --muted:     #B8AFA3;
  --line:      rgba(245,241,234,0.10);
  --line-2:    rgba(245,241,234,0.18);
  --ecg-green: #7DA86F;

  --serif: "Fraunces", "EB Garamond", Georgia, serif;
  --sans:  "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;

  --maxw: 1280px;
  --pad-x: clamp(20px, 5vw, 80px);
}

*,*::before,*::after{ box-sizing:border-box; }
html,body{ margin:0; padding:0; }
html{ scroll-behavior:smooth; }
body{
  background:var(--bg);
  color:var(--text);
  font-family:var(--sans);
  font-weight:400;
  font-size:16px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}

::selection{ background:var(--gold); color:var(--bg); }

img,svg{ display:block; max-width:100%; }
a{ color:inherit; text-decoration:none; }
button{ font:inherit; color:inherit; background:none; border:0; cursor:pointer; }

.wrap{
  max-width:var(--maxw);
  margin:0 auto;
  padding-left:var(--pad-x);
  padding-right:var(--pad-x);
}

/* ──────────────────────────────────────────────── Type system */
h1,h2,h3,h4{ font-family:var(--serif); font-weight:400; letter-spacing:-0.01em; margin:0; color:var(--text); }
h1{ font-size:clamp(44px, 7.4vw, 104px); line-height:1.02; letter-spacing:-0.025em; }
h2{ font-size:clamp(34px, 4.8vw, 60px); line-height:1.05; letter-spacing:-0.02em; }
h3{ font-size:clamp(22px, 2vw, 28px); line-height:1.2; }
.italic{ font-style:italic; font-weight:300; }
.gold{ color:var(--gold); }
.eyebrow{
  font-family:var(--sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.22em;
  color:var(--muted);
  font-weight:500;
}
.lede{
  font-size:clamp(17px, 1.4vw, 20px);
  line-height:1.55;
  color:var(--muted);
  max-width:56ch;
  font-weight:300;
}
p{ margin:0 0 1em 0; }

/* ──────────────────────────────────────────────── Buttons */
.btn{
  display:inline-flex; align-items:center; gap:10px;
  padding:16px 26px;
  font-family:var(--sans); font-size:14px; font-weight:500;
  letter-spacing:0.04em;
  border-radius:2px;
  transition:transform .25s ease, background .25s ease, color .25s ease, border-color .25s ease;
  white-space:nowrap;
}
.btn .arrow{ transition:transform .25s ease; }
.btn:hover .arrow{ transform:translateX(4px); }
.btn-primary{ background:var(--gold); color:#1A1410; }
.btn-primary:hover{ background:#e3b888; }
.btn-secondary{ border:0.5px solid var(--line-2); color:var(--text); }
.btn-secondary:hover{ border-color:var(--gold); color:var(--gold); }
.btn-outline-gold{
  border:0.5px solid var(--gold);
  color:var(--gold);
  background:transparent;
}
.btn-outline-gold:hover{ background:var(--gold); color:#1A1410; }
.btn-lg{ padding:20px 34px; font-size:15px; }

.section-cta{
  margin-top:clamp(48px, 5vw, 72px);
  display:flex; justify-content:center;
}

/* ──────────────────────────────────────────────── ECG accent (recurring sigil) */
.ecg-strip{ width:100%; height:28px; opacity:.55; overflow:hidden; }
.ecg-strip svg{ height:100%; width:100%; }
.ecg-strip .pulse{
  stroke:var(--ecg-green); stroke-width:1; fill:none;
  stroke-linecap:round; stroke-linejoin:round;
}

/* ──────────────────────────────────────────────── HEADER */
.site-header{
  position:sticky; top:0; z-index:50;
  background:rgba(26,20,16,0.78);
  backdrop-filter:blur(14px) saturate(140%);
  -webkit-backdrop-filter:blur(14px) saturate(140%);
  border-bottom:0.5px solid var(--line);
}
.site-header .inner{
  display:flex; align-items:center; justify-content:space-between;
  padding-top:18px; padding-bottom:18px;
  gap:32px;
}
.logo{
  display:flex; align-items:baseline; gap:0;
  font-family:var(--serif); font-size:22px; letter-spacing:-0.01em;
}
.logo .mark{
  display:inline-block; width:8px; height:8px;
  background:var(--gold); border-radius:50%;
  margin-right:10px; transform:translateY(-2px);
}
.logo b{ font-weight:500; }
.logo .italic{ font-style:italic; font-weight:300; color:var(--gold); }

nav.primary{ display:flex; align-items:center; gap:18px; flex-wrap:nowrap; }
nav.primary a{
  font-size:13px; letter-spacing:0.03em;
  color:var(--muted);
  position:relative;
  padding:6px 0;
  white-space:nowrap;
  transition:color .25s ease;
}
nav.primary a:hover{ color:var(--text); }
nav.primary a.active{ color:var(--text); }
nav.primary a.active::after{
  content:""; position:absolute; left:0; right:0; bottom:0;
  height:1px; background:var(--gold);
}
.header-cta{ display:inline-flex; }

.menu-toggle{
  display:none;
  width:40px; height:40px; padding:0;
  border:0.5px solid var(--line-2);
  border-radius:2px;
  align-items:center; justify-content:center;
}
.menu-toggle span{
  display:block; width:16px; height:1px; background:var(--text);
  position:relative;
}
.menu-toggle span::before,.menu-toggle span::after{
  content:""; position:absolute; left:0; width:16px; height:1px; background:var(--text);
}
.menu-toggle span::before{ top:-5px; }
.menu-toggle span::after{ top:5px; }

/* Mobile menu drawer */
.drawer{
  position:fixed; inset:0;
  background:rgba(26,20,16,0.96);
  backdrop-filter:blur(20px);
  z-index:100;
  display:flex; flex-direction:column;
  padding:24px var(--pad-x);
  transform:translateY(-100%);
  transition:transform .35s cubic-bezier(.4,0,.2,1);
  pointer-events:none; /* CRITICO: drawer chiuso non deve catturare i click (bug Safari iOS con transform) */
}
.drawer.open{
  transform:translateY(0);
  pointer-events:auto; /* Drawer aperto = interattivo */
}
.drawer-top{
  display:flex; justify-content:space-between; align-items:center;
  padding-bottom:24px;
  border-bottom:0.5px solid var(--line);
  flex:0 0 auto; /* altezza fissa, sempre in alto */
}
.drawer-close{
  width:40px; height:40px; border:0.5px solid var(--line-2); border-radius:2px;
  display:inline-flex; align-items:center; justify-content:center;
}
.drawer nav{
  padding:48px 0;
  display:flex; flex-direction:column; gap:8px;
  flex:1 1 auto; /* prende lo spazio rimanente */
  overflow-y:auto; /* scrolla se le voci sono troppe per stare in viewport */
  -webkit-overflow-scrolling:touch; /* momentum scroll iOS */
  min-height:0; /* fix flexbox: permette al child di shrinkare */
}
.drawer nav a{
  font-family:var(--serif);
  font-size:34px; font-weight:400; color:var(--text);
  padding:14px 0;
  border-bottom:0.5px solid var(--line);
  flex:0 0 auto; /* ogni voce mantiene la sua altezza, non si comprime */
}
.drawer nav a .italic{ color:var(--gold); }
.drawer .drawer-cta{ margin-top:24px; flex:0 0 auto; /* altezza naturale, mai compresso, sempre in fondo */ }

/* Safety reset: il drawer-cta deve stare SEMPRE dentro al drawer e seguire la sua
   visibilità via transform. Se vecchie cache CSS contengono position:fixed/absolute
   su .drawer-cta, questa regola le neutralizza con !important. */
.drawer-cta{
  position:static !important;
  top:auto !important;
  left:auto !important;
  right:auto !important;
  bottom:auto !important;
}
/* Backup hardening: anche se per qualche miracolo position non viene resettata,
   nascondiamo il drawer-cta quando il drawer NON è aperto */
.drawer:not(.open) .drawer-cta{
  visibility:hidden !important;
  pointer-events:none !important;
}
.drawer.open .drawer-cta{
  visibility:visible !important;
  pointer-events:auto !important;
}

/* ──────────────────────────────────────────────── HOMEPAGE HERO */
.hero{
  position:relative;
  padding-top:clamp(60px, 9vw, 120px);
  padding-bottom:clamp(80px, 10vw, 140px);
  overflow:hidden;
}
.hero .wrap{
  display:grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:center;
}
.hero-eyebrow{
  display:inline-flex; align-items:center; gap:14px;
  margin-bottom:36px;
}
.hero-eyebrow .dot{
  width:6px; height:6px; border-radius:50%; background:var(--ecg-green);
  box-shadow:0 0 0 4px rgba(125,168,111,0.12);
}
.hero h1{ margin-bottom:28px; }
.hero h1 .accent{ color:var(--gold); }
.hero p.lede{ margin-bottom:40px; }
.hero .ctas{
  display:flex; flex-wrap:wrap; gap:14px;
  margin-bottom:48px;
}
.hero .signature{
  display:flex; align-items:center; gap:18px;
  font-size:12px; color:var(--muted); letter-spacing:0.04em;
}
.hero .signature .divider{ width:36px; height:1px; background:var(--line-2); }
.hero .signature b{ color:var(--text); font-weight:500; }

/* Hero illustration column */
.hero-art{
  position:relative;
  aspect-ratio: 1 / 1;
  width:100%;
  max-width:560px;
  margin-left:auto;
}
.hero-art .frame{
  position:absolute; inset:0;
  border:0.5px solid var(--line-2);
  border-radius:2px;
  background:
    radial-gradient(ellipse at 30% 30%, rgba(212,165,116,0.06), transparent 60%),
    linear-gradient(180deg, var(--bg-2), var(--bg));
}
.hero-art .ticks{
  position:absolute; inset:24px;
  background-image:
    linear-gradient(rgba(212,165,116,0.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(212,165,116,0.05) 1px, transparent 1px);
  background-size: 32px 32px;
  pointer-events:none;
}
.hero-art .label-tl,.hero-art .label-tr,.hero-art .label-bl,.hero-art .label-br{
  position:absolute;
  font-family:var(--sans); font-size:10px;
  color:var(--muted); letter-spacing:0.18em; text-transform:uppercase;
}
.hero-art .label-tl{ top:18px; left:24px; }
.hero-art .label-tr{ top:18px; right:24px; color:var(--gold); }
.hero-art .label-bl{ bottom:18px; left:24px; }
.hero-art .label-br{ bottom:18px; right:24px; }
.hero-art .heart{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
}
.hero-art .heart svg{ width:78%; height:auto; }
.hero-art .heart .line{ fill:none; stroke:var(--text); stroke-width:1.1; stroke-linecap:round; stroke-linejoin:round; }
.hero-art .heart .line.thin{ stroke:var(--muted); stroke-width:0.6; opacity:0.7; }
.hero-art .heart .line.gold{ stroke:var(--gold); stroke-width:1.1; }
.hero-art .heart .ecg-trace{
  stroke:var(--ecg-green); stroke-width:1.4; fill:none;
  stroke-dasharray: 1400; stroke-dashoffset: 1400;
  animation: drawECG 4.2s ease-out 0.4s forwards;
}
@keyframes drawECG{ to{ stroke-dashoffset:0; } }
.hero-art .pulse-dot{
  fill:var(--ecg-green); opacity:0;
  animation: pulseDot 1.6s ease-in-out 4.6s infinite;
}
@keyframes pulseDot{
  0%,100%{ opacity:0; r:2; }
  50%{ opacity:1; r:3.2; }
}

/* ──────────────────────────────────────────────── PAGE HERO (sub-pages) */
.page-hero{
  padding-top:clamp(70px, 8vw, 120px);
  padding-bottom:clamp(60px, 6vw, 90px);
  border-bottom:0.5px solid var(--line);
}
.page-hero .eyebrow{ margin-bottom:24px; display:inline-block; }
.page-hero h1{
  font-size:clamp(40px, 5.6vw, 80px);
  max-width:18ch;
  margin-bottom:28px;
}
.page-hero h1 .italic{ color:var(--gold); }
.page-hero .lede{ max-width:60ch; margin:0; }
.page-hero .crumb{
  font-size:11px; letter-spacing:0.22em; text-transform:uppercase;
  color:var(--muted);
  display:flex; align-items:center; gap:14px;
  margin-bottom:32px;
}
.page-hero .crumb .sep{ width:18px; height:1px; background:var(--line-2); }
.page-hero .crumb .curr{ color:var(--gold); }

/* ──────────────────────────────────────────────── Section separators */
section{ position:relative; }
.rule{ border:0; height:0; border-top:0.5px solid var(--line); margin:0; }

/* ──────────────────────────────────────────────── STATS BAR */
.stats{
  padding:clamp(60px, 8vw, 110px) 0;
  background:var(--bg-2);
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
}
.stats .head{ text-align:center; margin-bottom:64px; }
.stats .head .eyebrow{ margin-bottom:14px; display:inline-block; }
.stats .head h2{ max-width:18ch; margin:0 auto; }
.stats-grid{ display:grid; grid-template-columns: repeat(4, 1fr); gap:0; }
.stat{
  padding:24px 28px;
  border-left:0.5px solid var(--line);
  position:relative;
}
.stat:first-child{ border-left:0; }
.stat .num{
  font-family:var(--serif);
  color:var(--gold);
  font-size:clamp(56px, 6.4vw, 88px);
  line-height:1;
  letter-spacing:-0.03em;
  font-weight:300;
  display:flex; align-items:flex-start; gap:4px;
  margin-bottom:14px;
}
.stat .num .sup{
  font-size:0.4em; color:var(--gold-dim); margin-top:0.4em;
  font-style:italic;
}
.stat .label{
  font-size:13px;
  color:var(--muted);
  letter-spacing:0.02em;
  line-height:1.45;
  max-width:22ch;
}

/* ──────────────────────────────────────────────── LA VISITA (home preview) */
.visita{ padding:clamp(80px, 10vw, 140px) 0; }
.visita .head{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:end;
  margin-bottom:80px;
}
.visita .head h2 .italic{ color:var(--gold); }
.visita-grid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap:0;
  border-top:0.5px solid var(--line);
}
.visita-grid.visita-grid-3{ grid-template-columns: repeat(3, 1fr); }
.v-item{
  padding:42px 32px 36px 0;
  border-right:0.5px solid var(--line);
  position:relative;
}
.v-item:last-child{ border-right:0; padding-right:0; }
.v-item:not(:first-child){ padding-left:32px; }
.v-item .num{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  color:var(--gold);
  font-size:14px;
  letter-spacing:0.05em;
  margin-bottom:20px;
}
.v-item h3{ margin-bottom:14px; font-family:var(--serif); font-weight:400; }
.v-item p{ color:var(--muted); font-size:14.5px; line-height:1.6; margin:0; }
.v-item .ecg-mini{ position:absolute; top:42px; right:32px; opacity:.5; }
.v-item:last-child .ecg-mini{ right:0; }

/* ──────────────────────────────────────────────── MEDICI */
.medici{
  padding:clamp(80px, 10vw, 140px) 0;
  background:var(--bg-2);
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
}
.medici .head{ text-align:center; margin-bottom:72px; }
.medici .head .eyebrow{ margin-bottom:14px; display:inline-block; }
.medici-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--line);
  border:0.5px solid var(--line);
}
.doc{
  background:var(--bg-2);
  padding:clamp(28px, 3.4vw, 48px);
  display:grid;
  grid-template-columns: 180px 1fr;
  gap:clamp(20px, 2.6vw, 40px);
  align-items:start;
}
.doc .portrait{
  aspect-ratio:3/4;
  background:
    repeating-linear-gradient(135deg, rgba(212,165,116,0.08) 0 1px, transparent 1px 9px),
    var(--bg-3);
  border:0.5px solid var(--line-2);
  position:relative;
  display:flex; align-items:flex-end; justify-content:center;
  overflow:hidden;
}
.doc .portrait .ph-label{
  font-family:"Inter",monospace;
  font-size:10px;
  color:var(--muted);
  letter-spacing:0.16em;
  text-transform:uppercase;
  padding:8px;
  background:rgba(26,20,16,0.6);
  border-top:0.5px solid var(--line-2);
  width:100%;
  text-align:center;
}
.doc .portrait .silhouette{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); opacity:0.35;
}
.doc .meta .role{
  font-size:11px; letter-spacing:0.22em; color:var(--gold); text-transform:uppercase;
  margin-bottom:18px;
}
.doc .meta h3{
  font-size:clamp(26px, 2.4vw, 34px);
  margin-bottom:8px;
  font-weight:400;
}
.doc .meta h3 em{ color:var(--gold); font-weight:300; }
.doc .meta .title{
  font-family:var(--serif); font-style:italic; font-weight:300;
  color:var(--muted); font-size:17px;
  margin-bottom:22px;
}
.doc .meta .albo{
  font-size:12.5px;
  color:var(--muted);
  line-height:1.5;
  padding-top:18px;
  border-top:0.5px solid var(--line);
}
.doc .meta .albo b{ color:var(--text); font-weight:500; }

/* ──────────────────────────────────────────────── COME PRENOTARE */
.prenotare{ padding:clamp(80px, 10vw, 140px) 0; }
.prenotare .head{
  display:grid;
  grid-template-columns: 0.9fr 1.1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:end;
  margin-bottom:80px;
}
.steps{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:0.5px solid var(--line);
}
.step{
  padding:44px 36px 40px 0;
  border-right:0.5px solid var(--line);
  position:relative;
}
.step:last-child{ border-right:0; padding-right:0; }
.step:not(:first-child){ padding-left:36px; }
.step .n{
  font-family:var(--serif);
  color:var(--gold);
  font-size:clamp(40px, 4.2vw, 56px);
  line-height:1;
  margin-bottom:22px;
  font-weight:300;
  letter-spacing:-0.02em;
  display:flex; align-items:baseline; gap:10px;
}
.step .n .slash{
  font-size:0.4em; color:var(--gold-dim); opacity:0.7;
  font-style:italic;
}
.step h3{ margin-bottom:12px; }
.step p{ color:var(--muted); font-size:14.5px; }

.prenotare-cta{
  margin-top:72px;
  display:flex; justify-content:center;
}

/* ──────────────────────────────────────────────── FOOTER */
footer{
  background:var(--bg-2);
  border-top:0.5px solid var(--line);
  padding-top:clamp(60px, 7vw, 90px);
  padding-bottom:36px;
  font-size:13px;
}
.footer-grid{
  display:grid;
  grid-template-columns: 1.4fr 1fr 1fr 1.2fr;
  gap:clamp(28px, 4vw, 60px);
  margin-bottom:64px;
}
.footer-col h4{
  font-family:var(--sans);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.22em;
  color:var(--muted);
  font-weight:500;
  margin-bottom:22px;
}
.footer-col ul{
  list-style:none; padding:0; margin:0;
  display:flex; flex-direction:column; gap:12px;
}
.footer-col ul a{ color:var(--text); transition:color .2s ease; font-size:14px; }
.footer-col ul a:hover{ color:var(--gold); }
.footer-col .contact-line{ color:var(--muted); margin-bottom:6px; }
.footer-col .contact-line b{ color:var(--text); font-weight:500; }

.footer-brand{ display:flex; flex-direction:column; gap:24px; }
.footer-brand .logo{ font-size:20px; }
.footer-brand .intestazione{
  color:var(--muted);
  font-size:12.5px;
  line-height:1.65;
  max-width:42ch;
}
.footer-brand .intestazione b{ color:var(--text); font-weight:500; }

.footer-bottom{
  padding-top:30px;
  border-top:0.5px solid var(--line);
  display:flex; flex-wrap:wrap; gap:24px; justify-content:space-between; align-items:flex-start;
  color:var(--muted); font-size:12px;
}
.footer-bottom .legal{ display:flex; gap:24px; flex-wrap:wrap; }
.footer-bottom .legal a:hover{ color:var(--gold); }
.disclaimer{
  max-width:64ch;
  color:var(--muted);
  font-size:12px;
  line-height:1.6;
  font-style:italic;
}

/* ──────────────────────────────────────────────── Section header pattern */
.section-head .eyebrow{ margin-bottom:18px; display:inline-block; }

/* ═════════════════════════════════════════════════════════════════════
   LA VISITA — page-specific components
   ═════════════════════════════════════════════════════════════════════ */

/* Section base for sub-pages */
.sec{ padding:clamp(70px, 8vw, 120px) 0; border-top:0.5px solid var(--line); }
.sec:first-of-type{ border-top:0; }
.sec.alt{ background:var(--bg-2); }
.sec-head{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:clamp(32px, 5vw, 90px);
  align-items:end;
  margin-bottom:clamp(40px, 5vw, 64px);
}
.sec-head h2{ max-width:14ch; }
.sec-head h2 .italic{ color:var(--gold); }
.sec-head .right{ color:var(--muted); }
.sec-head .right p{ font-size:16px; line-height:1.7; max-width:54ch; }
.sec-head .right p:last-child{ margin-bottom:0; }

/* Checklist — "Cosa include la visita" */
.checklist{
  display:grid;
  grid-template-columns:repeat(2, 1fr);
  gap:0;
  border-top:0.5px solid var(--line);
}
.check-item{
  padding:28px 32px 28px 0;
  border-bottom:0.5px solid var(--line);
  display:grid;
  grid-template-columns: 44px 1fr;
  gap:22px;
  align-items:start;
}
.check-item:nth-child(odd){ border-right:0.5px solid var(--line); padding-right:48px; }
.check-item:nth-child(even){ padding-left:48px; }
.check-item .icon{
  width:36px; height:36px;
  border:0.5px solid var(--line-2);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
  flex-shrink:0;
}
.check-item .icon svg{ width:18px; height:18px; }
.check-item h3{
  font-family:var(--serif); font-weight:400;
  font-size:19px; line-height:1.3;
  margin-bottom:8px;
}
.check-item h3 .italic{ color:var(--gold); }
.check-item p{
  font-size:14px;
  color:var(--muted);
  line-height:1.55;
  margin:0;
}

/* Durata two-column prose */
.durata-grid{
  display:grid;
  grid-template-columns: 0.95fr 1.05fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:start;
}
.durata-grid h2{ font-size:clamp(34px, 4.4vw, 56px); max-width:14ch; }
.durata-grid h2 .italic{ color:var(--gold); }
.prose{
  color:var(--muted);
  font-size:16px;
  line-height:1.75;
  max-width:56ch;
}
.prose p{ margin:0 0 1.2em 0; }
.prose p:last-child{ margin-bottom:0; }
.prose b{ color:var(--text); font-weight:500; }
.prose .pill{
  display:inline-block;
  font-family:var(--sans);
  font-size:11px; letter-spacing:0.18em; text-transform:uppercase;
  border:0.5px solid var(--line-2);
  padding:6px 12px; border-radius:99px;
  color:var(--gold);
  margin-right:8px; margin-bottom:8px;
}

/* Refertazione — 3 cols */
.referto-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:0;
  border-top:0.5px solid var(--line);
}
.referto-col{
  padding:42px 36px 40px 0;
  border-right:0.5px solid var(--line);
}
.referto-col:last-child{ border-right:0; padding-right:0; }
.referto-col:not(:first-child){ padding-left:36px; }
.referto-col .num{
  font-family:var(--serif);
  color:var(--gold-dim);
  font-style:italic;
  font-size:13px;
  letter-spacing:0.06em;
  margin-bottom:16px;
}
.referto-col h3{
  font-family:var(--serif);
  font-size:clamp(28px, 3vw, 40px);
  font-weight:400;
  margin-bottom:14px;
}
.referto-col h3 .italic{ color:var(--gold); }
.referto-col p{
  color:var(--muted);
  font-size:14.5px;
  line-height:1.65;
  margin:0;
}

/* Costi table */
.costi-wrap{
  border:0.5px solid var(--line);
  background:var(--bg-3);
  padding:clamp(32px, 4vw, 56px);
}
.costi-list{
  display:flex; flex-direction:column;
  gap:0;
}
.costi-row{
  display:grid;
  grid-template-columns: 1fr auto;
  gap:24px;
  align-items:baseline;
  padding:22px 0;
  border-bottom:0.5px solid var(--line);
}
.costi-row:last-child{ border-bottom:0; }
.costi-row .label{
  font-family:var(--serif);
  font-size:clamp(20px, 2.1vw, 26px);
  font-weight:400;
  color:var(--text);
}
.costi-row .label .italic{ color:var(--gold); }
.costi-row .price{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  color:var(--gold);
  font-size:clamp(28px, 3vw, 38px);
  letter-spacing:-0.01em;
  white-space:nowrap;
}
.costi-row .price .ph{
  color:var(--gold-dim);
  font-style:normal;
  opacity:0.6;
}
.costi-note{
  margin-top:28px;
  padding-top:24px;
  border-top:0.5px solid var(--line);
  font-size:13px;
  color:var(--muted);
  line-height:1.65;
  display:flex; flex-wrap:wrap; gap:16px 28px;
}
.costi-note .item{ display:flex; align-items:center; gap:10px; }
.costi-note .item svg{ color:var(--gold); flex-shrink:0; }

/* Preparazione list */
.prep-list{
  list-style:none; padding:0; margin:0;
  border-top:0.5px solid var(--line);
}
.prep-list li{
  display:grid;
  grid-template-columns: 56px 1fr;
  gap:24px;
  padding:24px 0;
  border-bottom:0.5px solid var(--line);
  align-items:center;
}
.prep-list li .n{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  color:var(--gold);
  font-size:24px;
  letter-spacing:-0.01em;
}
.prep-list li .body{
  font-size:16.5px;
  color:var(--text);
  line-height:1.5;
}
.prep-list li .body em{ font-style:italic; color:var(--muted); font-weight:300; }

/* CTA finale */
.final-cta{
  background:var(--bg-2);
  padding:clamp(80px, 10vw, 140px) 0;
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
  position:relative;
  overflow:hidden;
}
.final-cta::before{
  content:""; position:absolute;
  left:0; right:0; top:50%;
  height:1px;
  background:linear-gradient(90deg, transparent, rgba(212,165,116,0.15), transparent);
  pointer-events:none;
}
.final-cta .wrap{
  position:relative; z-index:2;
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
  gap:18px;
}
.final-cta .eyebrow{ display:inline-block; margin-bottom:8px; }
.final-cta h2{
  font-size:clamp(44px, 6vw, 88px);
  max-width:14ch;
  margin:0;
}
.final-cta h2 .italic{ color:var(--gold); }
.final-cta .sub{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  color:var(--muted);
  font-size:clamp(20px, 2vw, 26px);
  margin-bottom:20px;
}
.final-cta .ecg-wrap{
  width:100%; max-width:480px;
  margin-top:18px;
  opacity:0.7;
}

/* ──────────────────────────────────────────────── Mobile */
@media (max-width: 980px){
  nav.primary{ display:none; }
  .header-cta{ display:none; }
  .menu-toggle{ display:inline-flex; }

  .hero .wrap{ grid-template-columns:1fr; gap:60px; }
  .hero-art{ margin:0 auto; max-width:420px; }

  .stats-grid{ grid-template-columns:repeat(2,1fr); }
  .stat{ padding:32px 20px; border-left:0; border-top:0.5px solid var(--line); }
  .stat:nth-child(-n+2){ border-top:0; }
  .stat:nth-child(odd){ border-right:0.5px solid var(--line); }

  .visita .head, .prenotare .head, .sec-head, .durata-grid{
    grid-template-columns:1fr; gap:24px; align-items:start;
  }
  .visita-grid{ grid-template-columns:1fr; }
  .v-item{ border-right:0; border-bottom:0.5px solid var(--line); padding:32px 0 28px 0 !important; }
  .v-item:last-child{ border-bottom:0; }
  .v-item .ecg-mini{ right:0; top:32px; }

  .medici-grid{ grid-template-columns:1fr; }
  .doc{ grid-template-columns:140px 1fr; padding:32px 24px; }

  .steps{ grid-template-columns:1fr; }
  .step{ border-right:0; border-bottom:0.5px solid var(--line); padding:32px 0 28px 0 !important; }
  .step:last-child{ border-bottom:0; }

  .footer-grid{ grid-template-columns:1fr 1fr; gap:36px; }
  .footer-brand{ grid-column:1 / -1; }

  .checklist{ grid-template-columns:1fr; }
  .check-item{ padding:24px 0 !important; border-right:0 !important; }
  .referto-grid{ grid-template-columns:1fr; }
  .referto-col{ border-right:0; border-bottom:0.5px solid var(--line); padding:32px 0 !important; }
  .referto-col:last-child{ border-bottom:0; }
}

@media (max-width: 540px){
  .stats-grid{ grid-template-columns:1fr; }
  .stat{ border-right:0 !important; border-left:0; border-top:0.5px solid var(--line); }
  .stat:first-child{ border-top:0; }
  .doc{ grid-template-columns:1fr; }
  .doc .portrait{ max-width:220px; }
  .footer-grid{ grid-template-columns:1fr; }

  .costi-row{ grid-template-columns:1fr; gap:6px; }
  .prep-list li{ grid-template-columns:40px 1fr; gap:14px; }
}


/* ═════════════════════════════════════════════════════════════════
   MEDICI — page-specific components
   ═════════════════════════════════════════════════════════════════ */

.profile{
  padding:clamp(80px, 9vw, 130px) 0;
}
.profile-grid{
  display:grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap:clamp(40px, 6vw, 96px);
  align-items:start;
}
.profile-grid.mirror{
  grid-template-columns: 1.15fr 0.85fr;
}
.profile-img-col{ position:relative; }
.profile-img-col.right{ order:2; }
.profile-portrait{
  aspect-ratio: 3/4;
  width:100%;
  max-width:460px;
  background:
    repeating-linear-gradient(135deg, rgba(212,165,116,0.08) 0 1px, transparent 1px 11px),
    linear-gradient(180deg, var(--bg-3), var(--bg-2));
  border:0.5px solid var(--line-2);
  position:relative;
  display:flex; align-items:flex-end; justify-content:center;
  overflow:hidden;
}
.profile-portrait .corner-tl,
.profile-portrait .corner-tr,
.profile-portrait .corner-bl,
.profile-portrait .corner-br{
  position:absolute;
  width:14px; height:14px;
  opacity:0.7;
}
.profile-portrait .corner-tl{ top:14px; left:14px; border-top:0.5px solid var(--gold); border-left:0.5px solid var(--gold); }
.profile-portrait .corner-tr{ top:14px; right:14px; border-top:0.5px solid var(--gold); border-right:0.5px solid var(--gold); }
.profile-portrait .corner-bl{ bottom:42px; left:14px; border-bottom:0.5px solid var(--gold); border-left:0.5px solid var(--gold); }
.profile-portrait .corner-br{ bottom:42px; right:14px; border-bottom:0.5px solid var(--gold); border-right:0.5px solid var(--gold); }
.profile-portrait .silhouette{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  color:var(--muted); opacity:0.32;
}
.profile-portrait .ph-tag{
  font-family:"Inter", monospace;
  font-size:10px;
  color:var(--muted);
  letter-spacing:0.2em;
  text-transform:uppercase;
  padding:10px 12px;
  background:rgba(26,20,16,0.7);
  border-top:0.5px solid var(--line-2);
  width:100%;
  text-align:center;
}
.portrait-caption{
  margin-top:18px;
  display:flex; align-items:center; justify-content:space-between;
  font-size:10.5px; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--muted);
  padding:0 2px;
  max-width:460px;
}
.portrait-caption .ecg-mini-wrap{ width:90px; height:14px; opacity:0.7; }
.portrait-caption .fig{ color:var(--gold); }

.profile-meta .role{
  font-size:11px; letter-spacing:0.22em; color:var(--gold); text-transform:uppercase;
  margin-bottom:22px;
}
.profile-meta h2.name{
  font-size:clamp(40px, 4.6vw, 64px);
  line-height:1.05;
  margin-bottom:14px;
  font-weight:400;
}
.profile-meta h2.name em{ color:var(--gold); font-style:italic; font-weight:300; }
.profile-meta .albo-line{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  color:var(--muted);
  font-size:17px;
  margin-bottom:34px;
}
.profile-meta .gold-rule{
  height:1px; width:80px; background:var(--gold);
  margin-bottom:38px;
  opacity:0.6;
}
.profile-sections{
  display:flex; flex-direction:column; gap:0;
}
.profile-block{
  display:grid;
  grid-template-columns: 180px 1fr;
  gap:32px;
  padding:24px 0;
  border-bottom:0.5px solid var(--line);
}
.profile-block:first-child{ padding-top:0; }
.profile-block:last-child{ border-bottom:0; padding-bottom:0; }
.profile-block .label{
  font-size:11px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);
  padding-top:4px;
}
.profile-block .body{
  color:var(--text);
  font-size:15.5px;
  line-height:1.65;
}
.profile-block .body.muted{ color:var(--muted); font-style:italic; font-weight:300; }
.profile-block .body ul{
  margin:0; padding:0; list-style:none;
  display:flex; flex-direction:column; gap:10px;
}
.profile-block .body ul li{
  display:flex; align-items:baseline; gap:14px;
  font-size:15.5px;
}
.profile-block .body ul li::before{
  content:""; display:inline-block;
  width:8px; height:1px; background:var(--gold);
  transform:translateY(-4px);
  flex-shrink:0;
}
.profile-block .body .lang{
  display:inline-flex; gap:8px; flex-wrap:wrap;
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  font-size:18px;
  color:var(--text);
}
.profile-block .body .lang .dot{ color:var(--gold); }

/* Mid divider with ECG */
.divider-ecg{
  display:flex; align-items:center; justify-content:center;
  gap:24px;
  padding:clamp(36px, 4.5vw, 64px) 0;
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
  background:var(--bg-2);
}
.divider-ecg .line{
  flex:1; max-width:200px;
  height:1px;
  background:var(--line-2);
}
.divider-ecg .ecg-mini-wrap{ width:160px; height:24px; opacity:0.75; }

/* Protocollo section */
.protocollo{
  padding:clamp(80px, 10vw, 140px) 0;
  background:var(--bg);
  text-align:center;
}
.protocollo .inner{
  max-width:780px;
  margin:0 auto;
  display:flex; flex-direction:column; align-items:center; gap:24px;
}
.protocollo .eyebrow{ margin-bottom:6px; }
.protocollo h2{
  font-size:clamp(36px, 4.8vw, 64px);
  max-width:18ch;
  margin:0;
}
.protocollo h2 .italic{ color:var(--gold); }
.protocollo p{
  font-size:clamp(16px, 1.5vw, 19px);
  line-height:1.75;
  color:var(--muted);
  max-width:60ch;
  margin:0;
}
.protocollo .ecg-wrap{
  margin-top:24px; width:100%; max-width:320px; opacity:0.7;
}

@media (max-width: 980px){
  .profile-grid,
  .profile-grid.mirror{ grid-template-columns:1fr; gap:40px; }
  .profile-img-col.right{ order:0; }
  .profile-portrait{ max-width:340px; margin:0 auto; }
  .portrait-caption{ max-width:340px; margin-left:auto; margin-right:auto; }
  .profile-block{ grid-template-columns:1fr; gap:10px; padding:20px 0; }
  .profile-block .label{ padding-top:0; }
}


/* ═════════════════════════════════════════════════════════════════
   FAQ — page-specific components
   ═════════════════════════════════════════════════════════════════ */

.faq-section{
  padding:clamp(50px, 6vw, 90px) 0 clamp(60px, 7vw, 100px) 0;
}
.faq-wrap{
  max-width:920px;
  margin:0 auto;
  border-top:0.5px solid var(--line);
}
.faq-item{
  border-bottom:0.5px solid var(--line);
}
.faq-item summary{
  list-style:none;
  cursor:pointer;
  padding:28px 0;
  display:grid;
  grid-template-columns: 48px 1fr auto;
  gap:24px;
  align-items:center;
  font-family:var(--serif);
  font-size:clamp(19px, 1.8vw, 23px);
  font-weight:400;
  color:var(--text);
  line-height:1.35;
  transition:color .2s ease;
}
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item summary:hover{ color:var(--gold); }
.faq-item summary:hover .faq-chevron{ border-color:var(--gold); color:var(--gold); }
.faq-item .num{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  color:var(--gold);
  font-size:14px;
  letter-spacing:0.05em;
  padding-top:4px;
}
.faq-item .q{ padding-right:8px; }
.faq-item .q em{ color:var(--gold); font-style:italic; font-weight:300; }
.faq-chevron{
  width:36px; height:36px;
  border:0.5px solid var(--line-2);
  border-radius:50%;
  display:inline-flex; align-items:center; justify-content:center;
  color:var(--muted);
  transition:transform .35s cubic-bezier(.4,0,.2,1), border-color .25s ease, color .25s ease;
  flex-shrink:0;
}
.faq-chevron svg{ width:12px; height:12px; }
.faq-item[open] summary{ color:var(--gold); }
.faq-item[open] .faq-chevron{
  transform:rotate(180deg);
  border-color:var(--gold);
  color:var(--gold);
}
.faq-answer{
  padding:0 0 32px 72px;
  font-size:15.5px;
  line-height:1.75;
  color:var(--muted);
  max-width:64ch;
}
.faq-answer p{ margin:0 0 0.9em 0; }
.faq-answer p:last-child{ margin-bottom:0; }
.faq-answer b{ color:var(--text); font-weight:500; }

/* Animate open */
.faq-item[open] .faq-answer{
  animation: faqFade .35s ease both;
}
@keyframes faqFade{
  from{ opacity:0; transform:translateY(-4px); }
  to{ opacity:1; transform:none; }
}

/* "Altre domande?" box */
.altre-domande{
  padding:clamp(60px, 7vw, 100px) 0;
  background:var(--bg-2);
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
}
.altre-box{
  max-width:780px; margin:0 auto;
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
  gap:18px;
}
.altre-box .eyebrow{ display:inline-block; margin-bottom:4px; }
.altre-box h2{
  font-size:clamp(34px, 4.4vw, 56px);
  max-width:18ch;
  margin:0;
}
.altre-box h2 .italic{ color:var(--gold); }
.altre-box .sub{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  color:var(--muted);
  font-size:clamp(18px, 1.8vw, 22px);
  margin-bottom:14px;
}
.altre-box .ctas{
  display:flex; gap:14px; flex-wrap:wrap; justify-content:center;
}

@media (max-width: 720px){
  .faq-item summary{
    grid-template-columns: 36px 1fr 30px;
    gap:14px;
    padding:22px 0;
    font-size:18px;
  }
  .faq-chevron{ width:30px; height:30px; }
  .faq-answer{ padding:0 0 26px 50px; font-size:15px; }
}


/* ═════════════════════════════════════════════════════════════════
   CONTATTI — page-specific components
   ═════════════════════════════════════════════════════════════════ */

/* Three channel cards */
.canali{
  padding:clamp(70px, 8vw, 120px) 0;
}
.canali-grid{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap:1px;
  background:var(--line);
  border:0.5px solid var(--line);
}
.canale{
  background:var(--bg);
  padding:clamp(36px, 4vw, 56px) clamp(28px, 3vw, 44px);
  display:flex; flex-direction:column;
  gap:18px;
  position:relative;
  transition:background .3s ease;
}
.canale:hover{ background:var(--bg-2); }
.canale .icon{
  width:48px; height:48px;
  border:0.5px solid var(--gold);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
  margin-bottom:8px;
}
.canale .icon svg{ width:22px; height:22px; }
.canale h3{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  font-size:clamp(26px, 2.6vw, 34px);
  margin:0;
  color:var(--gold);
}
.canale .value{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(20px, 1.8vw, 24px);
  color:var(--text);
  letter-spacing:-0.01em;
  word-break:break-all;
}
.canale .desc{
  color:var(--muted);
  font-size:13.5px;
  line-height:1.55;
  margin:0;
  flex:1;
}
.canale .btn{ align-self:flex-start; margin-top:8px; }

/* Separator with ECG */
.sep-ecg{
  display:flex; align-items:center; justify-content:center;
  gap:24px;
  padding:0 var(--pad-x);
  max-width:var(--maxw);
  margin:0 auto;
  padding-top:clamp(16px, 2vw, 24px);
  padding-bottom:clamp(16px, 2vw, 24px);
}
.sep-ecg .line{
  flex:1; height:1px; background:var(--line-2);
}
.sep-ecg .ecg-mini-wrap{ width:200px; height:24px; opacity:0.65; }

/* Form section */
.form-section{
  padding:clamp(70px, 8vw, 120px) 0;
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
  background:var(--bg-2);
}
.form-grid{
  display:grid;
  grid-template-columns: 0.7fr 1fr;
  gap:clamp(40px, 6vw, 100px);
  align-items:start;
}
.form-intro .eyebrow{ display:inline-block; margin-bottom:18px; }
.form-intro h2{
  font-size:clamp(36px, 4.4vw, 56px);
  margin:0 0 28px 0;
  max-width:14ch;
}
.form-intro h2 .italic{ color:var(--gold); }
.form-intro p{
  color:var(--muted);
  font-size:16px;
  line-height:1.7;
  max-width:42ch;
  margin:0 0 22px 0;
}
.form-intro .gdpr-note{
  font-size:12px;
  color:var(--muted);
  line-height:1.6;
  font-style:italic;
  padding-top:22px;
  border-top:0.5px solid var(--line);
  margin:0;
}

/* Form fields */
.contact-form{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:22px;
}
.field{ display:flex; flex-direction:column; gap:8px; }
.field.full{ grid-column:1 / -1; }
.field label{
  font-family:var(--sans);
  font-size:10.5px;
  text-transform:uppercase;
  letter-spacing:0.22em;
  color:var(--muted);
  font-weight:500;
}
.field label .req{ color:var(--gold); margin-left:2px; }
.field input,
.field select,
.field textarea{
  font-family:var(--sans);
  font-size:15px;
  color:var(--text);
  background:var(--bg-3);
  border:0.5px solid var(--line-2);
  border-radius:2px;
  padding:14px 16px;
  width:100%;
  transition:border-color .25s ease, background .25s ease;
  outline:none;
}
.field input::placeholder,
.field textarea::placeholder{ color:rgba(184,175,163,0.45); }
.field input:hover,
.field select:hover,
.field textarea:hover{ border-color:rgba(212,165,116,0.4); }
.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color:var(--gold);
  background:var(--bg);
}
.field textarea{
  min-height:140px;
  resize:vertical;
  line-height:1.55;
  font-family:var(--sans);
}
.field select{
  appearance:none;
  -webkit-appearance:none;
  background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none' stroke='%23D4A574' stroke-width='1'><path d='M1 2 L6 7 L11 2'/></svg>");
  background-repeat:no-repeat;
  background-position: right 16px center;
  padding-right:42px;
}
.field input[type="date"]{
  color-scheme: dark;
}
.field input[type="date"]::-webkit-calendar-picker-indicator{
  filter:invert(0.7) sepia(0.6) saturate(2) hue-rotate(-10deg);
  cursor:pointer;
}

/* Checkbox */
.checkbox-field{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns: auto 1fr;
  gap:14px;
  align-items:start;
  padding:18px 0 4px 0;
  cursor:pointer;
}
.checkbox-field input{
  appearance:none;
  -webkit-appearance:none;
  width:18px; height:18px;
  border:0.5px solid var(--line-2);
  border-radius:2px;
  background:var(--bg-3);
  cursor:pointer;
  position:relative;
  transition:border-color .2s ease, background .2s ease;
  margin-top:2px;
  flex-shrink:0;
}
.checkbox-field input:hover{ border-color:var(--gold); }
.checkbox-field input:checked{
  background:var(--gold);
  border-color:var(--gold);
}
.checkbox-field input:checked::after{
  content:""; position:absolute;
  left:5px; top:1.5px;
  width:5px; height:10px;
  border:solid #1A1410;
  border-width:0 1.5px 1.5px 0;
  transform:rotate(45deg);
}
.checkbox-field .label{
  font-size:13.5px;
  color:var(--muted);
  line-height:1.55;
}
.checkbox-field .label a{ color:var(--gold); border-bottom:0.5px solid var(--gold); }
.checkbox-field .label a:hover{ color:var(--text); border-color:var(--text); }

.form-submit{
  grid-column:1 / -1;
  padding-top:14px;
  display:flex; align-items:center; gap:20px;
  flex-wrap:wrap;
}
.form-submit .meta{
  font-size:12px;
  color:var(--muted);
  font-style:italic;
}

/* Dove siamo */
.dove{ padding:clamp(80px, 9vw, 130px) 0; }
.dove .head{ margin-bottom:48px; }
.dove .head .eyebrow{ display:inline-block; margin-bottom:14px; }
.dove .head h2{ font-size:clamp(40px, 5vw, 64px); max-width:14ch; }
.dove .head h2 .italic{ color:var(--gold); }
.dove-grid{
  display:grid;
  grid-template-columns: 0.85fr 1.15fr;
  gap:clamp(40px, 5vw, 80px);
  align-items:start;
}
.dove-info{ display:flex; flex-direction:column; gap:32px; }
.info-block .label{
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:0.22em;
  color:var(--muted);
  margin-bottom:14px;
  font-family:var(--sans);
  font-weight:500;
}
.info-block .body{
  font-family:var(--serif);
  font-size:18px;
  line-height:1.55;
  color:var(--text);
  font-weight:400;
}
.info-block .body em{ color:var(--gold); font-style:italic; font-weight:300; }
.info-block .body.small{ font-family:var(--sans); font-size:14.5px; color:var(--muted); line-height:1.7; }
.info-block .body.small b{ color:var(--text); font-weight:500; }
.orari-grid{
  display:grid;
  grid-template-columns: 1fr auto;
  gap:8px 24px;
  font-family:var(--sans);
  font-size:14.5px;
}
.orari-grid .day{ color:var(--muted); }
.orari-grid .hours{
  color:var(--text);
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
}
.orari-grid .hours.closed{ color:var(--muted); }
.dove-note{
  margin-top:24px;
  padding:14px 18px;
  border:0.5px solid var(--line);
  background:var(--bg-2);
  color:var(--muted);
  font-size:13px;
  font-style:italic;
  line-height:1.5;
}

/* Map placeholder */
.map-wrap{
  position:relative;
  width:100%;
  aspect-ratio: 16/11;
  border:0.5px solid var(--line-2);
  overflow:hidden;
  background:
    /* warm overlay */
    linear-gradient(180deg, rgba(26,20,16,0.4), rgba(26,20,16,0.5)),
    /* faint streets pattern */
    repeating-linear-gradient(35deg, rgba(212,165,116,0.05) 0 1px, transparent 1px 26px),
    repeating-linear-gradient(125deg, rgba(212,165,116,0.04) 0 1px, transparent 1px 32px),
    repeating-linear-gradient(0deg, rgba(245,241,234,0.025) 0 1px, transparent 1px 60px),
    repeating-linear-gradient(90deg, rgba(245,241,234,0.025) 0 1px, transparent 1px 90px),
    linear-gradient(180deg, var(--bg-3), var(--bg-2));
}
.map-wrap iframe{
  position:absolute; inset:0;
  width:100%; height:100%;
  border:0;
  filter: invert(0.92) hue-rotate(180deg) saturate(0.6) brightness(0.85);
}
.map-pin{
  position:absolute;
  top:50%; left:50%;
  transform:translate(-50%, -50%);
  display:flex; flex-direction:column; align-items:center;
  z-index:2;
}
.map-pin .ring{
  width:46px; height:46px;
  border:0.5px solid var(--gold);
  border-radius:50%;
  position:relative;
  display:flex; align-items:center; justify-content:center;
}
.map-pin .ring::before{
  content:""; position:absolute; inset:-8px;
  border:0.5px solid var(--gold);
  border-radius:50%;
  opacity:0.4;
  animation: pinPulse 2.4s ease-out infinite;
}
@keyframes pinPulse{
  0%{ transform:scale(1); opacity:0.5; }
  100%{ transform:scale(1.6); opacity:0; }
}
.map-pin .dot{
  width:8px; height:8px; background:var(--gold); border-radius:50%;
}
.map-pin .tag{
  margin-top:14px;
  font-family:var(--sans);
  font-size:10px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  background:rgba(26,20,16,0.85);
  padding:6px 12px;
  border:0.5px solid var(--gold);
  white-space:nowrap;
}
.map-corner{
  position:absolute;
  font-family:"Inter", monospace;
  font-size:9.5px;
  letter-spacing:0.18em;
  text-transform:uppercase;
  color:var(--muted);
  opacity:0.7;
}
.map-corner.tl{ top:14px; left:16px; }
.map-corner.tr{ top:14px; right:16px; color:var(--gold); }
.map-corner.bl{ bottom:14px; left:16px; }
.map-corner.br{ bottom:14px; right:16px; }
.map-actions{
  margin-top:18px;
  display:flex; justify-content:flex-start;
}

/* Warm final CTA on contatti */
.final-cta.warm{
  background:
    radial-gradient(ellipse at 50% 0%, rgba(212,165,116,0.07), transparent 60%),
    var(--bg-2);
}

@media (max-width: 980px){
  .canali-grid{ grid-template-columns:1fr; }
  .form-grid, .dove-grid{ grid-template-columns:1fr; gap:40px; }
  .contact-form{ grid-template-columns:1fr; gap:18px; }
}

@media (max-width: 540px){
  .form-submit{ flex-direction:column; align-items:stretch; }
  .form-submit .btn{ width:100%; justify-content:center; }
}


/* ═════════════════════════════════════════════════════════════════
   BLOG — page-specific components
   ═════════════════════════════════════════════════════════════════ */

.blog-section{
  padding:clamp(70px, 8vw, 120px) 0;
}
.blog-section .section-head{
  margin-bottom:clamp(40px, 5vw, 64px);
}
.blog-section .section-head .meta{
  display:flex; align-items:center; gap:14px;
  color:var(--muted);
  font-size:12px; letter-spacing:0.12em; text-transform:uppercase;
}
.blog-section .section-head .meta .dot{
  width:6px; height:6px; border-radius:50%;
  background:var(--ecg-green);
  box-shadow:0 0 0 4px rgba(125,168,111,0.12);
}

.blog-grid{
  display:grid;
  grid-template-columns:repeat(3, 1fr);
  gap:1px;
  background:var(--line);
  border:0.5px solid var(--line);
}
.article-card{
  background:var(--bg);
  padding:clamp(28px, 3vw, 44px);
  display:flex; flex-direction:column;
  gap:18px;
  min-height:340px;
  position:relative;
  transition:background .3s ease;
}
.article-card.placeholder{
  background:var(--bg);
}
.article-card.placeholder .thumb{
  background:
    repeating-linear-gradient(45deg, rgba(212,165,116,0.06) 0 1px, transparent 1px 9px),
    linear-gradient(180deg, var(--bg-3), var(--bg-2));
  filter:saturate(0.4);
}
.article-card .thumb{
  aspect-ratio: 16/10;
  background: linear-gradient(180deg, var(--bg-3), var(--bg-2));
  border:0.5px solid var(--line-2);
  margin-bottom:6px;
  position:relative;
  display:flex; align-items:center; justify-content:center;
  overflow:hidden;
}
.article-card .thumb.thumb-image img{
  width:100%; height:100%;
  object-fit:cover;
  display:block;
  transition: transform .4s ease;
}
.article-card-link:hover .thumb.thumb-image img{
  transform: scale(1.03);
}
.article-card .thumb .glyph{
  font-family:var(--serif);
  font-style:italic;
  color:var(--gold-dim);
  opacity:0.5;
  font-size:42px;
  letter-spacing:-0.02em;
}
.article-card .category{
  font-family:var(--sans);
  font-size:10.5px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--gold);
  font-weight:500;
}
.article-card .category .dash{ color:var(--gold-dim); margin-right:6px; }
.article-card h3{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(22px, 2vw, 28px);
  line-height:1.2;
  color:var(--text);
  margin:0;
}
.article-card.placeholder h3{
  color:var(--muted);
  font-style:italic;
  font-weight:300;
}
.article-card p{
  color:var(--muted);
  font-size:14px;
  line-height:1.65;
  margin:0;
  flex:1;
  font-style:italic;
  font-weight:300;
}
.article-card .footer{
  display:flex; justify-content:space-between; align-items:center;
  padding-top:18px;
  border-top:0.5px solid var(--line);
  font-size:11.5px;
  letter-spacing:0.05em;
  color:var(--muted);
}
.article-card .footer .date{
  font-family:var(--serif);
  font-style:italic;
  font-size:14px;
  color:var(--gold-dim);
}
.article-card .footer .arrow-dim{
  color:var(--muted);
  opacity:0.5;
}
.article-card.placeholder .footer .arrow-dim{ opacity:0.3; }

/* Article card linkabile (articoli reali, non placeholder) */
.article-card-link{
  display:flex; flex-direction:column;
  gap:18px;
  color:inherit;
  text-decoration:none;
  height:100%;
}
.article-card-link:hover h3{
  color:var(--gold);
}
.article-card-link:hover .arrow{
  transform:translateX(4px);
}
.article-card:not(.placeholder){
  transition:background .25s ease, transform .25s ease;
  cursor:pointer;
}
.article-card:not(.placeholder):hover{
  background:rgba(212,164,107,0.03);
}
.article-card:not(.placeholder) .footer .arrow{
  color:var(--gold);
  transition:transform .25s ease;
  display:inline-block;
}
.article-card:not(.placeholder) .thumb{
  background:
    repeating-linear-gradient(135deg, rgba(212,165,116,0.08) 0 1px, transparent 1px 14px),
    linear-gradient(180deg, var(--bg-3), var(--bg-2));
}
.article-card:not(.placeholder) .thumb .glyph{
  color:var(--gold);
  opacity:0.75;
}
.article-card:not(.placeholder) h3{
  transition:color .2s ease;
}

/* Newsletter */
.newsletter{
  background:var(--bg-2);
  border-top:0.5px solid var(--line);
  border-bottom:0.5px solid var(--line);
  padding:clamp(60px, 7vw, 100px) 0;
}
.newsletter-inner{
  max-width:780px; margin:0 auto;
  text-align:center;
  display:flex; flex-direction:column; align-items:center;
  gap:16px;
}
.newsletter .eyebrow{ display:inline-block; margin-bottom:4px; }
.newsletter h2{
  font-size:clamp(32px, 4vw, 50px);
  max-width:20ch;
  margin:0;
}
.newsletter h2 .italic{ color:var(--gold); }
.newsletter .sub{
  font-family:var(--serif);
  font-style:italic; font-weight:300;
  color:var(--muted);
  font-size:clamp(16px, 1.6vw, 19px);
  max-width:48ch;
  margin-bottom:18px;
}
.newsletter form.nl-form{
  display:grid;
  grid-template-columns: 1fr auto;
  gap:10px;
  width:100%;
  max-width:520px;
  align-items:stretch;
}
.newsletter form.nl-form input{
  font-family:var(--sans);
  font-size:15px;
  color:var(--text);
  background:var(--bg-3);
  border:0.5px solid var(--line-2);
  border-radius:2px;
  padding:14px 18px;
  outline:none;
  transition:border-color .25s ease;
}
.newsletter form.nl-form input::placeholder{ color:rgba(184,175,163,0.5); }
.newsletter form.nl-form input:focus{ border-color:var(--gold); }
.newsletter form.nl-form .btn{ white-space:nowrap; }
.newsletter .note{
  font-size:12px;
  color:var(--muted);
  font-style:italic;
  margin-top:6px;
}

@media (max-width: 980px){
  .blog-grid{ grid-template-columns:1fr; }
  .article-card{ min-height:auto; }
}
@media (max-width: 540px){
  .newsletter form.nl-form{
    grid-template-columns:1fr;
  }
  .newsletter form.nl-form .btn{ justify-content:center; }
}


/* ═════════════════════════════════════════════════════════════════
   LE SEDI — two-studio layout on contatti
   ═════════════════════════════════════════════════════════════════ */

.sedi-section{
  padding:clamp(80px, 9vw, 130px) 0;
}
.sedi-section .head{
  margin-bottom:clamp(48px, 5vw, 72px);
  max-width:780px;
}
.sedi-section .head .eyebrow{ display:inline-block; margin-bottom:14px; }
.sedi-section .head h2{
  font-size:clamp(36px, 4.4vw, 60px);
  margin:0 0 24px 0;
  max-width:20ch;
}
.sedi-section .head h2 .italic{ color:var(--gold); }
.sedi-section .head p{
  color:var(--muted);
  font-size:16px;
  line-height:1.7;
  max-width:62ch;
  margin:0;
}

.sedi-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:1px;
  background:var(--line);
  border:0.5px solid var(--line);
}
.sede-card{
  background:var(--bg);
  padding:clamp(32px, 3.4vw, 48px);
  display:flex; flex-direction:column;
  gap:0;
}
.sede-card .label-top{
  font-family:var(--sans);
  font-size:10.5px;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--muted);
  font-weight:500;
  margin-bottom:18px;
}
.sede-card .label-top::before{
  content:""; display:inline-block;
  width:24px; height:1px; background:var(--gold);
  vertical-align:middle;
  margin-right:12px;
  transform:translateY(-2px);
}
.sede-card h3.sede-name{
  font-family:var(--serif);
  font-weight:400;
  font-size:clamp(28px, 2.8vw, 36px);
  margin:0 0 6px 0;
  line-height:1.1;
}
.sede-card h3.sede-name em{ color:var(--gold); font-style:italic; font-weight:300; }
.sede-card .sede-role{
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
  color:var(--muted);
  font-size:17px;
  margin:0 0 24px 0;
}
.sede-card .gold-line{
  height:1px; width:60px; background:var(--gold);
  opacity:0.6;
  margin-bottom:28px;
}

.sede-detail{
  display:flex; flex-direction:column; gap:24px;
  margin-bottom:28px;
}
.sede-detail .item{
  display:grid;
  grid-template-columns: 140px 1fr;
  gap:18px;
  align-items:start;
}
.sede-detail .item .k{
  font-size:10.5px;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--muted);
  font-family:var(--sans);
  font-weight:500;
  padding-top:4px;
}
.sede-detail .item .v{
  color:var(--text);
  font-size:15.5px;
  line-height:1.65;
  font-family:var(--serif);
  font-weight:400;
}
.sede-detail .item .v em{ font-style:italic; color:var(--muted); font-weight:300; }
.sede-detail .item .v.small{
  font-family:var(--sans);
  font-size:14px;
  color:var(--muted);
  line-height:1.7;
}
.sede-detail .item .v.small b{ color:var(--text); font-weight:500; }
.sede-detail .item .v.small .row{ display:block; margin-bottom:4px; }
.sede-detail .item .v.hours-grid{
  display:grid;
  grid-template-columns: 1fr auto;
  gap:6px 18px;
  font-family:var(--sans);
  font-size:14.5px;
}
.sede-detail .item .v.hours-grid .day{ color:var(--muted); }
.sede-detail .item .v.hours-grid .h{
  color:var(--text);
  font-family:var(--serif);
  font-style:italic;
  font-weight:300;
}

.sede-card .map-wrap{
  aspect-ratio: 16/10;
  margin-bottom:18px;
}
.sede-card .map-actions{
  margin-top:0;
}

/* Info note below both studios */
.sedi-note{
  margin-top:36px;
  padding:18px 22px;
  border:0.5px solid var(--line);
  background:var(--bg-2);
  color:var(--muted);
  font-size:14px;
  line-height:1.6;
  display:flex; align-items:center; gap:16px;
  max-width:760px;
  margin-left:auto; margin-right:auto;
}
.sedi-note .icon{
  width:32px; height:32px;
  border:0.5px solid var(--gold);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  color:var(--gold);
  flex-shrink:0;
}
.sedi-note .icon svg{ width:14px; height:14px; }
.sedi-note b{ color:var(--text); font-weight:500; }

@media (max-width: 980px){
  .sedi-grid{ grid-template-columns:1fr; }
  .sede-detail .item{ grid-template-columns:1fr; gap:6px; }
  .sede-detail .item .k{ padding-top:0; }
  .sedi-note{ flex-direction:column; align-items:flex-start; text-align:left; }
}


/* Studio actions row (Chiama / Email / Maps) */
.studio-actions{
  display:flex; flex-wrap:wrap; gap:8px;
  margin-top:0;
}
.studio-actions .btn{
  padding:12px 18px;
  font-size:12.5px;
  letter-spacing:0.04em;
}
.studio-actions .btn svg{ flex-shrink:0; }

@media (max-width: 600px){
  .studio-actions{ flex-direction:column; align-items:stretch; }
  .studio-actions .btn{ justify-content:center; }
}

/* Increase form textarea minimum height in simplified form */
.contact-form textarea{
  min-height:220px;
}

/* Article share buttons (top + bottom) */
.article-share {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 14px 0;
  border-top: 0.5px solid var(--line);
  border-bottom: 0.5px solid var(--line);
  margin: 24px auto;
  max-width: 720px;
  flex-wrap: wrap;
}
.article-share .share-label {
  font-family: var(--sans);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.18em;
  color: var(--muted);
  text-transform: uppercase;
}
.article-share .share-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.article-share .share-btn {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 0.5px solid var(--line);
  background: transparent;
  color: var(--gold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: border-color .15s ease, background .15s ease, transform .15s ease, color .15s ease;
  text-decoration: none;
  padding: 0;
}
.article-share .share-btn:hover {
  border-color: var(--gold);
  background: rgba(212,164,107,0.08);
  transform: translateY(-1px);
}
.article-share .share-btn:active { transform: translateY(0); }
.article-share .share-btn svg {
  width: 16px;
  height: 16px;
  fill: currentColor;
}
.article-share .share-btn.copied {
  border-color: var(--gold);
  background: rgba(212,164,107,0.15);
}
.share-toast {
  position: fixed;
  bottom: 24px;
  left: 50%;
  transform: translateX(-50%) translateY(100px);
  background: var(--bg-3, #2a1f18);
  border: 0.5px solid var(--gold);
  color: var(--text);
  padding: 12px 20px;
  border-radius: 4px;
  font-size: 13px;
  z-index: 1000;
  transition: transform .3s cubic-bezier(.4,0,.2,1), opacity .3s;
  opacity: 0;
  pointer-events: none;
  font-family: var(--sans);
  box-shadow: 0 8px 24px rgba(0,0,0,0.3);
}
.share-toast.show {
  transform: translateX(-50%) translateY(0);
  opacity: 1;
}
@media (max-width: 580px) {
  .article-share { gap: 10px; padding: 12px 16px; }
  .article-share .share-label { font-size: 10px; flex-basis: 100%; }
}
