/* Sana — portale prenotazioni. Design system replicato dal tema sana.med */

:root{
  --sana-teal:#1E7A8C; --sana-teal-dark:#155765; --sana-teal-deep:#0D3B45;
  --sana-teal-light:#E8F1F3; --sana-orange:#F5A62E; --sana-orange-deep:#E08A18;
  --sana-orange-light:#FDF3E0;
  --sana-ink:#0F1720; --sana-ink-80:#2A333F; --sana-ink-60:#55606D; --sana-ink-40:#8B93A0;
  --sana-ink-20:#CFD4DB; --sana-ink-10:#E6E9EE; --sana-ink-05:#F1F3F6;
  --sana-paper:#FAF8F4; --sana-white:#FFFFFF;
  --sana-sans:"Inter Tight","Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  --sana-serif:"Source Serif 4","Source Serif Pro",Georgia,serif;
  --sana-mono:"JetBrains Mono",ui-monospace,"SFMono-Regular",monospace;
  --sana-max:1320px; --sana-pad-x:64px; --sana-radius:4px;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{margin:0;font-family:var(--sana-sans);color:var(--sana-ink);background:var(--sana-paper);
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;line-height:1.5}
img,svg{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
a:hover{opacity:.85}
button{font:inherit;cursor:pointer}
h1,h2,h3,p,ul{margin:0}
ul{padding:0;list-style:none}

/* layout */
.sana-shell{max-width:1440px;margin:0 auto;width:100%;background:var(--sana-paper)}
.sana-section{padding:80px var(--sana-pad-x)}
.sana-section--sm{padding:48px var(--sana-pad-x)}
.sana-section--paper{background:var(--sana-paper)}
.sana-section--teal-deep{background:var(--sana-teal-deep);color:var(--sana-white)}
.sana-container{max-width:var(--sana-max);margin:0 auto}

/* typography */
.sana-eyebrow{display:inline-flex;align-items:center;gap:8px;font-size:12px;font-weight:600;
  text-transform:uppercase;letter-spacing:.12em;color:var(--sana-teal)}
.sana-eyebrow::before{content:"";width:24px;height:1px;background:currentColor;display:inline-block}
.sana-eyebrow--orange{color:var(--sana-orange)}
.sana-h1{font-size:64px;font-weight:600;line-height:1.02;letter-spacing:-.03em;margin-top:18px}
.sana-h1--serif{font-family:var(--sana-serif);font-weight:500}
.sana-lede{font-size:20px;line-height:1.5;color:var(--sana-ink-60);margin-top:20px;max-width:680px}
.sana-section--teal-deep .sana-lede{color:rgba(255,255,255,.78)}

/* buttons (pill) */
.sana-btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font-family:var(--sana-sans);
  font-weight:600;text-decoration:none;border:none;letter-spacing:-.01em;border-radius:999px;
  padding:12px 22px;font-size:15px;transition:.15s}
.sana-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px rgba(0,0,0,.08);opacity:1}
.sana-btn:disabled,.sana-btn[disabled]{background:var(--sana-ink-10,#e2e0dc);color:var(--sana-ink-40,#9a958d);
  cursor:not-allowed;opacity:.7;box-shadow:none;transform:none}
/* "spento" ma ancora cliccabile: grigio, ma il click mostra l'alert */
.sana-btn--off{background:var(--sana-ink-10,#e2e0dc);color:var(--sana-ink-40,#9a958d);cursor:not-allowed;box-shadow:none;transform:none}
.sana-btn--off:hover{transform:none;box-shadow:none}
.sana-btn--lg{padding:16px 28px;font-size:16px}
.sana-btn--primary{background:var(--sana-teal);color:var(--sana-white)}
.sana-btn--orange{background:var(--sana-orange);color:var(--sana-ink)}
.sana-btn--ghost{background:transparent;color:var(--sana-ink);border:1px solid var(--sana-ink-20)}

/* chips */
.sana-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:500;
  padding:6px 12px;border-radius:999px;border:1px solid transparent}
.sana-chip--teal{background:var(--sana-teal-light);color:var(--sana-teal-dark)}
.sana-chip--orange{background:var(--sana-orange-light);color:var(--sana-orange-deep)}
.sana-chip--default{background:var(--sana-ink-05);color:var(--sana-ink)}

/* nav */
.sana-nav{position:sticky;top:0;z-index:50;background:rgba(255,255,255,.92);
  backdrop-filter:saturate(1.2) blur(12px);-webkit-backdrop-filter:saturate(1.2) blur(12px);
  border-bottom:1px solid var(--sana-ink-10)}
.sana-nav__inner{max-width:1320px;margin:0 auto;padding:16px 32px;display:grid;
  grid-template-columns:auto 1fr auto;align-items:center;gap:32px}
.sana-nav__links{display:flex;gap:28px;justify-content:center;flex-wrap:wrap}
.sana-nav__link{font-size:14px;font-weight:500;letter-spacing:-.01em;color:var(--sana-ink-60);
  border-bottom:1px solid transparent;padding-bottom:2px}
.sana-nav__cta{display:flex;align-items:center;gap:10px}
.sana-nav__area-aziende{display:inline-flex;align-items:center;gap:8px;font-size:13px;font-weight:500;
  color:var(--sana-ink);padding:8px 14px;border-radius:999px;border:1px solid var(--sana-ink-10)}
.sana-nav__preventivo{display:inline-flex;align-items:center;font-size:13px;font-weight:600;
  color:var(--sana-white);background:var(--sana-teal);padding:9px 16px;border-radius:999px}

/* logo */
.sana-logo{display:inline-flex;align-items:center;gap:10px;color:inherit}
.sana-logo__img{height:32px;width:auto}
.sana-logo__text{display:flex;flex-direction:column;line-height:1}
.sana-logo__name{font-weight:700;font-size:24px;letter-spacing:-.02em}
.sana-logo__name .dot{color:var(--sana-orange)}
.sana-logo__tag{font-weight:500;font-size:10px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--sana-ink-60);margin-top:2px}
.sana-logo--light .sana-logo__name{color:var(--sana-white)}
.sana-logo--light .sana-logo__tag{color:rgba(255,255,255,.65)}

/* hero */
.hero{padding-top:72px;padding-bottom:96px}

/* filtri (card bianca che si sovrappone all'hero) */
.filters{display:grid;grid-template-columns:1.4fr 1.4fr .85fr .85fr auto;gap:16px;align-items:end;
  background:var(--sana-white);border:1px solid var(--sana-ink-10);border-radius:var(--sana-radius);
  padding:22px;margin-top:-72px;position:relative;z-index:2;box-shadow:0 16px 40px rgba(13,59,69,.12)}
.field{display:flex;flex-direction:column;gap:6px;min-width:0}
.field label{font-size:12px;font-weight:600;color:var(--sana-ink-60);text-transform:uppercase;letter-spacing:.06em}
.field .opt{text-transform:none;font-weight:400;color:var(--sana-ink-40)}
.field select,.field input{padding:12px;border:1px solid var(--sana-ink-20);border-radius:var(--sana-radius);
  font-family:var(--sana-sans);font-size:15px;background:var(--sana-white);color:var(--sana-ink);width:100%}
.field select:focus,.field input:focus{outline:none;border-color:var(--sana-teal)}
.field--btn{align-self:end}
#search{width:100%}

/* riga servizio + prezzo */
.service-meta{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin-top:28px}
.service-meta__name{font-family:var(--sana-serif);font-size:24px;font-weight:600}
.service-meta__price{font-family:var(--sana-mono);font-size:13px}
.service-meta__note{font-size:13px;color:var(--sana-ink-60)}

/* stato */
.status{margin-top:26px;padding:18px;border-radius:var(--sana-radius);background:var(--sana-white);
  border:1px solid var(--sana-ink-10);color:var(--sana-ink-60);text-align:center}

/* risultati */
.results{margin-top:24px;display:flex;flex-direction:column;gap:18px}
.day{background:var(--sana-white);border:1px solid var(--sana-ink-10);border-radius:var(--sana-radius);overflow:hidden}
.day__h{padding:13px 20px;background:var(--sana-ink-05);font-weight:600;text-transform:capitalize;
  border-bottom:1px solid var(--sana-ink-10);font-size:15px}
.slots{display:flex;flex-wrap:wrap;gap:10px;padding:18px 20px}
.slot{display:flex;flex-direction:column;align-items:flex-start;gap:2px;border:1px solid var(--sana-ink-20);
  border-radius:var(--sana-radius);padding:9px 14px;background:var(--sana-white);cursor:pointer;
  text-decoration:none;color:var(--sana-ink);transition:.12s}
.slot:hover{border-color:var(--sana-teal);background:var(--sana-teal-light);opacity:1;transform:translateY(-1px)}
.slot__t{font-weight:700;font-size:16px;letter-spacing:-.01em}
.slot__p{font-size:12px;color:var(--sana-ink-60)}

/* footer */
.sana-footer{background:var(--sana-ink);color:var(--sana-white);padding:72px 32px 32px;font-family:var(--sana-sans)}
.sana-footer__inner{max-width:1320px;margin:0 auto;display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px}
.sana-footer__intro{margin-top:20px;font-size:14px;line-height:1.6;color:rgba(255,255,255,.65);max-width:340px}
.sana-footer__badges{margin-top:24px;display:flex;gap:10px;flex-wrap:wrap}
.sana-footer__badge{font-size:11px;font-weight:500;padding:6px 10px;border-radius:var(--sana-radius)}
.sana-footer__badge--orange{background:rgba(245,166,46,.15);color:var(--sana-orange)}
.sana-footer__badge--neutral{background:rgba(255,255,255,.08);color:rgba(255,255,255,.8)}
.sana-footer__col-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.08em;
  color:rgba(255,255,255,.5);margin-bottom:16px}
.sana-footer__col ul{display:flex;flex-direction:column;gap:10px}
.sana-footer__col a{color:rgba(255,255,255,.85);font-size:14px}
.sana-footer__bottom{max-width:1320px;margin:56px auto 0;padding-top:24px;
  border-top:1px solid rgba(255,255,255,.08);display:flex;justify-content:space-between;
  gap:20px;flex-wrap:wrap;font-size:13px;color:rgba(255,255,255,.6)}
.sana-footer__legal-links{display:flex;gap:24px}

/* responsive */
@media(max-width:920px){
  .sana-section{padding:48px 22px}
  .sana-section--sm{padding:28px 22px}
  .sana-nav__inner{grid-template-columns:1fr auto;gap:12px;padding:12px 18px}
  .sana-nav__links{display:none}
  .sana-nav__cta{justify-content:flex-end}
  .hero{padding-top:44px;padding-bottom:64px}
  .sana-h1{font-size:40px;margin-top:14px}
  .sana-lede{font-size:17px;margin-top:16px}
  .filters{grid-template-columns:1fr 1fr;gap:14px;padding:18px;margin-top:-40px}
  .field--btn{grid-column:1 / -1}
  .service-meta{margin-top:22px}
  .service-meta__name{font-size:21px}
  .sana-footer{padding:48px 22px 28px}
  .sana-footer__inner{grid-template-columns:1fr 1fr;gap:28px}
  .sana-footer__bottom{flex-direction:column;gap:12px;margin-top:36px}
}
@media(max-width:560px){
  .sana-logo__img{height:28px}
  .sana-logo__name{font-size:20px}
  .hero{padding-bottom:56px}
  .sana-h1{font-size:32px}
  .filters{grid-template-columns:1fr;margin-top:-32px}
  .field select,.field input{font-size:16px}     /* evita lo zoom auto su iOS */
  .slots{gap:8px}
  .slot{flex:1 1 calc(50% - 8px)}                 /* due slot per riga, tap target ampi */
  .sana-footer__inner{grid-template-columns:1fr;gap:24px}
  .sana-nav__area-aziende{display:none}
}
