:root{--bg: #f4f7fb;--surface: #ffffff;--surface-muted: #f8fafc;--surface-strong: #edf3f8;--border: #d9e2ec;--border-strong: #b8c7d8;--text: #172033;--text-soft: #536173;--text-muted: #7a8796;--primary: #0b4a6f;--primary-strong: #07324c;--accent: #168574;--accent-soft: #e4f5f1;--danger: #b42318;--danger-soft: #fff0ee;--success: #11763f;--success-soft: #eaf7ef;--warning-soft: #fff7e6;--shadow: 0 12px 30px rgba(15, 45, 75, .08);--shadow-soft: 0 8px 18px rgba(15, 45, 75, .06);--radius-sm: 6px;--radius: 8px;--radius-lg: 12px;--nav-height: 72px;--max-width: 1180px;--font-body: "Microsoft YaHei", "PingFang SC", "Noto Sans SC", Arial, sans-serif}*,*:before,*:after{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-body);background:linear-gradient(180deg,#eef5f9 0%,var(--bg) 360px),var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;scroll-behavior:smooth}a{color:var(--primary);text-decoration:none}button,input,textarea,select{font:inherit}input,textarea,select{width:100%;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);padding:10px 12px;min-height:42px;transition:border-color .2s,box-shadow .2s}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #0b4a6f1f}textarea{resize:vertical}.app{min-height:100vh;display:flex;flex-direction:column}.navbar{height:var(--nav-height);background:#fffffff0;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:20;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.nav-inner{max-width:var(--max-width);height:100%;margin:0 auto;padding:0 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}.nav-brand,.admin-brand{display:flex;align-items:center;gap:12px;color:var(--text)}.nav-brand:hover{color:var(--text)}.nav-brand-logo{height:52px;width:auto;max-width:260px;object-fit:contain}.admin-brand-logo{height:44px;width:auto;max-width:220px;object-fit:contain}.nav-brand-icon,.admin-brand-mark{width:40px;height:40px;border-radius:8px;display:grid;place-items:center;background:var(--primary);color:#fff;font-weight:800}.nav-brand strong,.admin-brand strong{display:block;font-size:16px;line-height:1.15}.nav-brand small,.admin-brand small{display:block;color:var(--text-muted);font-size:11px;line-height:1.2;margin-top:3px}.nav-links{display:flex;align-items:center;gap:6px}.nav-links a,.nav-mobile a{color:var(--text-soft);padding:8px 12px;border-radius:var(--radius-sm);font-weight:600}.nav-links a:hover,.nav-links a.active,.nav-mobile a:hover,.nav-mobile a.active{background:var(--surface-strong);color:var(--primary)}.nav-user{color:var(--accent);background:var(--accent-soft);border:1px solid #bfe2d9;border-radius:999px;padding:5px 12px;font-size:13px;font-weight:700}.btn-link{border:0;background:transparent;color:var(--text-soft);cursor:pointer;padding:6px 8px}.btn-link:hover{color:var(--primary)}.nav-hamburger{display:none;width:42px;height:42px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;align-items:center;justify-content:center;flex-direction:column;gap:4px}.nav-hamburger span{width:20px;height:2px;background:var(--text)}.nav-mobile{display:none}.main-content{width:100%;max-width:var(--max-width);margin:0 auto;padding:42px 24px 56px;flex:1}.footer{border-top:1px solid var(--border);background:#fff;color:var(--text-muted);padding:18px 24px;display:flex;justify-content:center;gap:18px;font-size:13px}.btn{border:1px solid transparent;border-radius:var(--radius-sm);min-height:40px;padding:9px 16px;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;font-weight:700;transition:transform .15s,box-shadow .15s,background .15s,border-color .15s}.btn:hover:not(:disabled){transform:translateY(-1px)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-strong);box-shadow:var(--shadow-soft)}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover:not(:disabled){background:#126b5d;box-shadow:var(--shadow-soft)}.btn-outline{background:#fff;color:var(--primary);border-color:var(--border-strong)}.btn-outline:hover:not(:disabled){border-color:var(--primary);background:#f4f9fc}.btn-danger{background:var(--danger-soft);color:var(--danger);border-color:#f0b8b2}.btn-block{width:100%}.btn-lg{min-height:48px;padding:12px 20px}.btn-sm{min-height:34px;padding:6px 11px;font-size:13px}.eyebrow{display:inline-flex;color:var(--accent);font-weight:800;font-size:12px;letter-spacing:.08em;text-transform:uppercase}.hero{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(360px,.95fr);gap:34px;align-items:stretch;margin-bottom:26px}.hero-copy,.hero-panel,.panel,.form-card,.booking-card,.admin-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-soft)}.hero-copy{padding:54px;display:flex;flex-direction:column;justify-content:center}.hero h1,.page-title h1,.form-card h1,.admin-page h1,.not-found h1{margin:10px 0 14px;font-size:clamp(30px,4.8vw,54px);line-height:1.12;color:var(--primary-strong);letter-spacing:0}.hero-lead,.page-title p,.form-card-subtitle,.section-title p,.process-item p{color:var(--text-soft);margin:0}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:28px}.hero-panel{overflow:hidden}.hero-image,.hero-placeholder{width:100%;height:260px;object-fit:cover;background:linear-gradient(135deg,#dcecf4,#f5fbf8)}.hero-placeholder{display:grid;place-items:center;color:var(--primary)}.hero-placeholder span{font-size:64px;font-weight:900;letter-spacing:.12em;opacity:.14;grid-area:1 / 1}.hero-placeholder strong{grid-area:1 / 1;font-size:24px}.hero-facts{display:grid;gap:0}.hero-facts div{display:grid;grid-template-columns:88px 1fr;gap:16px;padding:18px 22px;border-top:1px solid var(--border)}.hero-facts span,.stat-card span{color:var(--text-muted);font-size:13px}.hero-facts strong{color:var(--text)}.process-band{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.process-item{padding:22px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}.process-item span{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-weight:900;margin-bottom:10px}.process-item strong{display:block;color:var(--primary-strong);margin-bottom:4px}.page-title{margin-bottom:24px}.compact-title h1{font-size:34px}.booking-layout,.settings-grid{display:grid;grid-template-columns:minmax(360px,.9fr) minmax(0,1.1fr);gap:22px}.booking-steps-stack{grid-template-columns:1fr}.booking-step-section{position:relative;overflow:hidden;scroll-margin-top:calc(var(--nav-height) + 88px)}.form-panel.booking-step-waiting{min-height:320px}.booking-step-waiting{opacity:.78}.booking-step-current{border-color:#b9d9d1;box-shadow:0 10px 28px #1685741a}.booking-step-ready:not(.booking-step-section-highlight){animation:booking-step-panel-enter .65s cubic-bezier(.22,1,.36,1)}.slot-panel.booking-step-ready:not(.booking-step-section-highlight){animation-name:booking-step-panel-enter-right}.form-panel.booking-step-ready:not(.booking-step-section-highlight){animation-name:booking-step-panel-enter-up}.form-panel-body{animation:form-panel-body-enter .55s cubic-bezier(.22,1,.36,1)}.booking-summary{margin-bottom:16px;padding:14px 16px;border-radius:var(--radius);background:var(--surface-muted);border:1px solid var(--border)}.booking-summary p{margin:4px 0;color:var(--text-soft)}@keyframes booking-step-panel-enter{0%{opacity:0;transform:translateY(18px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes booking-step-panel-enter-left{0%{opacity:0;transform:translate(-24px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes booking-step-panel-enter-right{0%{opacity:0;transform:translate(24px) scale(.98)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes booking-step-panel-enter-up{0%{opacity:0;transform:translateY(28px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes form-panel-body-enter{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.panel{padding:24px}.panel-head,.admin-header-bar{display:flex;align-items:center;justify-content:space-between;gap:18px;margin-bottom:18px}.panel-head h2,.section-title h2{margin:4px 0 0;font-size:22px;color:var(--primary-strong)}.panel-actions,.toolbar,.inline-edit,.upload-row{display:flex;align-items:center;gap:10px}.stepper{display:flex;gap:10px;margin-bottom:18px}.stepper.stepper-sticky{position:sticky;top:var(--nav-height);z-index:12;margin-bottom:18px;padding:12px 10px 14px;gap:8px;isolation:isolate}.stepper.stepper-sticky:before{content:"";position:absolute;top:-20px;bottom:-4px;left:50%;width:100vw;transform:translate(-50%);background:var(--bg);z-index:-1;pointer-events:none;box-shadow:0 10px 28px -16px #0f2d4b38}.stepper.stepper-sticky:after{content:"";position:absolute;left:50%;bottom:0;width:100vw;transform:translate(-50%);height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);pointer-events:none}.stepper.stepper-sticky>.step{position:relative;z-index:1;background:#fff;box-shadow:0 2px 10px #0f2d4b0d}.stepper.stepper-sticky>.step:hover{transform:translateY(-2px);z-index:2;box-shadow:0 10px 24px #0f2d4b1f}.step{flex:1;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:12px 14px;color:var(--text-muted);font-weight:700;cursor:pointer;text-align:left;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease,background .2s ease}.step:hover{transform:translateY(-1px);box-shadow:var(--shadow-soft)}.booking-section-highlight{animation:booking-section-focus 1.35s cubic-bezier(.22,1,.36,1)}.booking-section-highlight:before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:linear-gradient(90deg,var(--accent),#5fd4bc,var(--accent));background-size:200% 100%;animation:booking-top-bar 1.35s ease;z-index:2}.booking-section-highlight:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;border-radius:inherit;pointer-events:none;box-shadow:inset 0 0 0 3px #16857473;animation:booking-inner-ring 1.35s ease;z-index:1}@keyframes booking-section-focus{0%{transform:translateY(10px) scale(.985);opacity:.72;box-shadow:0 0 #16857400;border-color:var(--border);background:var(--surface)}18%{transform:translateY(0) scale(1.012);opacity:1;box-shadow:0 16px 36px #16857438;border-color:var(--accent);background:var(--accent-soft)}45%{transform:translateY(0) scale(1.006);box-shadow:0 10px 28px #16857429;border-color:#7ecdb9;background:#edf9f5}to{transform:translateY(0) scale(1);opacity:1;box-shadow:var(--shadow-soft);border-color:var(--border);background:var(--surface)}}@keyframes booking-top-bar{0%{transform:translate(-100%);opacity:0}20%{opacity:1}to{transform:translate(0);opacity:1}}@keyframes booking-inner-ring{0%{opacity:0;box-shadow:inset 0 0 #16857400}25%{opacity:1;box-shadow:inset 0 0 0 4px #1685748c}to{opacity:0;box-shadow:inset 0 0 #16857400}}.step.step-navigate{animation:step-navigate-pop .55s cubic-bezier(.22,1,.36,1)}@keyframes step-navigate-pop{0%{transform:scale(1)}35%{transform:scale(1.06);box-shadow:0 10px 24px #1685742e;border-color:var(--accent);background:var(--accent-soft)}to{transform:scale(1)}}.step em{font-style:normal}.step span{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:999px;background:var(--surface-strong);margin-right:8px}.step.active,.step.current{border-color:#b9d9d1;background:var(--accent-soft);color:var(--accent)}.step.done{border-color:#c8ddd7;background:#f3faf8;color:var(--text-soft)}.step-inline{display:inline-flex;margin-bottom:6px;padding:4px 10px;border-radius:999px;background:var(--accent-soft);color:var(--accent);font-size:12px;font-weight:800}.calendar-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:6px}.calendar-grid-7{grid-template-columns:repeat(7,minmax(0,1fr))}.cal-weekday{color:var(--text-muted);font-size:13px;font-weight:800;text-align:center;padding:6px 0}.cal-day{min-height:62px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text);cursor:pointer;padding:8px 4px}.cal-day:hover:not(:disabled),.cal-day.cal-selected{border-color:var(--primary);background:#eef6fb}.cal-day.cal-selected{animation:cal-select-pop .45s cubic-bezier(.22,1,.36,1)}@keyframes cal-select-pop{0%{transform:scale(.92)}60%{transform:scale(1.08)}to{transform:scale(1)}}.cal-day:disabled,.cal-day.cal-full,.cal-day.cal-past{background:#f2f4f7;color:var(--text-muted);cursor:not-allowed}.cal-past{opacity:.72}.cal-empty{background:transparent;border-color:transparent}.cal-day-num,.cal-day-info{display:block}.cal-day-num{font-weight:900;font-size:17px}.cal-day-info{color:var(--text-muted);font-size:12px}.slot-list{display:grid;gap:10px}.slot-card{width:100%;text-align:left;border:1px solid var(--border);border-radius:var(--radius);background:#fff;padding:16px;cursor:pointer}.slot-card:hover:not(:disabled),.slot-card.selected{border-color:var(--accent);background:var(--accent-soft)}.slot-card.selected{animation:slot-select-pop .45s cubic-bezier(.22,1,.36,1)}@keyframes slot-select-pop{0%{transform:scale(.96)}60%{transform:scale(1.03)}to{transform:scale(1)}}.slot-card.full{opacity:.55;cursor:not-allowed}.slot-time{display:block;font-weight:900;color:var(--primary-strong)}.slot-capacity{color:var(--text-soft);font-size:13px}.confirm-box{margin-top:18px;padding:18px;border-radius:var(--radius);background:var(--surface-muted);border:1px solid var(--border);position:relative;overflow:hidden;animation:confirm-box-enter .55s cubic-bezier(.22,1,.36,1)}@keyframes confirm-box-enter{0%{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.confirm-box p{margin:6px 0}.profile-prompt{display:flex;align-items:center;justify-content:space-between;gap:18px;background:var(--warning-soft);border:1px solid #f3d69a;border-radius:var(--radius);padding:16px;margin-bottom:18px}.profile-prompt p{margin:3px 0 0;color:var(--text-soft)}.form-page{min-height:62vh;display:grid;place-items:start center}.form-card{width:100%;max-width:460px;padding:30px}.form-card h1{font-size:30px}.form-group{margin-bottom:16px}.lookup-form{display:grid;gap:12px;margin-bottom:16px}.lookup-form input{width:100%}.booking-success-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:100;display:grid;place-items:center;background:#07324c6b;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);animation:booking-success-overlay-in .35s ease}.booking-success-overlay .booking-success-burst{position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,#16857459,#16857400 70%);animation:booking-success-burst .9s cubic-bezier(.22,1,.36,1) forwards}.booking-success-card{position:relative;z-index:1;width:min(320px,calc(100vw - 48px));padding:32px 28px 28px;border-radius:var(--radius-lg);background:#fff;box-shadow:0 24px 60px #0f2d4b38;text-align:center;animation:booking-success-card-pop .65s cubic-bezier(.22,1,.36,1)}.booking-success-card strong{display:block;margin-top:16px;font-size:26px;color:var(--primary-strong)}.booking-success-card p{margin:8px 0 0;color:var(--text-soft);font-size:14px}.booking-success-icon{width:72px;height:72px;margin:0 auto}.booking-success-icon svg{width:100%;height:100%;overflow:visible}.booking-success-icon-circle{fill:none;stroke:var(--accent);stroke-width:3;stroke-dasharray:151;stroke-dashoffset:151;animation:booking-success-circle-draw .6s cubic-bezier(.22,1,.36,1) .15s forwards}.booking-success-icon-check{fill:none;stroke:var(--accent);stroke-width:3.5;stroke-linecap:round;stroke-linejoin:round;stroke-dasharray:48;stroke-dashoffset:48;animation:booking-success-check-draw .45s cubic-bezier(.22,1,.36,1) .55s forwards}.my-bookings-page.my-bookings-pending{opacity:0;transform:translateY(24px)}.my-bookings-page.my-bookings-ready{animation:my-bookings-page-enter .7s cubic-bezier(.22,1,.36,1) forwards}.my-bookings-arrival .my-bookings-title{animation:my-bookings-title-enter .65s cubic-bezier(.22,1,.36,1) .1s both}.my-bookings-panel{opacity:1;transform:translateY(0)}.my-bookings-panel-ready{animation:my-bookings-panel-enter .65s cubic-bezier(.22,1,.36,1) .22s both}.booking-success-hero{margin-bottom:18px;padding:22px 24px;border-radius:var(--radius-lg);border:1px solid #b9d9d1;background:linear-gradient(135deg,#eaf7ef,#e4f5f1 48%,#eef6fb);box-shadow:0 12px 32px #1685741f;animation:booking-success-hero-enter .75s cubic-bezier(.22,1,.36,1) both;position:relative;overflow:hidden}.booking-success-hero:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.55) 50%,transparent 60%);transform:translate(-120%);animation:booking-success-hero-shine 1.1s ease .35s}.booking-success-hero-badge{display:inline-flex;align-items:center;border-radius:999px;padding:4px 12px;font-size:12px;font-weight:900;color:var(--success);background:#ffffffbf;border:1px solid #bde3c9;margin-bottom:10px}.booking-success-hero h2{margin:0 0 8px;font-size:22px;color:var(--primary-strong)}.booking-success-hero p{margin:4px 0 0;color:var(--text-soft)}.booking-success-hero-unit{font-size:14px}.booking-success-loading{animation:booking-success-loading-pulse 1.2s ease infinite}.booking-list-reveal .booking-card{animation:booking-card-reveal .6s cubic-bezier(.22,1,.36,1) both}.booking-card-fresh{border-color:#b9d9d1;box-shadow:0 10px 28px #16857424}@keyframes booking-success-overlay-in{0%{opacity:0}to{opacity:1}}@keyframes booking-success-burst{0%{transform:scale(.2);opacity:.8}to{transform:scale(2.2);opacity:0}}@keyframes booking-success-card-pop{0%{opacity:0;transform:scale(.82) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes booking-success-circle-draw{to{stroke-dashoffset:0}}@keyframes booking-success-check-draw{to{stroke-dashoffset:0}}@keyframes my-bookings-page-enter{0%{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}@keyframes my-bookings-title-enter{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes my-bookings-panel-enter{0%{opacity:0;transform:translateY(22px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes booking-success-hero-enter{0%{opacity:0;transform:translateY(20px) scale(.96)}60%{transform:translateY(-4px) scale(1.01)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes booking-success-hero-shine{to{transform:translate(120%)}}@keyframes booking-success-loading-pulse{0%,to{opacity:.55}50%{opacity:1}}@keyframes booking-card-reveal{0%{opacity:0;transform:translateY(18px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.form-group label{display:block;color:var(--text-soft);font-size:13px;font-weight:800;margin-bottom:6px}.form-row.cols-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.divider{display:flex;align-items:center;gap:12px;color:var(--text-muted);margin:18px 0}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border)}.form-footer{text-align:center;color:var(--text-soft);margin:18px 0 0}.booking-list{display:grid;gap:14px}.booking-card{padding:20px;display:flex;align-items:center;justify-content:space-between;gap:18px}.booking-card.cancelled{opacity:.7}.booking-info h2{margin:8px 0 6px;color:var(--primary-strong)}.booking-info p{margin:3px 0;color:var(--text-soft)}.booking-status,.role-badge{display:inline-flex;align-items:center;border-radius:999px;padding:3px 10px;font-size:12px;font-weight:900}.status-confirmed,.role-admin{color:var(--success);background:var(--success-soft);border:1px solid #bde3c9}.status-cancelled{color:var(--danger);background:var(--danger-soft);border:1px solid #f0b8b2}.role-user{color:var(--text-soft);background:var(--surface-strong);border:1px solid var(--border)}.alert{border-radius:var(--radius);padding:12px 14px;margin-bottom:16px;font-weight:700}.alert-success{color:var(--success);background:var(--success-soft);border:1px solid #bde3c9}.alert-error{color:var(--danger);background:var(--danger-soft);border:1px solid #f0b8b2}.toast{position:fixed;left:50%;bottom:28px;transform:translate(-50%);z-index:100;max-width:calc(100vw - 32px);min-width:240px;padding:14px 18px;border-radius:var(--radius);font-weight:700;text-align:center;box-shadow:var(--shadow);animation:toast-in .25s ease;cursor:pointer}.toast-success{color:var(--success);background:var(--success-soft);border:1px solid #bde3c9}.toast-error{color:var(--danger);background:var(--danger-soft);border:1px solid #f0b8b2}@keyframes toast-in{0%{opacity:0;transform:translate(-50%) translateY(12px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.loading,.empty{text-align:center;color:var(--text-soft);background:#fff;border:1px dashed var(--border-strong);border-radius:var(--radius);padding:48px 18px}.loading.slim{margin-top:18px;padding:18px}.empty.compact,.loading.compact{padding:22px 14px}.admin-layout{min-height:100vh;display:flex;background:var(--bg)}.admin-mobile-header{display:none;height:var(--nav-height);background:#fffffff0;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:25;padding:0 16px;align-items:center;justify-content:space-between;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.admin-mobile-drawer{display:none}.admin-nav-user{color:var(--accent);background:var(--accent-soft);border:1px solid #bfe2d9;border-radius:999px;padding:5px 12px;font-size:13px;font-weight:700}.admin-sidebar{width:260px;flex-shrink:0;background:#fff;border-right:1px solid var(--border);padding:22px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh}.admin-sidebar nav{display:grid;gap:6px}.admin-sidebar nav a{color:var(--text-soft);padding:11px 12px;border-radius:var(--radius-sm);font-weight:800}.admin-sidebar nav a:hover,.admin-sidebar nav a.active{color:var(--primary);background:var(--surface-strong)}.sidebar-footer{margin-top:auto;display:grid;gap:8px;padding-top:16px;border-top:1px solid var(--border)}.sidebar-footer span{color:var(--text-muted);font-size:13px}.admin-main{flex:1;min-width:0;padding:32px}.admin-header-bar{margin-bottom:22px}.admin-header-bar h1{font-size:32px}.admin-section{padding:22px;margin-top:20px}.section-title{margin-bottom:16px}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.stat-card{background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:20px;box-shadow:var(--shadow-soft)}.stat-card strong{display:block;color:var(--primary-strong);font-size:34px;line-height:1.1;margin-top:6px}.trend-bar{display:flex;align-items:flex-end;gap:16px;min-height:170px;overflow-x:auto;padding:12px 4px 0}.trend-bar-item{min-width:44px;flex:1;display:grid;justify-items:center;gap:5px}.trend-bar-fill{width:28px;border-radius:5px 5px 0 0;background:var(--accent)}.trend-bar-label,.trend-bar-val,.muted{color:var(--text-muted);font-size:12px}.data-table-wrap{width:100%;overflow-x:auto;background:#fff;border:1px solid var(--border);border-radius:var(--radius)}.data-table{width:100%;border-collapse:collapse;min-width:760px;font-size:14px}.data-table th,.data-table td{text-align:left;padding:12px 14px;border-bottom:1px solid var(--border);white-space:nowrap}.data-table th{color:var(--text-soft);background:var(--surface-muted);font-size:12px;letter-spacing:.04em}.data-table tr:last-child td{border-bottom:0}.toolbar input{width:170px}.filter-date-label{display:grid;gap:6px;min-width:200px;color:var(--text-soft);font-size:13px;font-weight:800}.filter-date-label input{width:170px}.admin-filter-toolbar{align-items:flex-end;flex-wrap:wrap}.admin-filter-toolbar .filter-date-label{flex:0 0 auto}.admin-filter-toolbar .date-picker{width:200px}.admin-filter-toolbar .btn{min-height:42px;white-space:nowrap}.date-picker{position:relative;width:100%}.date-picker-trigger{width:100%;min-height:42px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:#fff;color:var(--text-muted);text-align:left;cursor:pointer}.date-picker-trigger.has-value{color:var(--text);font-weight:700}.date-picker-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;border:0;background:#0f2d4b47;z-index:40;cursor:pointer}.date-picker-panel{position:absolute;top:calc(100% + 8px);left:0;right:auto;width:320px;min-width:320px;z-index:41;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:16px}.date-picker-head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:14px}.date-picker-head strong{color:var(--primary-strong);font-size:18px}.date-picker-actions{display:flex;justify-content:space-between;gap:10px;margin-top:14px}.date-picker-panel .cal-day{min-height:44px}.settings-grid{align-items:start}.upload-row img,.upload-placeholder{width:120px;height:76px;flex-shrink:0;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--border)}.upload-placeholder{display:grid;place-items:center;background:var(--surface-strong);color:var(--text-muted);font-size:13px}.slot-editor{display:grid;gap:10px;margin-bottom:14px}.slot-editor-row{display:grid;grid-template-columns:1fr auto 1fr 92px auto;gap:8px;align-items:center}.not-found{max-width:620px;margin:70px auto;text-align:center;background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);padding:46px;box-shadow:var(--shadow-soft)}.not-found p{color:var(--text-soft)}@media (max-width: 960px){.hero,.booking-layout,.settings-grid{grid-template-columns:1fr}.process-band,.stat-grid{grid-template-columns:repeat(2,1fr)}.admin-layout{flex-direction:column}.admin-mobile-header{display:flex}.admin-mobile-drawer{display:none;position:fixed;top:var(--nav-height);left:0;right:0;z-index:24;background:#fff;border-bottom:1px solid var(--border);box-shadow:var(--shadow);max-height:calc(100vh - var(--nav-height));overflow-y:auto}.admin-mobile-drawer.open{display:block}.admin-mobile-nav{display:grid;gap:6px;padding:14px 16px}.admin-mobile-nav a{color:var(--text-soft);padding:11px 12px;border-radius:var(--radius-sm);font-weight:800}.admin-mobile-nav a:hover,.admin-mobile-nav a.active{color:var(--primary);background:var(--surface-strong)}.admin-mobile-footer{display:grid;gap:8px;padding:14px 16px 18px;border-top:1px solid var(--border)}.admin-sidebar{display:none}}@media (max-width: 720px){.nav-links{display:none}.nav-hamburger{display:flex}.nav-mobile{display:none;position:fixed;top:var(--nav-height);left:0;right:0;z-index:30;background:#fff;border-bottom:1px solid var(--border);padding:14px 24px;box-shadow:var(--shadow)}.nav-mobile.open{display:grid;gap:8px}.main-content{padding:28px 16px 42px}.hero-copy{padding:30px}.hero h1,.page-title h1{font-size:32px}.hero-actions,.panel-head,.admin-header-bar,.profile-prompt,.booking-card,.toolbar,.inline-edit,.upload-row,.footer{align-items:stretch;flex-direction:column}.process-band,.stat-grid,.form-row.cols-2{grid-template-columns:1fr}.stepper,.stepper.stepper-sticky{gap:6px;margin-bottom:12px;padding:10px 6px 12px}.stepper.stepper-sticky:before{top:-14px}.step{padding:8px 6px;font-size:12px;text-align:center;line-height:1.25}.step span{display:grid;width:22px;height:22px;margin:0 auto 4px;font-size:12px}.step em{display:block}.page-title{margin-bottom:14px}.page-title h1{font-size:28px}.panel,.form-card,.admin-main{padding:18px}.slot-editor-row{grid-template-columns:1fr 1fr}.slot-editor-row span{display:none}.slot-editor-row .btn{grid-column:1 / -1}.toolbar input{width:100%}.data-table-wrap{overflow:visible;border:0;background:transparent}.data-table{min-width:0;border:0}.data-table thead{display:none}.data-table tbody{display:grid;gap:12px}.data-table tr{display:grid;gap:8px;background:#fff;border:1px solid var(--border);border-radius:var(--radius);padding:14px;box-shadow:var(--shadow-soft)}.data-table td{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:0;border:0;white-space:normal}.data-table td:before{content:attr(data-label);color:var(--text-muted);font-size:12px;font-weight:800;flex-shrink:0}.data-table td[data-label=""]:before,.data-table td:not([data-label]):before{content:none}.date-picker-panel{position:fixed;left:12px;right:12px;bottom:12px;top:auto;width:auto;min-width:0;max-height:calc(100vh - 24px);overflow-y:auto}.date-picker-panel .cal-day{min-height:48px}}@media (max-width: 460px){.calendar-grid{gap:4px}.cal-day{min-height:54px;padding:6px 2px}.cal-day-num{font-size:15px}}
