:root{
  --bg:#ffffff;--surface:#ffffff;--surface2:#f6f7fb;--border:#e7e9f2;
  --text:#111827;--muted:#4b5563;--accent:#2563eb;--accent2:#0ea5e9;
  --radius:16px;--shadow:0 10px 28px rgba(17,24,39,.08);
}
*{box-sizing:border-box}html,body{height:100%}
body{margin:0;font-family:ui-sans-serif,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--text);background:var(--bg);-webkit-text-size-adjust:100%}
a{color:inherit}.container{width:min(1100px,92%);margin:0 auto}
.topbar{
  position:sticky;top:0;z-index:50;
  background:rgba(255,255,255,.86);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
}
.nav{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 0}
.brand{display:flex;align-items:center;gap:10px;text-decoration:none;min-width:180px;color:var(--text)}
.brand-mark{
  width:34px;height:34px;border-radius:12px;
  background:linear-gradient(135deg,var(--accent),var(--accent2));
  box-shadow:0 10px 26px rgba(17,24,39,.08);
}
.brand-title strong{display:block;font-size:15px;letter-spacing:.2px}
.brand-title span{display:block;font-size:12px;color:var(--muted)}
.menu{display:flex;gap:8px;align-items:center}
.menu a{
  text-decoration:none;padding:10px 12px;border-radius:999px;
  border:1px solid transparent;color:var(--muted);
  font-weight:900;font-size:14px;transition:background .15s ease,border-color .15s ease,color .15s ease;
}
.menu a:hover{background:rgba(17,24,39,.04);border-color:var(--border);color:var(--text)}
.menu a.active{background:rgba(37,99,235,.10);border-color:rgba(37,99,235,.22);color:var(--text)}
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  padding:11px 14px;border-radius:999px;min-height:44px;
  border:1px solid rgba(37,99,235,.25);
  background:rgba(37,99,235,.08);
  color:var(--text);text-decoration:none;font-weight:900;font-size:14px;
  box-shadow:0 10px 26px rgba(17,24,39,.06);
}
.btn:hover{border-color:rgba(37,99,235,.4)}
.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff}
.burger{
  display:none;border:1px solid var(--border);background:#fff;border-radius:14px;
  width:44px;height:44px;align-items:center;justify-content:center;
  box-shadow:0 10px 26px rgba(17,24,39,.06);
}
.burger-lines{width:18px;height:12px;position:relative}
.burger-lines span{position:absolute;left:0;right:0;height:2px;background:#111827;border-radius:2px}
.burger-lines span:nth-child(1){top:0}.burger-lines span:nth-child(2){top:5px}.burger-lines span:nth-child(3){bottom:0}
.nav-right{display:flex;align-items:center;gap:10px}
.mobile-panel{display:none;border-top:1px solid var(--border);background:#fff}
.mobile-panel.open{display:block}
.mobile-panel-inner{padding:10px 0 14px;display:grid;gap:10px}
.mobile-links{display:flex;gap:10px;flex-wrap:wrap}.mobile-links a{flex:1 1 auto;text-align:center}
.hero{padding:18px 0 10px}
.hero-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:18px}
.kicker{display:inline-flex;padding:7px 10px;border-radius:999px;background:rgba(14,165,233,.1);border:1px solid rgba(14,165,233,.18);color:#0f172a;font-weight:900;font-size:12px}
.hero h1{margin:12px 0 8px;font-size:clamp(24px,5.2vw,40px);letter-spacing:-.02em}
.hero p{margin:0;color:var(--muted);line-height:1.7;font-size:16px}
.quick{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:14px}
.quick-item{padding:12px 14px;border-radius:14px;background:var(--surface2);border:1px solid var(--border)}
.quick-item strong{display:block;font-size:14px}
.quick-item span{display:block;font-size:14px;color:var(--muted);margin-top:2px}
.section-title{margin:18px 0 8px;font-size:18px}
.section-sub{margin:0 0 12px;color:var(--muted);line-height:1.65;font-size:15px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;padding:6px 0 18px}
.card{display:block;text-decoration:none;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);padding:18px;box-shadow:0 6px 18px rgba(17,24,39,.06);transition:transform .12s ease,box-shadow .12s ease}
.card:hover{transform:translateY(-2px);box-shadow:0 10px 26px rgba(17,24,39,.1)}
.card h3{margin:8px 0 8px;font-size:17px}
.card p{margin:0;color:var(--muted);line-height:1.6;font-size:15px}
.badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(37,99,235,.1);border:1px solid rgba(37,99,235,.18);color:#0f172a;font-weight:900;font-size:12px}
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:18px;box-shadow:0 6px 18px rgba(17,24,39,.06);margin:14px 0}
.breadcrumb{margin:14px 0 0;color:var(--muted);font-size:14px}
.breadcrumb a{color:var(--accent);text-decoration:none;font-weight:900}
ul.docs{margin:10px 0 0;padding-left:18px;color:var(--muted);line-height:1.9;font-size:15px}
.footer{border-top:1px solid var(--border);padding:18px 0 26px;color:var(--muted);margin-top:18px;font-size:14px}

/* Booking */

.booking-grid .calendar{ grid-area: cal; }
.booking-grid .side{ grid-area: side; display:grid; gap:10px; }

@media (max-width: 900px){
  .booking-grid{
    grid-template-columns: 1fr;
    grid-template-areas:
      "service"
      "cal"
      "slots"
      "form";
  }
  .booking-grid .service-panel{ grid-area: service; }
  .booking-grid .calendar{ grid-area: cal; }
  .booking-grid .slots-panel{ grid-area: slots; }
  .booking-grid .form-panel{ grid-area: form; }
}


.calendar{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:0 6px 18px rgba(17,24,39,.06);overflow:hidden}
.cal-head{display:flex;align-items:center;justify-content:space-between;padding:12px;background:var(--surface2);border-bottom:1px solid var(--border)}
.cal-head strong{font-size:15px}
.cal-head button{width:44px;height:44px;border-radius:12px;border:1px solid var(--border);background:#fff;font-weight:900}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr)}
.cal-dow{padding:10px 0;text-align:center;font-size:12px;color:var(--muted);border-bottom:1px solid var(--border);background:#fff}
.cal-day{min-height:54px;padding:8px;border-right:1px solid var(--border);border-bottom:1px solid var(--border);display:flex;align-items:flex-start;justify-content:flex-end}
.cal-day:nth-child(7n){border-right:none}
.cal-day button{width:40px;height:40px;border-radius:12px;border:1px solid transparent;background:transparent;font-weight:900}
.cal-day button:hover{background:var(--surface2);border-color:var(--border)}
.cal-day button.selected{background:rgba(37,99,235,.1);border-color:rgba(37,99,235,.25)}
.cal-day button.disabled{opacity:.35;pointer-events:none}
.slot-list{display:grid;gap:10px}
.slot{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);box-shadow:0 6px 18px rgba(17,24,39,.06);padding:14px}
.slot h3{margin:0 0 8px;font-size:16px}
.pills{display:flex;flex-wrap:wrap;gap:8px}
.pill{min-height:44px;padding:10px 12px;border-radius:999px;border:1px solid var(--border);background:#fff;font-weight:900;cursor:pointer}
.pill:hover{background:var(--surface2)}
.pill.selected{border-color:rgba(37,99,235,.35);background:rgba(37,99,235,.08)}
.pill.disabled{opacity:.4;pointer-events:none}
.form-row{display:grid;gap:10px}
.form-row input,.form-row select,.form-row textarea{width:100%;padding:12px;border-radius:14px;border:1px solid var(--border);background:#fff;font-size:16px}
.form-row textarea{min-height:90px;resize:vertical}
.helper{color:var(--muted);font-size:14px;line-height:1.5}

/* Responsive */
@media (max-width:820px){.grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:640px){
  .container{width:92%}
  .burger{display:flex}
  .menu,.nav-cta{display:none}
  .nav{padding:10px 0}
  .brand{min-width:0}
  .hero-card{padding:16px}
  .quick{grid-template-columns:1fr}
  .grid{grid-template-columns:1fr}
  .card{padding:16px}
  .section-title{font-size:19px}
}

/* Bottom bar */
.bottom-bar{display:none}
@media (max-width:640px){
  .bottom-bar{display:flex;position:fixed;left:0;right:0;bottom:0;padding:10px 12px;gap:10px;background:rgba(255,255,255,.95);border-top:1px solid var(--border);backdrop-filter:blur(8px);z-index:60}
  .bottom-bar .btn{flex:1}
  body{padding-bottom:78px}
}


/* Booking layout (robusto) */
.booking-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  align-items:start;
}
.booking-grid .calendar{ grid-column: 1; }
.booking-grid .service-panel,
.booking-grid .slots-panel,
.booking-grid .form-panel{ grid-column: 2; }

@media (max-width: 900px){
  .booking-grid{ grid-template-columns: 1fr; }
  .booking-grid .calendar,
  .booking-grid .service-panel,
  .booking-grid .slots-panel,
  .booking-grid .form-panel{ grid-column: 1; }
  /* ordine mobile: servizio -> calendario -> slot -> form */
  .booking-grid .service-panel{ order: 1; }
  .booking-grid .calendar{ order: 2; }
  .booking-grid .slots-panel{ order: 3; }
  .booking-grid .form-panel{ order: 4; }
}


/* --- Orari page helpers --- */
.link{
  color: inherit;
  text-decoration: underline;
}
.table-wrap{ overflow-x:auto; }
.table{
  width:100%;
  border-collapse: collapse;
  border-spacing: 0;
}
.table th, .table td{
  padding: 12px 12px;
  border-bottom: 1px solid rgba(0,0,0,.08);
  text-align: left;
  vertical-align: top;
}
.table th{ font-weight: 700; }
.list{
  margin: 0;
  padding-left: 18px;
}
.list li{ margin: 6px 0; }


/* ===== Orari di apertura ===== */
.hours-table{width:100%;border-collapse:separate;border-spacing:0;}
.hours-table th,.hours-table td{padding:10px 12px;border-bottom:1px solid var(--border);vertical-align:middle;}
.hours-table th{text-align:left;color:var(--muted);font-weight:800;font-size:12px;text-transform:uppercase;letter-spacing:.04em;}
.hours-table tr:last-child td{border-bottom:none;}
.range-pill{display:inline-block;padding:6px 10px;border-radius:999px;background:rgba(59,130,246,.12);color:var(--primary);font-weight:700;font-variant-numeric:tabular-nums;}
.range-pill.closed{background:rgba(107,114,128,.14);color:#6b7280;}

@media (max-width:640px){
  .hours-table th:nth-child(1),.hours-table td:nth-child(1){width:34%;}
}


/* Orari page polish */
.hours-page .hero-card{box-shadow:0 10px 30px rgba(15,23,42,.10);} 
.hours-page .badge{display:inline-flex;align-items:center;gap:.4rem;}
.hours-page .hours-table thead th{background:rgba(59,130,246,.08);}
.hours-page .hours-table{border:1px solid rgba(15,23,42,.08);} 
.hours-page .help{margin-top:.8rem;}

/* Spaziatura tra le card (richiesta) */
.hours-page main.container{display:grid;gap:22px;}
.hours-page main.container > section.card{margin:0;}


/* Rimuove sottolineatura dalla card Orari nei contatti */
.quick a,
a.quick-item{
  text-decoration: none;
  color: inherit;
}
