*,: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:#5a6e4b1f;--border-default:#5a6e4b38;--border-strong:#5a6e4b73;--border-accent:#3a7d5c99;--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 #0006, 0 1px 2px #0000004d;--shadow-md:0 4px 16px #00000080, 0 2px 4px #0000004d;--shadow-lg:0 12px 40px #0009, 0 4px 8px #0006;--shadow-glow-green:0 0 20px #3a7d5c40;--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{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px}body{font-family:var(--font-display);font-size:var(--text-base);color:var(--text-primary);background-color:var(--bg-app);min-height:100vh;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:var(--r-full)}::-webkit-scrollbar-thumb:hover{background:var(--clr-forest-400)}.app-shell{height:100vh;display:flex;overflow:hidden}.main-content{transition:margin-left var(--duration-slow) var(--ease-snappy);flex-direction:column;flex:1;display:flex;overflow:hidden}.page-body{padding:var(--space-8);background:var(--bg-app);flex:1;overflow-y:auto}.sidebar{width:var(--sidebar-w);background:var(--bg-sidebar);border-right:1px solid var(--border-subtle);height:100vh;transition:width var(--duration-slow) var(--ease-snappy);z-index:100;flex-direction:column;flex-shrink:0;display:flex;position:relative;overflow:hidden}.sidebar.collapsed{width:var(--sidebar-w-collapsed)}.sidebar-brand{padding:var(--space-5) var(--space-5);border-bottom:1px solid var(--border-subtle);align-items:center;gap:var(--space-3);min-height:var(--header-h);flex-shrink:0;display:flex}.sidebar-brand-icon{border-radius:var(--r-md);background:linear-gradient(135deg, var(--clr-forest-500), var(--clr-forest-400));width:32px;height:32px;box-shadow:var(--shadow-glow-green);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-brand-text{transition:opacity var(--duration-fast);overflow:hidden}.sidebar-brand-name{font-size:var(--text-lg);color:var(--text-primary);letter-spacing:-.02em;font-weight:700;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{padding:var(--space-4) var(--space-3);gap:var(--space-1);flex-direction:column;flex:1;display:flex;overflow-y:auto}.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);white-space:nowrap;overflow:hidden}.nav-item{align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--r-md);cursor:pointer;color:var(--text-secondary);font-size:var(--text-sm);transition:all var(--duration-fast) var(--ease-snappy);white-space:nowrap;border:1px solid #0000;font-weight:500;text-decoration:none;display:flex;position:relative;overflow:hidden}.nav-item:hover{background:var(--bg-card);color:var(--text-primary);border-color:var(--border-subtle)}.nav-item.active{color:var(--clr-forest-200);border-color:var(--border-accent);background:linear-gradient(135deg,#2763464d,#1a3a2b66);box-shadow:inset 0 0 0 1px #3a7d5c33}.nav-item.active:before{content:"";background:var(--clr-forest-400);border-radius:0 2px 2px 0;width:2px;position:absolute;top:25%;bottom:25%;left:0}.nav-icon{flex-shrink:0;width:18px;height:18px}.nav-badge{background:var(--clr-amber-500);color:#000;min-width:18px;height:18px;font-size:10px;font-weight:700;font-family:var(--font-mono);border-radius:var(--r-full);flex-shrink:0;justify-content:center;align-items:center;margin-left:auto;padding:0 4px;display:flex}.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);border:1px solid var(--border-subtle);color:var(--text-muted);cursor:pointer;transition:all var(--duration-fast);background:0 0;justify-content:center;align-items:center;display:flex}.sidebar-toggle-btn:hover{background:var(--bg-card);color:var(--text-secondary)}.header{height:var(--header-h);border-bottom:1px solid var(--border-subtle);padding:0 var(--space-8);align-items:center;gap:var(--space-4);background:var(--bg-app);flex-shrink:0;display:flex}.header-breadcrumb{align-items:center;gap:var(--space-2);font-size:var(--text-sm);color:var(--text-muted);display:flex}.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{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-full);width:260px;height:36px;padding:0 var(--space-4) 0 var(--space-10);color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-sm);transition:all var(--duration-fast);outline:none}.header-search input:focus{border-color:var(--clr-forest-400);width:300px;box-shadow:0 0 0 3px #3a7d5c26}.header-search input::placeholder{color:var(--text-muted)}.header-search-icon{left:var(--space-3);color:var(--text-muted);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.header-actions{align-items:center;gap:var(--space-3);margin-left:var(--space-4);display:flex}.header-notif-btn{border-radius:var(--r-md);background:var(--bg-card);border:1px solid var(--border-subtle);width:36px;height:36px;color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast);justify-content:center;align-items:center;display:flex;position:relative}.header-notif-btn:hover{border-color:var(--border-default);color:var(--text-primary)}.notif-dot{background:var(--clr-amber-500);border-radius:var(--r-full);border:1.5px solid var(--bg-app);width:7px;height:7px;position:absolute;top:6px;right:6px}.header-user{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);display:flex}.header-user:hover{border-color:var(--border-default)}.user-avatar{border-radius:var(--r-full);background:linear-gradient(135deg, var(--clr-forest-500), var(--clr-forest-400));width:28px;height:28px;font-size:var(--text-xs);color:#fff;flex-shrink:0;justify-content:center;align-items:center;font-weight:700;display:flex}.user-info{flex-direction:column;line-height:1.2;display:flex}.user-name{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.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);letter-spacing:-.025em;color:var(--text-primary);font-weight:700;line-height:1.25}.page-title{font-size:var(--text-2xl);letter-spacing:-.03em;font-weight:700}.page-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:var(--space-1)}.section-title{font-size:var(--text-lg);letter-spacing:-.02em;font-weight:600}.mono{font-family:var(--font-mono)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);transition:all var(--duration-base) var(--ease-snappy);overflow:hidden}.card:hover{border-color:var(--border-default)}.card-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.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);transition:all var(--duration-base) var(--ease-snappy);cursor:default;position:relative;overflow:hidden}.stat-card:hover{border-color:var(--border-default);box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card:before{content:"";background:var(--card-accent,var(--clr-forest-500));opacity:.6;height:2px;position:absolute;top:0;left:0;right:0}.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{border-radius:var(--r-lg);width:40px;height:40px;margin-bottom:var(--space-4);color:var(--card-accent,var(--clr-forest-400));background:#ffffff0a;justify-content:center;align-items:center;display:flex}.stat-value{font-size:var(--text-3xl);letter-spacing:-.04em;color:var(--text-primary);margin-bottom:var(--space-1);font-weight:700;line-height: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{justify-content:center;align-items:center;gap:var(--space-2);padding:0 var(--space-5);border-radius:var(--r-md);height:38px;font-family:var(--font-display);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-snappy);white-space:nowrap;border:1px solid #0000;flex-shrink:0;font-weight:600;text-decoration:none;display:inline-flex}.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{color:var(--text-secondary);background:0 0;border-color:#0000}.btn-ghost:hover:not(:disabled){background:var(--bg-card);color:var(--text-primary)}.btn-danger{color:#f87171;background:#dc262626;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{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;display:inline-flex}.badge-dot{border-radius:var(--r-full);background:currentColor;flex-shrink:0;width:5px;height:5px}.badge-programado{color:#6babf0;background:#4a90d91f}.badge-pendiente{color:#9ca3af;background:#9ca3af1f}.badge-realizado{color:var(--clr-forest-200);background:#3a7d5c26}.badge-informado{color:#5eead4;background:#0d948826}.badge-facturar{color:var(--clr-amber-400);background:#e8930a26}.badge-facturado{color:#a5b4fc;background:#6366f126}.badge-cobrado{color:var(--clr-forest-200);background:#27634640}.badge-vencido{color:#f87171;background:#dc262626}.badge-cancelado{color:#9ca3af;background:#6b72801f}.badge-salta{color:#fbbf24;background:#fbbf241a}.badge-jujuy{color:#818cf8;background:#6366f11a}.form-group{gap:var(--space-2);flex-direction:column;display:flex}.form-label{font-size:var(--text-xs);color:var(--text-secondary);font-weight:600;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:.07em}.form-label.required:after{content:" *";color:#f87171}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border-default);border-radius:var(--r-md);width:100%;padding:var(--space-3) var(--space-4);color:var(--text-primary);font-family:var(--font-display);font-size:var(--text-sm);transition:all var(--duration-fast);outline:none}.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{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{border-radius:var(--r-xl);border:1px solid var(--border-subtle);overflow-x:auto}.table{border-collapse:collapse;width:100%;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);color:var(--text-muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border-subtle);white-space:nowrap;font-weight:500}.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{align-items:flex-start;gap:var(--space-4);padding:var(--space-4) var(--space-5);border-radius:var(--r-lg);transition:all var(--duration-fast);border:1px solid #0000;display:flex}.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{border-radius:var(--r-md);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;display:flex}.alert-item.urgent .alert-icon{color:var(--clr-amber-400);background:#e8930a26}.alert-item.warning .alert-icon{color:#f87171;background:#dc262626}.alert-item.info .alert-icon{color:#6babf0;background:#4a90d926}.alert-content{flex:1;min-width:0}.alert-title{font-size:var(--text-sm);color:var(--text-primary);font-weight:600}.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{gap:var(--space-6);grid-template-columns:repeat(2,1fr);display:grid}.grid-3{gap:var(--space-6);grid-template-columns:repeat(3,1fr);display:grid}.grid-4{gap:var(--space-6);grid-template-columns:repeat(4,1fr);display:grid}.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{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.divider{background:var(--border-subtle);height:1px;margin:var(--space-4) 0}.page-container{max-width:1440px;margin:0 auto}.page-header{margin-bottom:var(--space-8);justify-content:space-between;align-items:flex-start;gap:var(--space-4);display:flex}.kanban-board{gap:var(--space-4);padding-bottom:var(--space-4);min-height:500px;display:flex;overflow-x:auto}.kanban-col{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--r-xl);flex-direction:column;flex-shrink:0;width:260px;display:flex}.kanban-col-header{padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;gap:var(--space-3);display:flex}.kanban-col-title{font-size:var(--text-sm);color:var(--text-secondary);align-items:center;gap:var(--space-2);font-weight:600;display:flex}.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{padding:var(--space-3);gap:var(--space-3);flex-direction:column;flex:1;display:flex;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);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.timeline{flex-direction:column;gap:0;display:flex}.timeline-item{gap:var(--space-4);padding-bottom:var(--space-6);display:flex;position:relative}.timeline-item:last-child{padding-bottom:0}.timeline-dot{border-radius:var(--r-full);background:var(--bg-panel);border:2px solid var(--border-default);z-index:1;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;margin-top:2px;display:flex;position:relative}.timeline-item.done .timeline-dot{background:var(--clr-forest-600);border-color:var(--clr-forest-400);color:var(--clr-forest-200)}.tabs{border-bottom:1px solid var(--border-subtle);margin-bottom:var(--space-6);gap:0;display:flex}.tab-btn{padding:var(--space-3) var(--space-5);font-size:var(--text-sm);color:var(--text-muted);cursor:pointer;font-weight:500;font-family:var(--font-display);transition:all var(--duration-fast);background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px}.tab-btn:hover{color:var(--text-secondary)}.tab-btn.active{color:var(--clr-forest-200);border-bottom-color:var(--clr-forest-400)}.empty-state{padding:var(--space-16) var(--space-8);text-align:center;flex-direction:column;justify-content:center;align-items:center;display:flex}.empty-state-icon{border-radius:var(--r-2xl);background:var(--bg-panel);border:1px solid var(--border-subtle);width:64px;height:64px;margin-bottom:var(--space-5);color:var(--text-muted);justify-content:center;align-items:center;display:flex}.empty-state-title{font-size:var(--text-lg);color:var(--text-secondary);margin-bottom:var(--space-2);font-weight:600}.empty-state-desc{font-size:var(--text-sm);color:var(--text-muted);max-width:320px;margin-bottom:var(--space-6)}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;padding:var(--space-6);animation:fadeIn var(--duration-base) var(--ease-snappy);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-modal);border:1px solid var(--border-default);border-radius:var(--r-2xl);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-lg);animation:modalIn var(--duration-slow) var(--ease-spring);overflow-y:auto}.modal-header{padding:var(--space-6) var(--space-6) var(--space-4);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.modal-body{padding:var(--space-6)}.modal-footer{padding:var(--space-4) var(--space-6) var(--space-6);gap:var(--space-3);justify-content:flex-end;display:flex}.filter-bar{align-items:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border-subtle);flex-wrap:wrap;display:flex}.filter-chip{align-items:center;gap:var(--space-2);padding:var(--space-1) var(--space-3);border-radius:var(--r-full);font-size:var(--text-xs);background:var(--bg-panel);border:1px solid var(--border-default);color:var(--text-secondary);cursor:pointer;transition:all var(--duration-fast);font-weight:500;display:inline-flex}.filter-chip:hover{border-color:var(--border-strong);color:var(--text-primary)}.filter-chip.active{border-color:var(--border-accent);color:var(--clr-forest-200);background:#3a7d5c26}.progress-bar{background:var(--bg-panel);border-radius:var(--r-full);height:4px;overflow:hidden}.progress-fill{background:linear-gradient(90deg, var(--clr-forest-500), var(--clr-forest-300));border-radius:var(--r-full);height:100%;transition:width var(--duration-slow) var(--ease-snappy)}.checklist-item{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);display:flex}.checklist-item:last-child{border-bottom:none}.checklist-item:hover{background:var(--bg-card-hover)}.checklist-checkbox{border-radius:var(--r-sm);border:1.5px solid var(--border-strong);background:var(--bg-input);cursor:pointer;width:20px;height:20px;transition:all var(--duration-fast);flex-shrink:0;justify-content:center;align-items:center;display:flex}.checklist-checkbox.checked{background:var(--clr-forest-500);border-color:var(--clr-forest-400);color:#fff}.notif-panel{top:calc(var(--header-h) + 8px);right:var(--space-6);background:var(--bg-modal);border:1px solid var(--border-default);border-radius:var(--r-xl);width:380px;box-shadow:var(--shadow-lg);z-index:500;animation:modalIn var(--duration-base) var(--ease-spring);position:absolute;overflow:hidden}@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%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@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>:first-child{animation-delay:0s}.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{border-radius:var(--r-full);background:#4ade80;width:8px;height:8px;animation:2s ease-in-out infinite pulse-dot}.drawer-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;background:#0009;justify-content:flex-end;display:flex;position:fixed;inset:0}.drawer{background:var(--bg-app);border-left:1px solid var(--border-subtle);width:500px;max-width:100%;height:100vh;animation:slideLeft var(--duration-base) var(--ease-snappy) forwards;flex-direction:column;display:flex;box-shadow:-8px 0 32px #00000080}.drawer-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;display:flex}.drawer-body{padding:var(--space-6);flex:1;overflow-y:auto}.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{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1050;padding:var(--space-4);background:#000000b3;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal{background:var(--bg-app);border-radius:var(--r-xl);width:100%;box-shadow:var(--shadow-lg);border:1px solid var(--border-subtle);max-height:90vh;animation:modalEnter var(--duration-fast) var(--ease-spring) forwards;flex-direction:column;display:flex}.modal-header{padding:var(--space-5) var(--space-6);border-bottom:1px solid var(--border-subtle);flex-shrink:0;justify-content:space-between;align-items:flex-start;display:flex}.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 (width<=1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}.page-body{padding:var(--space-5)}}@media (width<=768px){.sidebar{z-index:200;transition:left var(--duration-slow);position:fixed;left:-100%}.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)}}
