:root{color-scheme:light;--app-primary:#111827;--app-bg:#f6f7f8;--app-surface:#fff;--app-text:#1f2933;--app-muted:#6b7280;--app-border:#d0d5dd;--app-radius:10px;--app-space-unit:12px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;background:var(--app-bg);color:var(--app-text)}*{box-sizing:border-box}body{margin:0;background:var(--app-bg)}a{color:inherit;text-decoration:none}.container{max-width:880px;margin:0 auto;padding:calc(var(--app-space-unit) * 2.6) calc(var(--app-space-unit) * 1.6) calc(var(--app-space-unit) * 5.3)}.template-layout{display:block}.header{display:flex;align-items:center;justify-content:space-between;margin-bottom:calc(var(--app-space-unit) * 2)}.title{font-size:28px;font-weight:600}.section-title{font-size:20px;font-weight:600}.subtle{color:var(--app-muted);font-size:14px}.card{background:var(--app-surface);padding:calc(var(--app-space-unit) * 1.7);box-shadow:0 10px 30px rgba(15,23,42,.06);margin-bottom:calc(var(--app-space-unit) * 1.3)}.button,.card{border-radius:var(--app-radius)}.button{display:inline-flex;align-items:center;justify-content:center;padding:calc(var(--app-space-unit) * .85) calc(var(--app-space-unit) * 1.35);border:1px solid var(--app-border);background:var(--app-primary);color:#fff;font-size:14px;cursor:pointer;transition:transform .15s ease,opacity .15s ease}.button:disabled{opacity:.5;cursor:not-allowed}.button.secondary{background:var(--app-surface);color:var(--app-primary)}.grid{display:grid;grid-gap:var(--app-space-unit);gap:var(--app-space-unit)}.grid.services{grid-template-columns:repeat(auto-fit,minmax(240px,1fr))}.grid.dates{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}.grid.slots{grid-template-columns:repeat(auto-fit,minmax(100px,1fr))}.badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:999px;background:#ecfdf3;color:#027a48;font-size:12px}.error{color:#b42318;margin-top:8px}.input{width:100%;padding:calc(var(--app-space-unit) * .85) var(--app-space-unit);border-radius:var(--app-radius);border:1px solid var(--app-border);font-size:14px}.row{display:flex;flex-wrap:wrap;gap:var(--app-space-unit);align-items:center}.row.row-spread{justify-content:space-between}.table{width:100%;border-collapse:collapse}.table td,.table th{text-align:left;padding:10px 8px;border-bottom:1px solid #e5e7eb}.demo-entry{margin-top:calc(var(--app-space-unit) * 3)}.demo-entry-actions{margin-top:calc(var(--app-space-unit) * 2)}.calendar-days{display:grid;grid-gap:calc(var(--app-space-unit) * .6);gap:calc(var(--app-space-unit) * .6);grid-template-columns:repeat(auto-fit,minmax(120px,1fr))}.calendar-day{width:100%;min-height:72px;flex-direction:column;align-items:flex-start;justify-content:flex-start;gap:4px}.calendar-day.is-muted{opacity:.45}.booking-calendar{border:1px solid var(--app-border);border-radius:calc(var(--app-radius) + 2px);padding:calc(var(--app-space-unit) * .85);overflow-x:auto}.booking-calendar.is-loading{opacity:.75}.booking-calendar .rdp-root{--rdp-accent-color:var(--app-primary);--rdp-accent-background-color:rgba(17,24,39,.12);margin:0 auto}.booking-calendar .rdp-month_caption{font-size:16px}.booking-calendar .rdp-day_button{position:relative;border-radius:10px;border:1px solid transparent;transition:transform .14s ease,background-color .14s ease,border-color .14s ease}.booking-calendar .rdp-day_button:hover:not(:disabled){transform:translateY(-1px);background-color:rgba(17,24,39,.08)}.booking-calendar .booking-day--active .rdp-day_button{border-color:rgba(17,24,39,.26)}.booking-calendar .booking-day--dots-1 .rdp-day_button:after,.booking-calendar .booking-day--dots-2 .rdp-day_button:after,.booking-calendar .booking-day--dots-3 .rdp-day_button:after{position:absolute;inset-inline-start:50%;inset-block-end:4px;transform:translateX(-50%);letter-spacing:1px;font-size:9px;line-height:1;color:var(--app-primary);opacity:.75}.booking-calendar .booking-day--dots-1 .rdp-day_button:after{content:"●"}.booking-calendar .booking-day--dots-2 .rdp-day_button:after{content:"●●"}.booking-calendar .booking-day--dots-3 .rdp-day_button:after{content:"●●●"}.booking-calendar .booking-day--unknown .rdp-day_button:after{content:"●";position:absolute;inset-inline-start:50%;inset-block-end:4px;transform:translateX(-50%);font-size:9px;line-height:1;color:#9ca3af;opacity:.55}.booking-slot-grid{grid-template-columns:repeat(auto-fit,minmax(84px,1fr))}.booking-slot-btn{min-height:44px}.booking-slot-btn.is-disabled{opacity:.42}.booking-slot-btn.is-selected{box-shadow:inset 0 0 0 2px rgba(17,24,39,.14)}.slot-skeleton-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(84px,1fr));grid-gap:var(--app-space-unit);gap:var(--app-space-unit)}.slot-skeleton{height:42px;border-radius:var(--app-radius);background:linear-gradient(90deg,rgba(148,163,184,.24),rgba(148,163,184,.42) 50%,rgba(148,163,184,.24));background-size:220% 100%;animation:slot-skeleton-pulse 1.2s ease-in-out infinite}@keyframes slot-skeleton-pulse{0%{background-position:100% 0}to{background-position:-100% 0}}.booking-confirm{transition:opacity .22s ease,transform .22s ease}.booking-confirm.is-hidden{opacity:.66;transform:translateY(6px)}.booking-confirm.is-visible{opacity:1;transform:translateY(0)}.booking-success-inline{border:1px solid rgba(2,122,72,.2);background:linear-gradient(180deg,#ecfdf3,#fff)}