:root{--color-primary-50: #e8f5e9;--color-primary-100: #c8e6c9;--color-primary-200: #a5d6a7;--color-primary-300: #81c784;--color-primary-400: #66bb6a;--color-primary-500: #2d5a27;--color-primary-600: #265021;--color-primary-700: #1e401a;--color-primary-800: #173014;--color-primary-900: #0f200d;--color-neutral-50: #fafafa;--color-neutral-100: #f5f5f5;--color-neutral-200: #eeeeee;--color-neutral-300: #e0e0e0;--color-neutral-400: #bdbdbd;--color-neutral-500: #9e9e9e;--color-neutral-600: #757575;--color-neutral-700: #616161;--color-neutral-800: #424242;--color-neutral-900: #212121;--color-accent-50: #fff8e1;--color-accent-100: #ffecb3;--color-accent-200: #ffe082;--color-accent-300: #ffd54f;--color-accent-400: #ffca28;--color-accent-500: #d4a520;--color-accent-600: #b8860b;--color-accent-700: #9a6f0a;--color-accent-800: #7c5809;--color-accent-900: #5e4108;--color-success-light: #d4edda;--color-success-main: #28a745;--color-success-dark: #155724;--color-warning-light: #fff3cd;--color-warning-main: #ffc107;--color-warning-dark: #856404;--color-error-light: #f8d7da;--color-error-main: #dc3545;--color-error-dark: #721c24;--color-info-light: #cce5ff;--color-info-main: #17a2b8;--color-info-dark: #004085;--color-bg-default: #f5f5f5;--color-bg-paper: #ffffff;--color-bg-subtle: #fafafa;--color-text-primary: #212121;--color-text-secondary: #666666;--color-text-disabled: #9e9e9e;--color-text-hint: #bdbdbd;--color-text-inverse: #ffffff;--color-border-light: #e0e0e0;--color-border-main: #bdbdbd;--color-border-dark: #9e9e9e;--font-family-primary: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, Cantarell, sans-serif;--font-family-mono: SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;--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;--font-size-3xl: 1.875rem;--font-size-4xl: 2.25rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--spacing-0: 0;--spacing-1: .25rem;--spacing-2: .5rem;--spacing-3: .75rem;--spacing-4: 1rem;--spacing-5: 1.25rem;--spacing-6: 1.5rem;--spacing-8: 2rem;--spacing-10: 2.5rem;--spacing-12: 3rem;--spacing-16: 4rem;--spacing-20: 5rem;--radius-none: 0;--radius-sm: .25rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-full: 9999px;--shadow-none: none;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--transition-fast: .15s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family-primary);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-bg-default);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a1a1a1}.app{min-height:100vh;display:flex;flex-direction:column}header{background:var(--color-primary-500);color:var(--color-text-inverse);padding:var(--spacing-4) var(--spacing-6)}header h1{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);letter-spacing:-.025em}main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--spacing-6)}.card{background:var(--color-bg-paper);border:1px solid var(--color-border-main, #d1d5db);border-radius:6px;padding:18px 20px;margin-bottom:var(--spacing-5)}.card-primary{border-color:#b0b5bd}.dashboard-section{margin-top:var(--spacing-8);padding-top:var(--spacing-6);border-top:1px solid var(--color-border-light)}.dashboard-section:first-of-type{margin-top:var(--spacing-6)}.dashboard-section .section-header{border-bottom:none;padding-bottom:var(--spacing-2);margin-bottom:var(--spacing-4)}.last-inspection-card{background:#fff;border:1px solid #b0b5bd;border-radius:6px;padding:var(--spacing-5);margin-bottom:var(--spacing-5)}.last-inspection-card.overdue{border-color:var(--color-border-main, #d1d5db);border-left:4px solid var(--color-warning-500, #d97706)}.last-inspection-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--spacing-4)}.last-inspection-header .header-title{display:flex;align-items:center;gap:var(--spacing-3)}.last-inspection-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.days-ago-badge{display:inline-flex;align-items:center;padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-default);border-radius:4px}.days-ago-badge.overdue{color:var(--color-warning-700, #b45309);background:var(--color-warning-100, #fef3c7);font-weight:var(--font-weight-semibold)}.overdue-message{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-4);margin-bottom:var(--spacing-4);background:var(--color-warning-50, #fffbeb);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-warning-700, #b45309)}.overdue-message .overdue-icon{font-size:var(--font-size-base)}.last-inspection-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.inspection-detail{display:flex;flex-direction:column;gap:var(--spacing-1)}.inspection-detail.full-width{grid-column:1 / -1}.inspection-detail .detail-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.inspection-detail .detail-value{font-size:var(--font-size-base);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px;padding-bottom:10px;border-bottom:1px solid var(--color-border-light, #e5e7eb)}.section-header h2{font-size:14px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.inspections-header{border-bottom:none;padding-bottom:0;margin-bottom:var(--spacing-4)}.search-row{margin-bottom:var(--spacing-3)}.search-row .search-input{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm)}.filter-row{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border-light)}.filter-row.compact{align-items:center;gap:var(--spacing-2)}.filter-row.compact .filter-input{padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm)}.filter-separator{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-1)}.filter-group label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.filter-input{padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);min-width:120px}.filter-spacer{flex:1}.export-buttons{display:flex;gap:var(--spacing-2)}.export-buttons .btn{display:flex;align-items:center;gap:var(--spacing-1)}.selection-info{color:var(--color-primary-600);font-weight:var(--font-weight-medium)}.bulk-action-toolbar{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);background:var(--color-primary-50);border:1px solid var(--color-primary-200);border-radius:var(--radius-md);margin-bottom:var(--spacing-4);flex-wrap:wrap}.bulk-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-primary-700)}.bulk-action-group{display:flex;align-items:center;gap:var(--spacing-2)}.bulk-action-group .form-input-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-sm);min-width:140px}.bulk-action-group .custom-select,.bulk-action-group .user-select{min-width:160px}.bulk-action-group .custom-select-sm .custom-select-trigger{height:32px}.bulk-action-group .user-select-trigger{height:32px;font-size:var(--font-size-sm)}@media (max-width: 768px){.bulk-action-toolbar{flex-direction:column;align-items:stretch}.bulk-action-group{width:100%}.bulk-action-group .form-input-sm,.bulk-action-group .custom-select,.bulk-action-group .user-select{flex:1}}.checklist-list-header{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--spacing-4);padding:var(--spacing-2) var(--spacing-4);padding-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.checklist-list-item{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--spacing-4);padding:var(--spacing-4);border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.checklist-list-item:last-child{border-bottom:none}.checklist-list-item:hover{background:var(--color-primary-50, #f0fdf4);cursor:pointer}.checklist-list-item.has-failures{background:#fef2f2}.checklist-list-item.has-failures:hover{background:#fee2e2}.checklist-date{display:flex;align-items:baseline;gap:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.checklist-date .date-primary{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.checklist-date .date-secondary{display:block;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.checklist-date .date-remarks{margin-left:var(--spacing-3);font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.checklist-date .date-remarks:before{content:"—";margin-right:var(--spacing-2);color:var(--color-border-light)}.checklist-inspector{color:var(--color-text-primary)}.checklist-actions{display:flex;gap:var(--spacing-1);justify-content:flex-end;min-width:100px}.checklist-remarks{grid-column:1 / 3;margin-top:var(--spacing-1)}.checklist-remarks .remarks-text{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-style:italic}.btn{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-2) var(--spacing-4);border:none;border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn:focus{outline:none;box-shadow:0 0 0 3px #2d5a274d}.btn-primary{background:#fff;color:var(--color-primary-600);border:1px solid var(--color-primary-500)}.btn-primary:hover{background:var(--color-primary-50, #f0fdf4);border-color:var(--color-primary-600)}.btn-cta{background:var(--color-primary-500);color:var(--color-text-inverse);border:1px solid var(--color-primary-500)}.btn-cta:hover{background:var(--color-primary-600);border-color:var(--color-primary-600)}.btn-secondary{background:var(--color-neutral-200);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-neutral-300)}.btn-outline-danger{background:transparent;color:#dc2626;border:1px solid #fca5a5}.btn-outline-danger:hover{background:#fef2f2}.btn-outline-warning{background:transparent;color:#d97706;border:1px solid #fcd34d}.btn-outline-warning:hover{background:#fffbeb}.btn-outline-success{background:transparent;color:#16a34a;border:1px solid #86efac}.btn-outline-success:hover{background:#f0fdf4}.btn-danger{background:var(--color-error-main);color:var(--color-text-inverse)}.btn-danger:hover{background:var(--color-error-dark)}.btn-sm{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs)}.btn-icon{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;padding:0;background:transparent;border:1px solid var(--color-border-main, #d1d5db);border-radius:5px;cursor:pointer;color:var(--color-text-hint, #9ca3af);transition:background .12s,color .12s,border-color .12s;min-width:auto}.btn-icon:hover{background:var(--color-bg-subtle, #f9fafb);color:var(--color-text-primary);border-color:#b0b5bd}.btn-icon-danger:hover{background:#fee2e2;color:#dc2626;border-color:#dc2626}.btn-ghost{background:transparent;color:var(--color-text-hint, #9ca3af);border:1px solid transparent}.btn-ghost:hover{color:var(--color-text-secondary);background:var(--color-bg-subtle, #f9fafb);border-color:var(--color-border-light, #e5e7eb)}.data-table{width:100%;border-collapse:collapse}.data-table th,.data-table td{padding:var(--spacing-3) var(--spacing-4);text-align:left;border-bottom:1px solid var(--color-border-light)}.data-table th{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);background:var(--color-bg-subtle)}.data-table tbody tr{transition:background var(--transition-fast)}.data-table tbody tr:hover{background:var(--color-bg-subtle)}.data-table tbody tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:4px;font-size:12px;font-weight:600}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-error{background:var(--color-error-light);color:var(--color-error-dark)}.badge-info{background:var(--color-info-light);color:var(--color-info-dark)}.badge-neutral{background:var(--color-neutral-200);color:var(--color-neutral-700)}.role-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:4px;font-size:12px;font-weight:600}.role-admin{background:#dbeafe;color:#1e40af}.role-manager{background:#dcfce7;color:#166534}.role-worker{background:#fef3c7;color:#92400e}.role-viewer{background:#f3f4f6;color:#4b5563}.status-badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:4px;font-size:12px;font-weight:600}.status-active{background:#dcfce7;color:#166534}.status-inactive{background:#fee2e2;color:#991b1b}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:400;padding:var(--spacing-4)}.modal{background:var(--color-bg-paper);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);width:100%;max-width:500px;max-height:90vh;display:flex;flex-direction:column}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-4) var(--spacing-6);border-bottom:1px solid var(--color-border-light);flex-shrink:0}.modal-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-body{padding:var(--spacing-6);overflow-y:auto;flex:1;min-height:0}.modal-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border-light);display:flex;gap:var(--spacing-3);justify-content:flex-end;align-items:center;flex-wrap:wrap;flex-shrink:0}.modal-footer-left{display:flex;gap:var(--spacing-2);margin-right:auto}.custom-select-dropdown-portal,.user-select-dropdown-portal{background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);max-height:280px;overflow-y:auto}.form-group{margin-bottom:var(--spacing-4)}.form-group label{display:block;margin-bottom:var(--spacing-1);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.form-group input,.form-group select,.form-group textarea{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-paper);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--color-text-hint)}.form-group .help-text{margin-top:var(--spacing-1);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.form-check{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) 0}.form-check input[type=checkbox],.form-check input[type=radio]{width:auto;margin:0}.form-check label{margin:0;font-weight:var(--font-weight-normal)}.permission-group{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-4);margin-bottom:var(--spacing-4)}.permission-group h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-3)}.permission-checkboxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-2)}.permission-view-toggle{display:flex;gap:var(--spacing-2)}.permission-group.effective-view{background:var(--color-bg-default)}.permission-items{display:flex;flex-direction:column;gap:var(--spacing-2)}.permission-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--color-bg-paper)}.permission-item.granted{background:#22c55e1a;border:1px solid rgba(34,197,94,.2)}.permission-item.denied{background:#ef44440d;border:1px solid rgba(239,68,68,.1)}.permission-status{display:flex;align-items:center;gap:var(--spacing-2)}.permission-indicator{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;font-size:12px;font-weight:700}.permission-indicator.granted{background:var(--color-success-main);color:#fff}.permission-indicator.denied{background:var(--color-error-light);color:var(--color-error-main)}.permission-label{font-size:var(--font-size-sm);color:var(--color-text-primary)}.permission-sources{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.source-tag{display:inline-block;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:var(--font-weight-medium);color:#fff}.source-tag.source-direct{background:var(--color-primary-500)}.permissions-card{padding:var(--spacing-4)}.app-permissions-list{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.app-permission-item{border-bottom:1px solid var(--color-border)}.app-permission-item:last-child{border-bottom:none}.app-permission-header{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.app-permission-header:hover{background:var(--color-bg-secondary)}.app-permission-item.expanded .app-permission-header{background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border)}.app-icon{width:40px;height:40px;border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.app-info{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.app-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-base)}.app-access-summary{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.app-expand-icon{color:var(--color-text-secondary);flex-shrink:0}.app-permission-content{padding:var(--spacing-4);background:var(--color-bg-subtle)}.app-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.permission-details{display:flex;flex-direction:column;gap:var(--spacing-2)}.permission-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--color-bg-paper)}.permission-row.granted{background:#22c55e14}.permission-row.denied{background:#ef44440a}.permission-toggles{display:flex;flex-direction:column;gap:var(--spacing-1)}.permission-toggle-row{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3);background:var(--color-bg-paper);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.toggle-info{display:flex;flex-direction:column;gap:2px}.toggle-label{font-weight:var(--font-weight-medium);font-size:var(--font-size-sm);color:var(--color-text-primary)}.toggle-desc{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;border-radius:28px;transition:.2s}.toggle-slider:before{position:absolute;content:"";height:22px;width:22px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:.2s;box-shadow:0 2px 4px #0003}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:focus+.toggle-slider{box-shadow:0 0 0 2px #2563eb33}@media (max-width: 640px){.app-permission-header{padding:var(--spacing-3)}.app-icon{width:36px;height:36px;font-size:18px}.permission-toggle-row{padding:var(--spacing-2)}.toggle-switch{width:46px;height:24px}.toggle-slider:before{height:18px;width:18px}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}}.actions{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.empty-state{text-align:center;padding:var(--spacing-12) var(--spacing-6);color:var(--color-text-secondary)}.empty-state p{margin-bottom:var(--spacing-4)}.empty-state-actions{display:flex;gap:var(--spacing-4);justify-content:center}.section-description{margin-bottom:var(--spacing-6)}.loading{text-align:center;padding:var(--spacing-12);color:var(--color-text-secondary)}.alert{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);margin-bottom:var(--spacing-4)}.alert-error{background:var(--color-error-light);color:var(--color-error-dark);border:1px solid var(--color-error-main)}.alert-success{background:var(--color-success-light);color:var(--color-success-dark);border:1px solid var(--color-success-main)}nav.sidebar{width:240px;background:var(--color-bg-paper);border-right:1px solid var(--color-border-light);padding:var(--spacing-4)}nav.sidebar a{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);color:var(--color-text-secondary);text-decoration:none;font-weight:var(--font-weight-medium);transition:all var(--transition-fast)}nav.sidebar a:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}nav.sidebar a.active{background:var(--color-primary-50);color:var(--color-primary-500)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary-600) 0%,var(--color-primary-800) 100%);padding:var(--spacing-4)}.login-card{background:var(--color-bg-paper);border-radius:var(--radius-lg);border:1px solid var(--color-border-main, #d1d5db);width:100%;max-width:400px;overflow:hidden}.login-header{background:var(--color-primary-500);color:var(--color-text-inverse);padding:var(--spacing-8) var(--spacing-6);text-align:center}.login-logo{max-width:180px;margin:0 auto var(--spacing-4);border-radius:var(--radius-md)}.login-header h1{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);margin-bottom:var(--spacing-2)}.login-header p{font-size:var(--font-size-sm);opacity:.9}.login-form{padding:var(--spacing-6)}.login-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--color-border-light);text-align:center;background:var(--color-bg-subtle)}.login-footer p{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.link-button{background:none;border:none;color:var(--color-primary-500);cursor:pointer;font-weight:var(--font-weight-medium);text-decoration:underline}.link-button:hover{color:var(--color-primary-600)}.btn-block{width:100%}.btn:disabled{opacity:.6;cursor:not-allowed}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;text-align:center}.loading-screen h1{color:var(--color-primary-500);margin-bottom:var(--spacing-4)}.panel-loading{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:100}.panel-loading-spinner{width:36px;height:36px;border:3px solid var(--color-neutral-200);border-top-color:var(--color-primary-500);border-radius:50%;animation:spin .8s linear infinite}header{display:flex;justify-content:space-between;align-items:center}.home-page{height:100vh;display:flex;flex-direction:column;background:linear-gradient(150deg,#3a7233,#2d5a27 40%,#1a4020);position:relative;overflow:hidden}.home-header{background:transparent;color:var(--color-text-inverse);padding:var(--spacing-3) var(--spacing-6) var(--spacing-2);display:flex;justify-content:space-between;align-items:center;box-shadow:none;flex-shrink:0}.home-header-left{display:flex;align-items:center;gap:12px}.home-header-logo{width:44px;height:44px;object-fit:contain;flex-shrink:0}.home-header-text{display:flex;flex-direction:column;gap:1px}.home-greeting{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:#fff;text-shadow:0 1px 3px rgba(0,0,0,.2);margin:0;letter-spacing:-.01em}.home-date{font-size:var(--font-size-sm);color:#ffffffb3;text-shadow:0 1px 2px rgba(0,0,0,.2)}.home-header-right{display:flex;align-items:center;gap:var(--spacing-4)}.home-signout-btn{background:#ffffff26;border:1px solid rgba(255,255,255,.3);color:#fff;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .15s ease}.home-signout-btn:hover{background:#ffffff40;border-color:#ffffff80}.home-config-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.2);color:#ffffffbf;width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .15s ease}.home-config-btn:hover{background:#fff3;color:#fff}.home-main{flex:1;display:flex;padding:var(--spacing-4) var(--spacing-6);overflow:hidden;min-height:0}.widget-dashboard{width:100%;max-width:1200px;margin:0 auto}.widget-dashboard-loading{flex:1;display:flex;align-items:center;justify-content:center}.widget-loading-spinner{width:32px;height:32px;border:3px solid rgba(255,255,255,.2);border-top-color:#fffc;border-radius:50%;animation:widget-spin .8s linear infinite}@keyframes widget-spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.widget-dashboard{display:flex!important;flex-direction:column!important;gap:12px!important;overflow-y:auto}.widget-card{grid-area:unset!important}}.widget-card{background:#ffffff14;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.15);border-radius:16px;display:flex;flex-direction:column;overflow:hidden;min-height:0}.widget-card-header{display:flex;align-items:center;gap:var(--spacing-2);padding:14px 16px 8px;flex-shrink:0}.widget-card-icon{font-size:16px;line-height:1}.widget-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#ffffffe6;letter-spacing:.01em}.widget-content{flex:1;padding:4px 16px 14px;display:flex;flex-direction:column;min-height:0;overflow-y:auto}.widget-loading{align-items:center;justify-content:center}.widget-loading-text{font-size:var(--font-size-sm);color:#ffffff80}.widget-empty{font-size:var(--font-size-sm);color:#ffffff80;text-align:center;padding:var(--spacing-4) 0}.widget-view-all{background:none;border:none;color:#fff9;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);cursor:pointer;padding:var(--spacing-2) 0 0;margin-top:auto;text-align:center;transition:color .15s}.widget-view-all:hover{color:#ffffffe6}.widget-stats-row{display:flex;gap:12px;margin-bottom:10px}.widget-stat{display:flex;flex-direction:column;align-items:center;gap:2px;padding:6px 12px;background:#ffffff0f;border-radius:8px;min-width:56px}.widget-stat-value{font-size:20px;font-weight:700;color:#fff;line-height:1.1}.widget-stat-label{font-size:10px;font-weight:500;color:#ffffff8c;text-transform:uppercase;letter-spacing:.03em}.widget-stat-warning .widget-stat-value{color:#fbbf24}.widget-stat-info .widget-stat-value{color:#60a5fa}.widget-task-list{display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow-y:auto}.widget-task-item{display:flex;align-items:center;gap:8px;padding:7px 8px;background:none;border:none;border-radius:6px;cursor:pointer;text-align:left;transition:background .12s;width:100%}.widget-task-item:hover{background:#ffffff14}.widget-task-priority{width:6px;height:6px;border-radius:50%;flex-shrink:0}.widget-task-title{flex:1;font-size:var(--font-size-sm);color:#ffffffd9;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.widget-task-due{font-size:11px;font-weight:500;color:#ffffff73;flex-shrink:0}.widget-task-due.overdue{color:#fbbf24}.widget-task-item-compact{padding:4px 6px}.widget-stats-compact{gap:8px;margin-bottom:6px}.widget-stats-compact .widget-stat{padding:4px 8px;min-width:44px}.widget-stats-compact .widget-stat-value{font-size:16px}.weather-current{display:flex;align-items:center;gap:12px;margin-bottom:12px}.weather-icon-large{font-size:36px;line-height:1}.weather-temp-group{display:flex;flex-direction:column;gap:2px}.weather-temp-now{font-size:32px;font-weight:700;color:#fff;line-height:1}.weather-temp-range{font-size:var(--font-size-xs);color:#ffffff80}.weather-details{display:flex;flex-direction:column;gap:2px;margin-left:auto}.weather-detail{font-size:11px;color:#ffffff80;text-align:right}.weather-forecast-strip{display:flex;gap:8px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1)}.weather-forecast-day{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 4px}.weather-forecast-label{font-size:11px;font-weight:600;color:#fff9}.weather-forecast-icon{font-size:20px;line-height:1}.weather-forecast-temps{font-size:11px;color:#ffffffb3}.weather-forecast-rain{font-size:10px;color:#60a5fa}.weather-current-compact{gap:8px;margin-bottom:4px}.weather-current-compact .weather-icon-large{font-size:28px}.weather-current-compact .weather-temp-now{font-size:26px}.weather-hourly-list{display:flex;flex-direction:column;gap:2px;padding-top:8px;border-top:1px solid rgba(255,255,255,.1);flex:1;min-height:0;overflow-y:auto}.weather-hourly-row{display:grid;grid-template-columns:48px 28px 42px 1fr 1fr;align-items:center;gap:8px;padding:6px 8px;border-radius:6px;transition:background .12s}.weather-hourly-row:hover{background:#ffffff0a}.weather-hourly-row.weather-hourly-now{background:#ffffff1a;border-radius:8px}.weather-hourly-time{font-size:11px;font-weight:600;color:#ffffff80}.weather-hourly-now .weather-hourly-time{color:#fffffff2;font-weight:700}.weather-hourly-icon{font-size:16px;line-height:1;text-align:center}.weather-hourly-temp{font-size:13px;font-weight:700;color:#ffffffe6}.weather-hourly-rain-col{display:flex;align-items:center;gap:4px}.weather-hourly-rain-icon{font-size:13px;line-height:1}.weather-hourly-rain-val{font-size:11px;font-weight:600;color:#60a5fa}.weather-hourly-rain-none{font-size:11px;color:#ffffff26}.weather-hourly-wind-col{display:flex;align-items:center;gap:4px;justify-content:flex-end}.weather-hourly-wind-icon{font-size:12px;line-height:1}.weather-hourly-wind-val{font-size:10px;color:#fff6}.weather-forecast-day.weather-forecast-today{background:#ffffff0f;border-radius:8px}.weather-forecast-today .weather-forecast-label{color:#ffffffe6}.week-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.week-number{font-size:var(--font-size-sm);font-weight:600;color:#fffc}.week-plan-status{font-size:10px;font-weight:600;padding:2px 8px;border-radius:999px;text-transform:uppercase;letter-spacing:.04em}.week-plan-status.status-draft{background:#ffffff1a;color:#fff9}.week-plan-status.status-active{background:#22c55e33;color:#4ade80}.week-plan-status.status-completed{background:#60a5fa33;color:#93bbfd}.week-day-strip{display:flex;gap:4px;margin-bottom:12px}.week-day{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px 2px;border-radius:8px;transition:background .12s}.week-day.today{background:#ffffff1f}.week-day-label{font-size:10px;font-weight:600;color:#ffffff80;text-transform:uppercase}.week-day.today .week-day-label{color:#fff}.week-day-blocks{font-size:14px;font-weight:700;color:#ffffff4d;line-height:1.2}.week-day-blocks.has-blocks{color:#fffc}.week-day.today .week-day-blocks.has-blocks{color:#fff}.week-summary{display:flex;flex-wrap:wrap;gap:8px}.week-summary-item{font-size:var(--font-size-xs);color:#fff9}.week-summary-item.muted{color:#ffffff59}.week-compact-today{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}.week-compact-label{font-size:10px;font-weight:600;color:#ffffff80;text-transform:uppercase}.week-compact-value{font-size:var(--font-size-sm);font-weight:600;color:#fffc}.irr-progress-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:10px}.irr-progress-bar{flex:1;height:6px;border-radius:3px;background:#ffffff1a;overflow:hidden}.irr-progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,#4ade80,#22c55e);transition:width .3s ease}.irr-progress-text{font-size:11px;font-weight:700;color:#ffffffb3;white-space:nowrap}.irr-checklist{display:flex;flex-direction:column;gap:2px;flex:1;min-height:0;overflow-y:auto;margin-bottom:8px}.irr-block-row{display:flex;align-items:center;gap:8px;padding:5px 6px;border-radius:6px;font-size:12px;transition:background .15s}.irr-block-row.irr-status-completed{opacity:.65}.irr-block-row.irr-status-running{background:#3b82f61f}.irr-block-check{width:18px;height:18px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.irr-check-done{width:18px;height:18px;border-radius:50%;background:#22c55e;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}.irr-check-running{color:#3b82f6;font-size:10px;animation:irr-pulse 1.5s ease-in-out infinite}@keyframes irr-pulse{0%,to{opacity:1}50%{opacity:.4}}.irr-check-skipped{color:#ffffff4d;font-size:14px;font-weight:700}.irr-check-pending{width:16px;height:16px;border-radius:50%;border:2px solid rgba(255,255,255,.2)}.irr-block-name{flex:1;color:#ffffffd9;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.irr-status-completed .irr-block-name{text-decoration:line-through;text-decoration-color:#ffffff4d}.irr-block-meta{font-size:10px;color:#fff6;white-space:nowrap;flex-shrink:0}.irr-block-row.irr-more{font-size:11px;color:#fff6;padding-left:32px}.irr-summary{display:flex;gap:12px;font-size:11px;color:#ffffff80;margin-bottom:6px}.irr-summary-skipped{color:#ffc83299}.irr-progress-ring-row{display:flex;align-items:center;gap:12px;margin-bottom:8px}.irr-progress-circle{width:48px;height:48px;border-radius:50%;background:conic-gradient(#22c55e calc(var(--progress) * 1%),#ffffff1a calc(var(--progress) * 1%));display:flex;align-items:center;justify-content:center;flex-shrink:0;position:relative}.irr-progress-circle:before{content:"";position:absolute;top:5px;right:5px;bottom:5px;left:5px;border-radius:50%;background:#225022f2}.irr-progress-value{position:relative;z-index:1;font-size:11px;font-weight:700;color:#ffffffd9}.irr-progress-labels{display:flex;flex-direction:column;gap:2px}.irr-progress-title{font-size:12px;font-weight:600;color:#ffffffb3}.irr-status-running{font-size:11px;color:#3b82f6}.csw-compact-stats{display:flex;flex-direction:column;gap:6px;margin-bottom:8px}.csw-compact-row{display:flex;align-items:center;gap:6px}.csw-compact-label{font-size:10px;font-weight:600;color:#ffffff80;text-transform:uppercase;width:36px;flex-shrink:0}.csw-compact-value{font-size:var(--font-size-sm);font-weight:600;color:#ffffffd9;flex:1}.csw-section{display:flex;flex-direction:column;gap:4px}.csw-section-header{display:flex;align-items:center;gap:6px}.csw-section-icon{font-size:14px;line-height:1}.csw-section-title{font-size:11px;font-weight:600;color:#ffffff80;text-transform:uppercase;letter-spacing:.03em}.csw-metric-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px}.csw-metric{display:flex;align-items:baseline;gap:5px}.csw-metric-value{font-size:22px;font-weight:700;color:#fffffff2;line-height:1.1}.csw-metric-unit,.csw-detail{font-size:11px;color:#ffffff73}.csw-trend{font-size:12px;font-weight:700;white-space:nowrap}.csw-trend-up{color:#f59e0b}.csw-trend-down{color:#4ade80}.csw-trend-flat{color:#ffffff59}.csw-divider{height:1px;background:#ffffff14;margin:6px 0}.csw-compare-grid{display:grid;grid-template-columns:auto 1fr 1fr 1fr 1fr;gap:2px 8px;align-items:baseline;margin-bottom:6px}.csw-compare-header{font-size:10px;font-weight:600;color:#fff6;text-transform:uppercase;text-align:center;padding-bottom:4px}.csw-compare-label{font-size:12px;font-weight:600;color:#ffffffb3;white-space:nowrap;padding-right:4px}.csw-compare-cell{text-align:center;padding:3px 2px}.csw-compare-cell.csw-compare-primary{background:#ffffff0a;border-radius:6px}.csw-compare-value{font-size:14px;font-weight:700;color:#ffffffd9}.csw-compare-unit{font-size:10px;color:#ffffff59;margin-left:2px}.csw-avg-row{display:flex;gap:16px;padding-top:4px;border-top:1px solid rgba(255,255,255,.06);margin-bottom:4px}.csw-avg-item{font-size:11px;color:#fff6}.widget-card-empty{display:flex;align-items:center;justify-content:center;border-style:dashed;border-color:#ffffff1f}.dashboard-dock{flex-shrink:0;padding:var(--spacing-2) var(--spacing-6) var(--spacing-3)}.dock-apps{display:flex;align-items:center;justify-content:center;gap:6px;background:#ffffff1a;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:8px 16px;max-width:600px;margin:0 auto}.dock-app{display:flex;flex-direction:column;align-items:center;gap:3px;background:none;border:none;cursor:pointer;padding:4px 8px;border-radius:10px;transition:background .12s;min-width:52px}.dock-app:hover{background:#ffffff1a}.dock-app-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;line-height:1;text-shadow:0 1px 3px rgba(0,0,0,.3)}.dock-app-name{font-size:9px;font-weight:600;color:#ffffffb3;white-space:nowrap;max-width:56px;overflow:hidden;text-overflow:ellipsis}.dock-all-apps-icon{background:#ffffff26!important;color:#fffc}.all-apps-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.all-apps-modal{background:#1e3c19f2;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.15);border-radius:20px;padding:24px;width:90%;max-width:640px;max-height:80vh;overflow-y:auto;animation:modal-slide-up .2s ease}@keyframes modal-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.all-apps-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.all-apps-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:#fff;margin:0}.all-apps-close{background:#ffffff1a;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#ffffffb3;cursor:pointer;transition:background .12s}.all-apps-close:hover{background:#fff3}.all-apps-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}@media (max-width: 480px){.all-apps-grid{grid-template-columns:repeat(3,1fr)}}.all-apps-tile{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:12px 4px;background:transparent;border:none;border-radius:12px;color:#fff;cursor:pointer;transition:background .12s;text-align:center}.all-apps-tile:hover{background:#ffffff1a}.all-apps-tile-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:24px;line-height:1;text-shadow:0 2px 6px rgba(0,0,0,.3)}.all-apps-tile-name{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#ffffffd9}.config-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:100;display:flex;align-items:center;justify-content:center;animation:fade-in .15s ease}.config-modal{background:#1c3a18;border:1px solid rgba(255,255,255,.15);border-radius:16px;width:90%;max-width:580px;max-height:85vh;display:flex;flex-direction:column;animation:modal-slide-up .2s ease;overflow:hidden}.config-header{display:flex;justify-content:space-between;align-items:center;padding:18px 20px 12px;flex-shrink:0}.config-header h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:#fff;margin:0}.config-close{background:#ffffff1a;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;color:#ffffffb3;cursor:pointer;transition:background .12s}.config-close:hover{background:#fff3}.config-tabs{display:flex;gap:0;padding:0 20px;border-bottom:1px solid rgba(255,255,255,.1);flex-shrink:0}.config-tab{background:none;border:none;border-bottom:2px solid transparent;color:#ffffff80;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);padding:10px 16px;cursor:pointer;transition:all .15s}.config-tab:hover{color:#ffffffbf}.config-tab.active{color:#fff;border-bottom-color:#fff}.config-body{flex:1;overflow-y:auto;padding:16px 20px}.config-section{margin-bottom:20px}.config-section-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#fffc;margin:0 0 10px}.config-section-hint{font-size:var(--font-size-xs);color:#fff6;margin:-6px 0 12px}.config-subsection-title{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#fff9;margin:16px 0 8px;text-transform:uppercase;letter-spacing:.04em}.config-layout-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}@media (max-width: 480px){.config-layout-grid{grid-template-columns:repeat(2,1fr)}}.config-layout-card{display:flex;flex-direction:column;align-items:center;gap:6px;padding:10px 6px 8px;background:#ffffff0d;border:2px solid rgba(255,255,255,.08);border-radius:10px;cursor:pointer;transition:all .15s}.config-layout-card:hover{background:#ffffff1a;border-color:#ffffff26}.config-layout-card.selected{border-color:#fff9;background:#ffffff1f}.config-layout-preview{width:72px;height:48px;border-radius:4px;overflow:hidden}.config-layout-preview-cell{border-radius:3px}.config-layout-name{font-size:11px;font-weight:600;color:#fffc}.config-layout-desc{font-size:10px;color:#fff6}.config-widget-slots{display:flex;flex-direction:column;gap:10px}.config-widget-slot{display:flex;align-items:center;gap:12px}.config-slot-label{flex:0 0 120px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#ffffffb3;display:flex;align-items:center;gap:6px}.config-slot-size{font-size:10px;font-weight:500;padding:1px 6px;border-radius:999px;background:#ffffff14;color:#fff6;text-transform:uppercase}.config-slot-select{flex:1;padding:8px 10px;background:#ffffff14;border:1px solid rgba(255,255,255,.12);border-radius:8px;color:#fff;font-size:var(--font-size-sm);cursor:pointer;outline:none;transition:border-color .15s}.config-slot-select:hover,.config-slot-select:focus{border-color:#ffffff4d}.config-slot-select option{background:#1c3a18;color:#fff}.config-dock-list{display:flex;flex-direction:column;gap:4px}.config-dock-item{display:flex;align-items:center;gap:10px;padding:8px 10px;background:#ffffff0d;border-radius:8px}.config-dock-icon{width:28px;height:28px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;flex-shrink:0}.config-dock-name{flex:1;font-size:var(--font-size-sm);color:#fffc}.config-dock-actions{display:flex;align-items:center;gap:4px}.config-dock-move{background:#ffffff14;border:none;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#ffffff80;cursor:pointer;font-size:12px;transition:background .12s}.config-dock-move:hover:not(:disabled){background:#ffffff26;color:#fff}.config-dock-move:disabled{opacity:.3;cursor:default}.config-dock-remove{background:#ef444426;border:none;border-radius:4px;width:24px;height:24px;display:flex;align-items:center;justify-content:center;color:#ef4444;cursor:pointer;transition:background .12s}.config-dock-remove:hover{background:#ef44444d}.config-dock-empty{font-size:var(--font-size-sm);color:#ffffff59;text-align:center;padding:16px 0}.config-dock-available{display:grid;grid-template-columns:repeat(2,1fr);gap:4px}.config-dock-add-btn{display:flex;align-items:center;gap:8px;padding:6px 10px;background:#ffffff0a;border:1px dashed rgba(255,255,255,.12);border-radius:8px;cursor:pointer;font-size:var(--font-size-xs);color:#fff9;transition:all .12s}.config-dock-add-btn:hover{background:#ffffff1a;border-color:#ffffff40;color:#fff}.config-dock-add-icon{width:22px;height:22px;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;flex-shrink:0}.config-footer{display:flex;justify-content:flex-end;gap:8px;padding:12px 20px 16px;border-top:1px solid rgba(255,255,255,.1);flex-shrink:0}.config-cancel-btn{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#ffffffb3;padding:8px 18px;border-radius:8px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all .12s}.config-cancel-btn:hover{background:#ffffff1f;color:#fff}.config-save-btn{background:#fff3;border:1px solid rgba(255,255,255,.3);color:#fff;padding:8px 24px;border-radius:8px;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all .12s}.config-save-btn:hover{background:#ffffff4d}.config-save-btn:disabled{opacity:.5;cursor:default}.page-container{min-height:100vh;display:flex;flex-direction:column}.page-header{background:var(--color-bg-paper);border-bottom:1px solid var(--color-border-light);padding:var(--spacing-4) var(--spacing-6);display:flex;justify-content:space-between;align-items:center}.page-header h1{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.page-main{flex:1;max-width:1200px;width:100%;margin:0 auto;padding:var(--spacing-6)}.coming-soon{text-align:center;padding:var(--spacing-12) var(--spacing-6)}.coming-soon-icon{font-size:4rem;display:block;margin-bottom:var(--spacing-4)}.coming-soon h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.coming-soon p{color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.coming-soon-status{display:inline-block;margin-top:var(--spacing-4);padding:var(--spacing-2) var(--spacing-4);background:var(--color-warning-light);color:var(--color-warning-dark);border-radius:4px;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.settings-layout{display:flex;flex-direction:column;gap:var(--spacing-6)}@media (min-width: 768px){.settings-layout{flex-direction:row}}.settings-tabs{display:flex;gap:var(--spacing-2);flex-wrap:wrap}@media (min-width: 768px){.settings-tabs{flex-direction:column;min-width:200px;gap:var(--spacing-1)}}.settings-tab{padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.settings-tab:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.settings-tab.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-600)}.settings-content{flex:1}.settings-content .card{margin-bottom:0}.settings-content .card h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.form-actions{margin-top:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.input-disabled{background:var(--color-bg-subtle);color:var(--color-text-secondary);cursor:not-allowed}.stats-row{display:grid;grid-template-columns:repeat(3,1fr);border:1px solid var(--color-border-main, #d1d5db);border-radius:6px;overflow:hidden;margin-bottom:var(--spacing-6)}.stats-row.stats-row-2{grid-template-columns:repeat(2,1fr)}.stat-card{padding:14px 16px;text-align:center;border-right:1px solid var(--color-border-main, #d1d5db);background:var(--color-bg-paper)}.stat-card:last-child{border-right:none}.stat-value{display:block;font-size:22px;font-weight:var(--font-weight-bold);color:var(--color-primary-500);line-height:1.2}.stat-label{font-size:11px;color:var(--color-text-secondary);margin-top:1px}.user-list{border:1px solid var(--color-border-main, #d1d5db);border-radius:6px;overflow:hidden}.user-list-item{display:flex;align-items:center;gap:var(--spacing-4);padding:10px 16px;border-bottom:1px solid var(--color-border-main, #d1d5db);cursor:pointer;transition:background .12s}.user-list-item:last-child{border-bottom:none}.user-list-item:hover{background:#f3f4f6}.user-avatar{width:36px;height:36px;border-radius:var(--radius-full);background:var(--color-primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);flex-shrink:0;overflow:hidden}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-info{flex:1;min-width:0}.user-name{display:block;font-size:13px;font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.user-email{display:block;font-size:12px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role,.user-status{flex-shrink:0}.user-arrow{color:var(--color-text-hint, #9ca3af);display:flex;align-items:center}.user-detail-layout{display:grid;gap:var(--spacing-6)}@media (min-width: 768px){.user-detail-layout{grid-template-columns:280px 1fr}}.user-sidebar{background:var(--color-bg-paper);border:1px solid var(--color-border-main, #d1d5db);border-radius:6px;padding:var(--spacing-6);text-align:center;height:fit-content}.user-avatar-large{width:96px;height:96px;margin:0 auto;border-radius:var(--radius-full);overflow:hidden;position:relative}.user-avatar-editable{cursor:pointer}.user-avatar-editable:hover .avatar-upload-overlay{opacity:1}.avatar-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .2s;color:#fff;border-radius:var(--radius-full)}.user-avatar-large img{width:100%;height:100%;object-fit:cover}.avatar-placeholder{width:100%;height:100%;background:var(--color-primary-500);color:#fff;display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:var(--font-weight-bold)}.loading-spinner-sm{width:20px;height:20px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}.user-sidebar h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-1)}.user-sidebar .user-email{margin-bottom:var(--spacing-3)}.user-sidebar .user-role{margin-bottom:var(--spacing-4)}.user-groups-preview{border-top:1px solid var(--color-border-light);padding-top:var(--spacing-4);text-align:left}.user-groups-preview h4{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.group-tags{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.group-tag{display:inline-block;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:#fff}.user-detail-content{min-width:0}.detail-tabs{display:flex;gap:var(--spacing-1);margin-bottom:var(--spacing-4);border-bottom:1px solid var(--color-border-light);padding-bottom:var(--spacing-3)}.detail-tab{padding:var(--spacing-2) var(--spacing-4);background:none;border:none;font-family:inherit;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;border-radius:var(--radius-md);transition:all var(--transition-fast)}.detail-tab:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.detail-tab.active{background:var(--color-primary-500);color:#fff}.tab-content .card{margin-bottom:0}.tab-content .card h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.profile-info{display:grid;grid-template-columns:1fr 2fr;gap:var(--spacing-3)}.profile-info dt{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.profile-info dd{color:var(--color-text-primary)}.header-actions{display:flex;align-items:center;gap:var(--spacing-3)}.group-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.group-item{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.group-item:hover{background:var(--color-primary-50)}.group-item.is-member{background:var(--color-primary-50);border:1px solid var(--color-primary-200)}.group-color{width:12px;height:12px;border-radius:var(--radius-full);flex-shrink:0}.group-info{flex:1}.group-name{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.group-description{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.group-toggle{flex-shrink:0}.group-toggle input[type=checkbox]{width:18px;height:18px}.groups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.group-card{background:var(--color-bg-paper);border:1px solid var(--color-border-main, #d1d5db);border-radius:6px;overflow:hidden;transition:background .12s}.group-card:hover{background:var(--color-bg-subtle, #f9fafb)}.group-card.inactive{opacity:.7}.group-card-header{padding:var(--spacing-4);color:#fff;position:relative;display:flex;align-items:center;justify-content:space-between}.group-card-edit-btn{background:#fff3;border:none;color:#fff;width:32px;height:32px;border-radius:var(--radius-md);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast);flex-shrink:0}.group-card-edit-btn:hover{background:#ffffff59}.group-card-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.group-inactive-badge{position:absolute;top:var(--spacing-2);right:var(--spacing-2);padding:var(--spacing-1) var(--spacing-2);background:#0000004d;border-radius:var(--radius-sm);font-size:var(--font-size-xs)}.group-card-body{padding:var(--spacing-4)}.group-card-description{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4);min-height:40px}.group-card-actions{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.group-card-member-info{display:flex;gap:.75rem;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.color-picker{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.color-option{width:36px;height:36px;border-radius:var(--radius-md);border:3px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-option:hover{border-color:var(--color-border-main, #d1d5db)}.color-option.selected{border-color:var(--color-text-primary)}.group-preview{padding:var(--spacing-3) var(--spacing-4);border-radius:var(--radius-md);color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg);text-align:center}.form-group textarea{resize:vertical;min-height:80px}.groups-preview-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.group-preview-item{display:flex;flex-direction:column;padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);border-left:4px solid}.group-preview-item .group-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.group-preview-item .group-description{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.group-detail-layout{display:grid;gap:var(--spacing-6)}@media (min-width: 768px){.group-detail-layout{grid-template-columns:280px 1fr}}.group-sidebar{background:var(--color-bg-paper);border:1px solid var(--color-border-main, #d1d5db);border-radius:6px;padding:var(--spacing-6);text-align:center;height:fit-content}.group-avatar-large{width:96px;height:96px;margin:0 auto var(--spacing-4);border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:2.5rem;font-weight:var(--font-weight-bold);color:#fff}.group-sidebar h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin-bottom:var(--spacing-2)}.group-description-sidebar{color:var(--color-text-secondary);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.group-stats{display:flex;justify-content:center;gap:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.group-stat{text-align:center}.group-stat-value{display:block;font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-primary-500)}.group-stat-label{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.group-detail-content{min-width:0}@media (max-width: 768px){main{padding:var(--spacing-4)}.section-header{flex-direction:column;align-items:flex-start;gap:var(--spacing-3)}.data-table{display:block;overflow-x:auto}.actions{flex-direction:column}.page-header{padding:var(--spacing-3) var(--spacing-4)}.page-header h1{font-size:var(--font-size-base)}.page-main{padding:var(--spacing-4)}}.app-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:100;padding:var(--spacing-6);animation:overlayIn .3s ease-out forwards}.app-panel-overlay.app-panel-closing{animation:overlayOut .25s ease-in forwards}@keyframes overlayIn{0%{opacity:0;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}to{opacity:1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}}@keyframes overlayOut{0%{opacity:1;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}to{opacity:0;backdrop-filter:blur(0);-webkit-backdrop-filter:blur(0)}}.app-panel{position:relative;background:var(--color-bg-paper);border:1px solid var(--color-border-main, #d1d5db);border-radius:var(--radius-xl);width:100%;max-width:1400px;height:100%;max-height:calc(100vh - var(--spacing-12));display:flex;flex-direction:column;overflow:hidden;animation:slideUp .25s ease-out}.app-panel-closing .app-panel{animation:slideDown .25s ease-in forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(12px)}}.app-panel-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-6);border-bottom:1px solid rgba(255,255,255,.08);background:#1e293b;flex-shrink:0}.app-panel-title-section{display:flex;align-items:baseline;gap:var(--spacing-3)}.app-panel-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-inverse);margin:0}.app-panel-subtitle{font-size:var(--font-size-sm);color:#94a3b8}.app-panel-header-actions{display:flex;align-items:center;gap:var(--spacing-1)}.app-panel-fullscreen-btn{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border:none;background:transparent;border-radius:var(--radius-md);color:#94a3b8;cursor:pointer;transition:all var(--transition-fast)}.app-panel-fullscreen-btn:hover{background:#ffffff1a;color:var(--color-text-inverse)}.app-panel-close{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:none;background:transparent;border-radius:var(--radius-md);color:#94a3b8;cursor:pointer;transition:all var(--transition-fast)}.app-panel-close:hover{background:#ffffff26;color:var(--color-text-inverse)}.app-panel-overlay.app-panel-fullscreen{padding:0;background:none}.app-panel-fullscreen .app-panel{max-width:100%;max-height:100vh;height:100vh;border-radius:0;animation:none}.app-panel-toolbar{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);padding-bottom:0;background:#1e293b;flex-shrink:0;box-shadow:0 2px 0 0 var(--color-primary-500)}.app-panel-content{flex:1;overflow-y:scroll;padding:var(--spacing-6);padding-right:0;animation:contentFadeIn .15s ease-out;border-top:none;background:#fff;max-width:none;margin:0}.app-panel-content>*{padding-right:var(--spacing-6)}.app-panel-content::-webkit-scrollbar{width:12px}.app-panel-content::-webkit-scrollbar-track{background:#eaeaea;border-radius:0}.app-panel-content::-webkit-scrollbar-thumb{background:#bbb;border-radius:6px;border:2px solid #eaeaea}.app-panel-content::-webkit-scrollbar-thumb:hover{background:#999}@keyframes contentFadeIn{0%{opacity:0}to{opacity:1}}.app-panel-content .card{margin-bottom:var(--spacing-4)}.app-panel-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-6);height:100%}.app-panel-sidebar{border-right:1px solid var(--color-border-light);padding-right:var(--spacing-6);overflow-y:auto}.app-panel-main{overflow-y:auto}.toolbar-with-action{display:flex;align-items:flex-end;justify-content:space-between;width:100%;gap:var(--spacing-4)}.toolbar-with-action .panel-tabs{padding:0}.toolbar-action-btn{display:inline-flex;align-items:center;gap:var(--spacing-2);background:#fff3!important;border-color:#ffffff4d!important;color:#fff!important;white-space:nowrap;flex-shrink:0}.toolbar-action-btn:hover{background:#ffffff4d!important}.toolbar-actions{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.toolbar-settings-btn{padding:var(--spacing-1) var(--spacing-2);color:#fffc;border:none;background:transparent;cursor:pointer;border-radius:var(--radius-sm);transition:background .15s}.toolbar-settings-btn:hover{background:#fff3;color:#fff}.slideover-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#0003;z-index:10;animation:fade-in .15s ease;border-radius:inherit}.task-slideover{position:absolute;top:0;right:0;width:480px;max-width:65%;height:100%;background:#fff;border-left:1px solid var(--color-border);box-shadow:-6px 0 20px #0000001f;z-index:11;display:flex;flex-direction:column;animation:slideInRight .2s ease;border-radius:0 var(--radius-xl) var(--radius-xl) 0}@keyframes slideInRight{0%{transform:translate(100%)}to{transform:translate(0)}}.slideover-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid var(--color-border);background:#f8fafc;flex-shrink:0;min-height:48px}.slideover-header-left{display:flex;align-items:center;gap:8px}.slideover-open-full-btn{display:inline-flex;align-items:center;gap:4px;font-size:.6875rem;color:#64748b;padding:3px 8px;border-radius:4px}.slideover-open-full-btn:hover{color:#3b82f6;background:#f0f7ff}.slideover-header-right{display:flex;align-items:center;gap:4px}.slideover-body{flex:1;overflow-y:auto;padding:16px 20px;background:#fff}.slideover-title{font-size:1.125rem;font-weight:600;margin:0 0 8px;line-height:1.3;color:#0f172a}.slideover-description{font-size:.8125rem;color:#64748b;margin:0 0 16px;line-height:1.5}.slideover-meta-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px 16px;margin-bottom:16px;padding:12px;background:#f1f5f9;border-radius:8px;border:1px solid #e2e8f0}.slideover-meta-item{display:flex;flex-direction:column;gap:2px}.slideover-meta-label{font-size:.675rem;text-transform:uppercase;letter-spacing:.05em;color:#64748b;font-weight:600}.slideover-meta-value{font-size:.8125rem;color:#1e293b;display:flex;align-items:center;gap:4px}.slideover-meta-value.overdue{color:#dc2626}.slideover-quick-stats{font-size:.75rem;color:#64748b;margin-bottom:12px;padding:6px 10px;background:#f8fafc;border-radius:6px;border:1px solid #e2e8f0}.slideover-image-strip{display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;padding-bottom:2px}.slideover-image-thumb{flex-shrink:0;width:72px;height:72px;border-radius:8px;overflow:hidden;border:1px solid #e2e8f0;transition:border-color .15s}.slideover-image-thumb:hover{border-color:#3b82f6}.slideover-image-thumb img{width:100%;height:100%;object-fit:cover}.slideover-image-more{flex-shrink:0;width:72px;height:72px;border-radius:8px;border:1px dashed #cbd5e1;background:#f1f5f9;color:#64748b;font-size:.8125rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center}.slideover-image-more:hover{background:#e2e8f0;color:#475569}.slideover-activity-feed{display:flex;flex-direction:column;gap:2px}.slideover-activity-item{display:flex;gap:8px;padding:6px 8px;border-radius:6px}.slideover-activity-item:hover{background:#f8fafc}.slideover-activity-item.is-comment{background:#f8fafc;border:1px solid #e2e8f0}.slideover-activity-body{flex:1;min-width:0}.slideover-activity-header{display:flex;align-items:baseline;gap:4px;flex-wrap:wrap}.slideover-activity-author{font-size:.75rem;font-weight:600;color:#1e293b}.slideover-activity-action{font-size:.75rem;color:#64748b}.slideover-activity-time{font-size:.625rem;color:#94a3b8;margin-left:auto;flex-shrink:0}.slideover-activity-comment{font-size:.8125rem;color:#475569;margin:2px 0 0;line-height:1.4;word-break:break-word}.slideover-activity-detail{font-size:.75rem;color:#94a3b8;margin:1px 0 0;font-style:italic}.slideover-actions{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}.slideover-blocked-hint{font-size:.75rem;color:#94a3b8;font-style:italic}.slideover-section{margin-bottom:16px}.slideover-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.slideover-section-title{font-size:.75rem;font-weight:600;color:#475569;text-transform:uppercase;letter-spacing:.05em}.slideover-section-count{font-size:.75rem;color:#94a3b8;font-weight:500}.slideover-checklist-progress{height:4px;background:#e2e8f0;border-radius:2px;margin-bottom:8px;overflow:hidden}.slideover-checklist-bar{height:100%;background:#22c55e;border-radius:2px;transition:width .3s ease}.slideover-checklist{display:flex;flex-direction:column;gap:2px}.slideover-checklist-item{display:flex;align-items:center;justify-content:space-between;padding:4px 8px;border-radius:4px;font-size:.8125rem}.slideover-checklist-item:hover{background:#f1f5f9}.slideover-checklist-label{display:flex;align-items:center;gap:8px;cursor:pointer;flex:1}.slideover-checklist-label input[type=checkbox]{accent-color:#22c55e}.slideover-checklist-text{flex:1;font-size:.8125rem}.slideover-checklist-text.completed,.slideover-checklist-label span.completed{text-decoration:line-through;color:#94a3b8}.slideover-comments{display:flex;flex-direction:column;gap:8px}.slideover-comment{display:flex;gap:8px;padding:8px;border-radius:6px;background:#f8fafc}.slideover-comment-body{flex:1;min-width:0}.slideover-comment-header{display:flex;align-items:baseline;gap:8px}.slideover-comment-author{font-size:.75rem;font-weight:600;color:#1e293b}.slideover-comment-time{font-size:.625rem;color:#94a3b8}.slideover-comment-text{font-size:.8125rem;color:#475569;margin:2px 0 0;line-height:1.4;word-break:break-word}.slideover-comment-input{display:flex;gap:8px;margin-top:8px}.slideover-comment-input .form-input{flex:1;font-size:.8125rem;padding:8px 12px}.slideover-comment-textarea{flex:1;font-size:.8125rem;padding:8px 12px;border:1px solid #d1d5db;border-radius:6px;font-family:inherit;resize:vertical;min-height:48px;max-height:200px;line-height:1.4;overflow:hidden}.slideover-comment-textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.slideover-empty-hint{font-size:.8125rem;color:#94a3b8;margin:0 0 8px}.slideover-footer-link{padding-top:12px;border-top:1px solid #e2e8f0;text-align:center}.slideover-footer-link .btn-link{display:inline-flex;align-items:center;gap:4px;font-size:.8125rem}.task-status-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.04em}.task-status-badge.status-pending{background:#e5e7eb;color:#374151}.task-status-badge.status-in_progress{background:#dbeafe;color:#1d4ed8}.task-status-badge.status-pending_review{background:#ede9fe;color:#6d28d9}.task-status-badge.status-completed{background:#dcfce7;color:#15803d}.task-status-badge.status-rejected{background:#fee2e2;color:#b91c1c}.task-status-badge.status-cancelled{background:#f3f4f6;color:#6b7280}.slideover-work-header{background:#eff6ff;border-bottom:2px solid #93c5fd}.slideover-work-title{font-size:.875rem;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.slideover-timer-section{padding:12px 16px;background:#f8fafc;border-bottom:1px solid var(--color-border);flex-shrink:0}.slideover-timer-display{display:flex;align-items:center;justify-content:space-between;gap:12px}.slideover-timer-value{font-size:1.5rem;font-weight:700;font-variant-numeric:tabular-nums;color:#1e293b}.slideover-timer-value.timer-running{color:#1d4ed8}.slideover-timer-meta{display:flex;align-items:center;gap:12px;margin-top:8px;font-size:.75rem;color:#64748b}.slideover-timer-progress{flex:1;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.slideover-timer-progress-bar{height:100%;background:#3b82f6;border-radius:2px;transition:width .3s ease}.slideover-work-tabs{display:flex;border-bottom:1px solid var(--color-border);background:#fff;flex-shrink:0}.slideover-work-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 8px;font-size:.8125rem;font-weight:500;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:color .15s,border-color .15s}.slideover-work-tab:hover{color:#1e293b}.slideover-work-tab.active{color:#1d4ed8;border-bottom-color:#1d4ed8;font-weight:600}.slideover-work-tab-badge{font-size:.6875rem;font-weight:600;background:#e2e8f0;color:#475569;padding:1px 6px;border-radius:10px;line-height:1.4}.slideover-work-tab.active .slideover-work-tab-badge{background:#dbeafe;color:#1d4ed8}.slideover-work-content{flex:1;overflow-y:auto;padding:16px 20px;background:#fff}.slideover-work-checklist,.slideover-work-comments,.slideover-work-files{display:flex;flex-direction:column;gap:12px}.slideover-add-checklist{display:flex;gap:8px;margin-top:4px}.slideover-add-checklist .form-input{flex:1;font-size:.8125rem;padding:8px 12px}.slideover-file-list{display:flex;flex-direction:column;gap:4px}.slideover-file-item{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:6px;background:#f8fafc;border:1px solid #e2e8f0}.slideover-file-item:hover{background:#f1f5f9}.slideover-file-icon{color:#64748b;flex-shrink:0}.slideover-file-info{flex:1;min-width:0}.slideover-file-name{display:block;font-size:.8125rem;font-weight:500;color:#1d4ed8;text-decoration:none;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slideover-file-name:hover{text-decoration:underline}.slideover-file-meta{font-size:.6875rem;color:#94a3b8}.slideover-upload-btn{display:inline-flex;align-items:center;gap:6px;cursor:pointer;align-self:flex-start}.slideover-comment-meta{display:flex;align-items:baseline;gap:8px}.slideover-comment-time{font-size:.6875rem;color:#94a3b8;font-weight:400}.slideover-work-footer{padding:12px 16px;border-top:1px solid var(--color-border);background:#f8fafc;flex-shrink:0;display:flex;justify-content:stretch}.slideover-work-footer .btn{flex:1}.slideover-finish-menu{position:absolute;bottom:100%;left:12px;right:12px;margin-bottom:8px;background:#fff;border:1px solid var(--color-border);border-radius:8px;box-shadow:0 -4px 16px #0000001f;overflow:hidden;z-index:10}.slideover-finish-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:12px 16px;border:none;background:none;font-size:14px;color:var(--color-text);cursor:pointer;text-align:left;transition:background .15s}.slideover-finish-menu-item:hover{background:#f1f5f9}.slideover-finish-menu-item:not(:last-child){border-bottom:1px solid var(--color-border)}.slideover-finish-menu-item.finish-primary{color:var(--color-cta, #16a34a);font-weight:500}.task-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:5000;display:flex;align-items:center;justify-content:center;padding:24px}.task-detail-overlay-backdrop{position:absolute;top:0;right:0;bottom:0;left:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.task-detail-overlay-panel{position:relative;width:100%;max-width:1200px;height:100%;max-height:calc(100vh - 48px);background:var(--color-bg-paper, #fff);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius-xl, 16px);box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .2s ease-out}.task-detail-overlay-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-6);background:#1e293b;border-bottom:1px solid rgba(255,255,255,.08);flex-shrink:0}.task-detail-overlay-header-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--color-text-inverse, #fff);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-detail-overlay-header .btn-icon{color:#94a3b8;background:none;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px}.task-detail-overlay-header .btn-icon:hover{color:#fff;background:#ffffff1a}.task-detail-overlay-tabs{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-3) var(--spacing-6);padding-bottom:0;background:#1e293b;flex-shrink:0}.task-detail-overlay-content{flex:1;overflow:hidden;background:#fff}.task-detail-overlay-content .task-detail-layout{height:100%;min-height:0;padding:0}.task-detail-overlay-content .task-detail-sidebar,.task-detail-overlay-content .task-detail-main{overflow-y:auto;padding:var(--spacing-6)}.settings-drawer{position:absolute;top:0;right:0;width:480px;max-width:65%;height:100%;background:var(--color-surface, #fff);box-shadow:-6px 0 20px #0000001f;border-left:1px solid var(--color-border);z-index:11;display:flex;flex-direction:column;border-radius:0 var(--radius-xl) var(--radius-xl) 0;animation:slideInRight .2s ease}.settings-drawer-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--color-border);background:#f8fafc;flex-shrink:0}.settings-drawer-header h3{margin:0;font-size:1rem;font-weight:600;color:#1e293b}.settings-drawer-body{flex:1;overflow-y:auto;padding:var(--spacing-4) var(--spacing-5)}.section-header-collapsible{cursor:pointer;background:none;border:none;width:100%;text-align:left;padding:var(--spacing-2) 0;font-size:inherit;font-family:inherit;color:inherit}.section-header-collapsible:hover{opacity:.8}.section-chevron{transition:transform .2s;flex-shrink:0}.section-chevron.open{transform:rotate(90deg)}.filter-view-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.view-toggle-btn{padding:var(--spacing-1) var(--spacing-2);background:transparent;border:none;cursor:pointer;color:var(--color-text-secondary);display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.view-toggle-btn:hover{background:var(--color-hover)}.view-toggle-btn.active{background:var(--color-primary);color:#fff}.view-toggle-btn+.view-toggle-btn{border-left:1px solid var(--color-border)}.panel-tabs{display:flex;gap:0;padding:0 var(--spacing-6);background:transparent;position:relative;margin-bottom:-1px}.panel-tab{padding:var(--spacing-2) var(--spacing-5);border:1px solid transparent;border-bottom:none;background:transparent;border-radius:var(--radius-md) var(--radius-md) 0 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:#94a3b8;cursor:pointer;transition:all var(--transition-fast);position:relative;z-index:1}.panel-tab:hover{color:#e2e8f0}.panel-tab.active{background:#fff;color:var(--color-text-primary);font-weight:var(--font-weight-semibold);border-color:transparent;z-index:2}.panel-tab-help{margin-left:auto;width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full, 999px);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:#64748b;background:transparent;border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);flex-shrink:0;align-self:center}.panel-tab-help:hover{color:#e2e8f0;background:#ffffff14}.panel-tab-help.active{background:#fff;color:var(--color-text-primary);border-color:transparent}.help-tab{max-width:720px;margin:0 auto;padding:var(--spacing-8) var(--spacing-6)}.help-header h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-2) 0}.help-header p{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--spacing-6) 0}.help-section{margin-bottom:var(--spacing-6)}.help-section h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-3) 0}.help-section p{color:var(--color-text-secondary);line-height:1.6;margin:0 0 var(--spacing-3) 0}.help-section ul{margin:var(--spacing-2) 0 0 0;padding-left:var(--spacing-5);color:var(--color-text-secondary);line-height:1.8}.help-tabs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-3)}.help-tab-card{padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle, #f9fafb);border:1px solid var(--color-border, #e5e7eb);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--spacing-1)}.help-tab-card strong{font-size:var(--font-size-sm);color:var(--color-text-primary)}.help-tab-card span{font-size:var(--font-size-xs);color:var(--color-text-secondary);line-height:1.4}.help-tips{margin-top:var(--spacing-6);padding:var(--spacing-4) var(--spacing-5);background:#2d5a270f;border:1px solid rgba(45,90,39,.15);border-radius:var(--radius-md)}.help-tips h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-brand, #2d5a27);margin:0 0 var(--spacing-3) 0}.help-tips ul{margin:0;padding-left:var(--spacing-5);color:var(--color-text-secondary);line-height:1.8}.help-tips li::marker{content:"✓ ";color:var(--color-brand, #2d5a27)}.toolbar-divider{width:1px;height:24px;background:var(--color-border-light);margin:0 var(--spacing-3)}.panel-toolbar-actions{display:flex;align-items:center;gap:var(--spacing-2);margin-left:auto}@media (max-width: 768px){.app-panel-overlay{padding:0}.app-panel{border-radius:0;max-height:100vh}.app-panel-layout{grid-template-columns:1fr}.app-panel-sidebar{display:none}.app-panel-header{padding:var(--spacing-3) var(--spacing-4)}.app-panel-content{padding:var(--spacing-4)}}.app-panel-content:has(.tasks-content){overflow:hidden;display:flex;flex-direction:column}.tasks-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow-y:auto}.task-detail-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:var(--spacing-4);color:var(--color-text-secondary)}.completion-dialog{padding:var(--spacing-2) 0}.completion-dialog .form-group{margin-bottom:var(--spacing-4)}.completion-dialog .form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.quality-stars{display:flex;align-items:center;gap:var(--spacing-1)}.quality-star{background:none;border:none;cursor:pointer;padding:2px;color:var(--color-border);transition:transform .15s,color .15s}.quality-star:hover{transform:scale(1.15)}.quality-star.active{color:currentColor}.quality-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);margin-left:var(--spacing-2)}.time-assessment-chips{display:flex;gap:var(--spacing-2);flex-wrap:wrap}.chip{padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-full);border:1px solid var(--color-border);background:var(--color-surface);font-size:var(--font-size-sm);cursor:pointer;transition:background .15s,border-color .15s}.chip:hover{background:var(--color-surface-secondary)}.chip-active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-700);font-weight:var(--font-weight-medium)}.task-detail-layout{display:grid;grid-template-columns:280px 1fr;gap:var(--spacing-6);height:100%;min-height:0}.task-detail-sidebar{display:flex;flex-direction:column;gap:var(--spacing-4);padding-right:var(--spacing-6);border-right:1px solid var(--color-border-light);overflow-y:auto}.sidebar-section{display:flex;flex-direction:column;gap:var(--spacing-2)}.sidebar-section-header{display:flex;justify-content:space-between;align-items:center}.sidebar-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.task-status-large{display:inline-flex;align-items:center;justify-content:center;padding:var(--spacing-2) var(--spacing-4);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.task-status-large.status-pending{background:var(--color-warning-100, #fef3c7);color:var(--color-warning-800, #92400e)}.task-status-large.status-in_progress{background:var(--color-info-100, #dbeafe);color:var(--color-info-800, #1e40af)}.task-status-large.status-pending_review{background:#f3e8ff;color:#6b21a8}.task-status-large.status-completed{background:var(--color-success-100, #dcfce7);color:var(--color-success-800, #166534)}.task-status-large.status-rejected{background:var(--color-error-100, #fee2e2);color:var(--color-error-800, #991b1b)}.task-status-large.status-cancelled{background:var(--color-bg-subtle);color:var(--color-text-secondary)}.task-blocked-notice{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--color-error-50, #fef2f2);border:1px solid var(--color-error-200, #fecaca);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-error-700, #b91c1c)}.sidebar-assignee{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary)}.sidebar-due-date{font-size:var(--font-size-sm);color:var(--color-text-primary)}.sidebar-due-date.overdue{color:var(--color-error-600, #dc2626)}.sidebar-due-date .overdue-badge{display:inline-block;margin-left:var(--spacing-2);padding:2px var(--spacing-2);background:var(--color-error-100, #fee2e2);color:var(--color-error-700, #b91c1c);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);border-radius:var(--radius-sm)}.sidebar-due-date .no-date{color:var(--color-text-tertiary);font-style:italic}.task-type-badge{display:inline-block;padding:var(--spacing-1) var(--spacing-2);background:var(--color-bg-subtle);border-radius:var(--radius-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-transform:capitalize}.sidebar-actions{display:flex;flex-direction:column;gap:var(--spacing-2);padding-top:var(--spacing-2);border-top:1px solid var(--color-border-light)}.btn-block{width:100%;justify-content:center}.watchers-avatars{display:flex;align-items:center;gap:-4px}.watchers-avatars>*{margin-left:-4px}.watchers-avatars>*:first-child{margin-left:0}.watchers-more{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-left:var(--spacing-2)}.sidebar-meta{padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.meta-item{display:flex;justify-content:space-between;font-size:var(--font-size-xs);margin-bottom:var(--spacing-1)}.meta-label{color:var(--color-text-secondary)}.meta-value{color:var(--color-text-primary)}.task-detail-main{overflow-y:auto;padding-right:var(--spacing-4)}.task-title-large{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0 0 var(--spacing-4) 0;line-height:1.3}.task-title-edit{font-size:var(--font-size-2xl)!important;font-weight:var(--font-weight-bold)!important;margin-bottom:var(--spacing-4)!important;padding:var(--spacing-2) var(--spacing-3)!important}.task-description-edit{resize:vertical;min-height:80px}.task-description-section{margin-bottom:var(--spacing-6)}.task-description{font-size:var(--font-size-base);color:var(--color-text-primary);line-height:1.6;white-space:pre-wrap}.task-section{margin-bottom:var(--spacing-6);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.section-header h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.checklist-count,.subtask-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:var(--font-weight-medium)}.checklist-items{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.add-checklist-item{display:flex;gap:var(--spacing-2)}.add-checklist-item .form-input{flex:1}.comment-input-section{display:flex;gap:10px;align-items:flex-start;margin-bottom:var(--spacing-5)}.comment-input-section .comment-input-fields{flex:1;display:flex;flex-direction:column;gap:var(--spacing-2)}.comment-input-section .btn{align-self:flex-end}.comment-item{display:flex;gap:10px;align-items:flex-start;padding:10px 0;border-bottom:1px solid #f1f5f9}.comment-item:last-child{border-bottom:none}.comment-body{flex:1;min-width:0}.comment-header{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}.comment-author{font-size:.8125rem;font-weight:600;color:#1e293b}.comment-date{font-size:.6875rem;color:#94a3b8}.comment-content{font-size:.8125rem;color:#475569;line-height:1.5;white-space:pre-wrap}.activity-tab h2,.files-tab h2,.time-tab h2{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-4) 0}.activity-timeline{display:flex;flex-direction:column;gap:var(--spacing-3)}.activity-timeline-item{display:flex;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.activity-timeline-item .activity-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-paper);border-radius:var(--radius-full);flex-shrink:0}.activity-timeline-item .activity-content{flex:1}.activity-timeline-item .activity-text{font-size:var(--font-size-sm);color:var(--color-text-primary);display:block;margin-bottom:var(--spacing-1)}.activity-timeline-item .activity-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.file-upload-zone{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-8);border:2px dashed var(--color-border-main);border-radius:var(--radius-lg);background:var(--color-bg-subtle);cursor:pointer;transition:all var(--transition-fast);margin-bottom:var(--spacing-6)}.file-upload-zone:hover{border-color:var(--color-primary-500);background:var(--color-primary-50, #f0fdf4)}.file-upload-zone svg{color:var(--color-text-tertiary);margin-bottom:var(--spacing-3)}.file-upload-zone p{font-size:var(--font-size-base);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.file-upload-zone .file-types{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.no-files{text-align:center;color:var(--color-text-secondary);font-style:italic}.files-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-4)}.files-header h2{margin:0}.files-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--spacing-3)}.file-card{border:1px solid var(--color-border-light);border-radius:6px;overflow:hidden;background:var(--color-bg-paper);transition:border-color .12s}.file-card:hover{border-color:var(--color-border-main, #d1d5db)}.file-thumbnail-link{display:block}.file-thumbnail{width:100%;height:140px;object-fit:cover;display:block;background:var(--color-bg-subtle)}.file-icon-box{display:flex;align-items:center;justify-content:center;height:140px;background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.file-card-info{padding:var(--spacing-2) var(--spacing-3);display:flex;flex-direction:column;gap:2px}.file-card-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-card-uploader,.file-card-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.file-card-actions{display:flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);border-top:1px solid var(--color-border-light)}.btn-danger-text{color:var(--color-danger, #dc3545)!important}.compact-task-more{text-align:center;padding:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-tertiary);font-style:italic}.time-summary-card{display:flex;gap:var(--spacing-6);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.time-stat{display:flex;flex-direction:column;gap:var(--spacing-1)}.time-stat-label{font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.time-stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.time-progress-section{flex:1;display:flex;align-items:center;gap:var(--spacing-3)}.timer-section{margin-bottom:var(--spacing-6)}.timer-running-card{padding:var(--spacing-4);background:var(--color-success-50, #f0fdf4);border:1px solid var(--color-success-200, #bbf7d0);border-radius:var(--radius-lg)}.timer-indicator{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.timer-elapsed{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-success-700, #15803d)}.time-entries-section h3{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);margin:0 0 var(--spacing-3) 0}.time-entries-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.time-entry-card{padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.time-entry-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-1)}.time-entry-user{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.time-entry-duration{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-primary-600)}.time-entry-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.time-entry-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 var(--spacing-1);margin-left:var(--spacing-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);background:var(--color-primary-500);color:#fff;border-radius:4px}@media (max-width: 768px){.task-detail-layout{grid-template-columns:1fr}.task-detail-sidebar{border-right:none;border-bottom:1px solid var(--color-border-light);padding-right:0;padding-bottom:var(--spacing-4)}.time-summary-card{flex-direction:column;gap:var(--spacing-3)}}.task-dashboard{padding:0}.dashboard-stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-6)}@media (max-width: 768px){.dashboard-stats-row{grid-template-columns:repeat(2,1fr)}}.stat-card{background:var(--color-bg-subtle);border-radius:var(--radius-lg);padding:var(--spacing-4);text-align:center;border:1px solid var(--color-border-light)}.stat-card.warning{background:var(--color-warning-50, #fffbeb);border-color:var(--color-warning-200, #fde68a)}.stat-card.success{background:var(--color-success-50, #f0fdf4);border-color:var(--color-success-200, #bbf7d0)}.stat-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);display:block}.stat-card.warning .stat-card-value{color:var(--color-warning-600, #d97706)}.stat-card.success .stat-card-value{color:var(--color-success-600, #16a34a)}.stat-card-subvalue{font-size:11px;color:#6b7280;margin-top:2px;display:block}.stat-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.dashboard-columns{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6)}@media (max-width: 768px){.dashboard-columns{grid-template-columns:1fr}}.dashboard-section h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.empty-state-sm{padding:var(--spacing-6);text-align:center;background:var(--color-bg-subtle);border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm)}.empty-state-sm.success{background:var(--color-success-50, #f0fdf4);color:var(--color-success-700, #15803d)}.task-list-compact-legacy{display:none;gap:var(--spacing-2)}.task-list-grid{display:grid;grid-template-columns:1fr;gap:var(--spacing-2)}@media (min-width: 1024px){.task-list-grid{grid-template-columns:1fr 1fr}}.section-show-more{display:block;width:100%;padding:var(--spacing-2);margin-top:var(--spacing-1);background:transparent;border:1px dashed var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-secondary);font-size:var(--font-size-sm);cursor:pointer;text-align:center;transition:all var(--transition-fast)}.section-show-more:hover{background:var(--color-bg-subtle);border-color:var(--color-text-tertiary);color:var(--color-text-primary)}.tc-row{display:flex;align-items:center;cursor:pointer;border-bottom:1px solid #e5e7eb;transition:filter .1s}.tc-row:hover{filter:brightness(.97)}.tc-row:last-child{border-bottom:none}.tc-band{width:4px;align-self:stretch;flex-shrink:0}.tc-ring{width:32px;height:32px;flex-shrink:0;position:relative;margin-left:12px}.tc-ring svg{display:block}.tc-ring-text{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;font-size:8px;font-weight:700;color:#475569}.tc-content{flex:1;min-width:0;padding:11px 16px}.tc-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.tc-title{font-size:.8125rem;font-weight:600;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0}.tc-badge{font-size:.6rem;font-weight:700;color:#fff;padding:3px 10px;border-radius:4px;letter-spacing:.04em;white-space:nowrap;flex-shrink:0}.tc-meta{display:flex;align-items:center;flex-wrap:wrap;margin-top:3px;font-size:.7rem;color:#64748b}.tc-meta-item{display:inline-flex;align-items:center}.tc-meta-sep{display:inline-block;width:3px;height:3px;border-radius:50%;background:#cbd5e1;margin:0 8px}.tc-meta-overdue{color:#dc2626;font-weight:600}.tc-meta-block{font-weight:600;color:#059669}.tc-meta-form-pending{color:#d97706;font-weight:500}.tc-meta-form-done{color:#16a34a;font-weight:500}.task-list-compact{display:flex;flex-direction:column;border-top:1px solid #e5e7eb}.tab-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;margin-left:var(--spacing-2);border-radius:9px;font-size:11px;font-weight:var(--font-weight-semibold);background:#fff3;color:#fff;line-height:1}.panel-tab.active .tab-badge{background:var(--color-bg-subtle, #f3f4f6);color:var(--color-text-secondary)}.tab-badge-accent{background:#fef2f2;color:#ef4444}.my-tasks-quick-stats{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-5)}.quick-stat{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-3);border-radius:var(--radius-full, 9999px);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.quick-stat-overdue{background:#fef2f2;color:#dc2626}.quick-stat-today{background:#eff6ff;color:#2563eb}.quick-stat-review{background:#f5f3ff;color:#7c3aed}.quick-stat-clear{background:#f0fdf4;color:#16a34a}.my-tasks-sections{display:flex;flex-direction:column;gap:var(--spacing-5)}.section-header-bar{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.section-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.section-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.section-count{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.compact-task-actions{display:flex;gap:var(--spacing-1);flex-shrink:0;opacity:0;transition:opacity var(--transition-fast)}.compact-task-card:hover .compact-task-actions{opacity:1}@media (max-width: 768px){.compact-task-actions{opacity:1}}.btn-quick-action{padding:var(--spacing-1) var(--spacing-2);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);font-size:11px;font-weight:var(--font-weight-medium);cursor:pointer;background:#fff;transition:all var(--transition-fast);white-space:nowrap}.btn-quick-start{color:#2563eb;border-color:#bfdbfe}.btn-quick-start:hover{background:#eff6ff}.btn-quick-complete{color:#16a34a;border-color:#bbf7d0}.btn-quick-complete:hover{background:#f0fdf4}.btn-quick-submit{color:#7c3aed;border-color:#c4b5fd}.btn-quick-submit:hover{background:#f5f3ff}.btn-quick-approve{color:#16a34a;border-color:#bbf7d0}.btn-quick-approve:hover{background:#f0fdf4}.btn-quick-reject{color:#dc2626;border-color:#fecaca}.btn-quick-reject:hover{background:#fef2f2}.compact-task-checklist{color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.my-tasks-empty{text-align:center;padding:var(--spacing-12) var(--spacing-6);color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.mywork-header{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;padding-bottom:16px;margin-bottom:16px;border-bottom:1px solid #e5e7eb}.mywork-header-left{flex:1;min-width:0}.mywork-headline{display:flex;align-items:baseline;gap:8px;margin-bottom:4px}.mywork-headline-num{font-size:2rem;font-weight:800;color:#0f172a;line-height:1;letter-spacing:-.03em}.mywork-headline-text{font-size:.9375rem;color:#64748b;font-weight:500}.mywork-headline-clear{color:#22c55e}.mywork-mini-stats{display:flex;gap:12px;flex-wrap:wrap}.mywork-mini{font-size:.75rem;font-weight:600;white-space:nowrap}.mywork-dist-bar{display:flex;width:180px;height:8px;border-radius:4px;overflow:hidden;flex-shrink:0;background:#f1f5f9;margin-bottom:6px}.mywork-dist-seg{height:100%;transition:width .3s ease;min-width:3px}.mywork-panels{display:grid;grid-template-columns:260px 1fr;gap:20px;min-height:300px}@media (max-width: 900px){.mywork-panels{grid-template-columns:1fr}}.mywork-working-panel{background:#f8fafc;border:1px solid #e2e8f0;border-radius:10px;padding:14px;display:flex;flex-direction:column}.mywork-panel-title{display:flex;align-items:center;gap:6px;font-size:.8125rem;font-weight:600;color:#334155;margin-bottom:12px}.mywork-panel-badge{background:#06b6d4;color:#fff;font-size:.6875rem;font-weight:700;padding:1px 7px;border-radius:10px;margin-left:auto}.mywork-working-list{display:flex;flex-direction:column;gap:6px;flex:1;overflow-y:auto}.mywork-working-card{display:flex;flex-direction:column;gap:6px;padding:10px 12px;background:#fff;border:1px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .15s;text-align:left;font-family:inherit;width:100%}.mywork-working-card:hover{border-color:#06b6d4;box-shadow:0 2px 8px #06b6d41a}.mywork-working-card-top{display:flex;align-items:center;gap:6px}.mywork-working-title{font-size:.8125rem;font-weight:500;color:#1e293b;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mywork-working-progress{display:flex;align-items:center;gap:6px}.mywork-working-bar{flex:1;height:4px;background:#e2e8f0;border-radius:2px;overflow:hidden}.mywork-working-bar-fill{height:100%;background:#06b6d4;border-radius:2px;transition:width .3s ease}.mywork-working-pct{font-size:.6875rem;color:#64748b;font-weight:600;min-width:28px;text-align:right}.mywork-working-due{font-size:.6875rem;color:#94a3b8}.mywork-working-due.overdue{color:#dc2626;font-weight:600}.mywork-working-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;padding:24px 12px;flex:1;font-size:.75rem;color:#94a3b8;text-align:center}.mywork-list-panel{display:flex;flex-direction:column;min-width:0}.mywork-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.mywork-filter-pill{display:flex;align-items:center;gap:4px;padding:5px 12px;border:1px solid #e2e8f0;border-radius:16px;background:#fff;cursor:pointer;font-family:inherit;font-size:.75rem;color:#64748b;transition:all .12s;white-space:nowrap}.mywork-filter-pill:hover{border-color:var(--pill-color);color:var(--pill-color)}.mywork-filter-pill.active{background:var(--pill-color);border-color:var(--pill-color);color:#fff;font-weight:600}.mywork-filter-pill.empty:not(.active){opacity:.45}.mywork-filter-count{background:#ffffff40;padding:0 5px;border-radius:8px;font-size:.6875rem;font-weight:700}.mywork-filter-pill:not(.active) .mywork-filter-count{background:#f1f5f9;color:#475569}.mywork-list-empty{display:flex;align-items:center;justify-content:center;padding:48px 20px;font-size:.875rem;color:#94a3b8;text-align:center;background:#f8fafc;border-radius:8px;border:1px dashed #e2e8f0}.mywork-stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}@media (max-width: 768px){.mywork-stats-grid{grid-template-columns:repeat(2,1fr)}}.mywork-stat-card{display:flex;align-items:center;gap:14px;padding:18px 16px;border-radius:12px;border:1px solid #e5e7eb;border-left:4px solid #e5e7eb;background:#fff;transition:box-shadow .15s,transform .15s}.mywork-stat-card:hover{box-shadow:0 4px 12px #00000012;transform:translateY(-1px)}.mywork-stat-icon{display:flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:10px;flex-shrink:0}.mywork-stat-text{display:flex;flex-direction:column;gap:2px;min-width:0}.mywork-stat-count{font-size:1.75rem;font-weight:700;line-height:1;letter-spacing:-.02em}.mywork-stat-label{font-size:.75rem;color:#64748b;font-weight:500;white-space:nowrap}.mywork-stat-blue{border-left-color:#3b82f6;background:linear-gradient(135deg,#f0f7ff,#fff)}.mywork-stat-blue .mywork-stat-icon{background:#dbeafe;color:#2563eb}.mywork-stat-blue .mywork-stat-count{color:#1e40af}.mywork-stat-red{border-left-color:#d1d5db;background:#fafafa}.mywork-stat-red .mywork-stat-icon{background:#f3f4f6;color:#9ca3af}.mywork-stat-red .mywork-stat-count{color:#9ca3af}.mywork-stat-red.mywork-stat-active{border-left-color:#ef4444;background:linear-gradient(135deg,#fef2f2,#fff)}.mywork-stat-red.mywork-stat-active .mywork-stat-icon{background:#fee2e2;color:#dc2626}.mywork-stat-red.mywork-stat-active .mywork-stat-count{color:#b91c1c}.mywork-stat-cyan{border-left-color:#06b6d4;background:linear-gradient(135deg,#ecfeff,#fff)}.mywork-stat-cyan .mywork-stat-icon{background:#cffafe;color:#0891b2}.mywork-stat-cyan .mywork-stat-count{color:#0e7490}.mywork-stat-green{border-left-color:#22c55e;background:linear-gradient(135deg,#f0fdf4,#fff)}.mywork-stat-green .mywork-stat-icon{background:#dcfce7;color:#16a34a}.mywork-stat-green .mywork-stat-count{color:#15803d}.mywork-urgent-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--spacing-5);margin-bottom:var(--spacing-6)}@media (max-width: 900px){.mywork-urgent-grid{grid-template-columns:1fr}}.mywork-urgent-column{min-width:0}.mywork-empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:var(--spacing-12) var(--spacing-6);margin-top:var(--spacing-4)}.mywork-empty-icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;border-radius:50%;background:var(--color-bg-subtle);color:var(--color-text-tertiary);margin-bottom:var(--spacing-4)}.mywork-empty-state h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin:0 0 var(--spacing-2) 0}.mywork-empty-state p{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0;max-width:360px;line-height:1.5}.btn-link{background:none;border:none;padding:var(--spacing-1) var(--spacing-2);color:var(--color-primary-600);font-weight:var(--font-weight-medium);cursor:pointer}.btn-link:hover{color:var(--color-primary-700);text-decoration:underline}.btn-icon{padding:var(--spacing-2);min-width:auto;background:transparent;border:1px solid var(--color-border-light);color:var(--color-text-secondary)}.btn-icon:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.btn-ghost{background:transparent;border:none;color:var(--color-text-secondary);padding:var(--spacing-2)}.btn-ghost:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.task-list-view{display:flex;flex-direction:column;gap:0;height:100%;min-height:0;overflow:hidden}.task-filter-header{flex-shrink:0;background:var(--color-bg-paper, #ffffff);padding:var(--spacing-4);border-bottom:1px solid var(--color-border-light);display:flex;flex-direction:column;gap:var(--spacing-3)}.filter-main-row{display:flex;align-items:center;gap:var(--spacing-3);flex-wrap:wrap}.quick-filters{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.filter-chip{display:inline-flex!important;visibility:visible!important;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:var(--color-bg-subtle);border:1px solid var(--color-border-light);border-radius:4px;cursor:pointer;transition:background-color .15s ease,border-color .15s ease,color .15s ease;white-space:nowrap;flex-shrink:0;min-width:fit-content}.filter-chip:hover{background:var(--color-bg-paper);border-color:var(--color-border-medium);color:var(--color-text-primary)}.filter-chip.active{display:inline-flex!important;visibility:visible!important;background:var(--color-primary-500)!important;background-color:#265021!important;border-color:var(--color-primary-500)!important;border-color:#265021!important;color:#fff!important}.filter-chip.active:hover{background:var(--color-primary-600, #16a34a);border-color:var(--color-primary-600, #16a34a)}.filter-chip svg{opacity:.7;flex-shrink:0}.filter-chip.active svg{opacity:1}.filter-toggle-btn{display:inline-flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);background:transparent;border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);margin-left:auto}.filter-toggle-btn:hover{background:var(--color-bg-subtle);border-color:var(--color-border-medium)}.filter-toggle-btn.active{background:var(--color-bg-subtle);border-color:var(--color-primary-500);color:var(--color-primary-500)}.filter-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 var(--spacing-1);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);color:#fff;background:var(--color-primary-500);border-radius:4px}.filter-advanced-row{display:flex;align-items:flex-end;gap:var(--spacing-4);flex-wrap:wrap;padding-top:var(--spacing-3);border-top:1px solid var(--color-border-light)}.filter-group{display:flex;flex-direction:column;gap:var(--spacing-1);min-width:160px}.filter-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.05em}.clear-filters-btn{color:var(--color-text-tertiary);text-decoration:underline;font-size:var(--font-size-sm)}.clear-filters-btn:hover{color:var(--color-text-secondary)}.filter-results-row{display:flex;align-items:center;justify-content:space-between;padding-top:var(--spacing-2)}.results-count .selection-info{color:var(--color-primary-500);font-weight:var(--font-weight-medium)}.filter-actions{display:flex;align-items:center;gap:var(--spacing-2)}.sort-select{padding:var(--spacing-1) var(--spacing-2);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-surface);cursor:pointer}.task-list-scrollable{flex:1;min-height:0;overflow-y:auto;padding:var(--spacing-4)}@media (max-width: 768px){.filter-main-row{flex-direction:column;align-items:stretch}.search-input-wrapper{max-width:none}.quick-filters{justify-content:flex-start}.filter-chip{padding:var(--spacing-2) var(--spacing-3)}.filter-toggle-btn{margin-left:0;justify-content:center}.filter-advanced-row{flex-direction:column;align-items:stretch}.filter-group{width:100%}}.search-input-wrapper{position:relative;flex:1;max-width:300px}.search-input-wrapper svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary);pointer-events:none}.search-input-wrapper .form-input{padding-left:36px}.results-count{font-size:var(--font-size-sm);color:var(--color-text-secondary);padding:var(--spacing-2) 0}.task-table{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);overflow:hidden}.task-table-header{display:grid;grid-template-columns:40px 2fr 100px 100px 150px 100px;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-bottom:1px solid var(--color-border-light);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.task-table-row{display:grid;grid-template-columns:40px 2fr 100px 100px 150px 100px;gap:var(--spacing-3);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.task-table-row:last-child{border-bottom:none}.task-table-row:hover{background:var(--color-primary-50, #f0fdf4)}.task-table-row.selected{background:var(--color-primary-100, #dcfce7)}.task-checkbox-col{width:40px;flex-shrink:0;justify-content:center}.task-checkbox-col input[type=checkbox]{width:16px;height:16px;cursor:pointer}.task-table-cell{display:flex;align-items:center;font-size:var(--font-size-sm);color:var(--color-text-primary);min-width:0}.task-title-col{font-weight:var(--font-weight-medium);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-status-col .badge,.task-priority-col .badge{font-size:var(--font-size-xs)}@media (max-width: 768px){.task-table-header,.task-table-row{grid-template-columns:1fr;gap:var(--spacing-2)}.task-table-header{display:none}.task-table-cell:before{content:attr(data-label);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-right:var(--spacing-2);display:none}}.kanban-board{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--spacing-4);min-height:500px}.kanban-column{background:var(--color-bg-subtle);border-radius:var(--radius-lg);display:flex;flex-direction:column;min-height:400px}.kanban-column-header{padding:var(--spacing-3) var(--spacing-4);border-top:4px solid var(--color-primary-500);display:flex;justify-content:space-between;align-items:center}.kanban-column-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm)}.kanban-column-count{background:var(--color-bg-paper);color:var(--color-text-secondary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);padding:var(--spacing-1) var(--spacing-2);border-radius:4px}.kanban-column-content{flex:1;padding:var(--spacing-2) var(--spacing-3);display:flex;flex-direction:column;gap:var(--spacing-2);overflow-y:auto}.kanban-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:var(--spacing-3);cursor:pointer;transition:background .12s,border-color .12s}.kanban-card:hover{border-color:var(--color-primary-300);background:var(--color-bg-subtle, #f9fafb)}.kanban-card-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.kanban-card-meta{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:flex;align-items:center;flex-wrap:wrap;gap:var(--spacing-2)}.kanban-card-meta .unassigned-text{color:var(--color-text-tertiary);font-style:italic}.task-statistics{display:flex;flex-direction:column;gap:var(--spacing-6)}.stats-summary-row{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--spacing-4)}@media (max-width: 768px){.stats-summary-row{grid-template-columns:repeat(2,1fr)}}.stats-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4);text-align:center}.stats-card.warning{background:var(--color-warning-50, #fffbeb);border-color:var(--color-warning-200)}.stats-card-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);display:block}.stats-card.warning .stats-card-value{color:var(--color-warning-600, #d97706)}.stats-card-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.stats-card-pct{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.stats-charts-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-6)}@media (max-width: 768px){.stats-charts-row{grid-template-columns:1fr}}.stats-chart-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4)}.stats-chart-card h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.bar-chart{display:flex;flex-direction:column;gap:var(--spacing-3)}.bar-chart-row{display:grid;grid-template-columns:80px 1fr 40px;gap:var(--spacing-3);align-items:center}.bar-chart-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.bar-chart-bar-wrapper{height:24px;background:var(--color-bg-subtle);border-radius:var(--radius-sm);overflow:hidden}.bar-chart-bar{height:100%;border-radius:var(--radius-sm);transition:width .3s ease}.bar-chart-value{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);text-align:right}.stats-team-section{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);padding:var(--spacing-4)}.stats-team-section h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4)}.team-stats-table{display:flex;flex-direction:column}.team-stats-header{display:grid;grid-template-columns:1fr repeat(3,80px);gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.team-stats-row{display:grid;grid-template-columns:1fr repeat(3,80px);gap:var(--spacing-3);padding:var(--spacing-3);border-bottom:1px solid var(--color-border-light)}.team-stats-row:last-child{border-bottom:none}.team-member-name{display:flex;align-items:center;gap:var(--spacing-2);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.task-detail-modal{max-width:600px}.task-detail-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start}.task-detail-modal .modal-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-right:var(--spacing-4)}.modal-close{background:transparent;border:none;font-size:var(--font-size-xl);color:var(--color-text-secondary);cursor:pointer;padding:var(--spacing-1);line-height:1}.modal-close:hover{color:var(--color-text-primary)}.task-detail-status{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-bottom:var(--spacing-4)}.task-blocked-badge{background:var(--color-error-100);color:var(--color-error-700);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.task-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4);margin-bottom:var(--spacing-4)}.task-detail-label{display:block;font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.task-detail-section{margin-top:var(--spacing-4);padding-top:var(--spacing-4);border-top:1px solid var(--color-border-light)}.task-detail-section h4{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-3)}.task-detail-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-3)}.checklist-readonly{display:flex;flex-direction:column;gap:var(--spacing-2)}.checklist-readonly-item{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary)}.checklist-readonly-item.completed{color:var(--color-text-secondary);text-decoration:line-through}.dependencies-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.dependency-label{font-size:var(--font-size-xs);color:var(--color-text-secondary);font-weight:var(--font-weight-medium);margin-bottom:var(--spacing-1)}.dependency-item{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm)}.dependency-title{font-size:var(--font-size-sm);color:var(--color-text-primary)}.dependency-remove{background:transparent;border:none;color:var(--color-error-500);cursor:pointer;padding:var(--spacing-1);font-size:var(--font-size-lg)}.dependency-remove:hover{color:var(--color-error-700)}.no-dependencies{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.dependency-add-form{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-top:var(--spacing-3)}.dependency-add-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.blocked-list{background:var(--color-warning-50, #fffbeb);padding:var(--spacing-3);border-radius:var(--radius-md);margin-top:var(--spacing-3)}.watchers-list{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-top:var(--spacing-2)}.watcher-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-1) var(--spacing-2);background:var(--color-bg-subtle);border-radius:4px;font-size:var(--font-size-sm)}.watcher-name{color:var(--color-text-primary)}.watcher-reason{color:var(--color-text-tertiary);font-size:var(--font-size-xs)}.no-watchers{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.time-summary{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3);margin-bottom:var(--spacing-3)}.time-summary-row{display:flex;align-items:center;gap:var(--spacing-2);flex-wrap:wrap}.time-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.time-value{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.time-progress{display:flex;align-items:center;gap:var(--spacing-2);margin-top:var(--spacing-2)}.time-progress-bar{flex:1;height:8px;background:var(--color-border-main);border-radius:var(--radius-full);overflow:hidden}.time-progress-fill{height:100%;background:var(--color-primary-500);border-radius:var(--radius-full);transition:width .3s ease}.time-progress-percent{font-size:var(--font-size-sm);color:var(--color-text-secondary);min-width:40px;text-align:right}.timer-controls{margin-bottom:var(--spacing-3)}.timer-running{background:var(--color-success-50, #f0fdf4);border:1px solid var(--color-success-200, #bbf7d0);border-radius:var(--radius-md);padding:var(--spacing-3)}.timer-indicator{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.timer-pulse{width:12px;height:12px;background:var(--color-success-500);border-radius:50%;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.timer-elapsed{font-weight:var(--font-weight-semibold);color:var(--color-success-700, #15803d)}.timer-stop-form{display:flex;gap:var(--spacing-2)}.timer-stop-form .form-input{flex:1}.time-entries-list{margin-top:var(--spacing-3)}.time-entries-list h5{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.time-entry-item{padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm);margin-bottom:var(--spacing-2)}.time-entry-main{display:flex;justify-content:space-between;align-items:center}.time-entry-user{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:var(--font-weight-medium)}.time-entry-duration{font-size:var(--font-size-sm);color:var(--color-primary-600);font-weight:var(--font-weight-semibold)}.time-entry-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.time-entry-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-top:var(--spacing-1)}.checklist-progress{margin-bottom:var(--spacing-3)}.checklist-progress-bar{height:6px;background:var(--color-border-main);border-radius:var(--radius-full);overflow:hidden}.checklist-progress-fill{height:100%;background:var(--color-primary-500);border-radius:var(--radius-full);transition:width .3s ease}.checklist-interactive{display:flex;flex-direction:column;gap:var(--spacing-1)}.checklist-item-btn{display:flex;align-items:center;gap:var(--spacing-3);width:100%;padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);cursor:pointer;text-align:left;transition:all var(--transition-fast)}.checklist-item-btn:hover:not(:disabled){background:var(--color-bg-subtle);border-color:var(--color-primary-200, #bbf7d0)}.checklist-item-btn.completed{background:var(--color-success-50, #f0fdf4);border-color:var(--color-success-200, #bbf7d0)}.checklist-item-btn:disabled{cursor:default;opacity:.6}.checklist-item-btn .checkbox-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);flex-shrink:0}.checklist-item-btn.completed .checkbox-icon{color:var(--color-success-600, #16a34a)}.checklist-item-text{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.checklist-item-btn.completed .checklist-item-text{text-decoration:line-through;color:var(--color-text-secondary)}.task-detail-tabs{display:flex;gap:var(--spacing-1);margin-bottom:var(--spacing-3);border-bottom:1px solid var(--color-border-light)}.task-detail-tabs .tab-btn{padding:var(--spacing-2) var(--spacing-4);background:transparent;border:none;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;position:relative;transition:color var(--transition-fast)}.task-detail-tabs .tab-btn:hover{color:var(--color-text-primary)}.task-detail-tabs .tab-btn.active{color:var(--color-primary-500)}.task-detail-tabs .tab-btn.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-primary-500);border-radius:var(--radius-full)}.comments-section{display:flex;flex-direction:column;gap:var(--spacing-3)}.comment-input-wrapper{display:flex;flex-direction:column;gap:var(--spacing-2)}.comment-textarea{resize:none;min-height:60px}.comment-input-wrapper .btn{align-self:flex-end}.comments-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.comment-item{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3)}.comment-header{display:flex;align-items:center;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.comment-author{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.comment-date{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin-left:auto}.comment-content{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1.5;white-space:pre-wrap}.no-comments{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;text-align:center;padding:var(--spacing-4)}.activity-feed{max-height:300px;overflow-y:auto}.activity-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.activity-item{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);font-size:var(--font-size-sm)}.activity-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-subtle);border-radius:var(--radius-full);font-size:12px;flex-shrink:0}.activity-content{flex:1;display:flex;flex-direction:column;gap:2px}.activity-text{color:var(--color-text-primary)}.activity-meta{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.no-activity{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic;text-align:center;padding:var(--spacing-4)}.task-action-footer{display:flex;justify-content:space-between;align-items:center;gap:var(--spacing-3)}.footer-left,.footer-right{display:flex;align-items:center;gap:var(--spacing-2)}.footer-right .btn{display:inline-flex;align-items:center;gap:var(--spacing-1)}.btn-danger{background-color:var(--color-error-600, #dc2626);border-color:var(--color-error-600, #dc2626);color:#fff}.btn-danger:hover{background-color:var(--color-error-700, #b91c1c);border-color:var(--color-error-700, #b91c1c)}.subtask-checkbox{color:var(--color-text-tertiary)}.subtask-checkbox.checked{color:var(--color-success-600, #16a34a)}.subtask-status{font-size:var(--font-size-xs);color:var(--color-text-secondary);text-transform:capitalize}.subtask-add-form{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md);margin-top:var(--spacing-2)}.parent-task-info{background:var(--color-info-light, #eff6ff);padding:var(--spacing-3);border-radius:var(--radius-md)}.parent-label{font-size:var(--font-size-sm);color:var(--color-info-dark, #1e40af)}.modal-xl{max-width:950px}.create-task-modal{overflow:hidden}.create-task-modal .modal-header{display:none}.create-task-modal .modal-body{padding:0;overflow:visible}.create-task-modal .form-input,.create-task-modal .list-select-input,.create-task-modal .user-select-trigger{height:38px;font-size:14px}.create-task-modal .list-select-input{font-family:inherit;color:var(--color-text-primary)}.create-task-modal .form-group{margin-bottom:14px}.create-task-modal .form-group:last-child{margin-bottom:0}.create-task-modal .estimate-chips{gap:4px}.create-task-modal .estimate-chip{border-radius:4px;padding:4px 8px;font-size:11px;font-weight:600}.create-task-modal .estimate-chip.active{background:var(--color-primary-50, #f0fdf4);color:var(--color-primary-500);border-color:var(--color-primary-300, #a5d6a7)}.create-task-modal .checklist-builder-add .btn{height:38px;padding:0 14px;font-size:13px;font-weight:600;white-space:nowrap}.create-task-modal .modal-footer{padding:14px 28px}.recurring-rule-modal{overflow:hidden}.recurring-rule-modal .modal-header{display:none}.recurring-rule-modal .modal-body{padding:0;overflow:visible}.recurring-rule-modal .form-input,.recurring-rule-modal .list-select-input,.recurring-rule-modal .user-select-trigger{height:38px;font-size:14px}.recurring-rule-modal .list-select-input{font-family:inherit;color:var(--color-text-primary)}.recurring-rule-modal .form-group{margin-bottom:14px}.recurring-rule-modal .form-group:last-child{margin-bottom:0}.recurring-rule-modal .estimate-chips{gap:4px}.recurring-rule-modal .estimate-chip{border-radius:4px;padding:4px 8px;font-size:11px;font-weight:600}.recurring-rule-modal .estimate-chip.active{background:var(--color-primary-50, #f0fdf4);color:var(--color-primary-500);border-color:var(--color-primary-300, #a5d6a7)}.recurring-rule-modal .checklist-builder-add .btn{height:38px;padding:0 14px;font-size:13px;font-weight:600;white-space:nowrap}.recurring-rule-modal .modal-footer{padding:14px 28px}.wo-frequency-bar{background:#2d5a270f;border-bottom:1px solid var(--color-border-light);padding:10px 28px;display:flex;align-items:center;gap:16px;flex-wrap:wrap}.wo-frequency-bar .freq-group{display:flex;align-items:center;gap:6px}.wo-frequency-bar .freq-label{font-size:12px;font-weight:500;color:var(--color-text-secondary);white-space:nowrap}.wo-frequency-bar .freq-type-select{height:32px;padding:0 28px 0 10px;font-size:13px;font-weight:600;border:1px solid var(--color-border);border-radius:6px;background:var(--color-surface);color:var(--color-text-primary);cursor:pointer;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.5'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.wo-frequency-bar .freq-type-select:hover{border-color:var(--color-primary)}.wo-frequency-bar .freq-days{gap:3px}.wo-frequency-bar .day-toggle-btn{height:30px;min-width:38px;padding:0 8px;font-size:11px;font-weight:600;border:1px solid var(--color-border);border-radius:999px;background:var(--color-surface);color:var(--color-text-secondary);cursor:pointer;transition:all .15s ease}.wo-frequency-bar .day-toggle-btn:hover{border-color:#2d5a27;color:#2d5a27;background:#2d5a270f}.wo-frequency-bar .day-toggle-btn.active{background:#2d5a27;border-color:#2d5a27;color:#fff;box-shadow:0 1px 3px #2d5a2740}.wo-frequency-bar .freq-inline-pill{background:var(--color-surface);border:1px solid var(--color-border);border-radius:999px;padding:0 12px;height:32px;gap:6px}.wo-frequency-bar .freq-inline-pill .freq-label{font-size:12px;font-weight:500;color:var(--color-text-tertiary, #9ca3af)}.wo-frequency-bar .freq-num-input{height:28px;width:40px;padding:0 2px;font-size:13px;font-weight:600;text-align:center;border:none;border-radius:4px;background:transparent;color:var(--color-text-primary)}.wo-frequency-bar .freq-num-input:focus{outline:none;background:#2d5a270f}.wo-frequency-bar .freq-num-input::-webkit-outer-spin-button,.wo-frequency-bar .freq-num-input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}.wo-frequency-bar .freq-num-input[type=number]{-moz-appearance:textfield}.wo-frequency-bar .freq-time-input{height:28px;padding:0 2px;font-size:13px;font-weight:600;font-family:inherit;border:none;background:transparent;color:var(--color-text-primary);cursor:pointer}.wo-frequency-bar .freq-time-input:focus{outline:none}.wo-frequency-bar .freq-time-input::-webkit-calendar-picker-indicator{opacity:.4;cursor:pointer;margin-left:2px}.wo-frequency-bar .freq-active-group{margin-left:auto;gap:8px}@media (max-width: 768px){.wo-frequency-bar{padding:10px 16px;gap:10px}.wo-frequency-bar .freq-active-group{margin-left:0}}.wo-banner{background:linear-gradient(135deg,#2d5a27,#3a7233);padding:20px 28px;display:flex;align-items:flex-start;gap:16px}.wo-banner-left{flex:1;min-width:0}.wo-banner-badges{display:flex;align-items:center;gap:8px;margin-bottom:12px;flex-wrap:wrap}.wo-type-badge{display:inline-flex;align-items:center;gap:5px;background:#ffffff2e;color:#fff;font-size:11px;font-weight:700;padding:4px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.4px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);white-space:nowrap}.wo-type-badge svg{width:12px;height:12px}.wo-priority-badge-wrapper{position:relative}.wo-priority-badge{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:4px;text-transform:uppercase;letter-spacing:.4px}.wo-priority-badge-btn{border:1px solid transparent;cursor:pointer;font-family:inherit;transition:opacity .15s}.wo-priority-badge-btn:hover{opacity:.85}.wo-priority-chevron{width:10px;height:10px;opacity:.7}.wo-priority-badge.priority-low{background:#6b728033;color:#d1d5db}.wo-priority-badge.priority-medium{background:#3b82f633;color:#93c5fd}.wo-priority-badge.priority-high{background:#f9731633;color:#ffb066}.wo-priority-badge.priority-urgent{background:#ef444433;color:#fca5a5}.wo-priority-dropdown{position:absolute;top:calc(100% + 6px);left:0;z-index:100;min-width:140px;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-lg);padding:4px;box-shadow:var(--shadow-lg, 0 10px 25px rgba(0,0,0,.15))}.wo-priority-dropdown-item{display:flex;align-items:center;width:100%;padding:7px 12px;background:none;border:none;font-size:12px;font-weight:600;text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:background .12s}.wo-priority-dropdown-item:hover,.wo-priority-dropdown-item.active{background:var(--color-bg-subtle)}.wo-priority-dropdown-item.priority-low{color:var(--color-text-secondary)}.wo-priority-dropdown-item.priority-medium{color:#3b82f6}.wo-priority-dropdown-item.priority-high{color:#f97316}.wo-priority-dropdown-item.priority-urgent{color:#ef4444}.wo-priority-segmented{display:flex;background:#f1f3f5;border-radius:8px;padding:3px;gap:2px}.wo-priority-segment{flex:1;padding:6px 4px;border:none;background:transparent;font-size:12px;font-weight:600;color:#6b7280;cursor:pointer;border-radius:6px;transition:all .15s ease;font-family:inherit}.wo-priority-segment:hover:not(.active){background:#0000000d;color:#374151}.wo-priority-segment.active{box-shadow:0 1px 3px #0000001f}.wo-priority-segment.priority-low.active{background:#fff;color:#374151}.wo-priority-segment.priority-medium.active{background:#dbeafe;color:#1d4ed8}.wo-priority-segment.priority-high.active{background:#ffedd5;color:#c2410c}.wo-priority-segment.priority-urgent.active{background:#fee2e2;color:#b91c1c}.wo-banner-title{width:100%;font-size:20px;font-weight:700;color:#fff;background:transparent;border:none;border-bottom:2px solid rgba(255,255,255,.25);padding:8px 0;outline:none;font-family:inherit}.wo-banner-title::placeholder{color:#fff6;font-weight:400}.wo-banner-title:focus{border-bottom-color:#fff9}.wo-banner-title.has-error{border-bottom-color:#fca5a5}.wo-banner-title-error{font-size:12px;color:#fca5a5;margin-top:4px;font-weight:500}.wo-banner-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;cursor:pointer;color:#fff9;transition:all .15s;flex-shrink:0;background:none;border:none;padding:0}.wo-banner-close:hover{background:#ffffff1f;color:#fff}.work-order-body{display:grid;grid-template-columns:1fr 320px;gap:0;min-height:320px}.work-order-main{display:flex;flex-direction:column;gap:20px;padding:24px 28px;overflow-y:auto;max-height:60vh;border-right:1px solid var(--color-border-light)}.work-order-sidebar{display:flex;flex-direction:column;gap:12px;padding:20px;background:#fafbfc;overflow-y:auto;max-height:60vh}.work-order-main .form-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.4px;color:var(--color-text-secondary);margin-bottom:6px}.wo-info-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:var(--radius-md);padding:14px 16px}.wo-info-card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;color:var(--color-text-tertiary, #999);margin-bottom:10px;display:flex;align-items:center;gap:6px}.wo-info-card-title svg{opacity:.5}.wo-info-card .form-group{margin-bottom:10px}.wo-info-card .form-group:last-child{margin-bottom:0}.wo-info-card .form-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-secondary);margin-bottom:5px}.wo-toggle-switch{position:relative;display:inline-block;width:40px;height:22px;min-width:40px;min-height:22px;background:#ccc;border-radius:12px;cursor:pointer;transition:background .2s;flex-shrink:0;border:none;padding:0;-webkit-appearance:none;-moz-appearance:none;appearance:none;outline:none}.wo-toggle-switch.on{background:var(--color-primary-500)}.wo-toggle-switch:after{content:"";position:absolute;width:18px;height:18px;background:#fff;border-radius:50%;top:2px;left:2px;transition:transform .2s;box-shadow:0 1px 3px #00000026}.wo-toggle-switch.on:after{transform:translate(18px)}.wo-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:8px 0}.wo-toggle-row .wo-toggle-label{font-size:13px;font-weight:500;color:var(--color-text-primary)}.wo-checklist-item{display:flex;align-items:center;gap:10px;padding:8px 12px;background:var(--color-bg-subtle, #f5f5f5);border-radius:var(--radius-sm);margin-bottom:6px;font-size:14px;color:var(--color-text-primary)}.wo-checkbox{width:20px;height:20px;border:2px solid var(--color-primary-300, #a5d6a7);border-radius:5px;flex-shrink:0}.wo-checklist-item span{flex:1;min-width:0}.wo-checklist-item .checklist-builder-remove{opacity:0;transition:opacity .15s}.wo-checklist-item:hover .checklist-builder-remove{opacity:.6}.wo-checklist-item:hover .checklist-builder-remove:hover{opacity:1}.wo-checklist-add{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--color-primary-500);cursor:pointer;padding:6px 4px;font-weight:500;background:none;border:none;font-family:inherit}.wo-checklist-add:hover{text-decoration:underline}.wo-photo-zone{border:2px dashed var(--color-border-light);border-radius:var(--radius-md);padding:16px;text-align:center;color:var(--color-text-tertiary);font-size:13px;cursor:pointer;transition:border-color .15s,background .15s}.wo-photo-zone:hover{border-color:var(--color-primary-300, #86efac);background:var(--color-primary-50, #f0fdf4)}.wo-photo-zone.drag-over{border-color:var(--color-primary-500);background:var(--color-primary-50, #f0fdf4)}.wo-photo-zone svg{display:block;margin:0 auto 6px}@media (max-width: 768px){.modal-xl{max-width:100%}.wo-banner{padding:16px 20px}.wo-banner-title{font-size:16px}.work-order-body{grid-template-columns:1fr}.work-order-sidebar{border-top:1px solid var(--color-border-light);max-height:none}.work-order-main{border-right:none;max-height:none}}.task-type-info-box{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-3);background:var(--color-info-light, #eff6ff);border:1px solid var(--color-info-main, #3b82f6);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-info-dark, #1e40af);margin-top:var(--spacing-4)}.task-type-info-box svg{flex-shrink:0;margin-top:2px}.more-options-section{margin-top:var(--spacing-4);border-top:1px solid var(--color-border-light);padding-top:var(--spacing-3)}.more-options-toggle{display:flex;align-items:center;gap:var(--spacing-2);background:none;border:none;padding:var(--spacing-2) 0;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:color var(--transition-fast)}.more-options-toggle:hover{color:var(--color-text-primary)}.more-options-chevron{transition:transform var(--transition-fast)}.more-options-chevron.expanded{transform:rotate(180deg)}.more-options-content{display:flex;flex-direction:column;gap:var(--spacing-2);padding:var(--spacing-3) 0}.more-option-item{display:flex;flex-wrap:wrap;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.more-option-item:hover{background:var(--color-bg-secondary)}.more-option-item input[type=checkbox]{width:18px;height:18px;margin-top:2px;flex-shrink:0;accent-color:var(--color-primary-500);cursor:pointer}.more-option-item .option-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);line-height:1.4}.more-option-item .option-hint{width:100%;padding-left:26px;font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:0;line-height:1.4}.form-label-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--spacing-1)}.form-label-row .form-label{margin-bottom:0}.field-remove-btn{background:none;border:none;padding:2px 6px;font-size:16px;line-height:1;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.field-remove-btn:hover{background:var(--color-error-light, #fef2f2);color:var(--color-error-500)}.estimate-field{display:flex;flex-direction:column;gap:var(--spacing-2)}.estimate-chips{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.estimate-chip{padding:var(--spacing-1) var(--spacing-2);border:1px solid var(--color-border-main);border-radius:var(--radius-full, 9999px);background:var(--color-bg-default);font-size:var(--font-size-xs);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.estimate-chip:hover{border-color:var(--color-primary-500);color:var(--color-primary-600, #166534);background:var(--color-primary-50, #f0fdf4)}.estimate-chip.active{border-color:var(--color-primary-500);background:var(--color-primary-500);color:#fff}.wo-main-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.wo-main-header-title{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.3px;color:var(--color-text-secondary)}.wo-add-field-wrapper{position:relative}.wo-add-field-btn{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;border:1px solid var(--color-border-main);background:var(--color-bg-paper);color:var(--color-text-secondary);cursor:pointer;transition:all .15s}.wo-add-field-btn:hover{border-color:var(--color-primary-500);color:var(--color-primary-500);background:var(--color-primary-50, #f0fdf4)}.wo-add-field-dropdown{position:absolute;top:calc(100% + 4px);right:0;z-index:50;min-width:200px;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-lg);padding:var(--spacing-1);box-shadow:var(--shadow-lg, 0 10px 25px rgba(0,0,0,.15))}.add-field-item{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);background:none;border:none;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast)}.add-field-item:hover{background:var(--color-bg-subtle)}.add-field-icon{font-size:15px;width:20px;text-align:center;flex-shrink:0}.watcher-combo{position:relative}.watcher-tags-input{display:flex;flex-wrap:wrap;gap:6px;padding:6px 8px;min-height:38px;border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);cursor:text;align-items:center;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.watcher-tags-input:focus-within{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.watcher-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;background:var(--color-primary-100, #dcfce7);color:var(--color-primary-700, #15803d);border-radius:4px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);white-space:nowrap}.watcher-tag.locked{background:var(--color-bg-subtle);color:var(--color-text-secondary)}.watcher-tag-badge{font-size:10px;opacity:.7;margin-left:2px}.watcher-tag-remove{background:none;border:none;padding:0 2px;color:inherit;cursor:pointer;opacity:.6;font-size:14px;line-height:1}.watcher-tag-remove:hover{opacity:1}.watcher-search-input{border:none;outline:none;background:transparent;flex:1;min-width:80px;font-size:var(--font-size-sm);color:var(--color-text-primary);padding:2px 0}.watcher-dropdown{position:absolute;top:100%;left:0;right:0;z-index:50;margin-top:4px;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:0 4px 12px #0000001a;max-height:180px;overflow-y:auto}.watcher-dropdown-item{display:block;width:100%;padding:8px 12px;background:none;border:none;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.watcher-dropdown-item:hover{background:var(--color-bg-subtle)}.photo-preview-row{display:flex;flex-wrap:wrap;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.photo-preview-thumb{position:relative;width:64px;height:64px;border-radius:var(--radius-md);overflow:hidden}.photo-preview-thumb img{width:100%;height:100%;object-fit:cover}.photo-remove-btn{position:absolute;top:2px;right:2px;width:20px;height:20px;background:#0009;color:#fff;border:none;border-radius:50%;font-size:12px;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center}.photo-remove-btn:hover{background:#000c}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--spacing-4)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.form-input{width:100%;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);background:var(--color-bg-paper);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.form-hint{font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-top:var(--spacing-1)}.error-message{padding:var(--spacing-3);background:var(--color-error-light);border:1px solid var(--color-error-main);border-radius:var(--radius-md);color:var(--color-error-dark);font-size:var(--font-size-sm);margin-bottom:var(--spacing-4)}.wizard-steps{display:flex;gap:var(--spacing-1);padding:0 var(--spacing-4);margin-bottom:var(--spacing-4)}.wizard-step{flex:1;display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) 0;border-bottom:3px solid var(--color-border);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:all .15s ease}.wizard-step:hover{color:var(--color-text-primary)}.wizard-step.active{border-bottom-color:var(--color-primary-500);color:var(--color-primary-500)}.wizard-step.completed{border-bottom-color:var(--color-success-500);color:var(--color-success-500)}.wizard-step-number{width:22px;height:22px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;background:var(--color-bg-subtle);flex-shrink:0}.wizard-step.active .wizard-step-number{background:var(--color-primary-500);color:#fff}.wizard-step.completed .wizard-step-number{background:var(--color-success-500);color:#fff}.checklist-builder-item-row{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2);background:var(--color-bg-paper);border-radius:var(--radius-sm)}.checklist-builder-item-row .checklist-item-text{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary);min-width:0}.checklist-builder-item-row .checklist-item-form{flex-shrink:0}.checklist-builder-item-row .checklist-item-form select{font-size:.7rem;padding:2px 6px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-bg-paper);color:var(--color-text-secondary);max-width:140px}.checklist-form-badge{display:inline-block;font-size:.65rem;padding:1px 6px;border-radius:var(--radius-sm);background:#3b82f61a;color:var(--color-primary-500);font-weight:500}.checklist-builder{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3)}.checklist-builder-items{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.checklist-builder-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2);background:var(--color-bg-paper);border-radius:var(--radius-sm)}.checklist-icon{color:var(--color-text-secondary);font-size:var(--font-size-sm);flex-shrink:0;width:16px;text-align:center}.checklist-builder-item span:nth-child(2){flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.checklist-builder-remove{background:transparent;border:none;color:var(--color-error-500);cursor:pointer;padding:var(--spacing-1);font-size:var(--font-size-base);opacity:.6}.checklist-builder-remove:hover{opacity:1}.checklist-builder-add,.checklist-builder-input{display:flex;gap:var(--spacing-2)}.checklist-builder-add .form-input,.checklist-builder-input .form-input{flex:1}.templates-tab{display:flex;flex-direction:column;gap:var(--spacing-4);flex:1;min-height:0;overflow-y:auto;padding:var(--spacing-4)}.templates-header{display:flex;justify-content:space-between;align-items:flex-start}.templates-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.templates-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.templates-empty{text-align:center;padding:var(--spacing-12) var(--spacing-6);background:var(--color-bg-subtle);border-radius:var(--radius-lg)}.templates-empty-icon{font-size:3rem;margin-bottom:var(--spacing-4)}.templates-empty h4{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.templates-empty p{color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.templates-grid{display:flex;flex-direction:column;gap:var(--spacing-6)}.templates-category{display:flex;flex-direction:column;gap:var(--spacing-3)}.templates-category-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0;padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.templates-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.template-card{background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-radius:6px;padding:var(--spacing-4);transition:background .12s,border-color .12s}.template-card:hover{border-color:var(--color-primary-300);background:var(--color-bg-subtle, #f9fafb)}.template-card-header{display:flex;align-items:flex-start;gap:var(--spacing-2);margin-bottom:var(--spacing-2)}.template-priority-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:6px}.template-name{flex:1;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.template-shared-badge{background:var(--color-info-100);color:var(--color-info-700);padding:2px var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.template-feature-tag{background:var(--color-warning-100, #fef3c7);color:var(--color-warning-700, #92400e);padding:2px var(--spacing-2);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}.template-task-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.template-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-3)}.template-meta{display:flex;flex-wrap:wrap;gap:var(--spacing-3);margin-bottom:var(--spacing-3)}.template-meta-item{font-size:var(--font-size-xs);color:var(--color-text-secondary);display:flex;align-items:center;gap:var(--spacing-1)}.template-actions{display:flex;gap:var(--spacing-2);padding-top:var(--spacing-3);border-top:1px solid var(--color-border-light)}.template-type-badge{display:inline-block;padding:2px 8px;background:var(--color-bg-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize}.template-feature-badge{color:var(--color-primary-600);font-weight:var(--font-weight-medium)}.feature-toggles{display:flex;flex-direction:column;gap:var(--spacing-2);margin-top:var(--spacing-1)}.feature-toggle{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.feature-toggle:hover{background:var(--color-bg-tertiary)}.feature-toggle input[type=checkbox]{width:18px;height:18px;margin:0;flex-shrink:0;accent-color:var(--color-primary-500);cursor:pointer}.feature-toggle span{font-size:var(--font-size-sm);color:var(--color-text-primary);line-height:1}.use-template-preview{padding:var(--spacing-3);background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--spacing-4)}.use-template-preview .preview-title{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.use-template-preview .preview-meta{display:flex;flex-wrap:wrap;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.form-section-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.workload-container{padding:var(--spacing-4);overflow-y:auto;flex:1}.workload-week-nav{display:flex;align-items:center;gap:var(--spacing-3);margin-bottom:var(--spacing-5)}.workload-week-label{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);min-width:200px;text-align:center}.workload-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-12) var(--spacing-4);color:var(--color-text-secondary);text-align:center;gap:var(--spacing-2)}.workload-empty .text-secondary{font-size:var(--font-size-sm);color:var(--color-text-tertiary, #9ca3af)}.workload-grid{display:flex;flex-direction:column;border:1px solid var(--color-border-light);border-radius:var(--radius-lg);overflow:hidden}.workload-header-row{display:grid;grid-template-columns:180px repeat(7,1fr) 140px;background:var(--color-bg-subtle, #f9fafb);border-bottom:2px solid var(--color-border-light)}.workload-col-label{font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary);padding:var(--spacing-2) var(--spacing-3);display:flex;align-items:center}.workload-day-header{display:flex;flex-direction:column;align-items:center;padding:var(--spacing-2) var(--spacing-1);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.workload-day-name{font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em}.workload-day-num{font-size:var(--font-size-xs);color:var(--color-text-tertiary, #9ca3af)}.workload-total-header{display:flex;align-items:center;justify-content:center;padding:var(--spacing-2);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.workload-row{display:grid;grid-template-columns:180px repeat(7,1fr) 140px;border-bottom:1px solid var(--color-border-light);transition:background var(--transition-fast)}.workload-row:last-child{border-bottom:none}.workload-row:hover{background:var(--color-bg-subtle, #f9fafb)}.workload-row .workload-row-header{padding:var(--spacing-3);display:flex;align-items:center;border-right:1px solid var(--color-border-light);min-width:0}.workload-row .workload-row-header .user-display-inline,.workload-row .workload-row-header .team-display-inline{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.workload-day-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;padding:var(--spacing-2) var(--spacing-1);border-right:1px solid var(--color-border-light);min-height:48px}.workload-day-cell:last-of-type{border-right:none}.workload-bar-container{width:100%;height:8px;background:var(--color-bg-subtle, #f3f4f6);border-radius:4px;overflow:visible;position:relative}.workload-bar{height:100%;border-radius:4px;transition:width .3s ease}.workload-bar.workload-light{background:#22c55e}.workload-bar.workload-moderate{background:#f59e0b}.workload-bar.workload-heavy{background:#f97316}.workload-bar.workload-overloaded{background:#ef4444}.workload-bar-overflow{position:absolute;top:0;right:0;height:100%;background:repeating-linear-gradient(-45deg,#ef4444,#ef4444 2px,#dc2626 2px,#dc2626 4px);border-radius:0 4px 4px 0;transform:translate(100%)}.workload-cell-label{font-size:10px;color:var(--color-text-secondary);white-space:nowrap}.workload-total{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-2);border-left:1px solid var(--color-border-light)}.workload-total-hours{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.workload-total-capacity{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.workload-unestimated{font-size:10px;color:var(--color-text-tertiary, #9ca3af);font-style:italic;margin-top:2px}.workload-legend{display:flex;align-items:center;gap:var(--spacing-4);margin-top:var(--spacing-4);padding:var(--spacing-2) 0}.workload-legend-item{display:flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.workload-legend-swatch{display:inline-block;width:12px;height:8px;border-radius:2px}.workload-legend-swatch.workload-light{background:#22c55e}.workload-legend-swatch.workload-moderate{background:#f59e0b}.workload-legend-swatch.workload-heavy{background:#f97316}.workload-legend-swatch.workload-overloaded{background:#ef4444}@media (max-width: 768px){.workload-header-row,.workload-row{grid-template-columns:120px repeat(7,1fr) 100px}.workload-week-label{font-size:var(--font-size-sm);min-width:150px}.workload-day-header .workload-day-name{font-size:10px}.workload-row .workload-row-header{padding:var(--spacing-2);font-size:var(--font-size-xs)}}.settings-tab{max-width:600px}.settings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-6)}.settings-header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.settings-saving,.settings-saved{font-size:var(--font-size-sm);padding:var(--spacing-1) var(--spacing-3);border-radius:4px}.settings-saving{color:var(--color-warning-700);background:var(--color-warning-100)}.settings-saved{color:var(--color-success-700);background:var(--color-success-100)}.settings-section{margin-bottom:var(--spacing-6)}.settings-section h4{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-2)}.settings-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-4)}.settings-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:var(--spacing-3) var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.settings-item-content{flex:1}.settings-item-label{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.settings-item-description{display:block;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.settings-timing{max-width:200px}.settings-hint{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-style:italic;margin-top:var(--spacing-4)}.settings-nav{display:flex;gap:8px;padding:12px 20px;border-bottom:1px solid var(--color-border-light);background:#fff;flex-shrink:0}.settings-nav-btn{padding:var(--spacing-2) var(--spacing-4);background:transparent;border:1px solid var(--color-border-main);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.settings-nav-btn:hover{background:var(--color-bg-subtle);color:var(--color-text-primary)}.settings-nav-btn.active{background:var(--color-primary-50);border-color:var(--color-primary-500);color:var(--color-primary-700)}.autorules-list{display:flex;flex-direction:column;gap:var(--spacing-3)}.autorule-item{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-md);border:1px solid var(--color-border-light)}.autorule-info{flex:1}.autorule-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.autorule-type{font-size:var(--font-size-xs);color:var(--color-primary-600);background:var(--color-primary-50);padding:var(--spacing-1) var(--spacing-2);border-radius:4px;display:inline-block;margin-bottom:var(--spacing-2)}.autorule-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.autorule-last-triggered{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.autorule-actions{display:flex;align-items:center;gap:var(--spacing-3)}.archive-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-4);margin-bottom:var(--spacing-6)}.archive-stat{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-4);text-align:center}.archive-stat-value{display:block;font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-primary-600);margin-bottom:var(--spacing-1)}.archive-stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.archive-info{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-4)}.archive-info h4{margin-bottom:var(--spacing-2)}.archive-info ul{margin:0;padding-left:var(--spacing-4)}.archive-info li{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-1)}.empty-state{text-align:center;padding:var(--spacing-8);color:var(--color-text-secondary);font-style:italic}.subtasks-list{display:flex;flex-direction:column;gap:var(--spacing-2)}.subtask-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-sm)}.subtask-item.completed{opacity:.7}.subtask-item.completed .subtask-title{text-decoration:line-through;color:var(--color-text-secondary)}.subtask-checkbox{width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-full);border:2px solid var(--color-border-main);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.subtask-checkbox.checked{background:var(--color-success-500);border-color:var(--color-success-500);color:#fff}.subtask-title{flex:1;font-size:var(--font-size-sm);color:var(--color-text-primary)}.subtask-status{font-size:var(--font-size-xs);text-transform:capitalize;color:var(--color-text-tertiary)}.subtask-add-form{display:flex;flex-direction:column;gap:var(--spacing-2);margin-bottom:var(--spacing-3)}.subtask-add-actions{display:flex;gap:var(--spacing-2);justify-content:flex-end}.no-subtasks{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.parent-task-info{background:var(--color-bg-subtle);padding:var(--spacing-3);border-radius:var(--radius-md)}.parent-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-style:italic}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--color-neutral-300);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:var(--color-primary-500)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(22px)}.modal-lg{max-width:700px}.form-section{margin-bottom:var(--spacing-6)}.form-section:last-child{margin-bottom:0}.form-section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-4);padding-bottom:var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.custom-select{position:relative;display:inline-block;min-width:140px}.custom-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);width:100%;height:40px;padding:0 var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast);text-align:left}.custom-select-trigger:hover:not(.disabled){border-color:var(--color-border-dark)}.custom-select-trigger:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.custom-select-trigger.open{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.custom-select-trigger.disabled{background:var(--color-bg-subtle);color:var(--color-text-secondary);cursor:not-allowed}.custom-select-value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-select-placeholder{color:var(--color-text-tertiary)}.custom-select-chevron{flex-shrink:0;color:var(--color-text-secondary);transition:transform var(--transition-fast)}.custom-select-chevron.open{transform:rotate(180deg)}.custom-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:280px;overflow-y:auto}.custom-select-options{padding:var(--spacing-1)}.custom-select-option{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);border:none;border-radius:var(--radius-sm);background:transparent;font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.custom-select-option:hover{background:var(--color-bg-subtle)}.custom-select-option.selected{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:var(--font-weight-medium)}.custom-select-option-content{display:flex;align-items:center;gap:var(--spacing-2)}.custom-select-option-icon{display:flex;align-items:center;color:var(--color-text-secondary)}.custom-select-color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.custom-select-sm .custom-select-trigger{height:32px;padding:0 var(--spacing-2);font-size:var(--font-size-sm)}.custom-select-sm .custom-select-option{padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-xs)}.user-select{position:relative;display:inline-block;width:100%}.user-select-trigger{display:flex;align-items:center;justify-content:space-between;gap:var(--spacing-2);width:100%;height:40px;padding:0 var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);font-family:inherit;font-size:var(--font-size-base);color:var(--color-text-primary);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.user-select-trigger:hover{border-color:var(--color-border-dark)}.user-select-trigger:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.user-select-value{display:flex;align-items:center;gap:var(--spacing-2);flex:1;overflow:hidden}.user-select-value span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-select-placeholder{color:var(--color-text-tertiary)}.user-select-chevron{flex-shrink:0;color:var(--color-text-secondary);transition:transform var(--transition-fast)}.user-select-chevron.open{transform:rotate(180deg)}.user-select-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-bg-paper);border:1px solid var(--color-border-main);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:100;max-height:300px;overflow:hidden;display:flex;flex-direction:column}.user-select-search{padding:var(--spacing-2);border-bottom:1px solid var(--color-border-light)}.user-select-search-input{width:100%;height:36px;padding:0 var(--spacing-3);border:1px solid var(--color-border-light);border-radius:var(--radius-md);font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);background:var(--color-bg-subtle)}.user-select-search-input:focus{outline:none;border-color:var(--color-primary-500);background:var(--color-bg-paper)}.user-select-options{overflow-y:auto;padding:var(--spacing-1);max-height:240px}.user-select-option{display:flex;align-items:center;gap:var(--spacing-2);width:100%;padding:var(--spacing-2) var(--spacing-3);border:none;border-radius:var(--radius-sm);background:transparent;font-family:inherit;font-size:var(--font-size-sm);color:var(--color-text-primary);text-align:left;cursor:pointer;transition:background var(--transition-fast)}.user-select-option:hover{background:var(--color-bg-subtle)}.user-select-option.selected{background:var(--color-primary-50);color:var(--color-primary-700);font-weight:var(--font-weight-medium)}.user-select-option-avatar.empty{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.user-select-empty{padding:var(--spacing-4);text-align:center;color:var(--color-text-secondary);font-size:var(--font-size-sm)}.user-multi-select{position:relative;width:100%}.user-multi-select-trigger{display:flex;align-items:center;gap:var(--spacing-2);min-height:42px;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-main);border-radius:var(--radius-md);background:var(--color-bg-paper);cursor:pointer;transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.user-multi-select-trigger:hover{border-color:var(--color-border-dark)}.user-multi-select-trigger.focused{border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.user-multi-chips-area{display:flex;flex-wrap:wrap;align-items:center;gap:6px;flex:1;min-width:0}.user-multi-placeholder{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.user-multi-chip{display:inline-flex;align-items:center;gap:4px;padding:3px 8px 3px 3px;border-radius:999px;background:var(--color-primary-50);border:1px solid var(--color-primary-200);font-size:var(--font-size-sm);color:var(--color-primary-700);white-space:nowrap;line-height:1.4}.user-multi-chip.locked{background:var(--color-bg-subtle);border-color:var(--color-border-light);color:var(--color-text-secondary);padding-right:8px}.user-multi-chip-name{max-width:100px;overflow:hidden;text-overflow:ellipsis}.user-multi-chip-badge{font-size:10px;opacity:.7;padding:1px 5px;background:#0000000f;border-radius:4px}.user-multi-chip-remove{background:none;border:none;padding:0 2px;cursor:pointer;font-size:14px;line-height:1;color:var(--color-primary-500);opacity:.6;transition:opacity var(--transition-fast)}.user-multi-chip-remove:hover{opacity:1}.user-display{display:inline-flex;align-items:center;gap:var(--spacing-2)}.user-display.unassigned{color:var(--color-text-tertiary)}.user-display-avatar-placeholder{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:50%;background:var(--color-bg-subtle);color:var(--color-text-tertiary)}.user-display-name{font-size:var(--font-size-sm);color:inherit}.user-display-inline{display:inline-flex;align-items:center;gap:var(--spacing-1);font-size:var(--font-size-sm)}.user-display-inline.unassigned{color:var(--color-text-tertiary)}.team-display-swatch{width:14px;height:14px;border-radius:3px;flex-shrink:0}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;overflow:hidden;flex-shrink:0;font-weight:var(--font-weight-medium);color:#fff}.avatar img{width:100%;height:100%;object-fit:cover}.avatar-initials{text-transform:uppercase}.avatar-xs{width:20px;height:20px;font-size:9px}.avatar-sm{width:28px;height:28px;font-size:11px}.avatar-md{width:36px;height:36px;font-size:14px}.avatar-lg{width:48px;height:48px;font-size:18px}.avatar-xl{width:64px;height:64px;font-size:24px}.avatar-group{display:inline-flex;flex-direction:row-reverse}.avatar-group .avatar{margin-left:-8px;border:2px solid var(--color-bg-paper)}.avatar-group .avatar:last-child{margin-left:0}.avatar-more{background:var(--color-bg-subtle);color:var(--color-text-secondary);font-size:10px}.form-input{height:40px}.form-input-sm{height:32px;padding:var(--spacing-1) var(--spacing-2);font-size:var(--font-size-sm)}textarea.form-input{height:auto;min-height:80px;resize:vertical}select.form-input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.master-data-dashboard{display:flex;flex-direction:column;gap:var(--spacing-6)}.master-data-section{display:flex;flex-direction:column;gap:var(--spacing-4)}.master-data-section .section-header{margin-bottom:0;padding-bottom:var(--spacing-2)}.master-data-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--spacing-4)}.master-data-card{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-paper);border:1px solid var(--color-border-light);border-left:4px solid var(--card-accent, var(--color-primary-500));border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);text-align:left;width:100%}.master-data-card:hover{border-color:var(--card-accent, var(--color-primary-500));background:var(--color-bg-subtle, #f9fafb)}.master-data-card-icon{font-size:2rem;flex-shrink:0}.master-data-card-content{flex:1;min-width:0}.master-data-card-content h3{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.master-data-card-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.master-data-card-count{display:flex;align-items:baseline;gap:var(--spacing-1);flex-shrink:0}.master-data-card-count .count-active{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.master-data-card-count .count-total{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.master-data-list{display:flex;flex-direction:column}.master-data-list-item{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border-light);cursor:pointer;transition:background var(--transition-fast)}.master-data-list-item:last-child{border-bottom:none}.master-data-list-item:hover{background:var(--color-primary-50, #f0fdf4)}.master-data-list-item.inactive{opacity:.6;background:var(--color-bg-subtle)}.master-data-list-item.inactive:hover{background:var(--color-bg-default)}.master-data-list-item .item-main{flex:1;display:flex;align-items:center;gap:var(--spacing-3);min-width:0}.master-data-list-item .item-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.master-data-list-item .item-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.master-data-list-item .item-code{font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-bg-subtle);padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.master-data-list-item .item-type-badge{font-size:var(--font-size-xs);color:var(--color-text-secondary);background:var(--color-bg-default);padding:var(--spacing-1) var(--spacing-2);border-radius:4px;text-transform:capitalize}.master-data-list-item .item-status{flex-shrink:0}.master-data-list-item .item-actions{display:flex;gap:var(--spacing-1);flex-shrink:0}.category-header{display:flex;align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-subtle);border-radius:var(--radius-lg);margin-bottom:var(--spacing-4)}.category-header-icon{font-size:2.5rem}.category-header-content h2{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--spacing-1) 0}.category-header-content p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}.color-picker{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.color-swatch{width:32px;height:32px;border-radius:var(--radius-md);border:2px solid transparent;cursor:pointer;transition:all var(--transition-fast)}.color-swatch:hover{border-color:var(--color-border-main, #d1d5db)}.color-swatch.selected{border-color:var(--color-text-primary);outline:2px solid var(--color-text-primary);outline-offset:2px}.color-swatch.clear{background:var(--color-bg-subtle);border:1px dashed var(--color-border-default);display:flex;align-items:center;justify-content:center;color:var(--color-text-secondary);font-size:var(--font-size-xs)}.list-select{display:flex;flex-direction:column;gap:var(--spacing-1)}.list-select-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.list-select-label .required{color:var(--color-error-500);margin-left:var(--spacing-1)}.list-select-container{display:flex;gap:var(--spacing-2)}.list-select-input{flex:1;padding:var(--spacing-2) var(--spacing-3);border:1px solid var(--color-border-default);border-radius:var(--radius-md);font-size:var(--font-size-sm);background:var(--color-bg-paper)}.list-select-input:focus{outline:none;border-color:var(--color-primary-500);box-shadow:0 0 0 3px #2d5a271a}.list-select-add-btn{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border:1px solid var(--color-primary-500);background:var(--color-bg-paper);color:var(--color-primary-500);border-radius:var(--radius-md);font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);cursor:pointer;transition:all var(--transition-fast)}.list-select-add-btn:hover{background:var(--color-primary-50)}.empty-state .empty-icon{font-size:3rem;display:block;margin-bottom:var(--spacing-3)}.checkbox-label{display:flex;align-items:center;gap:var(--spacing-2);font-size:var(--font-size-sm);color:var(--color-text-primary);cursor:pointer}.checkbox-label input[type=checkbox]{width:16px;height:16px;cursor:pointer}.modal-sm{max-width:360px}.btn-danger:hover{background:var(--color-error-50);color:var(--color-error-600)}.btn-ghost{background:transparent;border:none;padding:var(--spacing-1) var(--spacing-2)}.btn-ghost:hover{background:var(--color-bg-subtle)}@media (max-width: 768px){.master-data-grid{grid-template-columns:1fr}.master-data-card{padding:var(--spacing-3)}.master-data-list-item{flex-wrap:wrap}.master-data-list-item .item-actions{width:100%;margin-top:var(--spacing-2);justify-content:flex-end}.category-header{flex-direction:column;text-align:center}}.field-map-container{display:flex;flex-direction:column;gap:var(--spacing-4)}.field-map{border-radius:var(--radius-lg);border:1px solid var(--color-border-light);overflow:hidden}.field-map-popup{min-width:150px}.field-map-popup .popup-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.field-map-popup .popup-code{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.field-map-popup .popup-info{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-3)}.field-map-popup .popup-info p{margin:var(--spacing-1) 0}.field-map-popup .popup-button{width:100%}.field-map-legend{background:var(--color-bg-paper);border-radius:var(--radius-md);padding:var(--spacing-3);border:1px solid var(--color-border-light)}.field-map-legend h5{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.field-map-legend .legend-items{display:flex;flex-wrap:wrap;gap:var(--spacing-2)}.field-map-legend .legend-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);border-radius:var(--radius-md);background:var(--color-bg-subtle);cursor:pointer;transition:background .2s}.field-map-legend .legend-item:hover{background:var(--color-bg-default)}.field-map-legend .legend-item.selected{background:var(--color-primary-50);border:1px solid var(--color-primary-500)}.field-map-legend .legend-color{width:12px;height:12px;border-radius:var(--radius-sm)}.field-map-legend .legend-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.field-map-legend .legend-area{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.field-map-unmapped{background:var(--color-bg-subtle);border-radius:var(--radius-md);padding:var(--spacing-3)}.field-map-unmapped h5{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin-bottom:var(--spacing-2)}.field-map-unmapped .unmapped-hint{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin-bottom:var(--spacing-2)}.field-map-unmapped .unmapped-list{display:flex;flex-wrap:wrap;gap:var(--spacing-1)}.field-map-unmapped .unmapped-field{display:inline-block;padding:var(--spacing-1) var(--spacing-2);background:var(--color-bg-paper);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-text-secondary)}.boundary-editor{display:flex;flex-direction:column;gap:var(--spacing-4)}.boundary-editor__header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:var(--spacing-3)}.boundary-editor__header h3{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.boundary-editor__toolbar{display:flex;align-items:center;gap:var(--spacing-3);padding:var(--spacing-2) var(--spacing-3);background:var(--color-bg-subtle);border-radius:var(--radius-md)}.boundary-editor__toolbar .toolbar-divider{width:1px;height:20px;background:var(--color-border-main)}.boundary-editor__toolbar .toolbar-info{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.boundary-editor__hint{padding:var(--spacing-3);background:var(--color-info-light);border-radius:var(--radius-md);font-size:var(--font-size-sm);color:var(--color-info-dark)}.boundary-editor__map{border-radius:var(--radius-lg);border:1px solid var(--color-border-light);overflow:hidden}.boundary-editor__footer{display:flex;justify-content:flex-end;gap:var(--spacing-2)}.boundary-vertex-marker{background:transparent!important;border:none!important}.boundary-vertex-marker .vertex-dot{width:14px;height:14px;background:var(--color-primary-500);border:2px solid white;border-radius:50%;box-shadow:0 2px 4px #0000004d;cursor:move}.boundary-add-marker{background:transparent!important;border:none!important}.boundary-add-marker .add-dot{width:18px;height:18px;background:var(--color-primary-100);border:2px dashed var(--color-primary-500);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:var(--color-primary-500);cursor:pointer}.boundary-add-marker .add-dot:hover{background:var(--color-primary-200)}.area-display{display:flex;align-items:baseline;gap:var(--spacing-2)}.area-display__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.area-display__value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-primary-500)}.area-display__secondary{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.area-display--empty .area-display__value{color:var(--color-text-tertiary)}.btn-map-view{display:inline-flex;align-items:center;gap:var(--spacing-2)}.boundary-badge{display:inline-flex;align-items:center;gap:var(--spacing-1);padding:var(--spacing-1) var(--spacing-2);background:var(--color-success-light);border-radius:4px;font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);color:var(--color-success-dark)}.boundary-badge--empty{background:var(--color-neutral-200);color:var(--color-text-secondary)}.map-modal{max-width:900px!important}.map-modal .modal-body{padding:var(--spacing-4)}.linked-tasks{margin-top:var(--spacing-4);padding:var(--spacing-3);background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px}.linked-tasks h4{margin:0 0 var(--spacing-2) 0;font-size:.875rem;font-weight:600;color:var(--color-text-secondary)}.linked-task-item{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-2);border-radius:6px;transition:background .15s}.linked-task-item:hover{background:var(--color-neutral-100)}.linked-task-item+.linked-task-item{border-top:1px solid var(--color-border-light)}.linked-task-item .task-title{flex:1;font-size:.875rem;font-weight:500;color:var(--color-text)}.linked-task-item .task-status{font-size:.75rem;text-transform:capitalize;color:var(--color-text-secondary)}.status-dot{display:inline-block;width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.status-pending{background-color:var(--color-warning, #f59e0b)}.status-dot.status-in_progress{background-color:var(--color-info, #3b82f6)}.status-dot.status-pending_review{background-color:#8b5cf6}.status-dot.status-completed{background-color:var(--color-success, #22c55e)}.status-dot.status-rejected{background-color:var(--color-danger, #ef4444)}.status-dot.status-cancelled{background-color:var(--color-neutral-400, #9ca3af)}.linked-record-info-bar{display:flex;align-items:center;gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-3);margin-bottom:var(--spacing-3);background:var(--color-neutral-100);border:1px solid var(--color-border);border-radius:6px;font-size:.875rem}.linked-record-info-bar .linked-label{color:var(--color-text-secondary);font-weight:500}.linked-record-info-bar .linked-value{color:var(--color-text);font-weight:600}.source-record-link{display:flex;align-items:flex-start;gap:var(--spacing-2);padding:var(--spacing-2);border:1px solid var(--color-border);border-radius:6px;background:var(--color-neutral-50);color:var(--color-primary-500)!important;font-size:.8125rem;font-weight:500;text-align:left;line-height:1.4;cursor:pointer;transition:background .15s,border-color .15s;text-decoration:none!important;width:100%}.source-record-link:hover{background:var(--color-primary-light, #eff6ff);border-color:var(--color-primary-500)}.source-record-link svg{flex-shrink:0;margin-top:1px}.sidebar-source-title{font-size:.8125rem;color:var(--color-text-secondary)}.notification-bell-container{position:relative}.notification-bell-button{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.3);background:#ffffff26;color:#fff;cursor:pointer;transition:all .15s ease;position:relative}.notification-bell-button:hover{background:#ffffff40;border-color:#ffffff80}.notification-bell-icon{width:20px;height:20px}.notification-badge{position:absolute;top:-4px;right:-4px;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:#ef4444;color:#fff;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;line-height:1}.notification-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:90}.notification-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:360px;max-height:480px;background:#fff;border-radius:var(--radius-lg);box-shadow:0 10px 40px #00000026,0 2px 8px #0000001a;z-index:100;overflow:hidden;display:flex;flex-direction:column}.notification-header{display:flex;align-items:center;justify-content:space-between;padding:var(--spacing-3) var(--spacing-4);border-bottom:1px solid var(--color-border)}.notification-header h3{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.notification-mark-all-read{background:none;border:none;color:var(--color-primary-500);font-size:var(--font-size-sm);cursor:pointer;padding:var(--spacing-1) var(--spacing-2);border-radius:var(--radius-sm)}.notification-mark-all-read:hover{background:var(--color-bg-secondary)}.notification-list{overflow-y:auto;max-height:420px}.notification-loading,.notification-empty{padding:var(--spacing-8) var(--spacing-4);text-align:center;color:var(--color-text-secondary)}.notification-empty-icon{font-size:2rem;display:block;margin-bottom:var(--spacing-2)}.notification-empty p{margin:0;font-size:var(--font-size-sm)}.notification-item{display:flex;align-items:flex-start;gap:var(--spacing-3);width:100%;padding:var(--spacing-3) var(--spacing-4);border:none;border-bottom:1px solid var(--color-border);background:none;cursor:pointer;text-align:left;transition:background .1s ease}.notification-item:last-child{border-bottom:none}.notification-item:hover{background:var(--color-bg-secondary)}.notification-item.unread{background:#3b82f60a}.notification-item.unread:hover{background:#3b82f614}.notification-item-icon{flex-shrink:0;font-size:1.125rem;line-height:1;margin-top:2px}.notification-item-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.notification-item-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.notification-item-message{font-size:var(--font-size-sm);color:var(--color-text-secondary);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.notification-item-time{font-size:.6875rem;color:var(--color-text-tertiary)}.notification-unread-dot{flex-shrink:0;width:8px;height:8px;border-radius:50%;background:var(--color-primary-500);margin-top:6px}.meter-field-error{display:block;font-size:12px;color:#ef4444;margin-top:4px;line-height:1.3}.meter-field-warning{display:block;font-size:12px;color:#d97706;margin-top:4px;line-height:1.3}.meter-confirm-label{display:flex;align-items:center;gap:8px;padding:10px 12px;margin-bottom:16px;background:#fffbeb;border:1px solid #fcd34d;border-radius:6px;font-size:13px;color:#92400e;cursor:pointer}.meter-confirm-label input[type=checkbox]{width:16px;height:16px;accent-color:#f59e0b;flex-shrink:0}.capture-form{padding:4px 0}.capture-context-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;padding:12px 16px;margin-bottom:16px}.capture-context-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.capture-context-row+.capture-context-row{margin-top:8px;padding-top:8px;border-top:1px solid var(--color-border)}.capture-context-item{display:flex;flex-direction:column;gap:2px}.capture-context-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.capture-context-value{font-size:14px;color:var(--color-text);font-weight:500}.capture-status-running{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;margin-bottom:16px;font-size:13px;color:#1d4ed8;font-weight:500}.capture-status-done{text-align:center;padding:10px;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px;color:#16a34a;font-weight:600;font-size:14px;margin-bottom:12px}.capture-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.capture-field{display:flex;flex-direction:column;gap:4px;font-size:12px;font-weight:600;color:#374151}.capture-field .form-input{font-size:13px}.capture-actions{display:flex;gap:8px;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--color-border)}.capture-readonly-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.capture-readonly-item{display:flex;flex-direction:column;gap:2px}.checklist-item-capture{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;border:1px solid var(--color-border);background:var(--color-surface);margin-bottom:4px;transition:background-color .15s}.checklist-item-capture:hover{background:var(--color-surface-hover, #f9fafb)}.checklist-item-capture.completed{background:#f0fdf4;border-color:#bbf7d0}.checklist-item-capture .checklist-item-text{flex:1;font-size:13px}.checklist-item-capture.completed .checklist-item-text{color:#16a34a}.checklist-capture-btn{padding:4px 10px;font-size:12px;font-weight:500;border-radius:4px;border:1px solid var(--color-border);background:#fff;color:var(--color-text-secondary);cursor:pointer;transition:all .15s;white-space:nowrap}.checklist-capture-btn:hover{background:var(--color-primary-500);color:#fff;border-color:var(--color-primary-500)}.checklist-capture-btn.view-btn{border-color:#bbf7d0;color:#16a34a}.checklist-capture-btn.view-btn:hover{background:#16a34a;color:#fff;border-color:#16a34a}.task-form-card{border:1px solid var(--color-border);border-radius:8px;padding:16px;margin-bottom:20px;background:#fefce8;border-color:#fde68a}.task-form-card.completed{background:#f0fdf4;border-color:#bbf7d0}.task-form-card-info{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.task-form-card-header{display:flex;gap:10px;align-items:flex-start}.task-form-card-header svg{flex-shrink:0;margin-top:2px;color:#6b7280}.task-form-card.completed .task-form-card-header svg{color:#16a34a}.task-form-card-actions{margin-top:12px;display:flex;justify-content:flex-end}.form-status-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 8px;border-radius:4px;white-space:nowrap}.form-status-badge.pending{background:#fef3c7;color:#92400e}.form-status-badge.completed{background:#dcfce7;color:#166534}.task-form-reminder{display:flex;align-items:center;gap:8px;font-size:12px;color:#92400e;background:#fef3c7;padding:8px 10px;border-radius:6px;border:1px solid #fde68a}.toast-container{position:fixed;bottom:1rem;right:1rem;display:flex;flex-direction:column;gap:.5rem;z-index:9999;pointer-events:none}.toast{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;border-radius:.5rem;box-shadow:0 4px 12px #00000026;animation:toast-slide-in .2s ease-out;pointer-events:auto;max-width:420px;min-width:280px;font-size:.875rem;line-height:1.4}.toast-removing{animation:toast-fade-out .2s ease-in forwards}.toast-icon{flex-shrink:0;width:1.25rem;height:1.25rem;display:flex;align-items:center;justify-content:center;border-radius:50%;font-size:.75rem;font-weight:700}.toast-message{flex:1;word-break:break-word}.toast-dismiss{flex-shrink:0;background:none;border:none;cursor:pointer;padding:.25rem;font-size:1.25rem;line-height:1;opacity:.6;transition:opacity .15s}.toast-dismiss:hover{opacity:1}.toast-error{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.toast-error .toast-icon{background:#dc2626;color:#fff}.toast-error .toast-dismiss{color:#991b1b}.toast-success{background:#dcfce7;color:#166534;border:1px solid #bbf7d0}.toast-success .toast-icon{background:#16a34a;color:#fff}.toast-success .toast-dismiss{color:#166534}.toast-warning{background:#fef9c3;color:#854d0e;border:1px solid #fde047}.toast-warning .toast-icon{background:#ca8a04;color:#fff}.toast-warning .toast-dismiss{color:#854d0e}.toast-info{background:#e0f2fe;color:#075985;border:1px solid #bae6fd}.toast-info .toast-icon{background:#0284c7;color:#fff}.toast-info .toast-dismiss{color:#075985}@keyframes toast-slide-in{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@keyframes toast-fade-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(100%)}}@media (max-width: 768px){.toast-container{left:1rem;right:1rem;bottom:1rem;align-items:center}.toast{max-width:100%;min-width:0;width:100%}}.documents-layout{display:flex;height:100%;min-height:0}.documents-sidebar{width:220px;min-width:220px;border-right:1px solid #d1d5db;padding:12px 0;overflow-y:auto;background:#f9fafb}.documents-sidebar-section{margin-bottom:16px}.documents-sidebar-heading{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#9ca3af;padding:4px 16px;margin-bottom:2px;display:flex;align-items:center;width:100%;border:none;background:none;cursor:pointer;text-align:left}.documents-sidebar-heading:hover{color:#6b7280}.documents-sidebar-add{margin-left:auto;font-size:14px;cursor:pointer;color:#9ca3af;padding:0 2px}.documents-sidebar-add:hover{color:#374151}.documents-sidebar-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 16px;border:none;background:none;font-size:13px;color:#374151;cursor:pointer;text-align:left;transition:background .15s}.documents-sidebar-item:hover{background:#e5e7eb}.documents-sidebar-item.active{background:#d4edda;color:#1a4d1a;font-weight:600}.documents-sidebar-item-row{display:flex;align-items:center;position:relative}.documents-sidebar-item-row .documents-sidebar-item{flex:1;min-width:0}.documents-sidebar-item-actions{display:none;align-items:center;gap:2px;padding-right:8px;flex-shrink:0}.documents-sidebar-item-row:hover .documents-sidebar-item-actions{display:flex}.documents-sidebar-action-btn{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;background:none;border-radius:4px;cursor:pointer;color:#6b7280;transition:background .15s,color .15s}.documents-sidebar-action-btn:hover{background:#e5e7eb;color:#374151}.documents-sidebar-action-btn.danger:hover{background:#fee2e2;color:#991b1b}.documents-visibility-toggle{display:flex;gap:0;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.documents-visibility-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:500;color:#6b7280;background:#fff;border:none;cursor:pointer;transition:background .15s,color .15s}.documents-visibility-btn:not(:last-child){border-right:1px solid #d1d5db}.documents-visibility-btn:hover{background:#f3f4f6}.documents-visibility-btn.active{background:#f0fdf4;color:#2d5a27;font-weight:600}.documents-visibility-badge{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:500;padding:2px 8px;border-radius:4px}.documents-visibility-badge.private{background:#f3f4f6;color:#6b7280}.documents-visibility-badge.shared{background:#f0fdf4;color:#2d5a27}.documents-sidebar-item-child{padding-left:32px;font-size:12px}.documents-sidebar-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.documents-sidebar-count{margin-left:auto;font-size:11px;color:#9ca3af;background:#f3f4f6;padding:0 6px;border-radius:8px;min-width:18px;text-align:center}.documents-sidebar-empty{padding:8px 16px;font-size:12px;color:#9ca3af}.documents-smart-view{padding:16px 20px}.documents-smart-view-header{display:flex;align-items:center;gap:10px;margin-bottom:4px}.documents-smart-view-header h3{font-size:16px;font-weight:600;color:#111827;margin:0}.documents-smart-view-count{font-size:12px;color:#6b7280}.documents-smart-view-desc{font-size:13px;color:#6b7280;margin:0 0 16px}.documents-cat-manager-item{margin-bottom:4px}.documents-cat-manager-row{display:flex;align-items:center;gap:8px;padding:6px 0}.documents-cat-manager-child{padding-left:20px}.documents-cat-manager-name{font-size:13px;color:#374151;flex:1}.documents-cat-manager-system{font-size:10px;color:#9ca3af;background:#f3f4f6;padding:1px 6px;border-radius:3px}.documents-categories-tab{padding:20px 24px;max-width:800px}.documents-categories-header{margin-bottom:20px}.documents-categories-header h3{font-size:16px;font-weight:600;color:#111827;margin:0 0 4px}.documents-categories-header p{font-size:13px;color:#6b7280;margin:0}.documents-categories-empty{text-align:center;padding:40px 0;color:#9ca3af}.documents-categories-empty p{margin:12px 0;font-size:14px}.documents-categories-list{display:flex;flex-direction:column;gap:2px}.documents-categories-group{border:1px solid #e5e7eb;border-radius:6px;overflow:hidden;margin-bottom:4px}.documents-categories-row{display:flex;align-items:center;gap:10px;padding:10px 14px;background:#fff;border-bottom:1px solid #f3f4f6}.documents-categories-row:last-child{border-bottom:none}.documents-categories-child{padding-left:34px;background:#fafafa}.documents-categories-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.documents-categories-name{font-size:14px;font-weight:500;color:#111827}.documents-categories-desc{font-size:12px;color:#9ca3af;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.documents-categories-badge{font-size:10px;color:#9ca3af;background:#f3f4f6;padding:1px 6px;border-radius:3px;text-transform:uppercase;letter-spacing:.03em}.documents-categories-actions{margin-left:auto;display:flex;gap:2px;opacity:0;transition:opacity .15s}.documents-categories-row:hover .documents-categories-actions{opacity:1}.documents-categories-edit-row{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#f9fafb;border-bottom:1px solid #f3f4f6}.documents-categories-edit-row .form-input{font-size:13px;padding:6px 10px}.documents-categories-color-input{width:32px;height:32px;padding:2px;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;flex-shrink:0}.documents-categories-add{margin-top:20px;padding-top:20px;border-top:1px solid #e5e7eb}.documents-categories-add h4{font-size:13px;font-weight:600;color:#374151;margin:0 0 10px}.documents-categories-add-form{display:flex;flex-direction:column;gap:8px}.documents-categories-add-row{display:flex;gap:8px;align-items:center}.documents-categories-add-row .form-input{font-size:13px;padding:7px 10px}.documents-visibility-card{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:6px;border:1px solid #e5e7eb}.documents-visibility-card.private{background:#f9fafb;border-color:#e5e7eb}.documents-visibility-card.shared{background:#f0fdf4;border-color:#bbf7d0}.documents-visibility-card-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;flex-shrink:0}.documents-visibility-card.private .documents-visibility-card-icon{background:#e5e7eb;color:#6b7280}.documents-visibility-card.shared .documents-visibility-card-icon{background:#dcfce7;color:#2d5a27}.documents-visibility-card-text{display:flex;flex-direction:column;gap:1px}.documents-visibility-card-label{font-size:13px;font-weight:600;color:#111827}.documents-visibility-card-desc{font-size:11px;color:#6b7280}.documents-main{flex:1;min-width:0;overflow-y:auto;padding:0}.documents-browse{position:relative;min-height:100%}.documents-browse.drag-over{background:#e8f5e9}.documents-breadcrumb{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb;flex-wrap:wrap;gap:8px}.documents-breadcrumb-path{display:flex;align-items:center;gap:2px;flex-wrap:wrap}.documents-breadcrumb-sep{color:#9ca3af;margin:0 2px;font-size:13px}.documents-breadcrumb-btn{border:none;background:none;font-size:13px;color:#6b7280;cursor:pointer;padding:2px 4px;border-radius:4px}.documents-breadcrumb-btn:hover{background:#e5e7eb;color:#111827}.documents-breadcrumb-btn.active{color:#111827;font-weight:600}.documents-breadcrumb-actions{display:flex;align-items:center;gap:6px}.documents-view-toggle{display:flex;border:1px solid #d1d5db;border-radius:6px;overflow:hidden}.documents-view-toggle .btn-icon{border:none;border-radius:0}.documents-view-toggle .btn-icon.active{background:#e5e7eb}.documents-upload-progress{height:24px;background:#f3f4f6;position:relative;border-bottom:1px solid #e5e7eb}.documents-upload-progress-bar{height:100%;background:#2d5a27;transition:width .3s;border-radius:0}.documents-upload-progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:11px;font-weight:600;color:#111827}.documents-drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#e8f5e9e6;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:10;border:2px dashed #2d5a27;border-radius:8px;margin:8px;font-size:15px;font-weight:600;color:#2d5a27;pointer-events:none}.documents-global-drag-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:#e8f5e9eb;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;z-index:50;border:3px dashed #2d5a27;border-radius:8px;font-size:16px;font-weight:600;color:#2d5a27;pointer-events:none}.documents-main.drag-over{position:relative}.documents-global-upload-bar{position:absolute;top:0;left:0;right:0;height:4px;background:#e5e7eb;z-index:40}.documents-global-upload-bar .documents-upload-progress-bar{height:100%;background:#2d5a27;transition:width .3s}.documents-global-upload-bar .documents-upload-progress-text{position:absolute;top:6px;right:12px;font-size:11px;font-weight:600;color:#2d5a27}.documents-empty,.documents-loading{display:flex;align-items:center;justify-content:center;height:200px;color:#9ca3af;font-size:14px}.documents-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;height:300px;color:#9ca3af}.documents-empty-state p{font-size:14px;margin:0}.documents-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px;padding:16px}.documents-card{border:1px solid #d1d5db;border-radius:8px;padding:12px;cursor:pointer;position:relative;transition:background .15s}.documents-card:hover{background:#f3f4f6}.documents-folder-card{display:flex;flex-direction:column;align-items:center;gap:8px;text-align:center}.documents-card-icon{margin-top:4px}.documents-card-name{font-size:13px;font-weight:500;color:#111827;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.documents-card-desc{font-size:11px;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.documents-file-card{display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.documents-card-preview{width:100%;height:80px;display:flex;align-items:center;justify-content:center;background:#f9fafb;border-radius:4px;overflow:hidden}.documents-card-thumbnail{width:100%;height:100%;object-fit:cover;border-radius:4px}.documents-card-meta{font-size:11px;color:#9ca3af}.documents-card-actions{position:absolute;top:6px;right:6px;opacity:0;transition:opacity .15s;display:flex;align-items:center;gap:2px}.documents-card:hover .documents-card-actions{opacity:1}.documents-card-delete-btn{background:none;border:none;cursor:pointer;padding:4px;border-radius:4px;color:#9ca3af;display:flex;align-items:center}.documents-card-delete-btn:hover{background:#fef2f2;color:#ef4444}.documents-upload-file-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px;padding:8px;background:#f9fafb;border-radius:6px;border:1px solid #e5e7eb;max-height:160px;overflow-y:auto}.documents-upload-file-item{display:flex;align-items:center;gap:8px;font-size:13px}.documents-upload-file-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:#111827}.documents-upload-file-size{color:#6b7280;font-size:12px;flex-shrink:0}.documents-list{width:100%}.documents-list-header{display:grid;grid-template-columns:1fr 80px 100px 120px 40px;padding:8px 16px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:#6b7280;background:#f9fafb;border-bottom:1px solid #d1d5db}.documents-recent .documents-list-header,.documents-search .documents-list-header,.documents-recent .documents-list-row,.documents-search .documents-list-row{grid-template-columns:1fr 80px 100px 100px 1fr}.documents-list-row{display:grid;grid-template-columns:1fr 80px 100px 120px 40px;padding:8px 16px;font-size:13px;color:#374151;border-bottom:1px solid #e5e7eb;cursor:pointer;align-items:center;transition:background .15s}.documents-list-row:hover{background:#f3f4f6}.documents-list-col-name{display:flex;align-items:center;gap:8px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.documents-list-col-size,.documents-list-col-modified,.documents-list-col-uploader{font-size:12px;color:#6b7280}.documents-list-col-folder{font-size:12px;color:#6b7280;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.documents-list-folder-link{cursor:pointer;color:#2d5a27}.documents-list-folder-link:hover{text-decoration:underline}.documents-context-menu-wrapper{position:relative}.documents-context-menu{position:absolute;top:100%;right:0;background:#fff;border:1px solid #d1d5db;border-radius:6px;box-shadow:0 4px 12px #00000014;min-width:120px;z-index:20;padding:4px 0}.documents-context-menu-item{display:block;width:100%;padding:6px 12px;border:none;background:none;font-size:13px;color:#374151;text-align:left;cursor:pointer}.documents-context-menu-item:hover{background:#f3f4f6}.documents-context-menu-item.danger{color:#991b1b}.documents-context-menu-item.danger:hover{background:#fee2e2}.documents-search-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;border-bottom:1px solid #e5e7eb}.documents-search-bar .form-input:first-of-type{flex:1;border:none;outline:none;box-shadow:none}.documents-permissions-list{display:flex;flex-direction:column;gap:6px}.documents-permission-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border:1px solid #e5e7eb;border-radius:6px;font-size:13px}.documents-permission-entity{display:flex;align-items:center;gap:6px;flex:1;color:#374151}.documents-permission-level{font-size:12px;font-weight:500;color:#6b7280;text-transform:capitalize;background:#f3f4f6;padding:2px 8px;border-radius:4px}.documents-move-list{display:flex;flex-direction:column;gap:4px;max-height:250px;overflow-y:auto}.documents-move-item{display:flex;align-items:center;gap:8px;width:100%;padding:8px 12px;border:1px solid #e5e7eb;border-radius:6px;background:#fff;font-size:13px;color:#374151;cursor:pointer;text-align:left}.documents-move-item:hover:not(:disabled){background:#f3f4f6}.documents-move-item.selected{border-color:#2d5a27;background:#e8f5e9}.documents-move-item.current{opacity:.5;cursor:not-allowed}.documents-category-badge{display:inline-flex;align-items:center;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:600;letter-spacing:.02em;border:1px solid;white-space:nowrap;margin-left:6px;vertical-align:middle}.documents-tag{display:inline-block;padding:1px 6px;border-radius:4px;font-size:10px;font-weight:500;background:#f3f4f6;color:#4b5563;border:1px solid #e5e7eb}.documents-card-tags{display:flex;gap:4px;flex-wrap:wrap;margin-top:2px}.documents-status-badge{display:inline-flex;padding:1px 6px;border-radius:4px;font-size:11px;font-weight:500;text-transform:capitalize}.documents-status-badge.current{background:#dcfce7;color:#166534}.documents-status-badge.draft{background:#fef3c7;color:#92400e}.documents-status-badge.archived{background:#f3f4f6;color:#6b7280}.documents-status-badge.superseded{background:#fce7f3;color:#9d174d}.documents-expiry-badge{display:inline-flex;padding:2px 8px;border-radius:4px;font-size:11px;font-weight:600}.documents-expiry-badge.expired{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}.documents-expiry-badge.warning{background:#fffbeb;color:#92400e;border:1px solid #fde68a}.documents-expired-text{color:#991b1b;font-weight:500}.documents-list-row.expired{background:#fef2f2}.documents-list-row.expired:hover{background:#fee2e2}.documents-detail-panel{width:360px;min-width:360px;border-left:1px solid #d1d5db;background:#fff;overflow-y:auto;display:flex;flex-direction:column}.documents-detail-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;border-bottom:1px solid #e5e7eb;gap:8px}.documents-detail-header h3{font-size:14px;font-weight:600;color:#111827;margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.documents-detail-body{flex:1;overflow-y:auto;padding:0}.documents-detail-section{padding:12px 16px;border-bottom:1px solid #f3f4f6}.documents-detail-file-info{display:flex;align-items:center;gap:12px}.documents-detail-filename{font-size:13px;font-weight:600;color:#111827;word-break:break-all}.documents-detail-filemeta{font-size:11px;color:#6b7280;margin-top:2px}.documents-detail-actions{display:flex;gap:8px;margin-top:12px}.documents-detail-label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.04em}.documents-detail-link{background:none;border:none;color:#2d5a27;font-size:13px;cursor:pointer;padding:0;margin-top:4px;text-decoration:underline;text-underline-offset:2px}.documents-detail-link:hover{color:#1a3d16}.documents-detail-row{display:flex;align-items:center;justify-content:space-between;padding:6px 0;font-size:13px;color:#374151;gap:8px}.documents-detail-row-block{flex-direction:column;align-items:flex-start}.documents-detail-row-block>span:last-child{margin-top:4px;line-height:1.5}.documents-detail-tags{display:flex;gap:4px;flex-wrap:wrap}.documents-detail-edit .form-group{margin-bottom:10px}.documents-detail-edit .form-label{font-size:11px;margin-bottom:2px}.documents-detail-edit .form-input{font-size:13px}.documents-detail-edit-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid #e5e7eb}.documents-detail-empty{text-align:center;padding:16px 0;color:#9ca3af;font-size:13px}.documents-detail-empty p{margin-bottom:8px}.documents-fullpage{flex:1;overflow-y:auto}.documents-detail-tabs{display:flex;border-bottom:1px solid #e5e7eb;padding:0 16px}.documents-detail-tab-btn{background:none;border:none;padding:8px 12px;font-size:13px;font-weight:500;color:#6b7280;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-1px}.documents-detail-tab-btn:hover{color:#374151}.documents-detail-tab-btn.active{color:#2d5a27;border-bottom-color:#2d5a27}.documents-access-info{display:flex;gap:12px;align-items:flex-start;padding:12px 16px}.documents-access-title{font-size:14px;font-weight:600;color:#111827;margin-bottom:2px}.documents-access-desc{font-size:12px;color:#6b7280;line-height:1.4}.documents-access-restricted{padding:0}.documents-access-grants{padding:0 16px 12px}.documents-access-grants-label{font-size:12px;font-weight:600;color:#374151;margin-bottom:6px;text-transform:uppercase;letter-spacing:.03em}.documents-access-grant-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:13px;color:#374151}.documents-access-grant-type{font-size:11px;color:#9ca3af;margin-left:auto}.documents-access-grants-note{font-size:11px;color:#9ca3af;margin-top:8px;font-style:italic}.documents-catperms{background:#fff;border:1px solid #e5e7eb;border-radius:6px;margin:4px 16px 8px;padding:12px}.documents-catperms-header{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:#374151;margin-bottom:8px}.documents-catperms-loading{font-size:12px;color:#9ca3af;padding:4px 0}.documents-catperms-empty{font-size:12px;color:#6b7280;padding:4px 0;line-height:1.4}.documents-catperms-list{display:flex;flex-direction:column;gap:2px;margin-bottom:8px}.documents-catperms-row{display:flex;align-items:center;gap:8px;padding:4px 6px;font-size:13px;color:#374151;border-radius:4px}.documents-catperms-row:hover{background:#f3f4f6}.documents-catperms-name{flex:1}.documents-catperms-type{font-size:11px;color:#9ca3af}.documents-catperms-add{display:flex;gap:8px;align-items:center;margin-top:8px}.documents-catperms-add .form-input{font-size:12px;padding:4px 8px}@media (max-width: 768px){.documents-layout{flex-direction:column}.documents-sidebar{width:100%;min-width:100%;border-right:none;border-bottom:1px solid #d1d5db;max-height:200px}.documents-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px;padding:12px}.documents-breadcrumb{flex-direction:column;align-items:flex-start}.documents-breadcrumb-actions{flex-wrap:wrap}.documents-list-header,.documents-list-row{grid-template-columns:1fr 60px 40px}.documents-list-col-uploader,.documents-list-col-modified{display:none}.documents-recent .documents-list-header,.documents-search .documents-list-header,.documents-recent .documents-list-row,.documents-search .documents-list-row{grid-template-columns:1fr 60px 40px}.documents-list-col-folder{display:none}.documents-detail-panel{width:100%;min-width:100%;border-left:none;border-top:1px solid #d1d5db;max-height:50vh}.documents-search-bar{flex-wrap:wrap}.documents-search-bar select{width:100%!important}}.env-dev .home-page{background:linear-gradient(150deg,#2a4a8a,#1e3a7b 40%,#142a5c)}.env-dev .login-container{background:linear-gradient(135deg,#1a3799,#10246c)}
