@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,*:before,*:after{box-sizing:border-box}:root{--primary: #2b3990;--primary-dark: #1e2a6b;--primary-hover: #1e2a6b;--primary-light: #27aae1;--secondary: #1a2155;--accent: #27aae1;--accent-dark: #1e8bbd;--accent-light: rgba(39, 170, 225, .15);--warning: #f59e0b;--danger: #ef4444;--success: #10b981;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--white: #ffffff;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--radius: 8px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--spacing-xs: .25rem;--spacing-sm: .5rem;--spacing-md: 1rem;--spacing-lg: 1.5rem;--spacing-xl: 2rem;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--bg: var(--gray-50);--surface: var(--white);--panel: var(--gray-100);--muted: var(--gray-500);--text: var(--gray-900);--glass-border: var(--gray-200);--shadow-strong: rgba(0,0,0,.1);--color-primary: var(--primary);--color-primary-dark: var(--primary-dark);--color-primary-light: rgba(43, 57, 144, .1);--color-danger: var(--danger);--color-danger-light: rgba(239, 68, 68, .1);--color-success: var(--success);--color-warning: var(--warning);--color-warning-bg: #fef3c7;--color-warning-text: #92400e;--color-info: #3b82f6;--color-info-bg: rgba(59, 130, 246, .1);--color-text: var(--gray-900);--color-text-primary: var(--gray-900);--color-text-secondary: var(--gray-500);--color-text-tertiary: var(--gray-400);--color-border: var(--gray-200);--color-bg-secondary: var(--gray-50);--color-surface: var(--white);--color-surface-secondary: var(--gray-100);--chart-revenue: #2b3990;--chart-expenses: #ef4444;--chart-profit: #27aae1}.recharts-tooltip-wrapper{z-index:1000!important}body{margin:0;padding:0;font-family:Inter,sans-serif;background-color:var(--bg);min-height:100vh;color:var(--text);overflow-x:hidden;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}html{overflow-x:hidden}#root{width:100%;max-width:100vw;min-height:100vh;display:flex;flex-direction:column}.app-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;width:100%;padding:1rem;box-sizing:border-box}.loading-state,.error-state{background-color:var(--surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);padding:3rem;text-align:center;border:1px solid var(--glass-border)}.loading-state--inline{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--muted);gap:1rem;background:transparent;border:none;box-shadow:none;border-radius:0}.loading-spinner{width:32px;height:32px;border:3px solid var(--glass-border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-spinner--sm{width:20px;height:20px;border-width:2px}.loading-spinner--lg{width:48px;height:48px;border-width:4px}.loading-text{font-size:1.8rem;font-weight:500;color:var(--muted);animation:pulse 1.5s infinite ease-in-out}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 2rem;text-align:center}.empty-state--card{background:var(--surface);border:1px dashed var(--glass-border);border-radius:var(--radius-lg)}.empty-state svg,.empty-state__icon{width:48px;height:48px;color:var(--gray-400);margin-bottom:1rem}.empty-state h2,.empty-state h3,.empty-state__heading{font-size:1.125rem;font-weight:600;color:var(--text);margin:0 0 .5rem}.empty-state p,.empty-state__text{font-size:.9375rem;color:var(--muted);margin:0 0 1.5rem;max-width:400px}.empty-state__action{margin-top:.5rem}.error-state{background-color:var(--surface);color:var(--text);border-color:var(--danger)}.error-title{font-size:2.8rem;font-weight:700;margin-bottom:.5rem;color:var(--danger)}.error-message{font-size:1.3rem;margin-bottom:.5rem}.error-sub-message{font-size:1rem;opacity:.8}.main-card-wrapper{background-color:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);border:1px solid var(--glass-border);display:flex;flex-direction:column;align-items:center;gap:2rem;padding:3rem;max-width:500px;width:90%;animation:fadeInScale .8s ease-out forwards}.app-logo{width:160px;margin-bottom:1.5rem;opacity:0;filter:drop-shadow(0 6px 12px rgba(0,0,0,.1));animation:slideInDown 1s ease-out forwards .2s}.main-title{font-size:2.8rem;font-weight:700;color:var(--text);text-align:center;margin-bottom:1rem;text-shadow:0 4px 10px rgba(0,0,0,.35);opacity:0;animation:fadeIn 1s ease-out forwards .4s}.action-card{background-color:var(--panel);border-radius:var(--radius-lg);box-shadow:var(--shadow);border:1px solid var(--glass-border);padding:2.5rem;display:flex;flex-direction:column;align-items:center;gap:1.8rem;width:calc(100% - 2rem);opacity:0;animation:fadeIn 1s ease-out forwards .6s}.action-text{font-size:1.25rem;color:var(--muted);text-align:center;line-height:1.6;font-weight:400}.button{padding:1.1rem 2.8rem;font-size:1.2rem;font-weight:600;border-radius:var(--radius);border:none;cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow);text-transform:uppercase;letter-spacing:.08em;outline:none}.button:focus{box-shadow:0 0 0 4px #27aae140}.button.login{padding:10px 20px;background-color:var(--primary);color:var(--white)}.button.login:hover{background-color:var(--primary-dark)}.button.logout{padding:10px 20px;background-color:var(--gray-200);color:var(--gray-700)}.button.logout:hover{background-color:var(--gray-300)}.logged-in-section{display:flex;flex-direction:column;align-items:center;gap:1.5rem;width:100%}.logged-in-message{font-size:1.5rem;color:var(--success);font-weight:600;animation:fadeIn 1s ease-out forwards .8s}.profile-section-title{font-size:2.2rem;animation:slideInUp 1s ease-out forwards 1s}.profile-card{padding:2.2rem;background:linear-gradient(180deg,rgba(255,255,255,.02),transparent);border-radius:12px;animation:scaleIn .8s ease-out forwards 1.2s}.profile-picture{width:110px;transition:transform .3s ease-in-out;border:3px solid var(--primary);border-radius:50%}.profile-picture:hover{transform:scale(1.05)}.profile-name{font-size:2rem;margin-top:.5rem;color:var(--text)}.profile-email{font-size:1.15rem;text-align:center;color:var(--muted)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInScale{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}@keyframes slideInDown{0%{opacity:0;transform:translateY(-70px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInUp{0%{opacity:0;transform:translateY(50px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}@keyframes scaleIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media(max-width:600px){.main-card-wrapper{padding:2rem;margin:1rem}.main-title{font-size:2.2rem}.button{padding:1rem 2rem;font-size:1.1rem}}[role=tablist]{display:flex;gap:0}[role=tab]{padding:.75rem 1.5rem;border:none;background:transparent;color:var(--muted);font-weight:600;cursor:pointer;transition:all .28s ease;border-bottom:2px solid transparent}[role=tab]:hover{color:var(--primary)}[role=tab][aria-selected=true]{color:var(--primary);border-bottom-color:var(--primary)}[role=tabpanel]{outline:none}[role=alertdialog],[role=dialog]{background-color:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl)}[role=dialog]>*{color:var(--text)}:focus-visible{outline:2px solid var(--primary);outline-offset:2px}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--primary)}.console-page{padding:2rem;max-width:100%;margin:0 auto}.console-page--narrow{max-width:800px}.console-page--medium{max-width:900px}.console-page--wide{max-width:1200px}.console-page--full{max-width:1400px}.list-page{padding:2rem;max-width:1400px;margin:0 auto;overflow-x:hidden}.detail-page{padding:2rem;max-width:900px;margin:0 auto}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem}.page-header.centered{align-items:center}.header-left{display:flex;flex-direction:column;gap:.5rem}.page-title{font-size:1.5rem;font-weight:600;color:var(--text);margin:0;display:flex;align-items:center;gap:.75rem}.page-subtitle{font-size:1rem;color:var(--muted);margin:0}.header-actions{display:flex;gap:.5rem;flex-wrap:wrap}.back-button{background:none;border:none;color:var(--muted);cursor:pointer;padding:0;font-size:.875rem;display:flex;align-items:center;gap:.25rem;transition:color .15s ease}.back-button:hover{color:var(--primary)}.breadcrumb{display:flex;align-items:center;gap:.5rem;font-size:.875rem;margin-bottom:.5rem}.breadcrumb-link{color:var(--primary);text-decoration:none;transition:color .15s ease}.breadcrumb-link:hover{text-decoration:underline;color:var(--primary-dark)}.breadcrumb-separator{color:var(--muted);-webkit-user-select:none;user-select:none}.breadcrumb-current{color:var(--muted)}.btn,.button{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.5rem 1rem;font-size:.875rem;font-weight:500;line-height:1.05;border-radius:var(--radius);cursor:pointer;border:1px solid transparent;transition:all .15s ease}.btn-icon,.button-icon{width:16px;height:16px;flex-shrink:0}.btn-icon svg,.button-icon svg{width:100%;height:100%}.btn:disabled,.button:disabled{opacity:.6;cursor:not-allowed}.btn-primary,.button-primary{background-color:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled),.button-primary:hover:not(:disabled){background-color:var(--primary-dark);border-color:var(--primary-dark)}.btn-secondary,.button-secondary{background-color:var(--surface);color:var(--text);border-color:var(--glass-border)}.btn-secondary:hover:not(:disabled),.button-secondary:hover:not(:disabled){background-color:var(--panel)}.btn-danger,.button-danger{background-color:var(--surface);color:var(--danger);border-color:var(--danger)}.btn-danger:hover:not(:disabled),.button-danger:hover:not(:disabled){background-color:var(--danger);color:#fff}.btn-danger-outline{background:transparent;color:var(--danger);border-color:var(--danger)}.btn-danger-outline:hover:not(:disabled){background:color-mix(in srgb,var(--danger) 10%,transparent)}.btn-link{background:none;border:none;color:var(--primary);cursor:pointer;padding:0;font-size:inherit;font-family:inherit;text-decoration:none;transition:color .15s ease}.btn-link:hover:not(:disabled){color:var(--primary-dark);text-decoration:underline}.btn-link:disabled{color:var(--gray-400);cursor:not-allowed;opacity:.6}.btn-sm{padding:.375rem .75rem;font-size:.8125rem}.btn-lg{padding:.75rem 1.5rem;font-size:1rem}.action-button{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--glass-border);border-radius:var(--radius);color:var(--muted);cursor:pointer;transition:all .15s ease}.action-button:hover{background:var(--panel);border-color:var(--primary);color:var(--text)}.page-toolbar{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1rem;align-items:center;justify-content:space-between}.filter-tabs{display:flex;gap:.25rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);padding:.25rem}.filter-tab{padding:.5rem 1rem;background:transparent;border:none;border-radius:6px;color:var(--muted);font-size:.875rem;cursor:pointer;transition:all .15s ease}.filter-tab:hover{color:var(--text);background:var(--panel)}.filter-tab.active{color:#fff;background:var(--primary)}.filter-row{display:flex;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem;align-items:center}.filter-dropdowns{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.filter-select{padding:.5rem 2rem .5rem .75rem;font-size:.875rem;border:1px solid var(--glass-border);border-radius:6px;background:var(--surface);color:var(--text);cursor:pointer;min-width:150px;appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25rem}.filter-select:focus{outline:none;border-color:var(--primary)}.clear-filters-button{padding:.5rem 1rem;font-size:.875rem;background:transparent;border:1px solid var(--glass-border);border-radius:6px;color:var(--muted);cursor:pointer;transition:all .15s ease}.clear-filters-button:hover{background:var(--panel);color:var(--text)}.quick-filters{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:1rem}.quick-filter{display:inline-flex;align-items:center;gap:.375rem;padding:.5rem 1rem;font-size:.875rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:20px;color:var(--text);cursor:pointer;transition:all .15s ease}.quick-filter:hover{background:var(--panel);border-color:var(--primary)}.quick-filter.active{background:var(--primary);border-color:var(--primary);color:#fff}.form-section{display:flex;flex-direction:column;gap:1rem;padding:1.5rem}@media(max-width:768px){.form-section{padding:1rem}}@media(max-width:480px){.form-section{padding:0}}.form-section .section-title{font-size:.875rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0;padding-bottom:.5rem;border-bottom:1px solid var(--glass-border)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text)}.form-label .required{color:var(--danger)}.form-input,.form-select,.form-textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--glass-border);border-radius:6px;font-size:.875rem;background-color:var(--surface);color:var(--text);transition:border-color .15s ease,box-shadow .15s ease}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2b39901a}.form-input.error,.form-select.error,.form-textarea.error{border-color:var(--danger)}.form-input.error:focus,.form-select.error:focus,.form-textarea.error:focus{box-shadow:0 0 0 3px #ef44441a}.form-textarea{resize:vertical;min-height:60px}.form-select{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.25rem;padding-right:2.5rem}.form-error{font-size:.75rem;color:var(--danger)}.form-actions{display:flex;gap:.75rem;margin-top:.5rem;padding-top:1rem;border-top:1px solid var(--glass-border)}.content-card{background:var(--surface);border-radius:var(--radius);border:1px solid var(--glass-border);padding:1rem}.detail-section{display:flex;flex-direction:column;gap:.75rem}.section-title{font-size:.875rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin:0}.detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{font-size:.75rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:.9375rem;color:var(--text)}.detail-value a{color:var(--primary);text-decoration:none}.detail-value a:hover{text-decoration:underline}.detail-text{font-size:.9375rem;color:var(--text);margin:0;line-height:1.5;white-space:pre-wrap}.empty-value{color:var(--gray-400);font-style:italic}.archived-badge{font-size:.75rem;padding:.25rem .5rem;background-color:var(--color-warning-bg, #fef3c7);color:var(--color-warning-text, #92400e);border-radius:4px;font-weight:500}.grid-container{margin-bottom:1rem}.cell-two-line{display:flex;flex-direction:column;gap:.125rem}.cell-primary{font-weight:500;color:var(--text)}.cell-secondary{font-size:.75rem;color:var(--muted)}.job-link{display:flex;flex-direction:column;gap:.125rem;background:none;border:none;padding:.25rem .5rem;margin:-.25rem -.5rem;cursor:pointer;text-align:left;border-radius:4px;transition:background-color .15s}.job-link:hover{background:var(--panel)}.job-link .job-number{font-weight:600;font-size:.8125rem;color:var(--primary)}.job-link .job-title{font-size:.75rem;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.client-link{background:none;border:none;padding:.25rem .5rem;margin:-.25rem -.5rem;cursor:pointer;text-align:left;border-radius:4px;transition:background-color .15s;font-size:.875rem;font-weight:500;color:var(--text)}.client-link:hover{background:var(--panel);color:var(--primary)}.mono-value{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-variant-numeric:tabular-nums}.id-column,.invoice-number,.proposal-number,.job-number,.milestone-number,.expense-number,.client-number{font-family:SF Mono,Consolas,Monaco,monospace;font-size:.85rem;font-weight:600;color:var(--primary);white-space:nowrap;letter-spacing:-.01em}.status-badge{display:inline-flex;align-items:center;padding:.25rem .75rem;font-size:.75rem;font-weight:500;border-radius:20px;white-space:nowrap}.status-badge.status-gray,.status-badge-gray{background:#6b728026;color:#6b7280}.status-badge.status-blue,.status-badge-blue{background:#3b82f626;color:#3b82f6}.status-badge.status-green,.status-badge-green{background:#10b98126;color:#10b981}.status-badge.status-red,.status-badge-red{background:#ef444426;color:#ef4444}.status-badge.status-yellow,.status-badge-yellow{background:#f59e0b26;color:#f59e0b}.status-badge.status-purple,.status-badge-purple{background:#9333ea26;color:#9333ea}.status-badge.status-teal,.status-badge-teal{background:#14b8a626;color:#14b8a6}.status-badge.active{background:#10b98126;color:#10b981}.status-badge.archived{background:#6b728026;color:#6b7280}.priority-badge{display:inline-flex;align-items:center;padding:.2rem .5rem;font-size:.7rem;font-weight:600;border-radius:4px;white-space:nowrap;text-transform:uppercase;letter-spacing:.025em}.priority-badge.priority-low{background:#6b728026;color:#6b7280}.priority-badge.priority-medium{background:#3b82f626;color:#3b82f6}.priority-badge.priority-high{background:#f9731626;color:#f97316}.priority-badge.priority-urgent{background:#ef444426;color:#ef4444}.status-badge--draft{background:var(--panel);color:var(--muted)}.status-badge--sent{background:#27aae126;color:var(--accent)}.status-badge--viewed{background:#fef3c7;color:#b45309}.status-badge--accepted{background:#d1fae5;color:#047857}.status-badge--declined{background:#fee2e2;color:#b91c1c}.status-badge--revised{background:#2b399026;color:var(--primary)}.status-badge--expired{background:#fecaca;color:#991b1b}.status-badge--superseded{background:#e5e7eb;color:#6b7280}.status-badge--partial{background:#2b399026;color:var(--primary)}.status-badge--paid{background:#d1fae5;color:#047857}.status-badge--voided{background:#e5e7eb;color:#6b7280}.status-badge--overdue{background:#fee2e2;color:#dc2626}.status-badge--pending{background:var(--panel);color:var(--muted)}.status-badge--invoiced{background:#27aae126;color:var(--accent)}.status-badge--complete{background:#d1fae5;color:#047857}.category-badge{display:inline-block;font-size:.75rem;padding:.25rem .5rem;border-radius:4px;font-weight:500;white-space:nowrap}.category-blue{background:#27aae126;color:var(--accent)}.category-purple{background:#ede9fe;color:#7c3aed}.category-orange{background:#fed7aa;color:#c2410c}.category-yellow{background:#fef3c7;color:#b45309}.category-red{background:#fee2e2;color:var(--danger)}.category-cyan{background:#cffafe;color:#0891b2}.category-pink{background:#fce7f3;color:#be185d}.category-gray{background:#e5e7eb;color:#4b5563}.category-indigo{background:#2b399026;color:var(--primary)}.category-teal{background:#ccfbf1;color:#0d9488}.category-green{background:#10b98126;color:var(--success)}.info-link{color:var(--primary);text-decoration:none;font-weight:500;transition:color .15s ease}.info-link:hover{color:var(--primary-dark, #1e3a8a);text-decoration:underline}@media(max-width:768px){.console-page,.list-page,.detail-page{padding:1rem}.page-header{flex-direction:column;gap:1rem;align-items:flex-start}.page-toolbar{flex-direction:column;align-items:stretch}.filter-tabs{justify-content:center}.filter-row{flex-direction:column}.filter-dropdowns{flex-direction:column;width:100%}.filter-select{width:100%}.quick-filters{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.5rem}}@media(max-width:480px){.console-page,.list-page,.detail-page{padding:.5rem}.page-title{font-size:1.25rem}.header-actions{width:100%}.header-actions .btn{flex:1}}.sidebar-toggle{position:fixed;top:1rem;left:1rem;z-index:1001;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background-color:var(--surface);border:1px solid var(--gray-200);border-radius:var(--radius);cursor:pointer;transition:all .2s ease;box-shadow:var(--shadow)}.sidebar-toggle:hover{background-color:var(--gray-100);border-color:var(--gray-300)}.sidebar-toggle svg{width:24px;height:24px;color:var(--gray-700)}.sidebar-overlay{position:fixed;inset:0;background-color:#00000080;z-index:999;opacity:1;transition:opacity .3s ease}.app-sidebar{position:fixed;top:0;left:0;height:100vh;width:280px;background-color:var(--surface);border-right:1px solid var(--gray-200);display:flex;flex-direction:column;z-index:1000;transform:translate(-100%);transition:transform .3s ease;box-shadow:var(--shadow-lg)}.app-sidebar.open{transform:translate(0)}.sidebar-header{border-bottom:1px solid var(--gray-200);display:flex;align-items:center;min-height:64px;padding:1rem 1rem 1rem 4.5rem}.sidebar-brand{display:flex;align-items:center;gap:.75rem;background:none;border:none;cursor:pointer;padding:.5rem;border-radius:var(--radius);transition:background-color .2s ease}.sidebar-brand:hover{background-color:var(--gray-100)}.sidebar-logo{height:32px;width:auto}.brand-text{font-size:1.25rem;font-weight:700;color:var(--primary)}.sidebar-nav{flex:1;padding:1rem;display:flex;flex-direction:column;gap:.25rem;overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;color:var(--gray-600);text-decoration:none;border-radius:var(--radius);transition:all .2s ease;font-weight:500}.sidebar-link:hover{background-color:var(--gray-100);color:var(--gray-900)}.sidebar-link.active{background-color:var(--primary);color:var(--white)}.sidebar-link.active:hover{background-color:var(--primary-dark);color:var(--white)}.sidebar-link--indented{padding-left:2.5rem}.sidebar-icon{display:flex;align-items:center;justify-content:center;width:24px;height:24px}.sidebar-icon svg{width:20px;height:20px}.sidebar-label{font-size:.95rem;flex:1}.sidebar-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;font-size:.7rem;font-weight:600;color:var(--white);background-color:var(--danger);border-radius:10px;cursor:pointer}.sidebar-link.active .sidebar-badge{background-color:#ffffff40}.sidebar-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--gray-200)}.sidebar-section-label{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--gray-400);padding:0 1rem .5rem}.sidebar-footer{padding:1rem;border-top:1px solid var(--gray-200)}.sidebar-user{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.sidebar-user-avatar{width:40px;height:40px;border-radius:50%;object-fit:cover;border:2px solid var(--gray-200)}.sidebar-user-info{flex:1;min-width:0;display:flex;flex-direction:column}.sidebar-user-name{font-size:.875rem;font-weight:600;color:var(--gray-900);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-email{font-size:.75rem;color:var(--gray-500);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user .button.logout{width:100%;margin-top:.75rem}.sidebar-auth{display:flex;justify-content:center}.sidebar-auth .button.login{width:100%;justify-content:center}@media(min-width:1024px){.sidebar-toggle,.sidebar-overlay{display:none}.app-sidebar{transform:translate(0);box-shadow:none}.sidebar-header{padding-left:1rem}}.footer{background-color:var(--surface);border-top:1px solid var(--gray-200);padding:1.5rem 2rem;margin-top:auto;width:100%}.footer-content{max-width:100%;display:flex;justify-content:center;align-items:center;gap:2rem;flex-wrap:wrap}.footer-links{display:flex;align-items:center;gap:1rem}.footer-link{color:var(--gray-500);text-decoration:none;font-size:.875rem;transition:color .2s ease}.footer-link:hover{color:var(--primary)}.footer-separator{color:var(--gray-300)}.footer-copyright{color:var(--gray-500);font-size:.875rem}@media(max-width:768px){.footer-content{flex-direction:column;gap:1rem;text-align:center}.footer{padding:1rem}}.payment-failure-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background-color:#fef2f2;border-bottom:1px solid rgba(239,68,68,.2);color:#991b1b;font-size:.875rem;line-height:1.4}.payment-failure-banner-content{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.payment-failure-banner-icon{display:flex;align-items:center;flex-shrink:0;color:var(--danger)}.payment-failure-banner-text{overflow:hidden;text-overflow:ellipsis}.payment-failure-banner-text strong{font-weight:600}.payment-failure-banner-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.payment-failure-banner-btn{background-color:var(--danger);color:#fff;border:none;padding:.35rem .75rem;border-radius:var(--radius);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .15s ease}.payment-failure-banner-btn:hover:not(:disabled){background-color:#dc2626}.payment-failure-banner-btn:disabled{opacity:.6;cursor:not-allowed}.payment-failure-banner-dismiss{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#991b1b;padding:.25rem;border-radius:4px;cursor:pointer;opacity:.6;transition:opacity .15s ease}.payment-failure-banner-dismiss:hover{opacity:1}@media(max-width:600px){.payment-failure-banner{flex-direction:column;align-items:flex-start;gap:.5rem}.payment-failure-banner-actions{align-self:flex-end}}.public-page-banner{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.75rem 1rem;background-color:#eff6ff;border-bottom:1px solid rgba(43,57,144,.15);color:#1e3a5f;font-size:.875rem;line-height:1.4}.public-page-banner-content{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.public-page-banner-icon{display:flex;align-items:center;flex-shrink:0;color:var(--primary)}.public-page-banner-text{overflow:hidden;text-overflow:ellipsis}.public-page-banner-text strong{font-weight:600}.public-page-banner-text a{color:var(--primary);font-weight:500;text-decoration:none;white-space:nowrap}.public-page-banner-text a:hover{text-decoration:underline}.public-page-banner-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.public-page-banner-btn{background-color:var(--primary);color:#fff;border:none;padding:.35rem .75rem;border-radius:var(--radius);font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color .15s ease;min-width:5.5rem}.public-page-banner-btn:hover{background-color:#232e78}.public-page-banner-dismiss{display:flex;align-items:center;justify-content:center;background:none;border:none;color:#1e3a5f;padding:.25rem;border-radius:4px;cursor:pointer;opacity:.6;transition:opacity .15s ease}.public-page-banner-dismiss:hover{opacity:1}@media(max-width:600px){.public-page-banner{flex-direction:column;align-items:flex-start;gap:.5rem}.public-page-banner-actions{align-self:flex-end}}.badge{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .5rem;border-radius:var(--radius);font-size:.75rem;font-weight:500;line-height:1;white-space:nowrap}.badge--default{background-color:color-mix(in srgb,var(--text) 10%,transparent);color:var(--text)}.badge--primary{background-color:color-mix(in srgb,var(--primary) 15%,transparent);color:var(--primary)}.badge--success{background-color:color-mix(in srgb,var(--success) 15%,transparent);color:var(--success)}.badge--warning{background-color:color-mix(in srgb,var(--warning) 15%,transparent);color:var(--warning)}.badge--danger{background-color:color-mix(in srgb,var(--danger) 15%,transparent);color:var(--danger)}.badge--muted{background-color:color-mix(in srgb,var(--muted) 20%,transparent);color:var(--muted)}.alert{display:flex;align-items:flex-start;gap:.75rem;padding:.875rem 1rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);font-size:.875rem;line-height:1.5}.alert-icon{flex-shrink:0;font-size:1rem}.alert-content{flex:1;color:var(--text)}.alert-title{font-weight:600}.alert--info{background:var(--surface);border-color:var(--glass-border);color:var(--muted)}.alert--info .alert-title{color:var(--text)}.alert--warning{background:color-mix(in srgb,var(--warning) 10%,transparent);border-color:color-mix(in srgb,var(--warning) 30%,transparent)}.alert--warning .alert-content{color:var(--text)}.alert--success{background:color-mix(in srgb,var(--success) 10%,transparent);border-color:color-mix(in srgb,var(--success) 30%,transparent)}.alert--success .alert-content{color:var(--text)}.alert--danger{background:color-mix(in srgb,var(--danger) 10%,transparent);border-color:color-mix(in srgb,var(--danger) 30%,transparent)}.alert--danger .alert-content{color:var(--text)}@media(max-width:480px){.alert{flex-direction:column;gap:.5rem}}.action-menu{position:relative;display:inline-flex}.action-menu-trigger{display:inline-flex;align-items:center;gap:.5rem}.action-menu-trigger.btn-icon-only{padding:.375rem .5rem;gap:0}.action-menu-trigger.btn-icon-only .btn-icon{margin:0}.action-menu-chevron{width:16px;height:16px;transition:transform .15s ease;flex-shrink:0}.action-menu-chevron.open{transform:rotate(180deg)}.action-menu-dropdown{min-width:180px;background:var(--surface);border:1px solid var(--glass-border);border-radius:var(--radius);box-shadow:0 4px 12px #00000026;z-index:9999;overflow:hidden}.action-menu-item{display:flex;align-items:center;gap:.5rem;width:100%;padding:.625rem 1rem;font-size:.875rem;font-weight:500;color:var(--text);background:none;border:none;cursor:pointer;text-align:left;transition:background-color .15s ease}.action-menu-item:hover:not(:disabled){background:var(--panel)}.action-menu-item:disabled{opacity:.5;cursor:not-allowed}.action-menu-item.danger{color:var(--danger)}.action-menu-item.danger:hover:not(:disabled){background:#ef44441a}.action-menu-item-icon{width:16px;height:16px;display:flex;align-items:center;justify-content:center}.action-menu-item-icon svg{width:16px;height:16px}.action-menu-item+.action-menu-item{border-top:1px solid var(--glass-border)}.confirm-dialog{position:fixed;padding:0;border:none;border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-xl);max-width:400px;width:calc(100% - 2rem)}.confirm-dialog::backdrop{background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-dialog-content{padding:1.5rem}.confirm-dialog-header{margin-bottom:1rem}.confirm-dialog-title{font-size:1.125rem;font-weight:600;color:var(--gray-900);margin:0}.confirm-dialog-body{margin-bottom:1.5rem}.confirm-dialog-message{font-size:.95rem;color:var(--gray-500);margin:0;line-height:1.5}.confirm-dialog-actions{display:flex;justify-content:flex-end;gap:.75rem}.confirm-dialog-btn{padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;border:none;border-radius:var(--radius);cursor:pointer;transition:all .2s ease;min-width:80px;display:inline-flex;align-items:center;justify-content:center}.confirm-dialog-btn:disabled{opacity:.6;cursor:not-allowed}.confirm-dialog-btn.cancel{background:var(--gray-200);color:var(--gray-700)}.confirm-dialog-btn.cancel:hover:not(:disabled){background:var(--gray-300)}.confirm-dialog-btn.confirm{color:#fff}.confirm-dialog-btn.confirm.primary{background:var(--primary)}.confirm-dialog-btn.confirm.primary:hover:not(:disabled){background:var(--primary-dark)}.confirm-dialog-btn.confirm.danger{background:#dc2626}.confirm-dialog-btn.confirm.danger:hover:not(:disabled){background:#b91c1c}.confirm-dialog-btn.confirm.warning{background:#d97706}.confirm-dialog-btn.confirm.warning:hover:not(:disabled){background:#b45309}.confirm-dialog-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.currency-input{display:flex;align-items:stretch}.currency-input .currency-input__prefix{display:flex;align-items:center;justify-content:center;padding:0 .75rem;background:var(--panel);border:1px solid var(--glass-border);border-right:none;border-radius:6px 0 0 6px;color:var(--muted);font-size:.875rem;font-weight:500;-webkit-user-select:none;user-select:none}.currency-input .currency-input__input{flex:1;min-width:0;padding:.625rem .875rem;font-size:.9375rem;border:1px solid var(--glass-border);border-radius:0 6px 6px 0;background-color:var(--surface);color:var(--text);font-variant-numeric:tabular-nums;transition:border-color .15s ease,box-shadow .15s ease}.currency-input .currency-input__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2b39901a}.currency-input .currency-input__input::placeholder{color:var(--muted)}.currency-input .currency-input__input:disabled{background-color:var(--panel);color:var(--muted);cursor:not-allowed}.currency-input.currency-input--error .currency-input__prefix,.currency-input.currency-input--error .currency-input__input{border-color:var(--danger)}.currency-input.currency-input--error .currency-input__input:focus{box-shadow:0 0 0 3px #ef44441a}.currency-input.currency-input--disabled .currency-input__prefix{background:var(--gray-100);color:var(--gray-400)}.currency-input.currency-input--sm .currency-input__prefix{padding:0 .5rem;font-size:.8125rem}.currency-input.currency-input--sm .currency-input__input{padding:.5rem .75rem;font-size:.875rem;border-radius:0 6px 6px 0}.currency-input.currency-input--lg .currency-input__prefix{padding:0 1rem;font-size:1rem}.currency-input.currency-input--lg .currency-input__input{padding:.75rem 1rem;font-size:1rem;border-radius:0 6px 6px 0}.currency-input .currency-input__input::-webkit-outer-spin-button,.currency-input .currency-input__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.currency-input .currency-input__input[type=number]{-moz-appearance:textfield}.date-input{min-width:150px}.date-input--error{border-color:var(--danger)}.date-input--error:focus{border-color:var(--danger);box-shadow:0 0 0 3px #ef444426}.date-input--disabled{background-color:var(--panel);cursor:not-allowed;opacity:.7}.date-input::-webkit-calendar-picker-indicator{cursor:pointer;opacity:.6;transition:opacity .2s}.date-input::-webkit-calendar-picker-indicator:hover{opacity:1}.duration-input-wrapper{display:flex;flex-direction:column;gap:.25rem}.duration-input-label{font-size:.875rem;font-weight:500;color:var(--color-text-secondary)}.duration-input-container{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:.5rem;background:var(--color-bg-primary);overflow:hidden;transition:border-color .2s,box-shadow .2s}.duration-input-container:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-alpha)}.duration-input-container.duration-input-error{border-color:var(--color-danger)}.duration-input-container.duration-input-error:focus-within{box-shadow:0 0 0 2px var(--color-danger-alpha)}.duration-input-container.duration-input-disabled{opacity:.6;cursor:not-allowed;background:var(--color-bg-secondary)}.duration-input-btn{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;padding:0;border:none;background:var(--color-bg-secondary);color:var(--color-text-secondary);cursor:pointer;transition:background-color .15s,color .15s;flex-shrink:0}.duration-input-btn:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--color-text-primary)}.duration-input-btn:active:not(:disabled){background:var(--color-primary-light)}.duration-input-btn:disabled{cursor:not-allowed;opacity:.4}.duration-input-btn svg{width:1rem;height:1rem}.duration-input-field-wrapper{display:flex;align-items:center;justify-content:center;gap:.25rem;flex:1;min-width:0;padding:0 .5rem}.duration-input-field{width:4rem;padding:.5rem 0;border:none;background:transparent;font-size:1rem;font-weight:500;text-align:center;color:var(--color-text-primary);appearance:textfield;-moz-appearance:textfield}.duration-input-field::-webkit-inner-spin-button,.duration-input-field::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.duration-input-field:focus{outline:none}.duration-input-display{font-size:1rem;font-weight:500;color:var(--color-text-primary);text-align:center}.duration-input-suffix{font-size:.875rem;color:var(--color-text-tertiary)}.duration-input-hint{font-size:.75rem;color:var(--color-text-tertiary);text-align:center}@media(max-width:480px){.duration-input-btn{width:2.25rem;height:2.25rem}.duration-input-field{width:3.5rem;font-size:.9375rem}}.percentage-input{display:flex;align-items:stretch}.percentage-input .percentage-input__input{flex:1;min-width:0;padding:.625rem .875rem;font-size:.9375rem;border:1px solid var(--glass-border);border-right:none;border-radius:6px 0 0 6px;background-color:var(--surface);color:var(--text);font-variant-numeric:tabular-nums;transition:border-color .15s ease,box-shadow .15s ease}.percentage-input .percentage-input__input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2b39901a}.percentage-input .percentage-input__input:focus+.percentage-input__suffix{border-color:var(--primary);box-shadow:0 0 0 3px #2b39901a}.percentage-input .percentage-input__input::placeholder{color:var(--muted)}.percentage-input .percentage-input__input:disabled{background-color:var(--panel);color:var(--muted);cursor:not-allowed}.percentage-input .percentage-input__suffix{display:flex;align-items:center;justify-content:center;padding:0 .75rem;background:var(--panel);border:1px solid var(--glass-border);border-left:none;border-radius:0 6px 6px 0;color:var(--muted);font-size:.875rem;font-weight:500;-webkit-user-select:none;user-select:none}.percentage-input.percentage-input--error .percentage-input__input,.percentage-input.percentage-input--error .percentage-input__suffix{border-color:var(--danger)}.percentage-input.percentage-input--error .percentage-input__input:focus{box-shadow:0 0 0 3px #ef44441a}.percentage-input.percentage-input--error .percentage-input__input:focus+.percentage-input__suffix{box-shadow:0 0 0 3px #ef44441a}.percentage-input.percentage-input--disabled .percentage-input__suffix{background:var(--gray-100);color:var(--gray-400)}.percentage-input.percentage-input--sm .percentage-input__input{padding:.5rem .75rem;font-size:.875rem}.percentage-input.percentage-input--sm .percentage-input__suffix{padding:0 .5rem;font-size:.8125rem}.percentage-input.percentage-input--lg .percentage-input__input{padding:.75rem 1rem;font-size:1rem}.percentage-input.percentage-input--lg .percentage-input__suffix{padding:0 1rem;font-size:1rem}.percentage-input .percentage-input__input::-webkit-outer-spin-button,.percentage-input .percentage-input__input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.image-upload{position:relative;background:var(--surface);border:2px dashed var(--gray-300);border-radius:var(--radius);cursor:pointer;overflow:hidden;transition:all .2s ease;flex-shrink:0}.image-upload--poster{width:100%;max-width:200px;aspect-ratio:2 / 3}.image-upload--profile{width:180px;height:180px;border-radius:var(--radius-lg)}.image-upload--square{width:180px;height:180px}.image-upload:hover:not(.loading):not(.disabled){border-color:var(--primary);background:#2b39900d}.image-upload:focus-visible{outline:2px solid var(--primary);outline-offset:2px}.image-upload.has-image{border-style:solid;border-color:var(--primary)}.image-upload.loading{cursor:wait}.image-upload.disabled{cursor:not-allowed;opacity:.6}.image-upload__input{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip-path:inset(50%);white-space:nowrap;border:0}.image-upload__placeholder{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:.5rem;padding:1rem}.image-upload__placeholder-icon{width:48px;height:48px;color:var(--gray-400);opacity:.5}.image-upload--profile .image-upload__placeholder-icon{width:40px;height:40px}.image-upload__placeholder-text{font-size:.9rem;font-weight:500;color:var(--gray-700)}.image-upload__placeholder-hint{font-size:.75rem;color:var(--gray-500);line-height:1.3}.image-upload__image{width:100%;height:100%;object-fit:scale-down;display:block}.image-upload__overlay{position:absolute;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s ease}.image-upload.has-image:hover:not(.loading):not(.disabled) .image-upload__overlay{opacity:1}.image-upload__overlay-content{display:flex;flex-direction:column;align-items:center;gap:.5rem;color:#fff;font-size:.9rem;font-weight:500}.image-upload__overlay-icon{width:32px;height:32px}.image-upload__delete-btn{position:absolute;top:8px;right:8px;width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:#000000b3;border:none;border-radius:50%;color:#fff;cursor:pointer;opacity:0;transition:all .2s ease;z-index:10}.image-upload.has-image:hover:not(.loading):not(.disabled) .image-upload__delete-btn{opacity:1}.image-upload__delete-btn:hover{background:#dc2626}.image-upload__delete-btn svg{width:14px;height:14px}.image-upload__loading-overlay{position:absolute;inset:0;background:#000000b3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;z-index:20}.image-upload__spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:image-upload-spin .8s linear infinite}.image-upload__loading-text{color:#fff;font-size:.85rem;font-weight:500}@keyframes image-upload-spin{to{transform:rotate(360deg)}}@media(max-width:640px){.image-upload--poster{max-width:150px}.image-upload--profile,.image-upload--square{width:140px;height:140px}.image-upload__placeholder-icon{width:36px;height:36px}.image-upload--profile .image-upload__placeholder-icon{width:32px;height:32px}.image-upload__placeholder-text{font-size:.85rem}.image-upload__placeholder-hint{font-size:.7rem}}.pagination{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:1rem;background:var(--panel);border-top:1px solid var(--glass-border)}.pagination-info{display:flex;align-items:center;gap:1rem;font-size:.875rem;color:var(--muted)}.pagination-size-select{padding:.375rem .75rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);font-size:.875rem;cursor:pointer;transition:border-color .15s ease}.pagination-size-select:hover{border-color:var(--primary)}.pagination-size-select:focus{outline:none;border-color:var(--primary)}.pagination-controls{display:flex;align-items:center;gap:.5rem}.pagination-pages{display:flex;align-items:center;gap:.25rem}.pagination-button,.pagination-page{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;padding:0 .75rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:6px;color:var(--text);font-size:.875rem;cursor:pointer;transition:all .15s ease}.pagination-button:hover:not(:disabled),.pagination-page:hover:not(.active){background:var(--panel);border-color:var(--primary)}.pagination-button:disabled{opacity:.5;cursor:not-allowed}.pagination-page.active{background:var(--primary);border-color:var(--primary);color:#fff}.pagination-ellipsis{display:flex;align-items:center;justify-content:center;min-width:36px;height:36px;color:var(--muted);font-size:.875rem}@media(max-width:640px){.pagination{flex-direction:column;gap:.75rem}.pagination-info{flex-direction:column;gap:.5rem;text-align:center}.pagination-pages{gap:.125rem}.pagination-button,.pagination-page{min-width:32px;height:32px;padding:0 .5rem;font-size:.8rem}}.search-input-container{position:relative;display:flex;align-items:center;width:100%;max-width:400px}.search-input-icon{position:absolute;left:12px;display:flex;align-items:center;justify-content:center;width:16px;height:16px;color:var(--muted);pointer-events:none;z-index:1}.search-input-icon svg{width:16px;height:16px}.search-input{width:100%;padding:.625rem 2.5rem .625rem 2.25rem;background:var(--surface);border:1px solid var(--glass-border);border-radius:8px;color:var(--text);font-size:.9rem;transition:border-color .15s ease,box-shadow .15s ease}.search-input::placeholder{color:var(--muted);padding-left:.25rem}.search-input:hover{border-color:#ffffff26}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #2b399026}.search-input-clear{position:absolute;right:8px;display:flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;background:transparent;border:none;border-radius:4px;color:var(--muted);cursor:pointer;transition:color .15s ease,background-color .15s ease}.search-input-clear:hover{color:var(--text);background:var(--panel)}.search-input-clear svg{width:16px;height:16px}.modal{position:fixed;inset:0;width:100%;height:100%;max-width:100%;max-height:100%;border:none;padding:1rem;background:transparent;display:flex;align-items:center;justify-content:center}.modal::backdrop{background-color:#0009;animation:modalFadeIn .2s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background-color:var(--bg-card, var(--surface, #ffffff));border-radius:12px;width:100%;max-height:calc(100vh - 2rem);overflow-y:auto;box-shadow:var(--shadow-lg, 0 20px 25px -5px rgba(0, 0, 0, .1));animation:modalSlideUp .2s ease-out}@keyframes modalSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal--sm .modal-content{max-width:400px}.modal--md .modal-content{max-width:520px}.modal--lg .modal-content{max-width:640px}.modal-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, var(--glass-border, #e5e7eb));position:sticky;top:0;background-color:var(--bg-card, var(--surface, #ffffff));z-index:1}.modal-header-text{flex:1;min-width:0}.modal-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text-primary, var(--text, #0f172a))}.modal-subtitle{margin:.25rem 0 0;font-size:.875rem;color:var(--text-secondary, var(--muted, #64748b))}.modal-close{display:flex;align-items:center;justify-content:center;flex-shrink:0;width:32px;height:32px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text-secondary, var(--muted, #64748b));transition:all .15s ease}.modal-close:hover:not(:disabled){background-color:var(--bg-tertiary, var(--panel, #f1f5f9));color:var(--text-primary, var(--text, #0f172a))}.modal-close:disabled{opacity:.5;cursor:not-allowed}.modal-close svg{width:20px;height:20px}.modal-body{padding:1.5rem;padding-top:0}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;background-color:var(--bg-card, var(--surface, #ffffff));position:sticky;bottom:0}.modal-info-banner{padding:.875rem 1.25rem;border-bottom:1px solid var(--border-color, var(--glass-border, #e5e7eb));font-size:.8125rem}.modal-info-banner--info{background-color:var(--blue-2, #eff6ff);border-bottom-color:var(--blue-5, #bfdbfe)}.modal-info-banner--warning{background-color:var(--yellow-2, #fefce8);border-bottom-color:var(--yellow-5, #fde68a)}.modal-info-banner--success{background-color:var(--green-2, #f0fdf4);border-bottom-color:var(--green-5, #bbf7d0)}.modal-body .form-group{margin-bottom:1rem}.modal-body .form-group:last-child{margin-bottom:0}.modal-body .form-row{display:flex;gap:1rem}.modal-body .flex-1{flex:1}.modal-body .form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--text-secondary, var(--muted, #64748b))}.modal-body .form-label .required{color:var(--danger, #ef4444)}.modal-body .form-input,.modal-body .form-select,.modal-body .form-textarea{width:100%;padding:.625rem .875rem;font-size:.9375rem;border:1px solid var(--border-color, var(--glass-border, #e5e7eb));border-radius:8px;background-color:var(--bg-input, var(--surface, #ffffff));color:var(--text-primary, var(--text, #0f172a));transition:border-color .15s ease,box-shadow .15s ease}.modal-body .form-input:focus,.modal-body .form-select:focus,.modal-body .form-textarea:focus{outline:none;border-color:var(--primary, #2b3990);box-shadow:0 0 0 3px #2b39901a}.modal-body .form-input.error,.modal-body .form-select.error,.modal-body .form-textarea.error{border-color:var(--danger, #ef4444)}.modal-body .form-input:disabled,.modal-body .form-select:disabled,.modal-body .form-textarea:disabled{opacity:.7;cursor:not-allowed;background-color:var(--bg-tertiary, var(--panel, #f1f5f9))}.modal-body .form-error{display:block;margin-top:.25rem;font-size:.75rem;color:var(--danger, #ef4444)}.modal-body .form-hint{display:block;margin-top:.25rem;font-size:.75rem;color:var(--text-secondary, var(--muted, #64748b))}.modal-body .form-checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary, var(--text, #0f172a));cursor:pointer}.modal-body .form-checkbox-label input[type=checkbox]{width:1rem;height:1rem;margin:0;flex-shrink:0;accent-color:var(--primary, #2b3990)}.modal-body .form-checkbox-group{display:flex;align-items:center;gap:.5rem}.modal-body .form-checkbox-group input[type=checkbox]{width:1rem;height:1rem;accent-color:var(--primary, #2b3990)}.modal-body .form-checkbox-group label{font-size:.875rem;color:var(--text-primary, var(--text, #0f172a));cursor:pointer}.modal-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;gap:1rem}.modal-loading-spinner{width:32px;height:32px;border:3px solid var(--border-color, var(--glass-border, #e5e7eb));border-top-color:var(--primary, #2b3990);border-radius:50%;animation:modalSpin .8s linear infinite}@keyframes modalSpin{to{transform:rotate(360deg)}}.modal-loading-text{font-size:.875rem;color:var(--text-secondary, var(--muted, #64748b))}.modal-danger-zone{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--error, #ef4444)}.modal-danger-zone-title{font-size:.875rem;font-weight:600;color:var(--error, #ef4444);margin:0 0 .5rem}.modal-danger-zone-description{font-size:.75rem;color:var(--text-secondary, var(--muted, #64748b));margin:0 0 1rem}.modal-danger-zone .btn-danger{background-color:var(--error, #ef4444);color:#fff;border:none}.modal-danger-zone .btn-danger:hover{background-color:var(--error-hover, #dc2626)}@media(max-width:640px){.modal{padding:.5rem}.modal-header{padding:1rem}.modal-body{padding:1rem;padding-top:0}.modal-footer{padding:.75rem 1rem;flex-direction:column-reverse}.modal-footer .btn{width:100%}.modal-body .form-row{flex-direction:column;gap:0}}.scrollable-tabs{position:relative;display:flex;align-items:stretch}.scrollable-tabs-container{flex:1;overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth}.scrollable-tabs-container::-webkit-scrollbar{display:none}.scroll-arrow{display:flex;align-items:center;justify-content:center;width:32px;height:auto;padding:0;background:linear-gradient(to right,var(--surface) 70%,transparent);border:none;cursor:pointer;color:var(--muted);transition:color .15s,background .15s;flex-shrink:0;z-index:1}.scroll-arrow:hover{color:var(--text)}.scroll-arrow-left{background:linear-gradient(to right,var(--surface) 70%,transparent);border-right:1px solid var(--glass-border)}.scroll-arrow-right{background:linear-gradient(to left,var(--surface) 70%,transparent);border-left:1px solid var(--glass-border)}.scroll-arrow:focus{outline:none}.scroll-arrow:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.side-panel-backdrop{position:fixed;inset:0;background:#00000080;z-index:999;animation:sidePanelFadeIn .2s ease-out}.side-panel{position:fixed;top:0;right:0;bottom:0;max-width:90vw;background:var(--surface, #fff);box-shadow:-4px 0 24px #00000026;z-index:1000;display:flex;flex-direction:column;animation:sidePanelSlideIn .25s ease-out;outline:none}.side-panel--narrow{width:360px}.side-panel--medium{width:480px}.side-panel--wide{width:600px}@keyframes sidePanelFadeIn{0%{opacity:0}to{opacity:1}}@keyframes sidePanelSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.side-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--glass-border, #e5e7eb);flex-shrink:0}.side-panel-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text, #111827)}.side-panel-close-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:transparent;border-radius:6px;font-size:1.5rem;line-height:1;color:var(--muted, #6b7280);cursor:pointer;transition:background-color .15s,color .15s}.side-panel-close-btn:hover{background:var(--panel, #f3f4f6);color:var(--text, #111827)}.side-panel-content{flex:1;overflow-y:auto;padding:1.5rem}.side-panel-footer{padding:1rem 1.5rem;border-top:1px solid var(--glass-border, #e5e7eb);flex-shrink:0;display:flex;justify-content:flex-end;gap:.75rem}.side-panel-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.75rem;padding:3rem 1rem;color:var(--muted, #6b7280)}.side-panel-loading .loading-spinner{width:32px;height:32px;border:3px solid var(--glass-border, #e5e7eb);border-top-color:var(--primary, #3b82f6);border-radius:50%;animation:sidePanelSpin .8s linear infinite}@keyframes sidePanelSpin{to{transform:rotate(360deg)}}.side-panel-empty{text-align:center;padding:2rem;color:var(--muted, #6b7280)}.side-panel-empty a{color:var(--primary, #3b82f6);text-decoration:none}.side-panel-empty a:hover{text-decoration:underline}.side-panel-error{padding:1rem;background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius, 8px);color:#dc2626;text-align:center;margin-bottom:1rem}@media(max-width:540px){.side-panel--narrow,.side-panel--medium,.side-panel--wide{width:100%;max-width:100%}}.panel{background:var(--surface);border-radius:var(--radius);border:1px solid var(--glass-border)}.panel+.panel{margin-top:1rem}.panel--danger{border-color:var(--danger);background:#ef444408;margin-top:1rem}.panel--danger .panel-title{color:var(--danger)}.panel--flush{background:transparent;border:none;border-radius:0}.panel--flush .panel-header{padding:0 0 .5rem}.panel--flush .panel-content{padding:0}.panel--flush+.panel--flush{margin-top:1.5rem}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.25rem;gap:1rem}.panel-header--collapsible{cursor:pointer;-webkit-user-select:none;user-select:none}.panel-header--collapsible:hover{background:#00000005}.panel-header--collapsible:focus-visible{outline:2px solid var(--primary);outline-offset:-2px;border-radius:var(--radius)}.panel-header-left{display:flex;align-items:center;gap:.75rem;min-width:0}.panel-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center;color:var(--muted)}.panel-titles{min-width:0}.panel-title{margin:0;font-size:1rem;font-weight:600;color:var(--text);line-height:1.4}.panel-subtitle{margin:.125rem 0 0;font-size:.8125rem;color:var(--muted);line-height:1.4}.panel-header-right{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.panel-chevron{flex-shrink:0;display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--muted);transition:transform .2s ease;border-radius:var(--radius-sm)}.panel-header--collapsible:hover .panel-chevron{background:#0000000d;color:var(--text)}.panel-chevron--expanded{transform:rotate(180deg)}.panel-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.panel-content{padding:0 1.25rem 1.25rem}.panel-content--no-padding{padding:0}.panel-header+.panel-content{padding-top:1rem}.panel:not(:has(.panel-header)) .panel-content{padding-top:1.25rem}.detail-grid{display:grid;grid-template-columns:repeat(var(--detail-grid-columns, 2),1fr);gap:1.25rem 1.5rem}@media(max-width:600px){.detail-grid{grid-template-columns:1fr}}.detail-grid-item{display:flex;flex-direction:column;gap:.25rem;min-width:0}.detail-grid-item--full-width{grid-column:1 / -1}.detail-grid-label{font-size:.75rem;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.025em;line-height:1.4}.detail-grid-value{font-size:.9375rem;color:var(--text);line-height:1.5;overflow-wrap:break-word}.detail-grid-value--empty{color:var(--muted);font-style:italic}.detail-grid-value a{color:var(--primary);text-decoration:none}.detail-grid-value a:hover{text-decoration:underline}.detail-grid-value pre,.detail-grid-value .preserve-whitespace{white-space:pre-wrap;font-family:inherit;margin:0}.form{display:flex;flex-direction:column}.form-field{display:flex;flex-direction:column;gap:.375rem;margin-top:1rem}.form-field-label{font-size:.8125rem;font-weight:500;color:var(--text);line-height:1.4}.form-field-required{color:var(--danger);margin-left:.25rem}.form-field-control{width:100%;padding:.5rem .75rem;font-size:.9375rem;font-family:inherit;color:var(--text);background:var(--input-bg, var(--surface));border:1px solid var(--glass-border);border-radius:var(--radius);transition:border-color .15s ease,box-shadow .15s ease}.form-field-control:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px rgba(var(--primary-rgb, 99, 102, 241),.15)}.form-field-control--error{border-color:var(--danger)}.form-field-control--error:focus{box-shadow:0 0 0 2px rgba(var(--danger-rgb, 239, 68, 68),.15)}.form-field-control::placeholder{color:var(--muted)}.form-field-control--textarea{min-height:80px;resize:vertical;line-height:1.5}select.form-field-control{appearance:none;background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3e%3cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='M6 8l4 4 4-4'/%3e%3c/svg%3e");background-position:right .5rem center;background-repeat:no-repeat;background-size:1.5em 1.5em;padding-right:2.5rem}.form-field-custom{width:100%}.form-field-error{font-size:.75rem;color:var(--danger);line-height:1.4}.form-field-hint{font-size:.75rem;color:var(--muted);line-height:1.4}.form-row{display:grid;grid-template-columns:repeat(var(--form-row-columns, 2),1fr);gap:1rem}@media(max-width:600px){.form-row{grid-template-columns:1fr}}.form-actions{display:flex;flex-wrap:wrap;gap:.75rem;padding-top:1rem}.form-actions--left{justify-content:flex-start}.form-actions--right{justify-content:flex-end}.form-actions--center{justify-content:center}.form-actions--space-between{justify-content:space-between}.form-field--full-width{grid-column:1 / -1}.form-field--checkbox{flex-direction:row;align-items:flex-start}.form-field-checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;-webkit-user-select:none;user-select:none}.form-field-checkbox{width:1rem;height:1rem;margin:0;cursor:pointer;accent-color:var(--primary);flex-shrink:0}.form-field-checkbox-text{font-size:.875rem;color:var(--text);line-height:1.4}.job-status-badge{display:inline-flex;align-items:center;padding:.25rem .625rem;font-size:.75rem;font-weight:500;border-radius:var(--radius);white-space:nowrap}.job-status-badge--planning{background:#9333ea26;color:#9333ea}.job-status-badge--approved{background:#3b82f626;color:#3b82f6}.job-status-badge--in-progress{background:#22c55e26;color:#22c55e}.job-status-badge--on-hold{background:#f59e0b26;color:#f59e0b}.job-status-badge--completed{background:#14b8a626;color:#14b8a6}.job-status-badge--closed{background:#6b728026;color:#6b7280}.toggle-button-group{display:inline-flex;gap:.25rem;background:var(--glass-bg);border-radius:var(--radius);padding:.25rem;border:1px solid var(--glass-border)}.toggle-button-group--sm .toggle-button{padding:.375rem .75rem;font-size:.75rem}.toggle-button-group--md .toggle-button{padding:.5rem 1rem;font-size:.8125rem}.toggle-button{font-weight:500;border:none;background:transparent;color:var(--muted);border-radius:calc(var(--radius) - 2px);cursor:pointer;transition:all .15s ease;white-space:nowrap}.toggle-button:hover:not(.toggle-button--active):not(:disabled){color:var(--text);background:var(--hover)}.toggle-button--active{background:var(--panel);color:var(--accent);box-shadow:0 1px 2px #0000001a}.toggle-button:disabled{opacity:.5;cursor:not-allowed}.toggle-button:focus-visible{outline:2px solid var(--primary);outline-offset:1px}.settings-card{display:flex;align-items:center;gap:var(--space-4);padding:10px;background:var(--white);border:1px solid var(--neutral-200);border-radius:var(--radius-lg);transition:box-shadow .15s ease,border-color .15s ease}.settings-card:hover{border-color:var(--neutral-300);box-shadow:0 2px 8px #0000000a}.settings-card--archived{background:var(--neutral-50);opacity:.75}.settings-card--dragging{opacity:.5;border-style:dashed}.settings-card__drag-handle{cursor:grab;color:var(--neutral-400);padding:var(--space-1);opacity:.5;transition:opacity .15s ease;flex-shrink:0}.settings-card__drag-handle:hover{opacity:1}.settings-card__drag-handle:active{cursor:grabbing}.settings-card__content{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.settings-card__header{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.settings-card__name{font-size:1rem;font-weight:600;color:var(--neutral-900);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-card__subtitle{font-size:var(--font-size-sm);color:var(--neutral-500)}.settings-card__badge{display:inline-flex;align-items:center;padding:4px 10px;border-radius:var(--radius-full);font-size:.6875rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.settings-card__badge--default{background:linear-gradient(135deg,var(--primary-50),var(--primary-100));color:var(--primary-700);border:1px solid var(--primary-200);box-shadow:0 1px 2px #3b82f614}.settings-card__badge--archived{background:var(--neutral-100);color:var(--neutral-600);border:1px solid var(--neutral-200)}.settings-card__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0;margin-left:auto}.settings-card__edit-inline{display:flex;align-items:center;gap:var(--space-2);flex:1}.settings-card__edit-inline input{flex:1;padding:var(--space-2) var(--space-3);border:1px solid var(--primary-500);border-radius:var(--radius-md);background:var(--white);font-size:var(--font-size-sm);color:var(--neutral-900);outline:none}.settings-card__edit-inline input:focus{box-shadow:0 0 0 2px var(--primary-100)}.action-icon-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;padding:0;border:none;background:transparent;border-radius:var(--radius-md);color:var(--neutral-500);cursor:pointer;transition:background-color .15s ease,color .15s ease}.action-icon-btn svg{width:16px;height:16px}.action-icon-btn:hover:not(:disabled){background:var(--neutral-100);color:var(--neutral-700)}.action-icon-btn:disabled{opacity:.5;cursor:not-allowed}.action-icon-btn--danger:hover:not(:disabled){background:var(--red-50);color:var(--red-600)}.action-icon-btn--success:hover:not(:disabled){background:var(--green-50);color:var(--green-600)}.action-icon-btn--active{color:var(--primary-500)}.action-icon-btn--active:hover:not(:disabled){background:var(--primary-50);color:var(--primary-600)}.help-panel{background:var(--blue-50);border:1px solid var(--blue-200);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:1.5rem}.help-panel--expanded{background:var(--white)}.help-panel__header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .15s ease}.help-panel__header:hover{background:#3b82f614}.help-panel__header:focus-visible{outline:2px solid var(--primary);outline-offset:-2px}.help-panel__header-left{display:flex;align-items:center;gap:.5rem}.help-panel__icon{display:flex;align-items:center;justify-content:center;color:var(--blue-500)}.help-panel__title{font-size:.875rem;font-weight:600;color:var(--blue-700)}.help-panel__chevron{display:flex;align-items:center;justify-content:center;color:var(--blue-400);transition:transform .2s ease}.help-panel__chevron--expanded{transform:rotate(180deg)}.help-panel__content{padding:0 1rem 1rem;border-top:1px solid var(--blue-100);background:var(--white)}.help-panel__content h3{margin:1rem 0 .5rem;font-size:.875rem;font-weight:600;color:var(--neutral-900)}.help-panel__content h3:first-child{margin-top:0}.help-panel__content p{margin:0 0 .75rem;font-size:.8125rem;color:var(--neutral-600);line-height:1.5}.help-panel__content p:last-child{margin-bottom:0}.help-panel__table{width:100%;border-collapse:collapse;font-size:.8125rem;margin-top:.75rem}.help-panel__table th,.help-panel__table td{padding:.5rem .75rem;text-align:left;border-bottom:1px solid var(--neutral-200)}.help-panel__table th{font-size:.75rem;font-weight:600;color:var(--neutral-600);background:var(--neutral-50);text-transform:uppercase;letter-spacing:.025em}.help-panel__table td{color:var(--neutral-700)}.help-panel__table tr:last-child td{border-bottom:none}.help-panel__table .help-panel__cell--label{font-weight:500;color:var(--neutral-900)}.help-panel__table .help-panel__cell--mono{font-variant-numeric:tabular-nums;font-family:var(--font-mono, monospace);font-size:.75rem}.help-panel__table .help-panel__cell--muted{color:var(--neutral-500);font-size:.75rem}.signature-capture{display:flex;flex-direction:column;gap:.75rem}.signature-capture__header{display:flex;align-items:center;justify-content:space-between}.signature-capture__label{font-size:.875rem;font-weight:500;color:var(--text-primary, #1f2937)}.signature-capture__mode-toggle{display:inline-flex;border-radius:6px;overflow:hidden;border:1px solid var(--border-color, #d1d5db)}.signature-capture__mode-btn{padding:.25rem .75rem;font-size:.8125rem;border:none;background:var(--bg-secondary, #f9fafb);color:var(--text-secondary, #6b7280);cursor:pointer;transition:background .15s,color .15s}.signature-capture__mode-btn:not(:last-child){border-right:1px solid var(--border-color, #d1d5db)}.signature-capture__mode-btn--active{background:var(--primary, #2563eb);color:#fff}.signature-capture__mode-btn:disabled{opacity:.5;cursor:not-allowed}.signature-capture__canvas-wrapper{position:relative;border:2px dashed var(--border-color, #d1d5db);border-radius:8px;overflow:hidden;background:#fff;transition:border-color .15s}.signature-capture__canvas-wrapper--signed{border-style:solid;border-color:var(--primary, #2563eb)}.signature-capture__canvas{display:block;width:100%;height:150px;touch-action:none;cursor:crosshair}.signature-capture__placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--text-tertiary, #9ca3af);font-size:.875rem;pointer-events:none;-webkit-user-select:none;user-select:none}.signature-capture__actions{display:flex;justify-content:flex-end;padding:.375rem .5rem}.signature-capture__actions button{font-size:.8125rem;color:var(--text-secondary, #6b7280);background:none;border:none;cursor:pointer;padding:.125rem .5rem;border-radius:4px;transition:background .15s}.signature-capture__actions button:hover:not(:disabled){background:var(--bg-secondary, #f3f4f6)}.signature-capture__type-wrapper{display:flex;flex-direction:column;gap:.5rem}.signature-capture__type-input{padding:.5rem .75rem;border:1px solid var(--border-color, #d1d5db);border-radius:6px;font-size:.9375rem;outline:none;transition:border-color .15s}.signature-capture__type-input:focus{border-color:var(--primary, #2563eb);box-shadow:0 0 0 2px #2563eb26}.signature-capture__type-preview{display:flex;align-items:center;justify-content:center;min-height:80px;border:2px solid var(--primary, #2563eb);border-radius:8px;background:#fff;padding:1rem}.signature-capture__type-preview--empty{border-style:dashed;border-color:var(--border-color, #d1d5db)}.signature-capture__type-preview-text{font-size:2.25rem;color:#1f2937;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.signature-capture__consent{display:flex;align-items:flex-start;gap:.5rem;cursor:pointer;padding:.75rem;border:1px solid var(--border-color, #d1d5db);border-radius:8px;background:var(--bg-secondary, #f9fafb);transition:border-color .15s}.signature-capture__consent:has(.signature-capture__consent-checkbox:checked){border-color:var(--primary, #2563eb);background:#2563eb0a}.signature-capture__consent-checkbox{margin-top:.2rem;flex-shrink:0;accent-color:var(--primary, #2563eb)}.signature-capture__consent-text{font-size:.8125rem;color:var(--text-secondary, #6b7280);line-height:1.45}.main-layout{display:flex;min-height:100vh;background-color:var(--bg);max-width:100vw;overflow-x:hidden}.main-layout-content{flex:1;display:flex;flex-direction:column;min-height:100vh;max-width:100%;overflow-x:hidden}.main-content{flex:1;padding:2rem;max-width:1400px;width:100%;margin:0 auto;box-sizing:border-box;overflow-x:hidden}@media(min-width:1024px){.main-layout-content{margin-left:280px}}@media(max-width:1023px){.main-content{padding-top:5rem}}@media(max-width:768px){.main-content{padding:5rem 1.5rem 1.5rem}}@media(max-width:480px){.main-content{padding:5rem 1rem 1rem}}
