:root { --green:#193c29; --sand:#f5efe3; --gold:#9b7441; --ink:#17231b; --line:#d9d5c9; }
* { box-sizing:border-box; }
.booking-body { margin:0; color:var(--ink); background:radial-gradient(circle at 80% 10%,#e8d9bf 0,transparent 35%),#f8f5ee; font-family:Inter,Arial,sans-serif; }
.booking-back { color:var(--green); font-weight:700; text-decoration:none; }
.booking-shell { display:grid; grid-template-columns:minmax(0,.8fr) minmax(480px,1.2fr); gap:clamp(32px,7vw,100px); width:min(1180px,calc(100% - 40px)); margin:70px auto; align-items:start; }
.booking-intro { position:sticky; top:110px; }
.booking-intro h1,.booking-result h1,.booking-admin h1 { margin:.25em 0; font-family:Georgia,serif; font-size:clamp(2.6rem,6vw,5rem); line-height:.98; color:var(--green); }
.booking-intro p,.booking-intro li { font-size:1.05rem; line-height:1.7; }
.booking-form { display:grid; gap:22px; padding:clamp(24px,5vw,52px); border:1px solid rgba(25,60,41,.15); border-radius:32px; background:rgba(255,255,255,.84); box-shadow:0 30px 80px rgba(35,45,35,.12); }
.booking-form label,.booking-form fieldset { display:grid; gap:8px; margin:0; border:0; padding:0; font-weight:700; }
.booking-form input,.booking-form select,.booking-form textarea { width:100%; border:1px solid var(--line); border-radius:14px; padding:14px 16px; background:#fff; color:var(--ink); font:inherit; }
.booking-grid { display:grid; grid-template-columns:1fr 1fr; gap:18px; }
.booking-slots { display:flex; flex-wrap:wrap; gap:10px; min-height:48px; }
.booking-slots button { border:1px solid var(--green); border-radius:999px; padding:11px 18px; color:var(--green); background:#fff; cursor:pointer; font-weight:800; }
.booking-slots button.is-selected { color:#fff; background:var(--green); }
.booking-legend { display:flex; flex-wrap:wrap; gap:16px; margin-top:28px; font-size:.9rem; font-weight:700; }
.booking-legend span { display:flex; align-items:center; gap:7px; }
.legend-dot { width:11px; height:11px; border-radius:50%; background:#d5d5cd; }
.legend-dot.is-open { background:#2f8152; }
.legend-dot.is-full { background:#b8925f; }
.booking-calendar { padding:18px; border:1px solid var(--line); border-radius:22px; background:#fbfaf6; }
.booking-calendar-head { display:grid; grid-template-columns:42px 1fr 42px; align-items:center; margin-bottom:16px; }
.booking-calendar-head h2 { margin:0; color:var(--green); font-family:Georgia,serif; text-align:center; }
.booking-calendar-head button { width:40px; height:40px; border:0; border-radius:50%; color:var(--green); background:#e8eee8; font-size:1.7rem; cursor:pointer; }
.booking-calendar-head button:disabled { opacity:.25; cursor:not-allowed; }
.booking-weekdays,.booking-calendar-grid { display:grid; grid-template-columns:repeat(7,1fr); gap:6px; }
.booking-weekdays { margin-bottom:6px; color:#7a7e76; font-size:.72rem; font-weight:800; text-align:center; text-transform:uppercase; }
.calendar-day { display:grid; align-content:center; min-height:66px; padding:6px 2px; border:1px solid transparent; border-radius:12px; background:#eeece6; color:#8c8d88; text-align:center; }
.calendar-day strong { font-size:1rem; }
.calendar-day small { font-size:.61rem; }
.calendar-day.is-available { border-color:#9cbba6; color:var(--green); background:#e6f0e8; cursor:pointer; }
.calendar-day.is-available:hover,.calendar-day.is-selected { color:#fff; background:var(--green); transform:translateY(-1px); }
.calendar-day.is-unavailable { color:#876b48; background:#eee4d6; }
.calendar-day.is-disabled { opacity:.38; }
.calendar-loading { grid-column:1/-1; text-align:center; }
.booking-error { margin:0; padding:12px 16px; border-radius:12px; color:#821e1e; background:#fff0ef; }
.booking-result { width:min(720px,calc(100% - 40px)); margin:12vh auto; padding:clamp(30px,7vw,70px); border-radius:32px; background:#fff; box-shadow:0 30px 80px rgba(35,45,35,.14); text-align:center; }
.booking-cancel { margin-top:28px; border:0; color:#7b2525; background:none; text-decoration:underline; cursor:pointer; }
.booking-admin { width:min(1180px,calc(100% - 40px)); margin:60px auto; }
.booking-admin-head { display:flex; justify-content:space-between; align-items:end; gap:20px; }
.booking-admin h1 { font-size:clamp(2.3rem,5vw,4rem); }
.booking-table-wrap { overflow:auto; border-radius:20px; background:#fff; box-shadow:0 20px 60px rgba(35,45,35,.1); }
.booking-admin table { width:100%; border-collapse:collapse; }
.booking-admin th,.booking-admin td { padding:16px; border-bottom:1px solid var(--line); text-align:left; white-space:nowrap; }
.booking-status { display:inline-block; padding:6px 10px; border-radius:999px; background:#e8f1ea; }
.booking-status-cancelled { background:#f2e7e5; }
.admin-login-shell { display:grid; min-height:100vh; place-items:center; padding:24px; }
.admin-login-card { display:grid; gap:20px; width:min(440px,100%); padding:42px; border:1px solid rgba(25,60,41,.14); border-radius:30px; background:#fff; box-shadow:0 30px 90px rgba(25,60,41,.16); }
.admin-login-card h1 { margin:0; color:var(--green); font:3.2rem/1 Georgia,serif; }
.admin-login-card label,.admin-form label { display:grid; gap:8px; font-weight:800; }
.admin-login-card input,.admin-form input,.admin-form select,.status-form select { width:100%; padding:13px 14px; border:1px solid var(--line); border-radius:12px; background:#fff; font:inherit; }
.admin-login-brand,.admin-logo { display:flex; align-items:center; gap:12px; color:var(--green); text-decoration:none; letter-spacing:.14em; }
.admin-login-brand span,.admin-logo span { display:grid; width:44px; height:44px; place-items:center; border-radius:12px; color:#b8a853; background:#151515; font-weight:900; }
.admin-eyebrow { margin:0; color:var(--gold); font-size:.76rem; font-weight:900; letter-spacing:.17em; }
.admin-primary { padding:14px 20px; border:0; border-radius:12px; color:#fff; background:var(--green); font:inherit; font-weight:800; cursor:pointer; }
.admin-body { padding-top:78px; }
.admin-topbar { position:fixed; z-index:10; inset:0 0 auto; display:grid; grid-template-columns:1fr auto 1fr; align-items:center; gap:20px; min-height:78px; padding:12px max(24px,calc((100vw - 1180px)/2)); border-bottom:1px solid var(--line); background:rgba(250,248,242,.95); backdrop-filter:blur(16px); }
.admin-topbar nav { display:flex; gap:24px; }
.admin-topbar nav a { color:var(--green); font-weight:800; text-decoration:none; }
.admin-topbar form { justify-self:end; }
.admin-topbar form button,.schedule-list button,.exception-list button { border:0; color:#7a2d2d; background:none; cursor:pointer; }
.admin-hero { display:flex; align-items:end; justify-content:space-between; gap:30px; padding:36px 0 50px; }
.admin-hero h1 { margin:.15em 0; }
.admin-stat { display:grid; min-width:160px; padding:24px; border-radius:20px; color:#fff; background:var(--green); }
.admin-stat strong { font:2.6rem/1 Georgia,serif; }
.admin-section { scroll-margin-top:100px; margin-bottom:64px; }
.admin-section-head { margin-bottom:20px; }
.admin-section h2 { margin:.2em 0; color:var(--green); font:2.2rem/1.1 Georgia,serif; }
.admin-two-column { display:grid; grid-template-columns:minmax(280px,.75fr) minmax(420px,1.25fr); gap:24px; align-items:start; }
.admin-card { padding:26px; border:1px solid var(--line); border-radius:22px; background:#fff; box-shadow:0 16px 45px rgba(35,45,35,.08); }
.admin-form { display:grid; gap:18px; }
.admin-inline { display:grid; grid-template-columns:1fr 1fr; gap:14px; }
.schedule-day,.exception-list>div { display:grid; grid-template-columns:130px 1fr; gap:16px; padding:14px 0; border-bottom:1px solid var(--line); }
.schedule-day:last-child,.exception-list>div:last-child { border:0; }
.schedule-day>div { display:flex; flex-wrap:wrap; gap:8px; }
.schedule-day form { display:flex; align-items:center; gap:8px; padding:7px 10px; border-radius:10px; background:#edf2ed; }
.exception-list>div { grid-template-columns:1fr auto; align-items:center; }
.exception-list span { display:grid; gap:4px; }
.exception-list small,.muted { color:#747a73; }
.booking-message { max-width:280px; overflow:hidden; text-overflow:ellipsis; white-space:nowrap!important; }
.status-form select { min-width:130px; padding:9px; }
@media (max-width:800px) {
  .booking-shell { grid-template-columns:1fr; margin:35px auto; }
  .booking-intro{position:static}
  .booking-grid,.admin-two-column{grid-template-columns:1fr}
  .booking-admin-head{align-items:start;flex-direction:column}
  .calendar-day { min-height:52px; }
  .calendar-day small { display:none; }
  .admin-topbar { grid-template-columns:1fr auto; }
  .admin-topbar nav { display:none; }
  .admin-hero { align-items:start; flex-direction:column; }
  .admin-stat { width:100%; }
}
