:root{font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:#2f3329;background:#f7f6f1;line-height:1.5;font-weight:400;--olive-900: #4f5644;--olive-700: #6f775f;--olive-500: #8b9278;--olive-200: #dfe4d5;--olive-100: #edf0e6;--surface: #ffffff;--surface-soft: #f8f8f4;--border: #dde2d5;--danger: #8c5a54;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{box-sizing:border-box}body{margin:0;min-width:320px;background:linear-gradient(180deg,#f3f3ed,#f9f8f3);color:#2f3329}button,input,select,textarea{font:inherit}button{cursor:pointer}#root,.app-shell{min-height:100vh}.portal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:30;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:#2f33296b;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.portal-card{width:min(980px,100%);max-height:calc(100vh - 3rem);overflow:auto;background:#fffffffa;border:1px solid rgba(221,226,213,.9);border-radius:28px;padding:1.5rem;box-shadow:0 24px 60px #2f332933}.hero{position:relative;padding:5rem 1.5rem 4rem;background:linear-gradient(135deg,#4f5644f2,#6f775fdb);color:#fff;overflow:hidden}.hero__overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:radial-gradient(circle at top left,rgba(255,255,255,.14),transparent 35%)}.hero__content{position:relative;max-width:1100px;margin:0 auto}.hero__topbar{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:2rem}.hero__brandmark{display:flex;align-items:center}.hero__heading-row{display:flex;align-items:center;gap:1rem}.hero__brandmark-image{display:block;max-height:96px;width:auto;object-fit:contain}.hero__actions{display:flex;justify-content:flex-end;gap:.75rem;flex-wrap:wrap}.eyebrow{margin:0 0 .75rem;text-transform:uppercase;letter-spacing:.18em;font-size:.78rem;opacity:.8}.hero h1{margin:0;font-size:clamp(2.2rem,4vw,3.7rem);line-height:1.05}.hero__text{max-width:640px;margin-top:1rem;color:#ffffffe6}.layout{max-width:1280px;margin:-2rem auto 0;padding:0 1.5rem 2rem;display:grid;grid-template-columns:1.5fr 1fr;gap:1.5rem}.panel{background:#fffffff0;border:1px solid rgba(221,226,213,.8);border-radius:24px;padding:1.5rem;box-shadow:0 18px 40px #4f564414;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.panel--main{grid-column:1}.panel--details{grid-column:2}.panel--admin{grid-column:1 / -1}.panel--portal{max-width:720px;margin:0 auto}.section-heading{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.25rem}.section-heading--stacked{align-items:flex-start}.section-heading__label{margin:0 0 .3rem;font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--olive-700)}.section-heading h2{margin:0;font-size:1.55rem;color:var(--olive-900)}.month-controls,.button-row,.stats-row{display:flex;gap:.75rem;flex-wrap:wrap}.button{border:none;border-radius:999px;padding:.8rem 1.1rem;transition:transform .2s ease,opacity .2s ease,background .2s ease}.button:hover{transform:translateY(-1px)}.button--ghost{background:var(--olive-100);color:var(--olive-900)}.button--olive{background:var(--olive-900);color:#fff}.button--hero{background:#ffffff29;color:#fff;border:1px solid rgba(255,255,255,.28);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.button--hero:hover{background:#ffffff38}.button--danger{background:#f3e6e4;color:var(--danger)}.calendar-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:.75rem}.calendar-grid--labels{margin-bottom:.75rem}.calendar-label{text-align:center;font-size:.85rem;font-weight:700;color:var(--olive-700)}.calendar-day{min-height:82px;padding:.9rem;border-radius:20px;border:1px solid var(--border);background:var(--surface-soft);text-align:left;display:flex;flex-direction:column;gap:.45rem}.calendar-day--selected{background:var(--olive-900);color:#fff;border-color:var(--olive-900)}.calendar-day--full{background:#f7eaea;border-color:#e8c6c2;color:var(--danger)}.calendar-day--full .calendar-day__number{color:var(--danger)}.calendar-day--full.calendar-day--selected{background:var(--danger);border-color:var(--danger);color:#fff}.calendar-day--full.calendar-day--selected .calendar-day__number{color:#fff}.calendar-day--muted{opacity:.48}.calendar-day__number{font-size:1.05rem;font-weight:700}.calendar-day__meta{font-size:.82rem}.stats-row{margin-bottom:1rem}.stat-card{flex:1;min-width:110px;padding:1rem;border-radius:18px;background:var(--olive-100);border:1px solid var(--border)}.stat-card span{display:block;font-size:.84rem;color:var(--olive-700)}.stat-card strong{font-size:1.7rem;color:var(--olive-900)}.slot-list{display:grid;gap:.8rem}.slot-card{display:flex;justify-content:space-between;gap:1rem;padding:1rem;border-radius:18px;border:1px solid var(--border);background:#fff}.slot-card--available{border-left:5px solid var(--olive-500)}.slot-card--booked{border-left:5px solid var(--olive-900)}.slot-card--blocked{border-left:5px solid var(--danger)}.slot-card__time,.slot-card__status,.slot-card__details{margin:0}.slot-card__time{font-weight:700;color:var(--olive-900)}.slot-card__status{text-transform:capitalize;color:var(--olive-700)}.slot-card__details{margin-top:.2rem;color:#4d5345}.slot-card__badge{align-self:flex-start;background:var(--olive-100);color:var(--olive-900);padding:.35rem .65rem;border-radius:999px;font-size:.8rem;font-weight:600}.notice{margin-bottom:1rem;padding:.95rem 1rem;border-radius:16px;border:1px solid var(--border);background:var(--surface-soft);color:var(--olive-900)}.notice--warning{background:#f3f0e2;border-color:#e6dcc0}.notice--error{background:#f7eaea;border-color:#e8c6c2;color:var(--danger)}.notice--success{background:#ebf1e5;border-color:#d5e0c7}.login-form{display:grid;gap:1rem;max-width:440px;margin-bottom:1.25rem}.login-form--portal{max-width:520px;margin-bottom:0}.admin-caption{margin:0;color:var(--olive-700)}.booking-builder{display:grid;gap:1rem;margin-bottom:1.25rem}.admin-group{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:1rem;margin-bottom:1.25rem}.admin-group--booking,.admin-group--slots{grid-template-columns:repeat(2,minmax(0,1fr))}.field,.admin-slot-editor{display:flex;flex-direction:column;gap:.45rem}.field span,.admin-slot-editor__header strong{color:var(--olive-900)}.field--full-width{grid-column:1 / -1}.field--read-only{justify-content:flex-end}.static-field{width:100%;border-radius:14px;border:1px solid var(--border);padding:.8rem .9rem;background:var(--surface-soft);color:#4d5345}.field select,.field input,.admin-slot-editor select,.admin-slot-editor input,.admin-slot-editor textarea{width:100%;border-radius:14px;border:1px solid var(--border);padding:.8rem .9rem;background:#fff;color:#2f3329}.admin-slot-editor{padding:1rem;border:1px solid var(--border);border-radius:18px;background:var(--surface-soft)}.admin-slot-editor__header{display:flex;justify-content:space-between;gap:1rem;align-items:center}.slot-selector-grid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:.75rem}.slot-selector{display:flex;flex-direction:column;align-items:flex-start;gap:.25rem;padding:.9rem;border-radius:16px;border:1px solid var(--border);background:#fff;color:var(--olive-900)}.slot-selector small{text-transform:capitalize;color:var(--olive-700)}.slot-selector--available{border-left:5px solid var(--olive-500)}.slot-selector--booked{border-left:5px solid var(--olive-900)}.slot-selector--blocked{border-left:5px solid var(--danger)}.slot-selector--selected{outline:3px solid rgba(79,86,68,.2);background:var(--olive-100)}@media (max-width: 1080px){.layout{grid-template-columns:1fr}.panel--main,.panel--details,.panel--admin{grid-column:auto}}@media (max-width: 760px){.portal-overlay{padding:1rem;align-items:flex-start}.portal-card{max-height:calc(100vh - 2rem);padding:1.1rem}.hero{padding-top:4rem}.hero__topbar,.hero__actions{flex-direction:column;align-items:flex-start}.hero__heading-row{align-items:flex-start}.hero__brandmark-image{max-height:68px}.layout{padding:0 1rem 1.5rem}.calendar-grid{gap:.5rem}.calendar-day{min-height:88px;padding:.7rem}.admin-group,.admin-group--slots,.admin-group--booking,.slot-selector-grid{grid-template-columns:1fr}.section-heading{flex-direction:column;align-items:flex-start}}
