html{--accent:#059669;--accent-strong:#047857;--accent-soft:#d1fae58a;--accent-shadow:#05966938;--ink:#101828;--muted:#667085;--muted-strong:#475467;--line-soft:#94a3b829;--glass-bg:#ffffff94;--glass-bg-strong:#ffffffb8;--glass-bg-soft:#ffffff6b;--glass-edge:#ffffffb8;--glass-shadow:inset 0 1px 0 #ffffffc7, inset 0 -1px 0 #0f172a0a, 0 18px 42px #0f172a1c;--glass-shadow-soft:inset 0 1px 0 #ffffffb3, 0 12px 30px #0f172a14;--glass-blur:blur(22px) saturate(1.45);color:var(--ink);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f7fb}html,body,#root{min-height:100%}body{background:linear-gradient(140deg,#d1fae5a3,#0000 38%),linear-gradient(225deg,#e2e8f0bd,#0000 34%),linear-gradient(#edf7f3,#f7fafc);margin:0;font-family:system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;overflow:hidden}button{font:inherit}#root{min-height:100dvh}.app-shell{height:100dvh;padding:calc(18px + env(safe-area-inset-top)) 18px calc(18px + env(safe-area-inset-bottom));box-sizing:border-box;background:linear-gradient(#ffffff80 0,#f5f7fb00 260px),linear-gradient(135deg,#d1fae573,#f8fafc94 54%,#ffffffb8);grid-template-rows:auto minmax(0,1fr);display:grid}.app-header{grid-template-columns:44px minmax(0,1fr) auto;align-items:center;gap:16px;width:100%;margin:0 0 18px;display:grid}.header-title{min-width:0}.eyebrow{color:#5b6678;margin:0 0 4px;font-size:13px;font-weight:800}.app-header h1{color:var(--ink);margin:0;font-size:28px;font-weight:750;line-height:1.15}.header-status{background:linear-gradient(135deg, #ffffffb8, #fff6), var(--glass-bg);color:#1f2937;box-shadow:var(--glass-shadow-soft);-webkit-backdrop-filter:var(--glass-blur);border-radius:999px;flex:none;align-items:center;gap:8px;padding:6px 8px 6px 12px;font-size:13px;font-weight:800;display:inline-flex}.header-status button{color:var(--accent-strong);cursor:pointer;background:#ecfdf5b8;border:0;border-radius:999px;padding:6px 9px;font-size:12px;font-weight:900}.auth-shell{box-sizing:border-box;background:linear-gradient(140deg,#d1fae5b3,#0000 40%),linear-gradient(225deg,#e2e8f0bd,#0000 36%),linear-gradient(#edf7f3,#f7fafc);place-items:center;min-height:100dvh;padding:24px;display:grid}.auth-panel{border:1px solid var(--line-soft);background:linear-gradient(145deg, #ffffffc2, #ffffff6b), var(--glass-bg);width:min(100%,420px);box-shadow:var(--glass-shadow);-webkit-backdrop-filter:var(--glass-blur);border-radius:8px;gap:18px;padding:24px;display:grid;position:relative;overflow:hidden}.auth-panel:after{content:"";pointer-events:none;mix-blend-mode:screen;background:linear-gradient(120deg,#ffffff8f,#0000 36%),linear-gradient(#ffffff47,#0000 52%);position:absolute;inset:0}.auth-panel>*{z-index:1;position:relative}.auth-panel h1{color:var(--ink);margin:0;font-size:34px;line-height:1.1}.auth-panel p{color:var(--muted);margin:8px 0 0;font-size:14px;line-height:1.55}.auth-config,.auth-error{border-radius:8px;padding:12px;font-size:13px;line-height:1.45}.auth-config{color:#8a4b0f;background:#fff7edb8;gap:4px;display:grid}.auth-error{color:#991b1b;background:#fee2e2b8;margin:0;font-weight:800}.auth-primary-button{color:#fff;cursor:pointer;min-height:48px;box-shadow:inset 0 1px 0 #ffffff38, 0 14px 30px var(--accent-shadow);background:linear-gradient(135deg,#111827f0,#059669db);border:0;border-radius:8px;font-size:15px;font-weight:900}.auth-primary-button:disabled{cursor:not-allowed;opacity:.48}.auth-progress{background:#d1fae5c7;border-radius:999px;height:5px;position:relative;overflow:hidden}.auth-progress:after{content:"";border-radius:inherit;background:linear-gradient(90deg, #111827f0, var(--accent));width:42%;animation:1.05s ease-in-out infinite auth-progress;position:absolute;inset:0}@keyframes auth-progress{0%{transform:translate(-100%)}to{transform:translate(240%)}}.app-main{overscroll-behavior:contain;scrollbar-width:none;-webkit-overflow-scrolling:touch;width:100%;min-height:0;margin:0;padding:0 0 20px;display:grid;overflow-y:auto}.app-main.reservations-main{padding-bottom:0;overflow:hidden}.app-main::-webkit-scrollbar{display:none}.screen-section,.screen-group{align-content:start;gap:16px;display:grid}.reservations-screen{grid-template-rows:auto auto auto minmax(0,1fr);align-content:start;height:100%;min-height:0;overflow:hidden}.screen-group{margin-top:8px}.section-header h2{color:var(--ink);margin:0;font-size:18px;font-weight:800;line-height:1.25}.section-header p{color:var(--muted);margin:4px 0 0;font-size:14px;line-height:1.45}.metric-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.metric{border:1px solid var(--line-soft);background:linear-gradient(145deg, #ffffffc2, #ffffff5c), var(--glass-bg);box-sizing:border-box;min-height:92px;box-shadow:var(--glass-shadow);-webkit-backdrop-filter:var(--glass-blur);border-radius:8px;padding:15px;position:relative;overflow:hidden}.metric:after,.sync-card:after,.list-item:after,.alert-item:after,.calendar-panel:after,.date-navigator:after,.period-summary:after{content:"";pointer-events:none;opacity:.72;mix-blend-mode:screen;background:linear-gradient(120deg,#ffffff8c,#0000 32%),linear-gradient(#ffffff52,#0000 46%);position:absolute;inset:0}.metric span{z-index:1;color:var(--muted);font-size:13px;font-weight:800;display:block;position:relative}.metric strong{z-index:1;color:var(--ink);margin-top:8px;font-size:22px;line-height:1.1;display:block;position:relative}.metric p{z-index:1;color:var(--muted-strong);margin:6px 0 0;font-size:13px;position:relative}.focus-panel{color:#fff;-webkit-backdrop-filter:blur(24px)saturate(1.35);background:linear-gradient(135deg,#111827eb,#23374dc2),#111827b8;border:1px solid #ffffff2e;border-radius:8px;grid-template-columns:minmax(0,1fr);gap:12px;padding:16px;display:grid;position:relative;overflow:hidden;box-shadow:inset 0 1px #ffffff2e,inset 0 -1px #ffffff14,0 24px 52px #11182742}.focus-panel.empty-focus{background:linear-gradient(135deg,#111827e6,#059669b3),#111827b8}.focus-panel:after{content:"";pointer-events:none;mix-blend-mode:screen;background:linear-gradient(120deg,#ffffff2e,#0000 34%),linear-gradient(#10b98129,#0000 38%);position:absolute;inset:0}.focus-panel>*{z-index:1;position:relative}.focus-panel-main span,.focus-panel-side span{color:#cbd5e1;font-size:12px;font-weight:800}.focus-panel-main strong{margin-top:10px;font-size:36px;line-height:1;display:block}.focus-panel-main h3{margin:10px 0 0;font-size:20px;line-height:1.2}.focus-panel-main p{color:#e5e7eb;margin:6px 0 0;font-size:14px}.focus-panel-side{justify-content:space-between;align-items:center;gap:12px;display:flex}.focus-panel .status-pill{color:#065f46;background:#d1fae5}.sync-grid{gap:12px;display:grid}.sync-card{border:1px solid var(--line-soft);background:linear-gradient(145deg, #ffffffad, #ffffff57), var(--glass-bg-soft);box-shadow:var(--glass-shadow-soft);-webkit-backdrop-filter:var(--glass-blur);border-radius:8px;gap:6px;padding:12px;display:grid;position:relative;overflow:hidden}.sync-card>div{z-index:1;align-items:center;gap:8px;display:flex;position:relative}.sync-card strong{color:var(--ink);font-size:13px;line-height:1.2}.sync-card p{z-index:1;color:var(--muted);margin:0;font-size:13px;line-height:1.45;position:relative}.sync-dot{background:#12b76a;border-radius:50%;width:8px;height:8px}.sync-card.disconnected .sync-dot{background:#94a3b8}.sync-card.disconnected p{color:#7a8798}.segmented-control{-webkit-backdrop-filter:var(--glass-blur);background:linear-gradient(145deg,#ffffff8f,#ffffff3d),#dce5f16b;border:1px solid #ffffff94;border-radius:8px;grid-auto-columns:1fr;grid-auto-flow:column;gap:4px;padding:4px;display:grid;box-shadow:inset 0 1px #fffc,0 12px 30px #0f172a14}.segmented-control button,.app-nav button,.menu-button,.menu-backdrop,.today-button{cursor:pointer;border:0}.segmented-control button{color:#536274;background:0 0;border-radius:6px;min-height:38px;font-size:14px;font-weight:700}.segmented-control button.active{color:#fff;box-shadow:inset 0 1px 0 #fff3, 0 10px 24px var(--accent-shadow);background:linear-gradient(135deg,#111827f0,#059669d1)}.date-navigator,.period-summary{border:1px solid var(--line-soft);background:linear-gradient(145deg, #ffffffbd, #ffffff57), var(--glass-bg);box-shadow:var(--glass-shadow);-webkit-backdrop-filter:var(--glass-blur);border-radius:8px;position:relative;overflow:hidden}.date-navigator{grid-template-columns:44px minmax(0,1fr) 44px;align-items:center;gap:8px;padding:8px;display:grid}.date-control-stack{gap:8px;display:grid}.date-shortcuts{justify-content:flex-end;display:flex}.date-navigator>div,.period-summary{z-index:1;text-align:center;min-width:0}.date-navigator span,.period-summary span{z-index:1;color:#667085;font-size:12px;font-weight:800;display:block;position:relative}.today-button{color:var(--accent-strong);background:linear-gradient(135deg,#d1fae5e6,#ffffff80),#ecfdf5d1;border-radius:999px;padding:8px 14px;font-size:13px;font-weight:900;line-height:1;box-shadow:inset 0 1px #fffc,0 8px 18px #0596691f}.today-button:active,.segmented-control button:active,.app-nav button:active,.icon-button:active{transform:translateY(1px)}.date-navigator strong,.period-summary strong{z-index:1;overflow-wrap:anywhere;color:#111827;margin-top:3px;font-size:17px;line-height:1.25;display:block;position:relative}.period-summary{padding:12px 14px}.icon-button{z-index:1;color:#111827;cursor:pointer;background:linear-gradient(135deg,#ffffff85,#ffffff38),#ecf3fab8;border:0;border-radius:8px;place-items:center;width:44px;height:44px;font-size:28px;line-height:1;display:grid;position:relative}.icon-button:active{background:#dbe3ec}.list-stack{gap:12px;display:grid}.reservation-results{overscroll-behavior:contain;scrollbar-width:none;-webkit-overflow-scrolling:touch;min-height:0;padding-right:2px;overflow-y:auto}.reservation-results.list-stack,.reservation-results.date-group-list{grid-auto-rows:max-content;align-content:start}.reservation-results .list-item{min-height:92px}.reservation-results::-webkit-scrollbar{display:none}.date-group-list{gap:16px;display:grid}.date-group{gap:8px;display:grid}.date-group-header{justify-content:space-between;align-items:center;gap:12px;padding:2px 2px 0;display:flex}.date-group-header h3{color:#111827;margin:0;font-size:15px;font-weight:800;line-height:1.25}.date-group-header span{color:#667085;flex:none;font-size:12px;font-weight:800}.calendar-panel{border:1px solid var(--line-soft);background:linear-gradient(145deg, #ffffffad, #ffffff57), var(--glass-bg);box-shadow:var(--glass-shadow);-webkit-backdrop-filter:var(--glass-blur);border-radius:8px;grid-template-rows:auto minmax(0,1fr);display:grid;position:relative;overflow:hidden}.calendar-weekdays,.calendar-grid{grid-template-columns:repeat(7,minmax(0,1fr));display:grid}.calendar-weekdays{z-index:1;background:#f8fafc94;position:relative}.calendar-weekdays span{color:#667085;text-align:center;min-width:0;padding:8px 0;font-size:12px;font-weight:800}.calendar-grid{z-index:1;background:0 0;grid-auto-rows:minmax(0,1fr);gap:2px;padding:2px;position:relative}.calendar-day{aspect-ratio:1;box-sizing:border-box;cursor:pointer;text-align:left;background:linear-gradient(145deg,#ffffffa8,#ffffff57),#ffffff75;border:0;border-radius:7px;min-width:0;min-height:0;padding:7px 6px;box-shadow:inset 0 1px #ffffff94}.calendar-day:active{transform:scale(.99)}.month-view .calendar-panel,.month-view .calendar-grid{min-height:0}.month-view .calendar-day{aspect-ratio:auto}.calendar-day.outside-month{background:#eef3f870}.calendar-day.today{box-shadow:inset 0 0 0 2px var(--accent)}.calendar-day.has-reservations{background:linear-gradient(145deg, #f7fbffc7, #ffffff6b), var(--accent-soft)}.calendar-day-top{justify-content:space-between;align-items:center;gap:4px;display:flex}.calendar-day-top span{color:#344054;font-size:13px;font-weight:800;line-height:1}.outside-month .calendar-day-top span{color:#98a2b3}.calendar-day-top strong{background:var(--accent);color:#fff;border-radius:999px;place-items:center;min-width:18px;height:18px;font-size:11px;line-height:1;display:grid}.calendar-reservation{border-left:3px solid var(--accent);margin-top:8px;padding-left:5px;overflow:hidden}.calendar-reservation span{color:var(--accent-strong);font-size:11px;font-weight:900;line-height:1.1;display:block}.calendar-reservation p{color:#111827;text-overflow:ellipsis;white-space:nowrap;margin:3px 0 0;font-size:11px;font-weight:800;line-height:1.2;overflow:hidden}.empty-state{background:linear-gradient(145deg, #ffffffb8, #ffffff57), var(--glass-bg-soft);color:var(--muted);text-align:center;box-shadow:var(--glass-shadow-soft);-webkit-backdrop-filter:var(--glass-blur);border:1px dashed #64748b38;border-radius:8px;margin:0;padding:26px 18px;font-size:14px;font-weight:700}.list-item,.alert-item{border:1px solid var(--line-soft);background:linear-gradient(145deg, #ffffffbd, #ffffff5c), var(--glass-bg);box-shadow:var(--glass-shadow);-webkit-backdrop-filter:var(--glass-blur);border-radius:8px;display:grid;position:relative;overflow:hidden}.list-item{grid-template-columns:72px minmax(0,1fr);gap:14px;padding:15px}.reservation-card{position:relative;overflow:hidden}.reservation-card:before{content:"";background:#12b76a;width:4px;position:absolute;inset:0 auto 0 0}.reservation-card.changed:before{background:#f79009}.reservation-card.cancelled:before{background:#f04438}.item-time{z-index:1;align-content:start;gap:4px;display:grid;position:relative}.item-time strong{color:var(--ink);font-size:18px;line-height:1}.item-time span,.item-meta span{color:var(--muted);font-size:12px;font-weight:700}.item-body{z-index:1;min-width:0;position:relative}.item-title-row{justify-content:space-between;align-items:center;gap:10px;display:flex}.item-title-row h3{overflow-wrap:anywhere;min-width:0;color:var(--ink);margin:0;font-size:16px;line-height:1.25}.item-title-row strong{color:var(--ink);flex:none;font-size:16px}.item-body p{color:var(--muted-strong);margin:6px 0 0;font-size:14px}.item-meta{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.item-meta span{background:#f0f4f8b8;border-radius:999px;padding:4px 8px;box-shadow:inset 0 1px #ffffff9e}.meta-chip.paid,.meta-chip.mail,.meta-chip.square{color:#137547;background:#e8f5ee}.meta-chip.unpaid{color:#8a5a00;background:#fff5d7}.meta-chip.salonboard_csv{color:#047857;background:#ecfdf5}.meta-chip.note{overflow-wrap:anywhere;max-width:100%}.status-pill{border-radius:999px;flex:none;padding:4px 8px;font-size:12px;font-weight:800}.status-pill.confirmed{color:#137547;background:#e8f5ee}.status-pill.changed{color:#8a5a00;background:#fff5d7}.status-pill.cancelled{color:#b42318;background:#ffe8e8}.alert-item{grid-template-columns:10px minmax(0,1fr);gap:12px;padding:14px}.alert-dot{z-index:1;border-radius:50%;width:10px;height:10px;margin-top:5px;position:relative}.alert-dot.warning{background:#f59e0b}.alert-dot.info{background:var(--accent)}.alert-item h3{z-index:1;color:#111827;margin:0;font-size:15px;position:relative}.alert-item p{z-index:1;color:#475467;margin:4px 0 0;font-size:13px;line-height:1.45;position:relative}.menu-button{width:46px;height:46px;-webkit-backdrop-filter:var(--glass-blur);background:radial-gradient(circle at 72% 18%,#ffffff47,#0000 28%),linear-gradient(135deg,#111827f5,#059669e0);border-radius:16px;display:block;position:relative;overflow:hidden;box-shadow:inset 0 1px #fff3,inset 0 -1px #0000002e,0 16px 32px #0596693d}.menu-button:before{content:"";pointer-events:none;background:linear-gradient(145deg,#fff3,#0000 44%),linear-gradient(315deg,#10b98152,#0000 46%);border-radius:15px;position:absolute;inset:1px}.menu-button span{background:#fffffff0;border-radius:999px;width:20px;height:2px;transition:opacity .18s,transform .18s,width .18s;display:block;position:absolute;left:13px;box-shadow:0 1px 8px #fff3}.menu-button span:first-child{top:15px}.menu-button span:nth-child(2){width:14px;top:22px}.menu-button span:nth-child(3){width:18px;top:29px}.menu-button.open span:first-child{width:20px;transform:translateY(7px)rotate(45deg)}.menu-button.open span:nth-child(2){opacity:0;transform:translate(-5px)}.menu-button.open span:nth-child(3){width:20px;transform:translateY(-7px)rotate(-45deg)}.menu-backdrop{z-index:20;-webkit-backdrop-filter:blur(4px);background:#0f172a2e;position:fixed;inset:0}.app-nav{z-index:30;width:min(300px,84vw);padding:calc(22px + env(safe-area-inset-top)) 10px calc(16px + env(safe-area-inset-bottom));-webkit-backdrop-filter:blur(28px)saturate(1.55);opacity:0;pointer-events:none;background:linear-gradient(145deg,#ffffffb8,#ffffff61),#ffffff8f;border-radius:0 14px 14px 0;grid-template-columns:minmax(0,1fr);align-content:start;gap:6px;transition:opacity .18s,transform .18s;display:grid;position:fixed;top:0;bottom:0;left:0;transform:translate(-100%);box-shadow:inset 0 1px #ffffffd1,0 22px 54px #0f172a38}.app-nav.open{opacity:1;pointer-events:auto;transform:translate(0)}.app-nav button{color:#526174;text-align:left;background:0 0;border-radius:8px;grid-template-columns:minmax(0,1fr);align-content:center;justify-items:start;gap:2px;min-height:52px;padding:11px 14px;font-size:13px;font-weight:800;display:grid}.app-nav button small{color:#8a97a8;font-size:10px;font-weight:800;line-height:1}.app-nav button.active{color:#fff;box-shadow:inset 0 1px 0 #fff3, 0 10px 24px var(--accent-shadow);background:linear-gradient(135deg,#111827f0,#059669cc)}.app-nav button.active small{color:#cbd5e1}@media (width>=720px){.app-shell{padding:calc(30px + env(safe-area-inset-top)) 30px calc(24px + env(safe-area-inset-bottom))}.app-header h1{font-size:34px}.metric-grid{grid-template-columns:repeat(4,minmax(0,1fr))}.focus-panel,.sync-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.focus-panel-main{grid-column:span 2}.focus-panel-side{text-align:right;flex-direction:column;justify-content:space-between;align-items:flex-end}.metric-grid.two-columns{grid-template-columns:repeat(2,minmax(0,1fr))}.list-item{grid-template-columns:92px minmax(0,1fr)}}@media (width>=960px){.app-shell{padding:calc(34px + env(safe-area-inset-top)) 34px calc(34px + env(safe-area-inset-bottom));grid-template-rows:auto minmax(0,1fr);grid-template-columns:224px minmax(0,1fr);column-gap:30px}.app-header{grid-column:2;grid-template-columns:minmax(0,1fr) auto;width:100%;margin-bottom:24px}.app-main{grid-column:2;padding-bottom:0}.menu-button,.menu-backdrop{display:none}.app-nav{opacity:1;pointer-events:auto;border:1px solid #ffffffa3;border-radius:8px;grid-area:1/1/span 2;align-self:start;width:auto;margin-top:46px;position:relative;inset:auto;transform:none}.app-nav button{min-height:58px;font-size:15px}}
