@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=DM+Mono:wght@400;500&display=swap";:root{--color-primary: #1D4ED8;--color-primary-dark: #1E3A8A;--color-primary-mid: #2563EB;--color-primary-light: #EFF6FF;--color-primary-hover: #1E40AF;--color-accent: #D97706;--color-accent-light: #FEF3C7;--color-accent-dark: #92400E;--color-bg: #F3F3F0;--color-surface: #FFFFFF;--color-surface-raised: #FFFFFF;--color-border: #E4E3DF;--color-border-light: #EDECE8;--color-text: #111827;--color-text-muted: #6B7280;--color-text-subtle: #9CA3AF;--color-text-inverse: #FFFFFF;--color-sidebar: #111827;--color-confirmed: #059669;--color-confirmed-bg: #D1FAE5;--color-confirmed-text: #065F46;--color-pending: #D97706;--color-pending-bg: #FEF3C7;--color-pending-text: #78350F;--color-cancelled: #DC2626;--color-cancelled-bg: #FEE2E2;--color-cancelled-text: #7F1D1D;--sidebar-width: 252px;--sidebar-collapsed: 64px;--topbar-height: 60px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05), 0 1px 3px rgba(0,0,0,.04);--shadow-md: 0 4px 16px rgba(0,0,0,.07), 0 1px 4px rgba(0,0,0,.04);--shadow-lg: 0 12px 32px rgba(0,0,0,.09), 0 2px 8px rgba(0,0,0,.05);--shadow-panel: -4px 0 24px rgba(0,0,0,.08);--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--transition-fast: .12s ease;--transition-base: .2s ease;--transition-slow: .3s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}body{font-family:var(--font-body);font-size:14px;line-height:1.5;color:var(--color-text);background-color:var(--color-bg);min-height:100vh}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-family:var(--font-body);font-weight:600;line-height:1.25;color:var(--color-text)}h1{font-size:24px}h2{font-size:20px}h3{font-size:16px}h4{font-size:14px}p{line-height:1.6}a{color:var(--color-primary);text-decoration:none}button{font-family:var(--font-body);cursor:pointer;border:none;background:none}input,select,textarea{font-family:var(--font-body);font-size:14px}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-subtle)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.badge{display:inline-flex;align-items:center;font-size:11px;font-weight:600;letter-spacing:.03em;padding:3px 9px;border-radius:var(--radius-full);white-space:nowrap}.badge--confirmed{background:var(--color-confirmed-bg);color:var(--color-confirmed-text)}.badge--pending{background:var(--color-pending-bg);color:var(--color-pending-text)}.badge--cancelled{background:var(--color-cancelled-bg);color:var(--color-cancelled-text)}.badge--declined{background:#f3f4f6;color:#374151}.badge--lang{background:var(--color-primary-light);color:var(--color-primary);font-size:10px;letter-spacing:.07em;font-weight:700}.btn{display:inline-flex;align-items:center;gap:var(--space-2);font-weight:500;border-radius:var(--radius-md);transition:background var(--transition-fast),color var(--transition-fast),box-shadow var(--transition-fast);white-space:nowrap}.btn--sm{font-size:13px;padding:5px 12px}.btn--md{font-size:14px;padding:8px 18px}.btn--primary{background:var(--color-primary);color:var(--color-text-inverse);box-shadow:0 1px 2px #1d4ed84d}.btn--primary:hover{background:var(--color-primary-hover)}.btn--primary:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.btn--secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn--secondary:hover{background:var(--color-bg)}.btn--ghost{background:transparent;color:var(--color-text-muted)}.btn--ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn__icon{display:flex;align-items:center}.card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);overflow:hidden}.card__header{padding:var(--space-4) var(--space-6);border-bottom:1px solid var(--color-border-light);background:var(--color-surface)}.card__title{font-size:13.5px;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.card__body{padding:var(--space-5) var(--space-6)}.card__footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--color-border-light)}.kpi-card{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);border-left:4px solid transparent;padding:var(--space-5) var(--space-6);transition:box-shadow var(--transition-fast)}.kpi-card:hover{box-shadow:var(--shadow-md)}.kpi-card__value{font-size:40px;font-weight:700;line-height:1;letter-spacing:-.03em;margin-bottom:var(--space-2)}.kpi-card__label{font-size:12.5px;color:var(--color-text-muted);font-weight:500;letter-spacing:.01em}.kpi-card__trend{margin-top:var(--space-2);font-size:12px;color:var(--color-confirmed);font-weight:500}.app-shell{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.app-shell__content{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.app-shell__main{flex:1;padding:var(--space-6);overflow-y:auto}.sidebar{background:var(--color-sidebar);display:flex;flex-direction:column;min-height:100vh;position:sticky;top:0;height:100vh;overflow:hidden}.sidebar__brand{display:flex;align-items:center;justify-content:center;padding:18px 12px 14px;border-bottom:1px solid rgba(255,255,255,.07)}.sidebar__brand-logo{display:block;width:210px;height:auto;mix-blend-mode:screen;opacity:.92}.sidebar__nav{flex:1;padding:var(--space-3);display:flex;flex-direction:column;gap:2px}.sidebar__nav-item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:10px var(--space-3);border-radius:var(--radius-md);color:#ffffff80;font-size:13.5px;font-weight:500;transition:background var(--transition-fast),color var(--transition-fast);text-align:left;position:relative}.sidebar__nav-item:hover{background:#ffffff0f;color:#ffffffd9}.sidebar__nav-item--active{background:#ffffff17;color:#fff}.sidebar__nav-item--active:before{content:"";position:absolute;left:0;top:7px;bottom:7px;width:3px;background:var(--color-accent);border-radius:0 2px 2px 0}.sidebar__nav-icon{display:flex;align-items:center;flex-shrink:0}.sidebar__nav-label{flex:1}.sidebar__footer{padding:var(--space-4) var(--space-5);border-top:1px solid rgba(255,255,255,.05)}.sidebar__version{font-size:11px;color:#fff3;font-family:var(--font-mono)}.topbar{height:var(--topbar-height);background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);flex-shrink:0}.topbar__title{font-size:15px;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.topbar__right{display:flex;align-items:center;gap:var(--space-4)}.topbar__date{font-size:13px;color:var(--color-text-muted)}.topbar__restaurant{font-size:12.5px;font-weight:600;color:var(--color-accent-dark);background:var(--color-accent-light);padding:4px 11px;border-radius:var(--radius-full);border:1px solid rgba(217,119,6,.15)}.restaurant-picker{position:relative}.restaurant-picker__trigger{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:600;color:var(--color-accent-dark);background:var(--color-accent-light);padding:4px 10px 4px 11px;border-radius:var(--radius-full);border:1px solid rgba(217,119,6,.15);cursor:pointer;font-family:var(--font-body);transition:filter var(--transition-fast)}.restaurant-picker__trigger:hover{filter:brightness(.96)}.restaurant-picker__chevron{display:flex;align-items:center;color:var(--color-accent-dark);transition:transform var(--transition-fast);flex-shrink:0}.restaurant-picker__chevron--open{transform:rotate(180deg)}.restaurant-picker__popover{position:absolute;top:calc(100% + 8px);right:0;min-width:260px;max-width:360px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:500;overflow:hidden}.restaurant-picker__search-wrap{padding:var(--space-3);border-bottom:1px solid var(--color-border-light)}.restaurant-picker__search{width:100%;padding:7px 11px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:13.5px;color:var(--color-text);background:var(--color-bg);outline:none;font-family:var(--font-body);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.restaurant-picker__search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1d4ed81a}.restaurant-picker__search::placeholder{color:var(--color-text-subtle)}.restaurant-picker__list{list-style:none;max-height:280px;overflow-y:auto;padding:var(--space-2) 0}.restaurant-picker__item{display:flex;align-items:center;justify-content:space-between;gap:var(--space-2);padding:9px 14px;font-size:13.5px;font-weight:500;color:var(--color-text);cursor:pointer;transition:background var(--transition-fast)}.restaurant-picker__item:hover{background:var(--color-bg)}.restaurant-picker__item--active{color:var(--color-primary);background:var(--color-primary-light);font-weight:600}.restaurant-picker__item--active:hover{background:#dbeafe}.restaurant-picker__empty{padding:var(--space-4);font-size:13px;color:var(--color-text-muted);text-align:center}.topbar__user{display:flex;align-items:center;gap:var(--space-2);padding:5px 5px 5px 7px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-surface)}.topbar__user-avatar{width:28px;height:28px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;font-size:12px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.topbar__user-info{display:flex;flex-direction:column;line-height:1.2}.topbar__user-name{font-size:12.5px;font-weight:600;color:var(--color-text);max-width:140px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.topbar__user-role{font-size:11px;color:var(--color-text-muted);font-weight:400}.topbar__logout-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);color:var(--color-text-muted);transition:background var(--transition-fast),color var(--transition-fast);margin-left:2px}.topbar__logout-btn:hover{background:var(--color-bg);color:var(--color-text)}.auth-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg)}.auth-loading__spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:var(--radius-full);animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg);padding:var(--space-6)}.login-card{width:100%;max-width:400px;background:var(--color-surface);border-radius:var(--radius-xl);border:1px solid var(--color-border);box-shadow:var(--shadow-lg);padding:var(--space-8)}.login-card__brand{display:flex;align-items:center;gap:var(--space-3);margin-bottom:var(--space-6)}.login-logo-mark{width:36px;height:36px;border-radius:var(--radius-md);background:var(--color-primary);color:#fff;font-size:13px;font-weight:700;letter-spacing:.02em;display:flex;align-items:center;justify-content:center;flex-shrink:0}.login-card__product{font-size:17px;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.login-card__title{font-size:20px;font-weight:700;color:var(--color-text);margin-bottom:var(--space-1);letter-spacing:-.02em}.login-card__subtitle{font-size:13.5px;color:var(--color-text-muted);margin-bottom:var(--space-6)}.login-form{display:flex;flex-direction:column;gap:var(--space-4)}.login-form__field{display:flex;flex-direction:column;gap:var(--space-1)}.login-form__label{font-size:13px;font-weight:500;color:var(--color-text)}.login-form__input{height:42px;padding:0 var(--space-3);border:1.5px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg);color:var(--color-text);font-size:14px;outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.login-form__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1d4ed81a;background:var(--color-surface)}.login-form__input--error{border-color:var(--color-cancelled)}.login-form__input:disabled{opacity:.6;cursor:not-allowed}.login-form__error{display:flex;align-items:center;gap:var(--space-2);font-size:13px;color:var(--color-cancelled);background:var(--color-cancelled-bg);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid rgba(220,38,38,.15)}.login-form__submit{height:44px;background:var(--color-primary);color:#fff;border-radius:var(--radius-md);font-size:14px;font-weight:600;transition:background var(--transition-fast),opacity var(--transition-fast);margin-top:var(--space-1);box-shadow:0 1px 3px #1d4ed84d}.login-form__submit:hover:not(:disabled){background:var(--color-primary-hover)}.login-form__submit:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.login-dev-hint{margin-top:var(--space-5);border-top:1px solid var(--color-border-light);padding-top:var(--space-4)}.login-dev-hint summary{font-size:11.5px;color:var(--color-text-subtle);cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:500}.login-dev-hint summary:hover{color:var(--color-text-muted)}.login-dev-hint__body{margin-top:var(--space-3);display:flex;flex-direction:column;gap:var(--space-2)}.login-dev-hint__row{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.login-dev-hint__label{font-size:11px;font-weight:600;color:var(--color-text-muted);min-width:74px}.login-dev-hint code{font-family:var(--font-mono);font-size:11px;background:var(--color-bg);padding:2px 6px;border-radius:var(--radius-sm);border:1px solid var(--color-border);color:var(--color-text-muted)}.res-table-wrap{display:flex;flex-direction:column;gap:var(--space-4)}.filter-tabs{display:flex;gap:2px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:4px;width:fit-content}.filter-tab{font-size:13px;font-weight:500;color:var(--color-text-muted);padding:5px 13px;border-radius:6px;display:flex;align-items:center;gap:6px;transition:background var(--transition-fast),color var(--transition-fast)}.filter-tab:hover{color:var(--color-text);background:var(--color-bg)}.filter-tab--active{background:var(--color-primary);color:#fff}.filter-tab--active:hover{background:var(--color-primary-hover);color:#fff}.filter-tab__count{font-size:11px;font-weight:600;background:#0000001a;border-radius:20px;padding:1px 6px}.filter-tab--active .filter-tab__count{background:#fff3}.res-table__empty{padding:var(--space-10);text-align:center;color:var(--color-text-muted);font-size:14px;background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light)}.res-table{width:100%;border-collapse:collapse;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--color-border-light);overflow:hidden}.res-table thead tr{border-bottom:1px solid var(--color-border)}.res-table th{text-align:left;font-size:11px;font-weight:700;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;padding:var(--space-3) var(--space-4);background:var(--color-bg)}.res-table__row{border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.res-table__row:last-child{border-bottom:none}.res-table__row:hover{background:#fafaf8}.res-table__row--selected{background:var(--color-primary-light)!important}.res-table td{padding:12px var(--space-4);vertical-align:middle}.res-table__guest{display:flex;flex-direction:column;gap:2px}.res-table__name{font-weight:500;font-size:14px;color:var(--color-text);display:flex;align-items:center;gap:6px}.res-table__new-badge{font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;background:var(--color-accent);color:#fff;padding:1px 6px;border-radius:var(--radius-full);line-height:1.6;flex-shrink:0}.res-table__phone{font-size:12px;color:var(--color-text-muted)}.res-table__datetime{font-size:13.5px;color:var(--color-text);white-space:nowrap}.res-table__party{font-size:13.5px;color:var(--color-text-muted);white-space:nowrap}.res-table__actions-cell{width:72px}.res-table__row-actions{display:flex;align-items:center;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.res-table__row:hover .res-table__row-actions{opacity:1}.row-action{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:var(--radius-md);border:1.5px solid transparent;transition:background var(--transition-fast),border-color var(--transition-fast),color var(--transition-fast);flex-shrink:0}.row-action:disabled{opacity:.4;cursor:not-allowed}.row-action--confirm{color:var(--color-confirmed);background:var(--color-confirmed-bg);border-color:#05966933}.row-action--confirm:hover:not(:disabled){background:#a7f3d0;border-color:var(--color-confirmed)}.row-action--decline{color:var(--color-cancelled);background:var(--color-cancelled-bg);border-color:#dc262633}.row-action--decline:hover:not(:disabled){background:#fecaca;border-color:var(--color-cancelled)}.res-detail{background:var(--color-surface);border-left:1px solid var(--color-border);display:flex;flex-direction:column;overflow-y:auto;flex-shrink:0}.res-detail__strip{height:4px;flex-shrink:0}.res-detail--pending .res-detail__strip{background:var(--color-pending)}.res-detail--confirmed .res-detail__strip{background:var(--color-confirmed)}.res-detail--cancelled .res-detail__strip{background:var(--color-cancelled)}.res-detail--declined .res-detail__strip{background:#9ca3af}.res-detail__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5);border-bottom:1px solid var(--color-border-light)}.res-detail--pending .res-detail__header{background:#d977060a}.res-detail--confirmed .res-detail__header{background:#0596690a}.res-detail--cancelled .res-detail__header{background:#dc262608}.res-detail--declined .res-detail__header{background:#6b72800a}.res-detail__avatar{width:46px;height:46px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:700;letter-spacing:.02em;flex-shrink:0}.res-detail__avatar--pending{background:var(--color-pending-bg);color:var(--color-pending-text)}.res-detail__avatar--confirmed{background:var(--color-confirmed-bg);color:var(--color-confirmed-text)}.res-detail__avatar--cancelled{background:var(--color-cancelled-bg);color:var(--color-cancelled-text)}.res-detail__avatar--declined{background:#f3f4f6;color:#374151}.res-detail__header-meta{flex:1;min-width:0}.res-detail__name{font-size:19px;font-weight:700;color:var(--color-text);line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:5px;letter-spacing:-.01em}.res-detail__status-label{display:inline-block;font-size:11.5px;font-weight:600;letter-spacing:.03em;padding:3px 10px;border-radius:var(--radius-full)}.res-detail__status-label--pending{background:var(--color-pending-bg);color:var(--color-pending-text)}.res-detail__status-label--confirmed{background:var(--color-confirmed-bg);color:var(--color-confirmed-text)}.res-detail__status-label--cancelled{background:var(--color-cancelled-bg);color:var(--color-cancelled-text)}.res-detail__status-label--declined{background:#f3f4f6;color:#374151}.res-detail__close{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-md);color:var(--color-text-muted);flex-shrink:0;align-self:flex-start;margin-top:2px;transition:background var(--transition-fast),color var(--transition-fast)}.res-detail__close:hover{background:var(--color-bg);color:var(--color-text)}.res-detail__tiles{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-bottom:1px solid var(--color-border-light);background:var(--color-bg)}.res-detail__tile{display:flex;flex-direction:column;align-items:center;gap:4px;padding:var(--space-4) var(--space-3);text-align:center;border-right:1px solid var(--color-border-light)}.res-detail__tile:last-child{border-right:none}.res-detail__tile-icon{display:flex;align-items:center;color:var(--color-primary);opacity:.7;margin-bottom:2px}.res-detail__tile-value{font-size:17px;font-weight:700;color:var(--color-text);line-height:1.1;white-space:nowrap;letter-spacing:-.01em}.res-detail__tile-label{font-size:10px;color:var(--color-text-subtle);font-weight:600;text-transform:uppercase;letter-spacing:.06em}.res-detail__body{flex:1}.res-detail__section{padding:var(--space-5);border-bottom:1px solid var(--color-border-light)}.res-detail__section--meta{border-bottom:none}.res-detail__section-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:var(--space-3)}.res-detail__contact-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);border:1px solid var(--color-border);text-decoration:none;color:var(--color-text);transition:border-color var(--transition-fast),background var(--transition-fast)}.res-detail__contact-row:hover{border-color:var(--color-primary);background:var(--color-primary-light);color:var(--color-primary)}.res-detail__contact-phone{font-size:14px;font-weight:500;font-family:var(--font-mono)}.res-detail__info-row{display:flex;align-items:center;gap:var(--space-3);padding:7px 0;font-size:13px;color:var(--color-text)}.res-detail__row-icon{display:flex;align-items:center;color:var(--color-text-subtle);flex-shrink:0;width:16px}.res-detail__row-label{color:var(--color-text-muted);flex-shrink:0;min-width:80px;font-size:13px}.res-detail__row-value{color:var(--color-text);font-size:13px}.res-detail__row-value--muted{color:var(--color-text-muted);font-size:12px}.res-detail__actions{padding:var(--space-5) var(--space-5) var(--space-6);border-top:1px solid var(--color-border-light);display:flex;align-items:center;justify-content:space-between;gap:var(--space-4);background:var(--color-bg)}.res-detail__action-primary{flex:1;justify-content:center}.res-detail__confirmed-btn{flex:1;font-size:13px;font-weight:600;font-family:var(--font-body);padding:8px 16px;border-radius:var(--radius-md);background:var(--color-confirmed-bg);color:var(--color-confirmed-text);border:1px solid transparent;cursor:default;opacity:.85}.res-page{display:flex;flex-direction:column;height:100%}.res-page--split{flex-direction:row;gap:0;height:calc(100vh - var(--topbar-height));overflow:hidden}.res-page__list{flex:1;overflow-y:auto;min-width:0}.res-page--split .res-page__list{padding-right:0}.res-page--split .res-detail{width:360px;min-width:320px}.dashboard{display:flex;flex-direction:column;gap:var(--space-6)}.dashboard__kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-4)}.dashboard__lower{display:grid;grid-template-columns:1fr 340px;gap:var(--space-4);align-items:start}.dashboard__empty{color:var(--color-text-muted);font-size:13px}.upcoming-list{list-style:none;display:flex;flex-direction:column}.upcoming-item{display:flex;align-items:center;gap:var(--space-4);padding:12px 0;border-bottom:1px solid var(--color-border-light)}.upcoming-item:last-child{border-bottom:none}.upcoming-item__time{font-size:13px;font-weight:600;color:var(--color-primary);min-width:72px;font-family:var(--font-mono)}.upcoming-item__info{flex:1;display:flex;align-items:center;gap:var(--space-3)}.upcoming-item__name{font-size:13.5px;font-weight:500}.upcoming-item__party{font-size:12px;color:var(--color-text-muted);display:flex;align-items:center}.upcoming-item__badges{display:flex;align-items:center;gap:var(--space-2)}.glance-list{display:flex;flex-direction:column;gap:0}.glance-row{display:flex;justify-content:space-between;align-items:center;padding:9px 0;border-bottom:1px solid var(--color-border-light);font-size:13.5px}.glance-row:last-child{border-bottom:none}.glance-row dt{color:var(--color-text-muted)}.glance-row dd{font-weight:500;color:var(--color-text)}.settings-page{max-width:680px;display:flex;flex-direction:column;gap:var(--space-8)}.settings-section{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.settings-section__head{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light)}.settings-section__title{font-size:15px;font-weight:600;letter-spacing:-.01em}.settings-section__desc{margin-top:4px;font-size:13px;color:var(--color-text-muted);line-height:1.5}.policy-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4);padding:var(--space-5) var(--space-6)}.policy-card{position:relative;display:flex;flex-direction:column;align-items:flex-start;gap:var(--space-2);padding:var(--space-4);border:1.5px solid var(--color-border);border-radius:var(--radius-md);text-align:left;transition:border-color var(--transition-fast),background var(--transition-fast);background:var(--color-surface)}.policy-card:hover,.policy-card--selected{border-color:var(--color-primary);background:var(--color-primary-light)}.policy-card__icon{font-size:20px}.policy-card__title{font-size:13.5px;font-weight:600;color:var(--color-text)}.policy-card__desc{font-size:12px;color:var(--color-text-muted);line-height:1.4}.policy-card__check{position:absolute;top:var(--space-3);right:var(--space-3);width:18px;height:18px;background:var(--color-primary);color:#fff;border-radius:50%;font-size:10px;display:flex;align-items:center;justify-content:center;font-weight:700}.lang-toggle{display:flex;gap:var(--space-3);padding:var(--space-5) var(--space-6)}.lang-toggle__btn{font-size:14px;font-weight:500;padding:9px 22px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);color:var(--color-text-muted);background:var(--color-surface);transition:all var(--transition-fast)}.lang-toggle__btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.lang-toggle__btn--active{border-color:var(--color-primary);background:var(--color-primary);color:#fff}.settings-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4) var(--space-6);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.settings-footer__note{font-size:12px;color:var(--color-text-subtle)}.api-state{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-6);font-size:13.5px;border-radius:var(--radius-lg)}.api-state--loading{color:var(--color-text-muted);background:var(--color-surface);border:1px solid var(--color-border-light)}.api-state--error{color:var(--color-cancelled-text);background:var(--color-cancelled-bg);border:1px solid rgba(220,38,38,.15)}.api-state__spinner{display:inline-block;width:16px;height:16px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;flex-shrink:0}.api-state__retry{margin-left:auto;font-size:13px;font-weight:600;color:var(--color-cancelled);text-decoration:underline;background:none;border:none;cursor:pointer;padding:0;font-family:var(--font-body)}.form-submit-error{font-size:13px;color:var(--color-cancelled-text);background:var(--color-cancelled-bg);border:1px solid rgba(220,38,38,.15);padding:var(--space-3) var(--space-4);border-radius:var(--radius-md)}.settings-footer__error{color:var(--color-cancelled);font-size:13px;font-weight:500}.res-page__toolbar{display:flex;justify-content:flex-end;margin-bottom:var(--space-4)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-4);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:90vh;display:flex;flex-direction:column;overflow:hidden}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.modal__title{font-size:17px;font-weight:700;color:var(--color-text);letter-spacing:-.01em}.modal__close{display:flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:var(--radius-md);color:var(--color-text-muted);transition:background var(--transition-fast),color var(--transition-fast)}.modal__close:hover{background:var(--color-bg);color:var(--color-text)}.modal__body{padding:var(--space-6);overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-4)}.modal__footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding-top:var(--space-5);border-top:1px solid var(--color-border-light);margin-top:var(--space-2)}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:13px;font-weight:600;color:var(--color-text)}.form-label--required:after{content:" *";color:var(--color-cancelled);font-weight:400}.form-input,.form-select,.form-textarea{width:100%;padding:9px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:14px;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);outline:none}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1d4ed81a}.form-field--error .form-input,.form-field--error .form-select,.form-field--error .form-textarea{border-color:var(--color-cancelled)}.form-field--error .form-input:focus,.form-field--error .form-select:focus,.form-field--error .form-textarea:focus{box-shadow:0 0 0 3px #dc26261a}.form-error{font-size:12px;color:var(--color-cancelled);font-weight:500}.form-textarea{resize:vertical;min-height:72px}.form-row--2col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.settings-section__body{padding:var(--space-5) var(--space-6)}.settings-field{display:flex;align-items:center;gap:var(--space-3)}.settings-field__input{width:120px;padding:9px 12px;border:1.5px solid var(--color-border);border-radius:var(--radius-md);font-size:15px;font-weight:600;color:var(--color-text);background:var(--color-surface);outline:none;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.settings-field__input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #1d4ed81a}.settings-field__unit{font-size:13px;color:var(--color-text-muted);font-weight:500}.hybrid-threshold{padding:var(--space-5) var(--space-6);border-top:1px solid var(--color-border-light);background:var(--color-bg)}.oh-page{max-width:680px;display:flex;flex-direction:column;gap:var(--space-6)}.oh-week{display:flex;flex-direction:column}.oh-row{display:flex;align-items:flex-start;gap:var(--space-4);padding:13px var(--space-5);border-bottom:1px solid var(--color-border-light)}.oh-row:last-child{border-bottom:none}.oh-row__day{font-size:13.5px;font-weight:600;color:var(--color-text);min-width:110px;flex-shrink:0;padding-top:2px}.oh-row__slots{display:flex;flex-wrap:wrap;gap:var(--space-2);flex:1}.oh-row__closed{font-size:13px;color:var(--color-text-subtle);font-style:italic;padding-top:2px}.oh-slot{display:inline-flex;align-items:center;gap:6px;background:var(--color-accent-light);border:1px solid rgba(217,119,6,.18);border-radius:var(--radius-full);padding:4px 6px 4px 10px;transition:opacity var(--transition-fast)}.oh-slot--deleting{opacity:.4;pointer-events:none}.oh-slot__time{font-size:13px;font-weight:500;color:var(--color-accent-dark);font-family:var(--font-mono);white-space:nowrap}.oh-slot__delete{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;color:var(--color-text-muted);flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast)}.oh-slot__delete:hover{background:var(--color-cancelled-bg);color:var(--color-cancelled)}.oh-slot__error{font-size:11px;color:var(--color-cancelled);margin-left:4px}.oh-empty{padding:var(--space-5);font-size:13px;color:var(--color-text-muted)}.oh-readonly-note{font-size:13px;color:var(--color-text-muted);padding:var(--space-3) var(--space-4);background:var(--color-bg);border:1px solid var(--color-border-light);border-radius:var(--radius-md)}.oh-form-section .card__header{border-bottom:1px solid var(--color-border-light)}.oh-form{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.oh-form__fields{display:flex;align-items:flex-end;gap:var(--space-4);flex-wrap:wrap}.oh-form__weekday{min-width:140px}.oh-form__time{width:110px}.oh-form__submit{padding-bottom:1px}.users-page{display:flex;flex-direction:column;gap:var(--space-5);max-width:820px}.users-page__header{display:flex;align-items:center;justify-content:space-between}.users-page__title{font-size:16px;font-weight:600;color:var(--color-text);letter-spacing:-.01em}.users-list{display:flex;flex-direction:column;gap:var(--space-3)}.user-card{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.user-card__header{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5)}.user-card__avatar{width:38px;height:38px;border-radius:var(--radius-full);background:var(--color-primary);color:#fff;font-size:14px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-card__avatar--inactive{background:var(--color-border);color:var(--color-text-muted)}.user-card__info{flex:1;min-width:0;display:flex;flex-direction:column;gap:3px}.user-card__name-row{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.user-card__name{font-size:14px;font-weight:600;color:var(--color-text)}.user-card__email{font-size:12.5px;color:var(--color-text-muted)}.user-card__edit-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-md);color:var(--color-text-muted);flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast)}.user-card__edit-btn:hover{background:var(--color-bg);color:var(--color-text)}.user-card__memberships{padding:var(--space-3) var(--space-5) var(--space-4);border-top:1px solid var(--color-border-light);background:#fafaf8;display:flex;flex-direction:column;gap:var(--space-2)}.user-card__memberships-label{font-size:10.5px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--color-text-muted)}.user-card__chips-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--space-2)}.user-card__no-access{font-size:12.5px;color:var(--color-text-subtle);font-style:italic}.user-card__chip{display:inline-flex;align-items:center;gap:5px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);padding:3px 4px 3px 10px;font-size:12.5px;transition:opacity var(--transition-fast)}.user-card__chip--deleting{opacity:.4;pointer-events:none}.user-card__chip-name{font-weight:500;color:var(--color-text)}.user-card__chip-role{font-size:11px;color:var(--color-text-muted)}.user-card__chip-delete{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;color:var(--color-text-muted);flex-shrink:0;transition:background var(--transition-fast),color var(--transition-fast)}.user-card__chip-delete:hover:not(:disabled){background:var(--color-cancelled-bg);color:var(--color-cancelled)}.user-card__chip-delete:disabled{opacity:.4;cursor:not-allowed}.user-card__add-btn{display:inline-flex;align-items:center;gap:4px;font-size:12.5px;font-weight:600;color:var(--color-primary);border:1.5px dashed var(--color-border);border-radius:var(--radius-full);padding:3px 10px;transition:background var(--transition-fast),border-color var(--transition-fast)}.user-card__add-btn:hover{background:var(--color-primary-light);border-color:var(--color-primary)}.form-hint{font-size:12px;color:var(--color-text-subtle);margin-top:var(--space-1);line-height:1.5}.badge--power-admin{background:#ede9fe;color:#5b21b6}.badge--user-role{background:var(--color-bg);color:var(--color-text-muted);border:1px solid var(--color-border)}.badge--inactive{background:#f3f4f6;color:#9ca3af}.user-active-toggle{display:flex;align-items:center;gap:var(--space-2);font-size:13.5px;color:var(--color-text);cursor:pointer}.user-active-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}@media (max-width: 1100px){.dashboard__kpis{grid-template-columns:repeat(2,1fr)}.dashboard__lower{grid-template-columns:1fr}}@media (max-width: 900px){.app-shell{grid-template-columns:var(--sidebar-collapsed) 1fr}.sidebar__brand{padding:8px 10px}.sidebar__brand-logo{width:42px}.sidebar__nav-label{display:none}.sidebar__nav-item{justify-content:center;padding:10px}.sidebar__nav-item--active:before{top:5px;bottom:5px}.sidebar__version{display:none}.policy-cards{grid-template-columns:1fr}.res-page--split{flex-direction:column;height:auto}.res-page--split .res-detail{width:100%;border-left:none;border-top:1px solid var(--color-border)}}@media (max-width: 640px){.app-shell__main{padding:var(--space-4)}.dashboard__kpis{grid-template-columns:1fr 1fr}.topbar__date{display:none}.filter-tabs{flex-wrap:wrap}}
