*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--clr-forest-900: #0d1f17;--clr-forest-800: #132b20;--clr-forest-700: #1a3a2b;--clr-forest-600: #204d38;--clr-forest-500: #276346;--clr-forest-400: #3a7d5c;--clr-forest-300: #5a9e7a;--clr-forest-200: #8dc4a5;--clr-forest-100: #c5e3d2;--clr-forest-50: #edf7f2;--clr-stone-950: #0e0f0d;--clr-stone-900: #161714;--clr-stone-800: #1e2019;--clr-stone-700: #2e3126;--clr-stone-600: #454940;--clr-stone-500: #636860;--clr-stone-400: #858980;--clr-stone-300: #aaae9e;--clr-stone-200: #cdd0c4;--clr-stone-100: #e8eae0;--clr-stone-50: #f5f6f0;--clr-amber-600: #c27a00;--clr-amber-500: #e8930a;--clr-amber-400: #f5a623;--clr-amber-200: #fde68a;--clr-amber-100: #fef9e7;--clr-status-programado: #4a90d9;--clr-status-pendiente: #9ca3af;--clr-status-realizado: #3a7d5c;--clr-status-informado: #0d9488;--clr-status-facturar: #e8930a;--clr-status-facturado: #6366f1;--clr-status-cobrado: #276346;--clr-status-vencido: #dc2626;--clr-status-cancelado: #6b7280;--bg-app: #0e100c;--bg-sidebar: #0a0e08;--bg-card: #161914;--bg-card-hover: #1c2018;--bg-panel: #1e2219;--bg-input: #1a1d16;--bg-modal: #111410;--border-subtle: rgba(90, 110, 75, .12);--border-default: rgba(90, 110, 75, .22);--border-strong: rgba(90, 110, 75, .45);--border-accent: rgba(58, 125, 92, .6);--text-primary: #e8eae0;--text-secondary: #9aab8e;--text-muted: #5a6454;--text-accent: #5a9e7a;--text-inverse: #0e100c;--font-display: "Sora", system-ui, sans-serif;--font-mono: "DM Mono", "Courier New", monospace;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .9375rem;--text-lg: 1.0625rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 2rem;--text-4xl: 2.75rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--r-2xl: 24px;--r-full: 9999px;--shadow-sm: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 16px rgba(0,0,0,.5), 0 2px 4px rgba(0,0,0,.3);--shadow-lg: 0 12px 40px rgba(0,0,0,.6), 0 4px 8px rgba(0,0,0,.4);--shadow-glow-green: 0 0 20px rgba(58, 125, 92, .25);--ease-snappy: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--duration-fast: .12s;--duration-base: .2s;--duration-slow: .35s;--sidebar-w: 240px;--sidebar-w-collapsed: 64px;--header-h: 58px}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-app);line-height:1.6;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--clr-forest-400)}.app-shell{display:flex;height:100vh;overflow:hidden}.main-content{flex:1;display:flex;flex-direction:column;overflow:hidden;transition:margin-left var(--duration-slow) var(--ease-snappy)}.page-body{flex:1;overflow-y:auto;padding:var(--space-8);background:var(--bg-app)}.sidebar{width:var(--sidebar-w);height:100vh;background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;flex-shrink:0;transition:width var(--duration-slow) var(--ease-snappy);overflow:hidden;position:relative;z-index:100}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-brand{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;gap:var(--space-3);min-height:var(--header-h);flex-shrink:0}.sidebar-brand-icon{width:32px;height:32px;border-radius:var(--r-md);background:linear-gradient(135deg,var(--clr-forest-500),var(--clr-forest-400));display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:var(--shadow-glow-green)}.sidebar-brand-text{overflow:hidden;transition:opacity var(--duration-fast)}.sidebar-brand-name{font-size:var(--text-lg);font-weight:700;color:var(--text-primary);letter-spacing:-.02em;line-height:1.2}.sidebar-brand-sub{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-4) var(--space-3);display:flex;flex-direction:column;gap:var(--space-1)}.sidebar-section-label{font-size:var(--text-xs);font-family:var(--font-mono);color:var(--text-muted);text-transform:uppercase;letter-spacing:.1em;padding:var(--space-3) var(--space-3) var(--space-1);overflow:hidden;white-space:nowrap}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--r-md);cursor:pointer;text-decoration:none;color:var(--text-secondary);font-size:var(--text-sm);font-weight:500;transition:all var(--duration-fast) var(--ease-snappy);white-space:nowrap;overflow:hidden;position:relative;border:1px solid transparent}.nav-item:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-subtle)}.nav-item.active{background:linear-gradient(135deg,#2763464d,#1a3a2b66);color:var(--clr-forest-200);border-color:var(--border-accent);box-shadow:inset 0 0 0 1px #3a7d5c33}.nav-item.active:before{content:"";position:absolute;left:0;top:25%;bottom:25%;width:2px;background:var(--clr-forest-400);border-radius:0 2px 2px 0}.nav-icon{width:18px;height:18px;flex-shrink:0}.nav-badge{margin-left:auto;min-width:18px;height:18px;background:var(--clr-amber-500);color:#000;font-size:10px;font-weight:700;font-family:var(--font-mono);border-radius:var(--r-full);display:flex;align-items:center;justify-content:center;padding:0 4px;flex-shrink:0}.sidebar-toggle{padding:var(--space-3);border-top:1px solid var(--border-subtle);flex-shrink:0}.sidebar-toggle-btn{width:100%;padding:var(--space-2) var(--space-3);border-radius:var(--r-md);background:transparent;border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast)}.sidebar-toggle-btn:hover{background:var(--bg-card);color:var(--text-secondary)}.header{height:var(--header-h);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;padding:0 var(--space-8);gap:var(--space-4);background:var(--bg-app);flex-shrink:0}.header-breadcrumb{display:flex;align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted)}.header-breadcrumb-sep{color:var(--text-muted);opacity:.4}.header-breadcrumb-current{color:var(--text-primary);font-weight:600}.header-search{margin-left:auto;position:relative}.header-search input{width:260px;height:36px;background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-full);padding:0 var(--space-4) 0 var(--space-10);color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-sm);outline:none;transition:all var(--duration-fast)}.header-search input:focus{border-color:var(--clr-forest-400);box-shadow:0 0 0 3px #3a7d5c26;width:300px}.header-search input::placeholder{color:var(--text-muted)}.header-search-icon{position:absolute;left:var(--space-3);top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.header-actions{display:flex;align-items:center;gap:var(--space-3);margin-left:var(--space-4)}.header-notif-btn{position:relative;width:36px;height:36px;border-radius:var(--r-md);background:var(--bg-card);border:1px solid var(--border-subtle);color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all var(--duration-fast)}.header-notif-btn:hover{border-color:var(--border-default);color:var(--text-primary)}.notif-dot{position:absolute;top:6px;right:6px;width:7px;height:7px;background:var(--clr-amber-500);border-radius:var(--r-full);border:1.5px solid var(--bg-app)}.header-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--r-md);border:1px solid var(--border-subtle);background:var(--bg-card);cursor:pointer;transition:all var(--duration-fast)}.header-user:hover{border-color:var(--border-default)}.user-avatar{width:28px;height:28px;border-radius:var(--r-full);background:linear-gradient(135deg,var(--clr-forest-500),var(--clr-forest-400));display:flex;align-items:center;justify-content:center;font-size:var(--text-xs);font-weight:700;color:#fff;flex-shrink:0}.user-info{display:flex;flex-direction:column;line-height:1.2}.user-name{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.user-role{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono)}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);font-weight:700;line-height:1.25;letter-spacing:-.025em;color:var(--text-primary)}.page-title{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.03em}.page-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.section-title{font-size:var(--text-lg);font-weight:600;letter-spacing:-.02em}.mono{font-family:var(--font-mono)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);overflow:hidden;transition:all var(--duration-base) var(--ease-snappy)}.card:hover{border-color:var(--border-default)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-subtle)}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);padding:var(--space-5) var(--space-6);position:relative;overflow:hidden;transition:all var(--duration-base) var(--ease-snappy);cursor:default}.stat-card:hover{transform:translateY(-2px);border-color:var(--border-default);box-shadow:var(--shadow-md)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--card-accent, var(--clr-forest-500));opacity:.6}.stat-card-urgent{--card-accent: var(--clr-amber-500)}.stat-card-success{--card-accent: var(--clr-forest-500)}.stat-card-info{--card-accent: #4a90d9}.stat-card-warning{--card-accent: var(--clr-amber-400)}.stat-card-danger{--card-accent: #dc2626}.stat-card-icon{width:40px;height:40px;border-radius:var(--r-lg);background:#ffffff0a;display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-4);color:var(--card-accent, var(--clr-forest-400))}.stat-value{font-size:var(--text-3xl);font-weight:700;letter-spacing:-.04em;line-height:1;color:var(--text-primary);margin-bottom:var(--space-1)}.stat-label{font-size:var(--text-xs);color:var(--text-muted);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.08em}.stat-subtitle{font-size:var(--text-xs);color:var(--text-secondary);margin-top:var(--space-2)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:0 var(--space-5);height:38px;border-radius:var(--r-md);font-family:var(--font-display);font-size:var(--text-sm);font-weight:600;cursor:pointer;border:1px solid transparent;text-decoration:none;transition:all var(--duration-fast) var(--ease-snappy);white-space:nowrap;flex-shrink:0}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--clr-forest-500);color:#fff;border-color:var(--clr-forest-400)}.btn-primary:hover:not(:disabled){background:var(--clr-forest-400);box-shadow:var(--shadow-glow-green);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-default)}.btn-secondary:hover:not(:disabled){background:var(--bg-panel);border-color:var(--border-strong)}.btn-ghost{background:transparent;color:var(--text-secondary);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--bg-card);color:var(--text-primary)}.btn-danger{background:#dc262626;color:#f87171;border-color:#dc26264d}.btn-danger:hover:not(:disabled){background:#dc262640}.btn-sm{height:30px;padding:0 var(--space-3);font-size:var(--text-xs)}.btn-lg{height:46px;padding:0 var(--space-8);font-size:var(--text-base)}.btn-icon{width:38px;padding:0}.btn-icon.btn-sm{width:30px}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-3);border-radius:var(--r-full);font-size:11px;font-weight:600;font-family:var(--font-mono);letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.badge-dot{width:5px;height:5px;border-radius:var(--r-full);background:currentColor;flex-shrink:0}.badge-programado{background:#4a90d91f;color:#6babf0}.badge-pendiente{background:#9ca3af1f;color:#9ca3af}.badge-realizado{background:#3a7d5c26;color:var(--clr-forest-200)}.badge-informado{background:#0d948826;color:#5eead4}.badge-facturar{background:#e8930a26;color:var(--clr-amber-400)}.badge-facturado{background:#6366f126;color:#a5b4fc}.badge-cobrado{background:#27634640;color:var(--clr-forest-200)}.badge-vencido{background:#dc262626;color:#f87171}.badge-cancelado{background:#6b72801f;color:#9ca3af}.badge-salta{background:#fbbf241a;color:#fbbf24}.badge-jujuy{background:#6366f11a;color:#818cf8}.form-group{display:flex;flex-direction:column;gap:var(--space-2)}.form-label{font-size:var(--text-xs);font-weight:600;color:var(--text-secondary);font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.07em}.form-label.required:after{content:" *";color:#f87171}.form-input,.form-select,.form-textarea{width:100%;background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-md);padding:var(--space-3) var(--space-4);color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-sm);outline:none;transition:all var(--duration-fast)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--clr-forest-400);box-shadow:0 0 0 3px #3a7d5c26}.form-input::placeholder,.form-textarea::placeholder{color:var(--text-muted)}.form-select{-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' fill='%235a6454' viewBox='0 0 16 16'%3E%3Cpath d='M7.247 11.14L2.451 5.658C1.885 5.013 2.345 4 3.204 4h9.592a1 1 0 0 1 .753 1.659l-4.796 5.48a1 1 0 0 1-1.506 0z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right var(--space-4) center;padding-right:var(--space-10);cursor:pointer}.form-select option{background:var(--bg-panel);color:var(--text-primary)}.form-textarea{resize:vertical;min-height:100px}.form-hint{font-size:var(--text-xs);color:var(--text-muted)}.form-error{font-size:var(--text-xs);color:#f87171}.table-wrapper{overflow-x:auto;border-radius:var(--r-xl);border:1px solid var(--border-subtle)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table thead th{background:var(--bg-panel);padding:var(--space-3) var(--space-5);text-align:left;font-size:var(--text-xs);font-family:var(--font-mono);font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.table tbody tr{border-bottom:1px solid var(--border-subtle);transition:background var(--duration-fast)}.table tbody tr:last-child{border-bottom:none}.table tbody tr:hover{background:var(--bg-card-hover)}.table tbody td{padding:var(--space-4) var(--space-5);color:var(--text-primary);vertical-align:middle}.table tbody td.text-muted{color:var(--text-muted)}.table tbody td.mono{font-family:var(--font-mono);font-size:var(--text-xs)}.alert-item{display:flex;align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--r-lg);border:1px solid transparent;transition:all var(--duration-fast)}.alert-item.urgent{background:#e8930a0f;border-color:#e8930a33}.alert-item.warning{background:#dc26260f;border-color:#dc262633}.alert-item.info{background:#4a90d90f;border-color:#4a90d933}.alert-icon{width:32px;height:32px;border-radius:var(--r-md);display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:14px}.alert-item.urgent .alert-icon{background:#e8930a26;color:var(--clr-amber-400)}.alert-item.warning .alert-icon{background:#dc262626;color:#f87171}.alert-item.info .alert-icon{background:#4a90d926;color:#6babf0}.alert-content{flex:1;min-width:0}.alert-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary)}.alert-desc{font-size:var(--text-xs);color:var(--text-secondary);margin-top:2px}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.flex-1{flex:1}.min-w-0{min-width:0}.w-full{width:100%}.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6)}.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-6)}.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-6)}.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-muted{color:var(--text-muted)}.text-secondary{color:var(--text-secondary)}.text-accent{color:var(--text-accent)}.text-danger{color:#f87171}.text-amber{color:var(--clr-amber-400)}.font-mono{font-family:var(--font-mono)}.font-semibold{font-weight:600}.font-bold{font-weight:700}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-auto{margin-left:auto}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.divider{height:1px;background:var(--border-subtle);margin:var(--space-4) 0}.page-container{max-width:1440px;margin:0 auto}.page-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:var(--space-8);gap:var(--space-4)}.kanban-board{display:flex;gap:var(--space-4);overflow-x:auto;padding-bottom:var(--space-4);min-height:500px}.kanban-col{flex-shrink:0;width:260px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);display:flex;flex-direction:column}.kanban-col-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.kanban-col-title{font-size:var(--text-sm);font-weight:600;color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-2)}.kanban-col-count{font-family:var(--font-mono);font-size:var(--text-xs);color:var(--text-muted);background:var(--bg-panel);border-radius:var(--r-full);padding:1px 6px}.kanban-col-body{flex:1;padding:var(--space-3);display:flex;flex-direction:column;gap:var(--space-3);overflow-y:auto}.kanban-card{background:var(--bg-panel);border:1px solid var(--border-subtle);border-radius:var(--r-lg);padding:var(--space-4);cursor:pointer;transition:all var(--duration-fast)}.kanban-card:hover{border-color:var(--border-default);transform:translateY(-1px);box-shadow:var(--shadow-sm)}.timeline{display:flex;flex-direction:column;gap:0}.timeline-item{display:flex;gap:var(--space-4);padding-bottom:var(--space-6);position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{width:28px;height:28px;border-radius:var(--r-full);background:var(--bg-panel);border:2px solid var(--border-default);display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px;position:relative;z-index:1}.timeline-item.done .timeline-dot{background:var(--clr-forest-600);border-color:var(--clr-forest-400);color:var(--clr-forest-200)}.tabs{display:flex;gap:0;border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-6)}.tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);font-weight:500;color:var(--text-muted);cursor:pointer;border:none;background:transparent;font-family:var(--font-display);border-bottom:2px solid transparent;margin-bottom:-1px;transition:all var(--duration-fast)}.tab-btn:hover{color:var(--text-secondary)}.tab-btn.active{color:var(--clr-forest-200);border-bottom-color:var(--clr-forest-400)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-16) var(--space-8);text-align:center}.empty-state-icon{width:64px;height:64px;border-radius:var(--r-2xl);background:var(--bg-panel);border:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:center;margin-bottom:var(--space-5);color:var(--text-muted)}.empty-state-title{font-size:var(--text-lg);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-2)}.empty-state-desc{font-size:var(--text-sm);color:var(--text-muted);max-width:320px;margin-bottom:var(--space-6)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-6);animation:fadeIn var(--duration-base) var(--ease-snappy)}.modal{background:var(--bg-modal);border:1px solid var(--border-default);border-radius:var(--r-2xl);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modalIn var(--duration-slow) var(--ease-spring)}.modal-header{padding:var(--space-6) var(--space-6) var(--space-4);display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border-subtle)}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6) var(--space-6);display:flex;gap:var(--space-3);justify-content:flex-end}.filter-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap}.filter-chip{display:inline-flex;align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--r-full);font-size:var(--text-xs);font-weight:500;background:var(--bg-panel);border:1px solid var(--border-default);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast)}.filter-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.filter-chip.active{background:#3a7d5c26;border-color:var(--border-accent);color:var(--clr-forest-200)}.progress-bar{height:4px;background:var(--bg-panel);border-radius:var(--r-full);overflow:hidden}.progress-fill{height:100%;background:linear-gradient(90deg,var(--clr-forest-500),var(--clr-forest-300));border-radius:var(--r-full);transition:width var(--duration-slow) var(--ease-snappy)}.checklist-item{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);transition:background var(--duration-fast)}.checklist-item:last-child{border-bottom:none}.checklist-item:hover{background:var(--bg-card-hover)}.checklist-checkbox{width:20px;height:20px;border-radius:var(--r-sm);border:1.5px solid var(--border-strong);background:var(--bg-input);cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--duration-fast)}.checklist-checkbox.checked{background:var(--clr-forest-500);border-color:var(--clr-forest-400);color:#fff}.notif-panel{position:absolute;top:calc(var(--header-h) + 8px);right:var(--space-6);width:380px;background:var(--bg-modal);border:1px solid var(--border-default);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);z-index:500;overflow:hidden;animation:modalIn var(--duration-base) var(--ease-spring)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalIn{0%{opacity:0;transform:scale(.96) translateY(8px)}to{opacity:1;transform:scale(1) translateY(0)}}@keyframes slideIn{0%{transform:translate(-20px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.animate-fade-up{animation:fadeUp var(--duration-slow) var(--ease-snappy) both}.animate-slide-in{animation:slideIn var(--duration-slow) var(--ease-snappy) both}.stagger>*:nth-child(1){animation-delay:0ms}.stagger>*:nth-child(2){animation-delay:60ms}.stagger>*:nth-child(3){animation-delay:.12s}.stagger>*:nth-child(4){animation-delay:.18s}.stagger>*:nth-child(5){animation-delay:.24s}.stagger>*:nth-child(6){animation-delay:.3s}.stagger>*:nth-child(7){animation-delay:.36s}.stagger>*:nth-child(8){animation-delay:.42s}.live-dot{width:8px;height:8px;background:#4ade80;border-radius:var(--r-full);animation:pulse-dot 2s ease-in-out infinite}.drawer-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;justify-content:flex-end}.drawer{width:500px;max-width:100%;background:var(--bg-app);height:100vh;box-shadow:-8px 0 32px #00000080;display:flex;flex-direction:column;border-left:1px solid var(--border-subtle);animation:slideLeft var(--duration-base) var(--ease-snappy) forwards}.drawer-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between}.drawer-body{flex:1;overflow-y:auto;padding:var(--space-6)}.drawer-footer{padding:var(--space-5) var(--space-6);border-top:1px solid var(--border-subtle);background:var(--bg-card)}@keyframes slideLeft{0%{transform:translate(100%)}to{transform:translate(0)}}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1050;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.modal{width:100%;background:var(--bg-app);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);display:flex;flex-direction:column;max-height:90vh;animation:modalEnter var(--duration-fast) var(--ease-spring) forwards}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;flex-shrink:0}.modal-body{padding:var(--space-6);overflow-y:auto}.modal-footer{padding:var(--space-5) var(--space-6);border-top:1px solid var(--border-subtle);background:var(--bg-card);border-radius:0 0 var(--r-xl) var(--r-xl);flex-shrink:0}@keyframes modalEnter{0%{opacity:0;transform:scale(.96) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}@media(max-width:1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.page-body{padding:var(--space-5)}}@media(max-width:768px){.sidebar{position:fixed;left:-100%;z-index:200;transition:left var(--duration-slow)}.sidebar.mobile-open{left:0}.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}.header-search{display:none}.page-body{padding:var(--space-4)}}
