*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #2563eb;--color-primary-hover: #1d4ed8;--color-primary-light: #eff6ff;--color-pending: #9ca3af;--color-confirmed: #16a34a;--color-reschedule: #eab308;--color-cancelled: #dc2626;--color-no-answer: #f97316;--color-success: #16a34a;--color-warning: #eab308;--color-danger: #dc2626;--color-info: #2563eb;--color-bg: #f8fafc;--color-surface: #ffffff;--color-border: #e2e8f0;--color-hover: #f1f5f9;--color-text: #0f172a;--color-text-muted: #64748b;--color-text-inverse: #ffffff;--input-bg: #ffffff;--input-border: #cbd5e1;--input-focus-border: #2563eb;--input-focus-shadow: rgba(37, 99, 235, .2);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--touch-min: 48px;--font-sans: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--transition-fast: .15s ease;--transition-normal: .3s ease}[data-theme=dark]{--color-primary: #3b82f6;--color-primary-hover: #60a5fa;--color-primary-light: #1e293b;--color-bg: #0f172a;--color-surface: #1e293b;--color-border: #334155;--color-hover: #334155;--color-text: #e2e8f0;--color-text-muted: #94a3b8;--color-text-inverse: #0f172a;--input-bg: #1e293b;--input-border: #475569;--input-focus-border: #3b82f6;--input-focus-shadow: rgba(59, 130, 246, .25);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .5)}html{font-family:var(--font-sans);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%}body{min-height:100dvh;transition:background-color var(--transition-normal),color var(--transition-normal)}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2;color:var(--color-text)}.page-title{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-md)}input:not([type=checkbox]):not([type=radio]),select,textarea{font-family:inherit;font-size:var(--font-size-base);color:var(--color-text);background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-md);padding:.75rem 1rem;min-height:var(--touch-min);width:100%;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none}input:not([type=checkbox]):not([type=radio]):focus,select:focus,textarea:focus{outline:none;border-color:var(--input-focus-border);box-shadow:0 0 0 3px var(--input-focus-shadow)}input:not([type=checkbox]):not([type=radio])::placeholder,textarea::placeholder{color:var(--color-text-muted)}label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);margin-bottom:var(--space-xs)}.form-group{display:flex;flex-direction:column}.form-text{display:block;margin-top:var(--space-xs);font-size:var(--font-size-sm);color:var(--color-text-muted)}button,.btn{font-family:inherit;font-size:var(--font-size-base);font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;min-height:var(--touch-min);padding:.75rem 1.5rem;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);transition:background-color var(--transition-fast),opacity var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation;-webkit-user-select:none;user-select:none}button:active{opacity:.85}button:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-hover)}.btn-danger{background:var(--color-danger);color:var(--color-text-inverse)}.btn-full{width:100%}.btn-sm{min-height:36px;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm)}.btn-lg{min-height:56px;padding:var(--space-md) var(--space-xl);font-size:var(--font-size-lg)}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:var(--space-lg);transition:box-shadow var(--transition-fast)}.card-header{padding-bottom:var(--space-md);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-md)}.card-footer{padding-top:var(--space-md);border-top:1px solid var(--color-border);margin-top:var(--space-md)}.badge{display:inline-block;font-size:var(--font-size-sm);font-weight:500;padding:var(--space-xs) var(--space-sm);border-radius:9999px;line-height:1}.badge-pending{background:#f1f5f9;color:var(--color-pending)}.badge-confirmed{background:#f0fdf4;color:var(--color-confirmed)}.badge-reschedule{background:#fefce8;color:var(--color-reschedule)}.badge-cancelled{background:#fef2f2;color:var(--color-cancelled)}.badge-no-answer{background:#fff7ed;color:var(--color-no-answer)}[data-theme=dark] .badge-pending{background:#1e293b}[data-theme=dark] .badge-confirmed{background:#052e16}[data-theme=dark] .badge-reschedule{background:#422006}[data-theme=dark] .badge-cancelled{background:#450a0a}[data-theme=dark] .badge-no-answer{background:#431407}.alert{padding:var(--space-md);margin-bottom:var(--space-md);border:1px solid transparent;border-radius:var(--radius-md);font-size:var(--font-size-sm)}.alert-success{color:#166534;background:#f0fdf4;border-color:#bbf7d0}.alert-warning{color:#854d0e;background:#fefce8;border-color:#fef08a}.alert-danger{color:#991b1b;background:#fef2f2;border-color:#fecaca}.alert-info{color:#1e40af;background:#eff6ff;border-color:#bfdbfe}[data-theme=dark] .alert-success{color:#4ade80;background:#052e16;border-color:#166534}[data-theme=dark] .alert-warning{color:#facc15;background:#422006;border-color:#854d0e}[data-theme=dark] .alert-danger{color:#f87171;background:#450a0a;border-color:#991b1b}[data-theme=dark] .alert-info{color:#60a5fa;background:#172554;border-color:#1e40af}.toast-container{position:fixed;top:var(--space-lg);right:var(--space-lg);z-index:1050;display:flex;flex-direction:column;gap:var(--space-sm)}.toast{max-width:350px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);padding:var(--space-md);opacity:0;transform:translate(100%);transition:opacity var(--transition-normal),transform var(--transition-normal)}.toast.show{opacity:1;transform:translate(0)}.toast-title{font-weight:600;font-size:var(--font-size-sm);margin-bottom:var(--space-xs)}.toast-message{font-size:var(--font-size-sm);color:var(--color-text-muted)}@media(max-width:576px){.toast-container{right:var(--space-md);left:var(--space-md)}.toast{max-width:none}}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:1040;opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.modal-backdrop.show{opacity:1;pointer-events:auto}.modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:calc(100% - 2rem);max-width:500px;max-height:calc(100dvh - 2rem);overflow-y:auto;background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1050;opacity:0;transition:opacity var(--transition-normal);pointer-events:none}.modal.show{opacity:1;pointer-events:auto}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-title{font-weight:600;margin:0}.modal-close{background:transparent;border:0;cursor:pointer;font-size:var(--font-size-xl);color:var(--color-text-muted);min-height:var(--touch-min);min-width:var(--touch-min)}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border)}.loading-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--color-bg);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:2000;opacity:1;transition:opacity var(--transition-normal)}.loading-overlay.hidden{opacity:0;pointer-events:none}.loading-spinner{display:inline-block;width:2rem;height:2rem;border:.25rem solid var(--color-border);border-radius:50%;border-top-color:var(--color-primary);animation:spin 1s linear infinite}.loading-spinner.sm{width:1rem;height:1rem;border-width:.125rem}.loading-spinner.lg{width:3rem;height:3rem;border-width:.375rem}@keyframes spin{to{transform:rotate(360deg)}}.tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:var(--space-lg)}.tab{flex:1;padding:var(--space-sm) 0;min-height:var(--touch-min);display:flex;align-items:center;justify-content:center;font-weight:500;color:var(--color-text-muted);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color var(--transition-fast),border-color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.tab:hover{color:var(--color-text)}.tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.text-muted{color:var(--color-text-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}@media(prefers-reduced-motion:reduce){*,*:before,*:after{transition-duration:.01ms!important;animation-duration:.01ms!important}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;padding:var(--space-lg)}.login-container{width:100%;max-width:24rem}.login-title{font-size:var(--font-size-2xl);font-weight:700;text-align:center;margin-bottom:var(--space-md)}.login-lang{display:flex;justify-content:center;gap:var(--space-sm);margin-bottom:var(--space-lg)}.login-lang-btn{background:none;border:none;font-size:var(--font-size-sm);color:var(--color-text-muted);min-height:36px;padding:var(--space-xs) var(--space-sm);cursor:pointer;border-bottom:2px solid transparent;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.login-lang-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:500}.login-card{padding:0;overflow:hidden}.login-card .tabs{margin-bottom:0;padding:0 var(--space-lg);padding-top:var(--space-sm)}.login-form{display:flex;flex-direction:column;gap:var(--space-md);padding:var(--space-lg)}.login-error{font-size:var(--font-size-sm);color:var(--color-danger)}.login-footer{text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted);margin-top:var(--space-sm)}.login-footer a{color:var(--color-primary);text-decoration:none}.login-footer a:hover{text-decoration:underline}.login-success{display:flex;align-items:center;justify-content:center;min-height:12rem}.login-success .alert{margin:0;text-align:center;font-size:var(--font-size-base)}.login-step-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted)}.login-checkbox-group{display:flex;flex-direction:column;gap:var(--space-sm)}.login-checkbox-label{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);cursor:pointer;min-height:32px;margin-bottom:0}.login-checkbox-label input[type=checkbox]{width:20px;height:20px;min-height:auto;accent-color:var(--color-primary)}.login-form-actions{display:flex;gap:var(--space-sm)}.login-form-actions button{flex:1;min-height:var(--touch-min)}.login-consent{font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.5;text-align:center;margin-top:var(--space-xs)}.sheet-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1100;animation:sheetFadeIn .2s ease}.sheet{position:fixed;bottom:0;left:0;right:0;background:var(--color-surface);border-top-left-radius:var(--radius-lg);border-top-right-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:1101;padding:var(--space-sm) var(--space-lg) var(--space-xl);max-height:85dvh;overflow-y:auto;animation:sheetSlideUp .25s ease}.sheet-handle{width:36px;height:4px;background:var(--color-border);border-radius:2px;margin:0 auto var(--space-lg)}.sheet-profile{display:flex;flex-direction:column;align-items:center;text-align:center;padding-bottom:var(--space-lg);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-lg)}.sheet-avatar{width:64px;height:64px;border-radius:50%;background:var(--color-primary);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:var(--font-size-2xl);margin-bottom:var(--space-sm)}.sheet-avatar.admin{background:#a855f7}.sheet-name{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-xs)}.sheet-meta{font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.4}.sheet-section{margin-bottom:var(--space-lg)}.sheet-section-title{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.sheet-toggle-group{display:flex;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.sheet-toggle{flex:1;min-height:var(--touch-min);padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);font-weight:500;background:var(--color-surface);color:var(--color-text-muted);border:none;border-radius:0;cursor:pointer;transition:background-color var(--transition-fast),color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.sheet-toggle+.sheet-toggle{border-left:1px solid var(--color-border)}.sheet-toggle:hover{background:var(--color-hover)}.sheet-toggle.active{background:var(--color-primary);color:var(--color-text-inverse)}@keyframes sheetSlideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes sheetFadeIn{0%{opacity:0}to{opacity:1}}@media(prefers-reduced-motion:reduce){.sheet,.sheet-backdrop{animation:none}}@media(min-width:768px){.sheet{left:50%;right:auto;transform:translate(-50%);width:24rem;bottom:var(--space-xl);border-radius:var(--radius-lg);animation:sheetFadeIn .2s ease}}.shell{display:flex;flex-direction:column;min-height:100dvh}.shell-topbar{position:fixed;top:0;left:0;right:0;height:56px;background:var(--color-surface);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-md);z-index:1000}.shell-topbar-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-primary)}.shell-hamburger,.shell-theme-toggle{background:none;border:none;font-size:1.25rem;color:var(--color-text-muted);min-height:var(--touch-min);min-width:var(--touch-min);display:flex;align-items:center;justify-content:center;-webkit-tap-highlight-color:transparent;touch-action:manipulation}.shell-body{display:flex;flex:1;padding-top:56px}.shell-nav{position:fixed;top:56px;left:-280px;width:280px;bottom:0;background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;z-index:999;transition:left var(--transition-normal);overflow-y:auto}.shell-nav.open{left:0}.shell-overlay{position:fixed;right:0;bottom:0;left:0;top:56px;background:#0006;z-index:998}.shell-brand{display:none}.shell-brand h1{font-size:var(--font-size-xl);font-weight:700;margin:0}.shell-clinic{padding:var(--space-xs) var(--space-lg);font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shell-admin-badge{margin:var(--space-xs) var(--space-lg);padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-xs);font-weight:600;color:#a855f7;background:#a855f71a;border-radius:var(--radius-sm);text-align:center}[data-theme=dark] .shell-admin-badge{background:#a855f733}.shell-quick-vox-btn{display:flex;align-items:center;justify-content:center;margin:var(--space-sm) var(--space-md);padding:var(--space-sm) var(--space-md);min-height:var(--touch-min);font-size:var(--font-size-base);font-weight:600;color:#fff;background:var(--color-primary);border:none;border-radius:var(--radius-md);text-decoration:none;cursor:pointer;transition:opacity var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.shell-quick-vox-btn:hover{opacity:.9;text-decoration:none;color:#fff}.shell-quick-vox-btn.active{background:var(--color-primary);opacity:.85;color:#fff}.shell-nav-list{list-style:none;padding:var(--space-sm) 0;flex:1}.shell-nav-link{display:flex;align-items:center;min-height:var(--touch-min);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-base);font-weight:500;color:var(--color-text-muted);text-decoration:none;transition:color var(--transition-fast),background-color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.shell-nav-link:hover{color:var(--color-text);background:var(--color-hover);text-decoration:none}.shell-nav-link.active{color:var(--color-primary);background:var(--color-primary-light)}.shell-nav-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-sm)}.shell-user{display:flex;align-items:center;gap:var(--space-sm);width:100%;background:none;border:none;padding:var(--space-sm);margin:calc(-1 * var(--space-sm));border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:background-color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation;min-height:auto}.shell-user:hover{background:var(--color-hover)}.shell-user:active{opacity:1}.shell-user-avatar{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:var(--color-text-inverse);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm);flex-shrink:0}.shell-user-avatar.admin{background:#a855f7}.shell-user-info{min-width:0}.shell-user-name{font-weight:600;font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.shell-user-role{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:capitalize}.shell-main{flex:1;padding:var(--space-lg);min-width:0}@media(min-width:768px){.shell-hamburger,.shell-topbar-title{display:none}.shell-nav{position:fixed;left:0;width:14rem}.shell-overlay{display:none}.shell-brand{display:block;padding:var(--space-lg) var(--space-lg) var(--space-md)}.shell-main{margin-left:14rem;padding:var(--space-xl)}.shell-nav-footer{position:fixed;bottom:0;left:0;width:14rem;background:var(--color-surface)}.shell-nav-list{padding-bottom:120px}}.dashboard-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm);margin-bottom:var(--space-md)}.dashboard-view-toggle{display:flex;gap:var(--space-xs)}.dashboard-week-nav{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap}.dashboard-week-label{font-weight:500;font-size:var(--font-size-base);flex:1;text-align:center;min-width:0}.dashboard-batch{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-primary-light);border:1px solid var(--color-primary);border-radius:var(--radius-md);margin-bottom:var(--space-md);font-size:var(--font-size-sm);font-weight:500}.dashboard-batch-type{font-size:var(--font-size-xs);font-weight:600;color:var(--color-primary);background:var(--color-surface);padding:2px 10px;border-radius:9999px}.dashboard-week{display:flex;flex-direction:column;gap:var(--space-sm)}.dashboard-day{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.dashboard-day.today{border-color:var(--color-primary)}.dashboard-day-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);background:var(--color-hover)}.dashboard-day-label{font-weight:600;font-size:var(--font-size-sm);text-transform:capitalize}.dashboard-day-label.today{color:var(--color-primary)}.dashboard-day-count{font-size:var(--font-size-xs);font-weight:600;background:var(--color-primary);color:var(--color-text-inverse);border-radius:9999px;width:22px;height:22px;display:flex;align-items:center;justify-content:center}.dashboard-day-appts{padding:var(--space-sm);display:flex;flex-direction:column;gap:var(--space-xs)}.dashboard-day-empty{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:var(--space-sm);text-align:center}.appt-card{padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border-left:3px solid var(--color-pending);background:var(--color-surface);cursor:pointer;transition:background-color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.appt-card:hover{background:var(--color-hover)}.appt-card.selected{background:var(--color-primary-light)}.appt-card.status-locked{opacity:.4;pointer-events:auto}.appt-card.status-locked .appt-check{cursor:not-allowed}.appt-card.dot-confirmed{border-left-color:var(--color-confirmed)}.appt-card.dot-reschedule{border-left-color:var(--color-reschedule)}.appt-card.dot-cancelled{border-left-color:var(--color-cancelled)}.appt-card.dot-no-answer{border-left-color:var(--color-no-answer)}.appt-card-top{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-xs)}.appt-check{width:18px;height:18px;min-height:auto;flex-shrink:0;accent-color:var(--color-primary)}.appt-time{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.appt-name{font-size:var(--font-size-sm);font-weight:500}.appt-staff{font-size:var(--font-size-xs);color:var(--color-text-muted)}.appt-treatment{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.appt-lang-badge{display:inline-block;font-size:.625rem;font-weight:700;background:#eff6ff;color:#2563eb;padding:1px 5px;border-radius:var(--radius-sm);margin-top:var(--space-xs)}[data-theme=dark] .appt-lang-badge{background:#1e3a5f;color:#60a5fa}.detail-grid{display:flex;flex-direction:column;gap:var(--space-sm);margin-bottom:var(--space-lg)}.detail-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);font-size:var(--font-size-sm)}.detail-label{font-weight:500;color:var(--color-text-muted);flex-shrink:0}.detail-section-title{font-size:var(--font-size-base);font-weight:600;margin-bottom:var(--space-sm);padding-top:var(--space-sm);border-top:1px solid var(--color-border)}.detail-calls{display:flex;flex-direction:column;gap:var(--space-sm)}.detail-call-card{padding:var(--space-sm);background:var(--color-hover);border-radius:var(--radius-sm)}.detail-call-header{display:flex;justify-content:space-between;align-items:center;font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-xs)}.detail-call-meta{font-size:var(--font-size-xs);color:var(--color-text-muted);margin-bottom:var(--space-xs)}.detail-call-notes{font-size:var(--font-size-xs);color:var(--color-text);line-height:1.4}.month-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--color-border);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.month-header{background:var(--color-hover);padding:var(--space-sm);text-align:center;font-size:var(--font-size-xs);font-weight:600;text-transform:uppercase;color:var(--color-text-muted)}.month-cell{background:var(--color-surface);border:none;border-radius:0;padding:var(--space-sm);min-height:60px;display:flex;flex-direction:column;align-items:flex-start;gap:2px;cursor:pointer;transition:background-color var(--transition-fast);text-align:left;font-family:inherit;color:var(--color-text)}.month-cell:hover{background:var(--color-hover)}.month-cell.outside{color:var(--color-text-muted);opacity:.5}.month-cell.today{background:var(--color-primary-light)}.month-cell-day{font-size:var(--font-size-sm);font-weight:500}.month-cell-dots{display:flex;gap:3px;flex-wrap:wrap}.month-dot{width:6px;height:6px;border-radius:50%;background:var(--color-pending)}.month-dot.dot-confirmed{background:var(--color-confirmed)}.month-dot.dot-reschedule{background:var(--color-reschedule)}.month-dot.dot-cancelled{background:var(--color-cancelled)}.month-dot.dot-no-answer{background:var(--color-no-answer)}.month-cell-count{font-size:var(--font-size-xs);color:var(--color-text-muted);font-weight:500}.detail-vox-row{display:flex;gap:var(--space-sm);flex:1}.detail-vox-select{flex:1;min-height:36px;font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text)}.dashboard-legend{margin-top:var(--space-lg);padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md)}.dashboard-legend-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);margin-bottom:var(--space-sm)}.dashboard-legend-items{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-lg)}.dashboard-legend-item{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm)}.dashboard-legend-color{width:12px;height:12px;border-radius:var(--radius-sm);background:var(--color-pending);flex-shrink:0}.dashboard-legend-color.dot-confirmed{background:var(--color-confirmed)}.dashboard-legend-color.dot-reschedule{background:var(--color-reschedule)}.dashboard-legend-color.dot-cancelled{background:var(--color-cancelled)}.dashboard-legend-color.dot-no-answer{background:var(--color-no-answer)}@media(min-width:768px){.dashboard-week{flex-direction:row}.dashboard-day{flex:1;min-width:0}.dashboard-week.cols-1 .dashboard-day{max-width:600px;margin:0 auto}.dashboard-week.cols-3 .dashboard-day{max-width:none}.month-cell{min-height:80px}}.quick-call{max-width:28rem;margin:0 auto}.quick-call-form{display:flex;flex-direction:column;gap:var(--space-md)}.quick-call-actions{display:flex;gap:var(--space-sm);padding-top:var(--space-sm)}.quick-call-actions button{flex:1;min-height:56px;font-size:var(--font-size-lg)}.call-status{font-size:var(--font-size-sm);font-weight:500}.call-status--active{color:var(--color-primary)}.call-status--done{color:var(--color-confirmed)}.qv-contact-status{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);font-size:var(--font-size-sm);animation:qvFadeIn .2s ease}.qv-contact-status.known{background:#f0fdf4;border:1px solid #bbf7d0}.qv-contact-status.new{background:#fffbeb;border:1px solid #fde68a}[data-theme=dark] .qv-contact-status.known{background:#052e16;border-color:#166534}[data-theme=dark] .qv-contact-status.new{background:#422006;border-color:#854d0e}.qv-contact-badge{display:inline-block;font-size:var(--font-size-xs);font-weight:600;padding:2px 8px;border-radius:9999px;width:fit-content}.qv-contact-badge.known{background:var(--color-confirmed);color:#fff}.qv-contact-badge.new{background:#f59e0b;color:#fff}.qv-contact-detail{color:var(--color-text);line-height:1.4}.qv-contact-notes{display:block;margin-top:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted);line-height:1.4}.qv-autofill-btn{align-self:flex-start;padding:6px 14px;font-size:var(--font-size-sm);font-weight:600;color:#fff;background:var(--color-confirmed);border:none;border-radius:var(--radius-sm);cursor:pointer;min-height:36px}.qv-autofill-btn:hover{opacity:.9}.qv-prefill-note{color:var(--color-confirmed);font-style:italic}@keyframes qvFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.qv-contact-status{animation:none}}.import-page{max-width:900px}.import-input-card{margin-bottom:var(--space-lg)}.import-instructions{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-md);line-height:1.5}.import-textarea{font-family:monospace;font-size:var(--font-size-sm);min-height:120px;resize:vertical;margin-bottom:var(--space-md)}.import-actions{display:flex;gap:var(--space-sm)}.import-preview-card{margin-bottom:var(--space-lg)}.import-preview-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-md)}.import-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:var(--space-md)}.import-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.import-table th{text-align:left;padding:var(--space-sm);border-bottom:2px solid var(--color-border);font-weight:600;color:var(--color-text-muted);white-space:nowrap}.import-table td{padding:var(--space-sm);border-bottom:1px solid var(--color-border);vertical-align:middle}.import-row-error{opacity:.6}.import-row-error td{background:#dc26260a}[data-theme=dark] .import-row-error td{background:#dc262614}.import-lang-select{min-height:32px;padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);width:auto;min-width:60px}.import-confirm-bar{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--color-border)}.import-valid-count{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-muted)}.import-empty{text-align:center;padding:var(--space-xl)}.import-success{text-align:center;font-weight:500}.notif-page{max-width:700px}.notif-header{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.notif-unread-badge{font-size:var(--font-size-xs);font-weight:600;background:var(--color-primary);color:var(--color-text-inverse);padding:var(--space-xs) var(--space-sm);border-radius:9999px}.notif-tabs,.notif-actions{margin-bottom:var(--space-md)}.notif-list{display:flex;flex-direction:column;gap:var(--space-sm)}.notif-card{position:relative;padding:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;transition:background-color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.notif-card:hover{background:var(--color-hover)}.notif-card.unread{border-left:3px solid var(--color-primary);background:var(--color-primary-light)}.notif-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.notif-time{font-size:var(--font-size-xs);color:var(--color-text-muted)}.notif-message{font-size:var(--font-size-sm);line-height:1.5}.notif-dot{position:absolute;top:var(--space-md);right:var(--space-md);width:8px;height:8px;border-radius:50%;background:var(--color-primary)}.notif-empty{text-align:center;padding:var(--space-xl)}.settings-page{max-width:700px}.settings-tabs-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:var(--space-lg)}.settings-tabs{min-width:max-content}.settings-tab-content{display:flex;flex-direction:column;gap:var(--space-md)}.settings-field{margin-bottom:0}.settings-location-card{padding:var(--space-md)}.settings-location-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.settings-location-header h4{font-size:var(--font-size-base);font-weight:600}.settings-detail{display:flex;gap:var(--space-sm);font-size:var(--font-size-sm);line-height:1.5;padding:var(--space-xs) 0}.settings-detail-label{font-weight:500;color:var(--color-text-muted);flex-shrink:0;min-width:100px}.settings-pronunciation-value{font-style:italic;color:var(--color-text-muted)}.settings-staff-list{display:flex;flex-direction:column;gap:var(--space-sm)}.settings-staff-card{padding:var(--space-md)}.settings-staff-card.inactive{opacity:.6}.settings-staff-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-sm);margin-bottom:var(--space-sm)}.settings-staff-name{font-weight:600;font-size:var(--font-size-base)}.settings-staff-title{font-size:var(--font-size-sm);color:var(--color-text-muted)}.settings-staff-arrow{background:none;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;min-width:var(--touch-min);min-height:var(--touch-min);display:flex;align-items:center;justify-content:center;flex-shrink:0;-webkit-tap-highlight-color:transparent;touch-action:manipulation;transition:color var(--transition-fast)}.settings-staff-arrow:hover{color:var(--color-primary)}.settings-staff-badges{display:flex;gap:var(--space-xs);flex-wrap:wrap;margin-bottom:var(--space-xs)}.settings-call-preview{padding:var(--space-md);background:var(--color-hover);border-style:dashed}.settings-call-preview-label{font-size:var(--font-size-sm);font-style:italic;color:var(--color-text-muted);line-height:1.5}.settings-calendar-card{padding:var(--space-md)}.settings-calendar-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-sm)}.settings-calendar-header h4{font-size:var(--font-size-base);font-weight:600}.settings-calendar-desc{font-size:var(--font-size-sm);margin-bottom:var(--space-sm)}.settings-connect-btn{margin-top:var(--space-xs)}.staff-sheet{max-height:90dvh}.staff-sheet-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-xs)}.staff-sheet-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-bottom:var(--space-lg)}.staff-sheet-form{display:flex;flex-direction:column;gap:var(--space-md);margin-bottom:var(--space-lg)}.staff-sheet-locations{display:flex;flex-direction:column;gap:var(--space-sm)}.staff-sheet-checkbox{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);cursor:pointer;min-height:36px}.staff-sheet-checkbox input[type=checkbox]{width:20px;height:20px;min-height:auto;accent-color:var(--color-primary)}.staff-sheet-toggles{display:flex;flex-direction:column;gap:0;border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.staff-sheet-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);min-height:var(--touch-min);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background-color var(--transition-fast);-webkit-tap-highlight-color:transparent;touch-action:manipulation}.staff-sheet-toggle-row:hover{background:var(--color-hover)}.staff-sheet-toggle-row+.staff-sheet-toggle-row{border-top:1px solid var(--color-border)}.staff-sheet-switch{width:44px;height:24px;border-radius:12px;background:var(--color-border);position:relative;transition:background-color var(--transition-fast);flex-shrink:0}.staff-sheet-switch:after{content:"";position:absolute;top:2px;left:2px;width:20px;height:20px;border-radius:50%;background:#fff;transition:transform var(--transition-fast);box-shadow:0 1px 3px #0003}.staff-sheet-switch.on{background:var(--color-confirmed)}.staff-sheet-switch.on:after{transform:translate(20px)}.staff-sheet-actions{display:flex;gap:var(--space-sm)}.staff-sheet-actions button{flex:1;min-height:var(--touch-min)}@media(max-width:480px){.settings-staff-header{flex-direction:column}.settings-staff-badges{justify-content:flex-start}.settings-detail{flex-direction:column;gap:var(--space-xs)}.settings-detail-label{min-width:auto}}
