@import url('https://fonts.googleapis.com/css2?family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap');

:root { --bg:#0b0d13; --card:rgba(16,21,34,.9); --line:rgba(255,255,255,.09); --line-strong:rgba(255,255,255,.15); --text:#eef0f4; --muted:#8a9ab0; --accent:#ff6d2d; --blue:var(--tenant-secondary); --tenant-secondary:#4da3ff; --tenant-secondary-soft:rgba(77,163,255,.14); --tenant-secondary-line:rgba(77,163,255,.32); --tenant-secondary-deep:color-mix(in srgb, var(--tenant-secondary) 58%, #081018 42%); --tenant-secondary-deeper:color-mix(in srgb, var(--tenant-secondary) 42%, #05080f 58%); --font:"Plus Jakarta Sans",system-ui,sans-serif; --font-display:Impact,"Trebuchet MS",sans-serif; }
*{box-sizing:border-box}
body{margin:0;min-height:100vh;background:radial-gradient(circle at 16% 12%, var(--tenant-secondary-soft) 0%, transparent 26%),radial-gradient(circle at 86% 12%, rgba(255,109,45,.18) 0%, transparent 22%),radial-gradient(circle at 78% 82%, rgba(255,109,45,.13) 0%, transparent 20%),linear-gradient(180deg,#0b0d13 0%,#101524 48%,#090d16 100%);color:var(--text);font-family:var(--font);display:block;-webkit-font-smoothing:antialiased}
body::before{content:"";position:fixed;inset:0;background:linear-gradient(rgba(255,255,255,.028) 1px, transparent 1px),linear-gradient(90deg, rgba(255,255,255,.028) 1px, transparent 1px);background-size:64px 64px;mask-image:linear-gradient(180deg, rgba(0,0,0,.75), transparent 82%);pointer-events:none}
.shell{width:min(100% - 28px, 1180px);margin:0 auto;padding:1rem 0 2rem;position:relative;z-index:1}
.card{background:radial-gradient(circle at top right, rgba(255,109,45,.07), transparent 30%),radial-gradient(circle at bottom left, var(--tenant-secondary-soft), transparent 28%),rgba(255,255,255,.045);border:1px solid rgba(255,255,255,.12);border-radius:28px;padding:clamp(1rem, 2vw, 1.35rem);box-shadow:0 22px 70px rgba(0,0,0,.28), inset 0 1px 0 rgba(255,255,255,.07);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px)}
.tenant-public-nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:0 auto 1rem;padding:.7rem .85rem;border:1px solid rgba(255,255,255,.1);border-radius:999px;background:rgba(8,11,18,.72);box-shadow:0 18px 52px rgba(0,0,0,.22);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px)}
.tenant-public-brand{display:flex;align-items:center;gap:.72rem;min-width:0}
.tenant-public-logo{width:76px;height:44px;border-radius:18px;margin:0;flex:0 0 76px}
.tenant-public-logo .brand-main{transform:scale(.72);transform-origin:left center}
.tenant-public-logo .brand-side{display:none}
.tenant-public-brand-copy{display:grid;gap:.12rem;min-width:0}
.tenant-public-brand-copy strong{color:#fff;font-weight:950;line-height:1.05;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tenant-public-brand-copy span{color:#9aa8bd;font-size:.8rem;line-height:1.1}
.tenant-public-links{display:flex;align-items:center;gap:.25rem}
.tenant-public-links a{display:inline-flex;align-items:center;min-height:38px;padding:0 .9rem;border-radius:999px;color:#dfe6f3;font-size:.85rem;font-weight:900;text-decoration:none}
.tenant-public-links a:hover{background:rgba(255,255,255,.07);color:#fff}
.booking-shell-card{display:grid;grid-template-columns:minmax(380px,.9fr) minmax(520px,1.1fr);overflow:hidden;border:1px solid rgba(255,255,255,.12);border-radius:36px;background:radial-gradient(circle at 8% 8%, var(--tenant-secondary-soft), transparent 34%),radial-gradient(circle at 100% 12%, rgba(255,109,45,.18), transparent 30%),linear-gradient(135deg, rgba(255,255,255,.07), rgba(255,255,255,.025));box-shadow:0 24px 80px rgba(0,0,0,.34), inset 0 1px 0 rgba(255,255,255,.08)}
.booking-hero-panel{display:grid;align-content:start;gap:1rem;min-width:0;padding:clamp(1.4rem, 3vw, 2.8rem);border-right:1px solid rgba(255,255,255,.1)}
.booking-hero-panel h1{display:grid;gap:.04em;max-width:100%;margin:.25rem 0 0;font-size:clamp(2.65rem, 4.1vw, 4.25rem);line-height:.88;letter-spacing:.01em;text-transform:uppercase;color:#fff}
.booking-hero-panel h1 span{display:block;min-width:0}
.booking-hero-panel .hero-subtitle{max-width:42rem;margin:0;color:#d7deeb;font-size:clamp(1rem, 1.35vw, 1.16rem);line-height:1.55}
.booking-form-card{border:0;border-left:1px solid rgba(255,255,255,.05);border-radius:0;background:rgba(10,13,20,.58);box-shadow:none}
.form-head{margin-bottom:1rem;padding-bottom:.85rem;border-bottom:1px solid rgba(255,255,255,.09)}
.form-head h2{margin:.25rem 0;color:#fff;font-size:1.45rem;line-height:1.1}
.form-head p{margin:0;color:#a9b4c8;line-height:1.45}
.hero-block{border:1px solid rgba(255,255,255,.18);border-radius:18px;padding:.85rem;background:radial-gradient(circle at top left, var(--tenant-secondary-soft), transparent 26%),linear-gradient(150deg,rgba(255,109,45,.12),rgba(255,255,255,.04));box-shadow:inset 0 1px 0 rgba(255,255,255,.08),0 12px 26px rgba(0,0,0,.16);margin:.35rem 0 .85rem}
.hero-kicker{margin:0 0 .45rem;color:var(--tenant-secondary);font-size:.8rem;letter-spacing:.08em;text-transform:uppercase;font-weight:700}
.logo-panel{width:100%;height:96px;border:1px solid rgba(255,255,255,.14);border-radius:14px;display:grid;place-items:center;overflow:hidden;background:#000;margin-bottom:.9rem}
.intro-logo{height:136px;max-width:520px;margin:0}
.brand-logo{display:flex;align-items:center;justify-content:space-between;padding:.75rem .85rem;background:radial-gradient(circle at 75% 26%, var(--tenant-secondary-soft), transparent 44%),linear-gradient(120deg,#050505,#0f0f0f)}
.brand-main{display:flex;flex-direction:column;align-items:flex-start;gap:.08rem}
.brand-caf{font-family:"Plus Jakarta Sans",system-ui,sans-serif;font-size:2rem;line-height:.95;letter-spacing:.18em;color:#fff;font-weight:800}
.brand-largo{color:var(--tenant-secondary);font-weight:800;font-size:.84rem;letter-spacing:.18em}
.brand-tagline{color:var(--muted);font-size:.76rem;line-height:1.15;max-width:31ch}
.brand-side{display:flex;flex-direction:column;align-items:flex-end;gap:.32rem}
.brand-pill{border:1px solid var(--tenant-secondary-line);border-radius:999px;padding:.16rem .58rem;font-weight:800;color:var(--tenant-secondary);font-size:.76rem;letter-spacing:.08em}
.brand-side-text{color:#fff;font-family:"Plus Jakarta Sans",system-ui,sans-serif;font-size:.88rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;text-align:right;line-height:1}
.tenant-public-nav .tenant-public-logo{width:76px;height:44px;min-height:0;max-width:none;margin:0;padding:.42rem .5rem;flex:0 0 76px;border-radius:18px}
.tenant-public-nav .tenant-public-logo .brand-main{transform:scale(.68);transform-origin:left center}
.tenant-public-nav .tenant-public-logo .brand-tagline,
.tenant-public-nav .tenant-public-logo .brand-side{display:none}
h1{margin:0;font-family:var(--font-display)}p{margin:.4rem 0 .8rem;color:var(--muted)}
.booking-proof-grid{display:grid;gap:.72rem;margin:1rem 0 .25rem}
.booking-proof-grid article{display:grid;grid-template-columns:44px 1fr;gap:.18rem .8rem;align-items:center;padding:.88rem;border:1px solid rgba(255,255,255,.1);border-radius:22px;background:rgba(255,255,255,.045)}
.booking-proof-grid span{grid-row:span 2;display:grid;place-items:center;width:44px;height:44px;border-radius:16px;background:linear-gradient(135deg, rgba(255,109,45,.88), var(--tenant-secondary));color:#fff;font-weight:950}
.booking-proof-grid strong{color:#fff}
.booking-proof-grid small{color:#a9b4c8;line-height:1.35}
.info-panel{display:grid;gap:.24rem;border:1px solid var(--line);border-radius:18px;padding:.95rem 1rem;background:rgba(255,255,255,.05);margin:.25rem 0 0}
.info-panel strong{color:#fff}
.info-panel span{color:#d5d5d5;font-size:.92rem;line-height:1.35}
.summary-panel{display:grid;gap:.55rem;border:1px solid var(--line-strong);border-radius:14px;padding:.82rem .88rem;background:radial-gradient(circle at top right, rgba(255,109,45,.08), transparent 34%),linear-gradient(170deg, rgba(20,24,34,.96), rgba(12,14,20,.96));box-shadow:0 12px 28px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.04);margin:.25rem 0 .8rem}
.summary-panel strong{color:#ffb08e;font-size:1rem;letter-spacing:.01em}
.summary-title{color:#ffb08e !important}
.summary-header{display:flex;align-items:center;justify-content:flex-start;gap:.7rem}
.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:.38rem .7rem}
.summary-grid span{color:#e4e4e4;font-size:.92rem;line-height:1.35}
.summary-grid b{color:#ffffff}

form{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.7rem .8rem}
label{display:block;color:var(--muted);margin-bottom:0;font-size:.9rem;font-weight:750;line-height:1.35}
label:has(#serviceTypeSelect),
label:has(#bookingDurationSelect),
label:has(#dayInput),
.booking-calendar-panel,
.summary-panel,
.consent,
form > button{grid-column:1 / -1}
input,select,button{width:100%;border:1px solid var(--line-strong);border-radius:14px;background:linear-gradient(180deg, rgba(14,18,29,.96), rgba(17,22,36,.96));color:var(--text);font:inherit;padding:.75rem .78rem;margin-top:.38rem}
button{margin-top:.2rem;border:1px solid var(--tenant-secondary-line);background:linear-gradient(180deg, rgba(255,255,255,.08), rgba(255,255,255,.02)),rgba(10,14,22,.58);color:#f8fbff;font-weight:850;cursor:pointer;box-shadow:0 8px 24px rgba(6,10,18,.22), inset 0 1px 0 rgba(255,255,255,.1),0 0 0 1px color-mix(in srgb, var(--tenant-secondary) 10%, transparent),0 0 18px color-mix(in srgb, var(--tenant-secondary) 18%, transparent);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px)}
form > button[type="submit"]{min-height:54px;border-color:rgba(255,109,45,.62);background:linear-gradient(135deg, #ffb07b, var(--accent) 58%, #f45f18);color:#111827;box-shadow:0 18px 36px rgba(255,109,45,.22);font-weight:950}
button:hover{border-color:var(--tenant-secondary);background:linear-gradient(180deg, rgba(255,255,255,.11), rgba(255,255,255,.03)),rgba(12,17,27,.68);color:#ffffff;box-shadow:0 10px 28px rgba(6,10,18,.28), inset 0 1px 0 rgba(255,255,255,.12),0 0 0 1px color-mix(in srgb, var(--tenant-secondary) 16%, transparent),0 0 20px color-mix(in srgb, var(--tenant-secondary) 22%, transparent)}
.consent{display:flex;align-items:flex-start;gap:.55rem}
.consent input{width:auto;margin:.22rem 0 0;flex:0 0 auto}
.consent span{color:var(--muted);line-height:1.45}
.consent-link{color:inherit;text-decoration:underline;text-underline-offset:2px;font-weight:700}
.ghost-mini-btn{width:auto;margin-top:0;border:1px solid var(--tenant-secondary-line);border-radius:10px;background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.02)),rgba(10,14,22,.52);color:#f8fbff;padding:.52rem .7rem;box-shadow:0 8px 22px rgba(6,10,18,.24), inset 0 1px 0 rgba(255,255,255,.09),0 0 14px color-mix(in srgb, var(--tenant-secondary) 16%, transparent)}
.feedback{min-height:1.2rem;color:#ffb290;margin-top:.8rem;padding:.78rem .85rem;border-radius:12px;border:1px solid var(--line);background:rgba(255,255,255,.04)}
.feedback:empty{display:none}
.feedback-info{color:#ffe0d2;border-color:rgba(255,109,45,.28);background:rgba(255,109,45,.09)}
.feedback-success{color:#dff8e8;border-color:rgba(104,214,146,.28);background:rgba(55,140,91,.14)}
.feedback-error{color:#ffd2d2;border-color:rgba(255,99,99,.3);background:rgba(140,45,45,.18)}
.link{color:#ffb290;text-decoration:none}

.back-link{
  color:#f3f6ff;
  text-decoration:none;
  display:inline-flex;
  align-items:center;
  width:max-content;
  border:1px solid rgba(255,143,88,.42);
  border-radius:999px;
  padding:.45rem .72rem;
  background:linear-gradient(180deg, rgba(255,255,255,.07), rgba(255,255,255,.03));
  margin-bottom:.2rem;
  font-size:.86rem;
  font-weight:850;
}

.booking-calendar-panel{
  display:grid;
  gap:.45rem;
  margin:.2rem 0 .8rem;
  border:1px solid var(--line);
  border-radius:14px;
  padding:.8rem;
  background:rgba(255,255,255,.035);
  position:relative;
}

.booking-calendar-head{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:.45rem;
  align-items:center;
}

.booking-calendar-head strong{
  text-align:center;
  font-family:Impact,"Trebuchet MS",sans-serif;
  font-size:1.18rem;
  color:#fff;
}

.booking-weekday-row,
.booking-calendar-grid{
  display:grid;
  grid-template-columns:repeat(7,1fr);
  gap:.36rem;
}

.booking-weekday-row{
  color:#d9d9d9;
  font-size:.84rem;
  text-align:center;
}

.booking-calendar-grid .calendar-cell{
  border:1px solid var(--line);
  background:rgba(255,255,255,.03);
  border-radius:12px;
  min-height:64px;
  padding:.32rem;
  display:grid;
  gap:.32rem;
  position:relative;
  overflow:visible;
}

.booking-calendar-grid .calendar-cell.is-empty{
  opacity:.18;
  cursor:default;
}

.booking-calendar-grid .calendar-cell.is-selected{
  border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(255,109,45,.45) inset;
  background:rgba(255,109,45,.1);
}

.booking-calendar-grid .calendar-cell.has-slots{
  border-color:rgba(111,191,154,.38);
}

.booking-calendar-grid .calendar-cell.no-slots{
  opacity:.62;
}

.booking-calendar-grid .calendar-cell.no-slots:disabled{
  cursor:not-allowed;
  opacity:.34;
  filter:grayscale(.2);
}

.booking-calendar-grid .calendar-cell.is-expanded{
  border-color:rgba(255,109,45,.32);
  background:rgba(255,109,45,.08);
  z-index:12;
}

.calendar-day-trigger{
  width:100%;
  min-height:56px;
  margin:0;
  border:1px solid transparent;
  border-radius:10px;
  background:transparent;
  color:inherit;
  padding:.28rem;
  display:grid;
  justify-items:start;
  align-content:start;
  text-align:left;
}

.calendar-day-trigger.is-selected{
  border-color:rgba(255,109,45,.44);
  background:rgba(255,109,45,.12);
  box-shadow:0 0 0 1px rgba(255,109,45,.2) inset;
}

.calendar-day-trigger:disabled{
  cursor:not-allowed;
}

.calendar-slot-panel{
  position:absolute;
  top:0;
  left:0;
  min-width:248px;
  max-width:min(300px, 92vw);
  border:1px solid var(--line);
  border-radius:12px;
  background:radial-gradient(circle at top right, rgba(255,109,45,.08), transparent 34%),rgba(15,17,24,.98);
  box-shadow:0 18px 36px rgba(0,0,0,.28);
  padding:.42rem;
  display:grid;
  gap:.35rem;
  z-index:20;
}

.calendar-slot-panel.align-right{
  left:auto;
  right:0;
}

.calendar-slot-title{
  font-size:.74rem;
  color:#f3c1aa;
  font-weight:700;
  padding:0 .12rem;
}

.calendar-slot-options{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:.28rem;
}

.calendar-slot-btn{
  width:100%;
  margin:0;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.05);
  color:#fff;
  padding:.55rem .36rem;
  font-weight:700;
  min-height:40px;
}

.calendar-slot-btn.is-selected{
  border-color:var(--accent);
  background:rgba(255,109,45,.14);
}

.booking-calendar-grid .day-num{
  font-weight:700;
  font-size:1rem;
}

.booking-calendar-grid .day-badge{
  margin-top:.32rem;
  display:inline-block;
  border-radius:999px;
  padding:.14rem .42rem;
  font-size:.74rem;
  background:rgba(255,109,45,.24);
  color:#fff;
}

.slot-popover{
  position:fixed;
  z-index:80;
  min-width:300px;
  max-width:min(420px, 94vw);
  border:1px solid rgba(255,255,255,.18);
  border-radius:14px;
  background:rgba(15,15,15,.98);
  box-shadow:0 18px 42px rgba(0,0,0,.35);
  padding:.72rem;
}

.slot-popover[hidden]{
  display:none;
}

.slot-popover-layout{
  display:grid;
  grid-template-columns:88px minmax(0,1fr);
  gap:.7rem;
  align-items:start;
}

.slot-popover.is-flipped .slot-popover-layout{
  grid-template-columns:minmax(0,1fr) 88px;
}

.slot-popover.is-flipped .slot-popover-day{
  order:2;
}

.slot-popover.is-flipped .slot-popover-main{
  order:1;
}

.slot-popover-day{
  border:1px solid rgba(255,255,255,.12);
  border-radius:12px;
  background:rgba(255,255,255,.05);
  padding:.58rem .45rem;
  text-align:center;
  display:grid;
  gap:.1rem;
}

.slot-popover-day-num{
  font-family:Impact,"Trebuchet MS",sans-serif;
  font-size:1.55rem;
  line-height:1;
  color:#fff;
}

.slot-popover-day-label{
  color:#d7d7d7;
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}

.slot-popover-title{
  color:#fff;
  font-weight:700;
  margin-bottom:.5rem;
}

.slot-popover-options{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:.42rem;
}

.slot-popover-btn{
  width:100%;
  margin:0;
  border:1px solid rgba(255,255,255,.12);
  border-radius:10px;
  background:rgba(255,255,255,.05);
  color:#fff;
  padding:.5rem .4rem;
  font-weight:700;
}

.slot-popover-btn.is-selected{
  border-color:var(--accent);
  background:rgba(255,109,45,.14);
}

.slot-popover-empty{
  color:#d7d7d7;
  font-size:.92rem;
  line-height:1.35;
}

html[data-theme="light"] body{
  background:radial-gradient(circle at 10% 0%, rgba(255,173,122,.22), rgba(255,173,122,0) 34%),radial-gradient(circle at 90% 100%, rgba(255,109,45,.12), rgba(255,109,45,0) 28%),#f7efe8;
  color:#2f1d14;
}

html[data-theme="light"] .card{
  background:radial-gradient(circle at top right, rgba(255,109,45,.1), transparent 34%),linear-gradient(160deg, rgba(255,255,255,.98), rgba(250,241,235,.98));
  border-color:rgba(168,120,88,.18);
  box-shadow:0 16px 34px rgba(170,122,93,.12);
}

html[data-theme="light"] .hero-block{
  border-color:rgba(190,128,92,.2);
  background:linear-gradient(150deg, var(--tenant-secondary-soft), rgba(255,255,255,.72)), #fff7f2;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.72), 0 16px 28px rgba(170,122,93,.08);
}

html[data-theme="light"] .hero-kicker,
html[data-theme="light"] .summary-title{
  color:var(--tenant-secondary) !important;
}

html[data-theme="light"] p,
html[data-theme="light"] label,
html[data-theme="light"] .info-panel span,
html[data-theme="light"] .booking-weekday-row{
  color:#7a6558;
}

html[data-theme="light"] h1,
html[data-theme="light"] .booking-calendar-head strong,
html[data-theme="light"] .info-panel strong{
  color:#2f1d14;
}

html[data-theme="light"] input,
html[data-theme="light"] select{
  background:#fffdfa;
  color:#2f1d14;
  border-color:rgba(168,120,88,.24);
}

html[data-theme="light"] .back-link,
html[data-theme="light"] .ghost-mini-btn{
  background:linear-gradient(180deg, rgba(255,255,255,.94), rgba(255,247,242,.88));
  color:#8e4926;
  border-color:rgba(255,109,45,.3);
  box-shadow:0 8px 18px rgba(170,122,93,.12), inset 0 1px 0 rgba(255,255,255,.75);
}

html[data-theme="light"] button{
  background:linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,244,238,.9)), rgba(255,109,45,.06);
  color:#8e4926;
  border-color:rgba(255,109,45,.3);
  box-shadow:0 10px 20px rgba(170,122,93,.12), inset 0 1px 0 rgba(255,255,255,.8);
}

html[data-theme="light"] .feedback,
html[data-theme="light"] .info-panel,
html[data-theme="light"] .booking-calendar-panel{
  background:rgba(255,248,242,.86);
  border-color:rgba(168,120,88,.18);
  color:#7a6558;
}

html[data-theme="light"] .summary-panel{
  border-color: rgba(168,120,88,.22) !important;
  background: radial-gradient(circle at top right, rgba(255,109,45,.1), transparent 34%), linear-gradient(160deg, rgba(255,255,255,.98), rgba(250,241,235,.98)) !important;
  box-shadow: 0 12px 28px rgba(170,122,93,.14), inset 0 1px 0 rgba(255,255,255,.55) !important;
}

html[data-theme="light"] .summary-grid span{
  color:#5c4639 !important;
}

html[data-theme="light"] .summary-grid b{
  color:#2f1d14 !important;
}

html[data-theme="light"] .booking-calendar-grid .calendar-cell,
html[data-theme="light"] .slot-popover-day,
html[data-theme="light"] .slot-popover-btn,
html[data-theme="light"] .calendar-slot-btn{
  background:rgba(255,255,255,.8);
  border-color:rgba(168,120,88,.2);
  color:#2f1d14;
}

html[data-theme="light"] .booking-calendar-grid .calendar-cell.is-expanded,
html[data-theme="light"] .booking-calendar-grid .calendar-cell.is-selected,
html[data-theme="light"] .slot-popover-btn.is-selected,
html[data-theme="light"] .calendar-slot-btn.is-selected{
  border-color:#ff6d2d;
  background:rgba(255,177,137,.2);
  box-shadow:0 0 0 1px rgba(255,109,45,.24) inset;
}

html[data-theme="light"] .calendar-slot-title,
html[data-theme="light"] .slot-popover-title,
html[data-theme="light"] .slot-popover-day-num{
  color:#8e4926;
}

html[data-theme="light"] .slot-popover-day-label,
html[data-theme="light"] .slot-popover-empty{
  color:#7a6558;
}

html[data-theme="light"] .slot-popover,
html[data-theme="light"] .calendar-slot-panel{
  border-color:rgba(168,120,88,.18);
  background:rgba(255,252,249,.98);
  box-shadow:0 18px 36px rgba(170,122,93,.18);
}

html[data-theme="light"] .calendar-slot-btn.is-selected{
  border-color:#5d9bc4;
  background:rgba(190,223,245,.92);
}

html[data-theme="light"] .calendar-day-trigger.is-selected{
  border-color:#5d9bc4;
  background:rgba(190,223,245,.92);
  box-shadow:0 0 0 1px rgba(93,155,196,.18) inset;
}

@media (max-width: 980px){
  .tenant-public-nav{border-radius:28px;align-items:flex-start;flex-direction:column}
  .tenant-public-links{width:100%;justify-content:space-between;flex-wrap:wrap}
  .booking-shell-card{grid-template-columns:1fr;border-radius:30px}
  .booking-hero-panel{border-right:0;border-bottom:1px solid rgba(255,255,255,.1)}
  .booking-form-card{border-left:0;border-radius:0}
  .booking-proof-grid{grid-template-columns:repeat(3,minmax(0,1fr))}
  .booking-proof-grid article{grid-template-columns:1fr}
  .booking-proof-grid span{grid-row:auto}
}

@media (max-width: 640px){
  .shell{width:min(100% - 18px, 1180px);padding:.7rem 0 1.4rem}
  .tenant-public-nav .tenant-public-logo{width:64px;height:40px;min-height:0;flex-basis:64px;padding:.38rem .45rem}
  .tenant-public-nav .tenant-public-logo .brand-main{transform:scale(.58)}
  .tenant-public-links a{padding:0 .62rem;font-size:.8rem}
  .booking-hero-panel{padding:1.15rem}
  .booking-hero-panel h1{font-size:clamp(2.55rem, 16vw, 3.25rem)}
  .booking-proof-grid{grid-template-columns:1fr}
  form{grid-template-columns:1fr}
  .card{padding:.9rem}
  .intro-logo{height:auto;min-height:122px}
  .brand-logo{flex-direction:column;align-items:flex-start;gap:.45rem}
  .brand-side{align-items:flex-start}
  .brand-side-text{text-align:left}
  .brand-caf{font-size:2.45rem}
  .tenant-public-logo .brand-caf{font-size:1.7rem}
  .summary-grid{grid-template-columns:1fr}
  .booking-calendar-head{grid-template-columns:1fr;justify-items:stretch}
  .booking-calendar-grid .calendar-cell{min-height:56px;padding:.36rem}
  .booking-calendar-grid .day-num{font-size:.96rem}
  .calendar-slot-panel{
    min-width:min(260px, 82vw);
    max-width:min(300px, 82vw);
  }
  .calendar-slot-options{grid-template-columns:1fr}
}
