:root{--primary-50: #f0fdf4;--primary-100: #dcfce7;--primary-200: #bbf7d0;--primary-300: #86efac;--primary-400: #4ade80;--primary-500: #22c55e;--primary-600: #16a34a;--primary-700: #15803d;--primary-800: #166534;--primary-900: #14532d;--secondary-50: #f0f9ff;--secondary-100: #e0f2fe;--secondary-200: #bae6fd;--secondary-300: #7dd3fc;--secondary-400: #38bdf8;--secondary-500: #0ea5e9;--secondary-600: #0284c7;--secondary-700: #0369a1;--secondary-800: #075985;--secondary-900: #0c4a6e;--accent-50: #fff7ed;--accent-100: #ffedd5;--accent-200: #fed7aa;--accent-300: #fdba74;--accent-400: #fb923c;--accent-500: #f97316;--accent-600: #ea580c;--accent-700: #c2410c;--accent-800: #9a3412;--accent-900: #7c2d12;--gray-50: #f9fafb;--gray-100: #f3f4f6;--gray-200: #e5e7eb;--gray-300: #d1d5db;--gray-400: #9ca3af;--gray-500: #6b7280;--gray-600: #4b5563;--gray-700: #374151;--gray-800: #1f2937;--gray-900: #111827;--dark-bg: #0f172a;--dark-surface: #1e293b;--dark-border: #334155;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--info: #3b82f6;--phase-collection: #8b5cf6;--phase-sorting: #06b6d4;--phase-trims: #f59e0b;--phase-shredding: #ec4899;--phase-production: #10b981;--phase-impact: #6366f1;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-mono: "Fira Code", "JetBrains Mono", monospace;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--shadow-xl: 0 20px 25px -5px rgb(0 0 0 / .1), 0 8px 10px -6px rgb(0 0 0 / .1);--shadow-glow: 0 0 20px rgba(34, 197, 94, .3);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-sticky: 200;--z-modal: 300;--z-tooltip: 400}[data-theme=dark]{--bg-primary: var(--dark-bg);--bg-secondary: var(--dark-surface);--bg-tertiary: #293548;--text-primary: #f1f5f9;--text-secondary: #94a3b8;--text-muted: #64748b;--border-color: var(--dark-border);--card-bg: rgba(30, 41, 59, .8)}[data-theme=light]{--bg-primary: #ffffff;--bg-secondary: var(--gray-50);--bg-tertiary: var(--gray-100);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-muted: var(--gray-500);--border-color: var(--gray-200);--card-bg: rgba(255, 255, 255, .9)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);line-height:1.6;min-height:100vh;transition:background-color var(--transition-base),color var(--transition-base)}[data-theme=dark] body{background:linear-gradient(135deg,var(--dark-bg) 0%,#1a1f35 50%,var(--dark-bg) 100%);background-attachment:fixed}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3;color:var(--text-primary)}h1{font-size:2.25rem}h2{font-size:1.875rem}h3{font-size:1.5rem}h4{font-size:1.25rem}h5{font-size:1.125rem}h6{font-size:1rem}p{color:var(--text-secondary)}a{color:var(--primary-500);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--primary-400)}.app-container{display:flex;min-height:100vh}.main-content{flex:1;padding:var(--space-lg);margin-left:280px;transition:margin-left var(--transition-base)}@media(max-width:1024px){.main-content{margin-left:0;padding:var(--space-md)}}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);transition:transform var(--transition-base),box-shadow var(--transition-base)}.card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.card-title{font-size:1.25rem;font-weight:600}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:.875rem;font-weight:500;border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.btn-primary{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff}.btn-primary:hover{background:linear-gradient(135deg,var(--primary-400),var(--primary-500));transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-secondary{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--border-color)}.btn-danger{background:linear-gradient(135deg,var(--error),#dc2626);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}.btn-icon{padding:var(--space-sm);border-radius:var(--radius-md)}.form-group{margin-bottom:var(--space-md)}.form-label{display:block;font-size:.875rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.form-input{width:100%;padding:var(--space-sm) var(--space-md);font-size:.875rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #22c55e33}.form-input::placeholder{color:var(--text-muted)}.table-container{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.table{width:100%;border-collapse:collapse}.table th{background:var(--bg-tertiary);padding:var(--space-sm) var(--space-md);text-align:left;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary)}.table td{padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border-color);font-size:.875rem}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background:var(--bg-tertiary)}.badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);font-size:.75rem;font-weight:500;border-radius:var(--radius-full)}.badge-collection{background:#8b5cf633;color:var(--phase-collection)}.badge-sorting{background:#06b6d433;color:var(--phase-sorting)}.badge-trims{background:#f59e0b33;color:var(--phase-trims)}.badge-shredding{background:#ec489933;color:var(--phase-shredding)}.badge-production{background:#10b98133;color:var(--phase-production)}.badge-impact{background:#6366f133;color:var(--phase-impact)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-md)}.stat-card{background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);display:flex;align-items:center;gap:var(--space-md)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.5rem}.stat-icon.collection{background:linear-gradient(135deg,var(--phase-collection),#7c3aed)}.stat-icon.sorting{background:linear-gradient(135deg,var(--phase-sorting),#0891b2)}.stat-icon.shredding{background:linear-gradient(135deg,var(--phase-shredding),#db2777)}.stat-icon.production{background:linear-gradient(135deg,var(--phase-production),#059669)}.stat-icon.impact{background:linear-gradient(135deg,var(--phase-impact),#4f46e5)}.stat-content{flex:1}.stat-label{font-size:.875rem;color:var(--text-secondary)}.stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .2s ease}.modal{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-xl);width:100%;max-width:500px;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.modal-title{font-size:1.25rem;font-weight:600}.modal-close{background:none;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;transition:color var(--transition-fast)}.modal-close:hover{color:var(--text-primary)}.modal-body{padding:var(--space-lg)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-sm);padding:var(--space-lg);border-top:1px solid var(--border-color)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{animation:pulse 1.5s ease-in-out infinite}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl)}.page-title{font-size:1.875rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:var(--space-xs)}.grid{display:grid;gap:var(--space-md)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media(max-width:768px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb{background:var(--gray-500);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--gray-400)}.empty-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted)}.empty-state-icon{font-size:4rem;margin-bottom:var(--space-md);opacity:.5}.empty-state-title{font-size:1.25rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.toast{position:fixed;bottom:var(--space-lg);right:var(--space-lg);padding:var(--space-md) var(--space-lg);border-radius:var(--radius-lg);background:var(--dark-surface);color:#fff;box-shadow:var(--shadow-xl);animation:slideUp .3s ease;z-index:var(--z-tooltip)}.toast-success{border-left:4px solid var(--success)}.toast-error{border-left:4px solid var(--error)}.toast-warning{border-left:4px solid var(--warning)}.toast-info{border-left:4px solid var(--info)}.toast-container{position:fixed;top:20px;right:20px;z-index:9999;display:flex;flex-direction:column;gap:10px;pointer-events:none}.toast{background:#fff;padding:12px 16px;border-radius:8px;box-shadow:0 4px 12px #00000026;display:flex;align-items:center;justify-content:space-between;min-width:300px;max-width:400px;animation:slideIn .3s ease-out forwards;pointer-events:auto;border-left:4px solid #ccc;color:#333;font-size:.9rem}.toast-success{border-left-color:#10b981;background-color:#ecfdf5;color:#065f46}.toast-error{border-left-color:#ef4444;background-color:#fef2f2;color:#991b1b}.toast-info{border-left-color:#3b82f6;background-color:#eff6ff;color:#1e40af}.toast-warning{border-left-color:#f59e0b;background-color:#fffbeb;color:#92400e}.toast-content{flex:1;padding-right:12px}.toast-close{background:none;border:none;cursor:pointer;font-size:1.2rem;line-height:1;padding:0;color:inherit;opacity:.6;transition:opacity .2s}.toast-close:hover{opacity:1}@keyframes slideIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.sidebar{position:fixed;top:0;left:0;width:280px;height:100vh;background:var(--bg-secondary);border-right:1px solid var(--border-color);display:flex;flex-direction:column;z-index:var(--z-sticky);transition:transform var(--transition-base)}@media(max-width:1024px){.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}}.sidebar-overlay{display:none}@media(max-width:1024px){.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-sticky) - 1)}}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:var(--space-sm)}.logo-img{height:40px;width:auto;object-fit:contain}.logo-text{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--primary-500),var(--secondary-500));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-close{display:none;background:none;border:none;font-size:1.25rem;color:var(--text-muted);cursor:pointer;padding:var(--space-xs)}@media(max-width:1024px){.sidebar-close{display:block}}.sidebar-nav{flex:1;overflow-y:auto;padding:var(--space-md)}.nav-list{list-style:none}.nav-item{margin-bottom:var(--space-xs)}.nav-link{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-lg);color:var(--text-secondary);text-decoration:none;transition:all var(--transition-fast);position:relative}.nav-link:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-link.active{background:linear-gradient(135deg,var(--primary-500),var(--primary-600));color:#fff;box-shadow:var(--shadow-md)}.nav-icon{font-size:1.25rem;width:28px;text-align:center}.nav-label{flex:1;font-size:.9375rem;font-weight:500}.nav-phase{font-size:.6875rem;font-weight:600;padding:2px 6px;border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-muted)}.nav-link.active .nav-phase{background:#fff3;color:#fff}.sidebar-footer{padding:var(--space-lg);border-top:1px solid var(--border-color)}.sidebar-footer-content{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.footer-icon{font-size:1.25rem}.footer-text{font-size:.75rem;color:var(--text-muted)}.navbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--card-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:var(--z-sticky)}.navbar-left{display:flex;align-items:center;gap:var(--space-md)}.menu-toggle{display:none;background:none;border:none;font-size:1.5rem;color:var(--text-primary);cursor:pointer;padding:var(--space-xs)}@media(max-width:1024px){.menu-toggle{display:block}}.breadcrumb{display:flex;align-items:center;gap:var(--space-sm);font-size:.875rem}.breadcrumb-home{font-size:1rem}.breadcrumb-separator{color:var(--text-muted)}.breadcrumb-current{color:var(--text-secondary);font-weight:500}.navbar-right{display:flex;align-items:center;gap:var(--space-md)}.theme-toggle{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:1.25rem;padding:var(--space-sm);cursor:pointer;transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--border-color);transform:scale(1.05)}.user-menu{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-full)}.user-avatar{font-size:1.25rem}.user-name{font-size:.875rem;font-weight:500;color:var(--text-primary)}@media(max-width:640px){.user-name,.breadcrumb{display:none}}.dashboard{max-width:1400px;margin:0 auto;padding-bottom:var(--space-2xl)}.dashboard-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;gap:var(--space-lg);color:var(--text-muted)}.loading-spinner-ring{display:inline-block;position:relative;width:56px;height:56px}.loading-spinner-ring div{box-sizing:border-box;display:block;position:absolute;width:48px;height:48px;margin:4px;border:4px solid var(--primary-500);border-radius:50%;animation:ring-spin 1.2s cubic-bezier(.5,0,.5,1) infinite;border-color:var(--primary-500) transparent transparent transparent}.loading-spinner-ring div:nth-child(1){animation-delay:-.45s}.loading-spinner-ring div:nth-child(2){animation-delay:-.3s}.loading-spinner-ring div:nth-child(3){animation-delay:-.15s}@keyframes ring-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.dash-hero{display:flex;justify-content:space-between;align-items:center;padding:var(--space-xl) var(--space-2xl);margin-bottom:var(--space-xl);background:linear-gradient(135deg,#22c55e14,#06b6d40f,#8b5cf60d);border:1px solid var(--border-color);border-radius:var(--radius-2xl);position:relative;overflow:hidden}.dash-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--phase-collection),var(--phase-sorting),var(--phase-trims),var(--phase-shredding),var(--phase-production),var(--phase-impact))}.dash-hero-content{flex:1}.dash-hero-title{font-size:1.75rem;font-weight:700;display:flex;align-items:center;gap:var(--space-sm);color:var(--text-primary)}.dash-hero-icon{font-size:2rem}.dash-hero-subtitle{color:var(--text-secondary);margin-top:var(--space-xs);font-size:.95rem}.dash-hero-actions{display:flex;gap:var(--space-sm)}.dash-section{margin-bottom:var(--space-2xl)}.dash-section-title{font-size:1.15rem;font-weight:600;color:var(--text-primary);margin-bottom:var(--space-lg);display:flex;align-items:center;gap:var(--space-sm)}.dash-section-icon{font-size:1.25rem}.dash-modules-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}@media(max-width:1024px){.dash-modules-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.dash-modules-grid{grid-template-columns:1fr}}.dash-module-card{position:relative;background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);cursor:pointer;transition:all .25s ease;overflow:hidden}.dash-module-card:hover{transform:translateY(-4px);box-shadow:0 12px 36px #00000026;border-color:#ffffff1a}.dash-module-glow{position:absolute;top:-50%;right:-30%;width:160px;height:160px;border-radius:50%;opacity:.06;pointer-events:none;transition:opacity .3s ease}.dash-module-card:hover .dash-module-glow{opacity:.12}.dash-module-collection .dash-module-glow{background:var(--phase-collection)}.dash-module-sorting .dash-module-glow{background:var(--phase-sorting)}.dash-module-trims .dash-module-glow{background:var(--phase-trims)}.dash-module-shredding .dash-module-glow{background:var(--phase-shredding)}.dash-module-production .dash-module-glow{background:var(--phase-production)}.dash-module-impact .dash-module-glow{background:var(--phase-impact)}.dash-module-collection{border-left:3px solid var(--phase-collection)}.dash-module-sorting{border-left:3px solid var(--phase-sorting)}.dash-module-trims{border-left:3px solid var(--phase-trims)}.dash-module-shredding{border-left:3px solid var(--phase-shredding)}.dash-module-production{border-left:3px solid var(--phase-production)}.dash-module-impact{border-left:3px solid var(--phase-impact)}.dash-module-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-md)}.dash-module-icon{font-size:1.75rem}.dash-module-count{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1}.dash-module-body{margin-bottom:var(--space-md)}.dash-module-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:2px}.dash-module-desc{font-size:.8rem;color:var(--text-muted)}.dash-module-footer{display:flex;justify-content:flex-end}.dash-module-link{font-size:.8rem;font-weight:500;color:var(--primary-500);opacity:0;transform:translate(-8px);transition:all .25s ease}.dash-module-card:hover .dash-module-link{opacity:1;transform:translate(0)}.dash-impact-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-md)}@media(max-width:900px){.dash-impact-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.dash-impact-grid{grid-template-columns:1fr}}.dash-impact-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg) var(--space-xl);text-align:center;position:relative;overflow:hidden;transition:transform .2s ease,box-shadow .2s ease}.dash-impact-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px #0000001a}.dash-impact-card:after{content:"";position:absolute;bottom:0;left:0;right:0;height:3px}.dash-impact-co2:after{background:linear-gradient(90deg,#22c55e,#10b981)}.dash-impact-waste:after{background:linear-gradient(90deg,#8b5cf6,#a855f7)}.dash-impact-water:after{background:linear-gradient(90deg,#0ea5e9,#06b6d4)}.dash-impact-weight:after{background:linear-gradient(90deg,#f97316,#fb923c)}.dash-impact-icon-wrap{margin-bottom:var(--space-sm)}.dash-impact-icon{font-size:2rem;display:inline-block;animation:float 3s ease-in-out infinite}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.dash-impact-value{font-size:1.75rem;font-weight:800;color:var(--text-primary);line-height:1.2}.dash-impact-unit{font-size:.85rem;font-weight:500;color:var(--text-muted);margin-left:4px}.dash-impact-label{font-size:.8rem;color:var(--text-secondary);margin-top:var(--space-xs);font-weight:500}.dash-weight-row{display:flex;align-items:center;gap:var(--space-lg);justify-content:center;flex-wrap:wrap}.dash-weight-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-2xl);display:flex;align-items:center;gap:var(--space-lg);flex:1;max-width:380px;transition:transform .2s ease}.dash-weight-card:hover{transform:translateY(-2px)}.dash-weight-ring{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dash-weight-ring.collected{background:linear-gradient(135deg,#8b5cf626,#8b5cf60d);border:2px solid var(--phase-collection)}.dash-weight-ring.shredded{background:linear-gradient(135deg,#ec489926,#ec48990d);border:2px solid var(--phase-shredding)}.dash-weight-ring-icon{font-size:1.5rem}.dash-weight-info{flex:1}.dash-weight-label{font-size:.85rem;color:var(--text-secondary);margin-bottom:4px}.dash-weight-value{font-size:1.5rem;font-weight:700;color:var(--text-primary)}.dash-weight-value span{font-size:.85rem;font-weight:400;color:var(--text-muted)}.dash-weight-divider{display:flex;align-items:center;gap:var(--space-sm);color:var(--text-muted)}.dash-weight-divider-line{width:24px;height:2px;background:var(--border-color)}.dash-weight-divider-arrow{font-size:1.25rem;color:var(--primary-500)}@media(max-width:768px){.dash-weight-row{flex-direction:column}.dash-weight-card{max-width:100%}.dash-weight-divider{transform:rotate(90deg)}}.dash-pipeline{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:0;background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl) var(--space-lg)}.dash-pipeline-item{display:flex;align-items:center;gap:var(--space-sm)}.dash-pipeline-node{width:52px;height:52px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;font-size:1.4rem;transition:transform .2s ease;flex-shrink:0}.dash-pipeline-node:hover{transform:scale(1.1)}.dash-pipeline-collection{background:linear-gradient(135deg,var(--phase-collection),#7c3aed)}.dash-pipeline-sorting{background:linear-gradient(135deg,var(--phase-sorting),#0891b2)}.dash-pipeline-trims{background:linear-gradient(135deg,var(--phase-trims),#d97706)}.dash-pipeline-shredding{background:linear-gradient(135deg,var(--phase-shredding),#db2777)}.dash-pipeline-production{background:linear-gradient(135deg,var(--phase-production),#059669)}.dash-pipeline-impact{background:linear-gradient(135deg,var(--phase-impact),#4f46e5)}.dash-pipeline-info{text-align:left;min-width:70px}.dash-pipeline-name{font-size:.75rem;font-weight:500;color:var(--text-secondary);white-space:nowrap}.dash-pipeline-count{font-size:1.1rem;font-weight:700;color:var(--text-primary)}.dash-pipeline-connector{color:var(--text-muted);opacity:.4;margin:0 var(--space-xs);flex-shrink:0}@media(max-width:900px){.dash-pipeline{flex-direction:column;gap:var(--space-sm)}.dash-pipeline-item{width:100%;justify-content:center}.dash-pipeline-connector{transform:rotate(90deg)}}.dash-recent-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(max-width:768px){.dash-recent-grid{grid-template-columns:1fr}}.dash-recent-card{background:var(--card-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--border-color);border-radius:var(--radius-xl);overflow:hidden;transition:box-shadow .2s ease}.dash-recent-card:hover{box-shadow:0 4px 20px #00000014}.dash-recent-header{padding:var(--space-md) var(--space-lg);font-size:.85rem;font-weight:600;display:flex;align-items:center;gap:var(--space-sm);color:#fff}.dash-recent-header.collection{background:linear-gradient(135deg,var(--phase-collection),#7c3aed)}.dash-recent-header.sorting{background:linear-gradient(135deg,var(--phase-sorting),#0891b2)}.dash-recent-header.shredding{background:linear-gradient(135deg,var(--phase-shredding),#db2777)}.dash-recent-header.production{background:linear-gradient(135deg,var(--phase-production),#059669)}.dash-recent-body{padding:var(--space-sm)}.dash-recent-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background .15s ease}.dash-recent-item:hover{background:var(--bg-tertiary)}.dash-recent-id{font-family:var(--font-mono);font-size:.7rem;padding:2px 6px;border-radius:var(--radius-sm);background:#22c55e1a;color:var(--primary-500);white-space:nowrap}.dash-recent-detail{flex:1;font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-recent-weight{font-size:.8rem;font-weight:600;color:var(--text-primary);white-space:nowrap}.dash-recent-empty{padding:var(--space-lg);text-align:center;color:var(--text-muted);font-size:.85rem}.phase-page{max-width:1400px;margin:0 auto}.phase-icon{margin-right:var(--space-sm)}.loading-state{text-align:center;padding:var(--space-3xl);color:var(--text-muted)}.unique-id{font-family:var(--font-mono);font-size:.75rem;background:var(--bg-tertiary);padding:2px 8px;border-radius:var(--radius-sm);color:var(--text-primary)}.actions{display:flex;gap:var(--space-xs)}.btn-icon{background:transparent;border:none;cursor:pointer;padding:var(--space-xs);border-radius:var(--radius-sm);transition:background var(--transition-fast)}.btn-icon:hover{background:var(--bg-tertiary)}textarea.form-input{resize:vertical;min-height:80px}.form-select{width:100%;padding:var(--space-sm) var(--space-md);font-size:.875rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%236b7280' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.form-select:focus{outline:none;border-color:var(--primary-500);box-shadow:0 0 0 3px #22c55e33}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-md)}@media(max-width:640px){.form-row{grid-template-columns:1fr}}.impact-preview{background:linear-gradient(135deg,#22c55e1a,#10b9811a);border:1px solid var(--primary-500);border-radius:var(--radius-lg);padding:var(--space-md);margin-top:var(--space-md)}.impact-preview-title{font-size:.875rem;font-weight:600;color:var(--primary-500);margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-sm)}.impact-preview-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.impact-preview-item{text-align:center}.impact-preview-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.impact-preview-label{font-size:.6875rem;color:var(--text-muted)}.trace-search{display:flex;gap:var(--space-md);margin-bottom:var(--space-xl)}.trace-search .form-input{flex:1;max-width:400px}.trace-result{background:var(--card-bg);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl)}.trace-timeline{position:relative;padding-left:var(--space-xl)}.trace-timeline:before{content:"";position:absolute;left:15px;top:0;bottom:0;width:2px;background:var(--border-color)}.trace-item{position:relative;margin-bottom:var(--space-xl);padding:var(--space-md);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.trace-item:before{content:"";position:absolute;left:calc(-1 * var(--space-xl) + 8px);top:50%;transform:translateY(-50%);width:16px;height:16px;border-radius:50%;background:var(--primary-500);border:3px solid var(--bg-primary)}.trace-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.trace-item-title{font-weight:600;display:flex;align-items:center;gap:var(--space-sm)}.trace-item-id{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted)}.trace-item-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-sm)}.trace-detail{font-size:.875rem}.trace-detail-label{color:var(--text-muted);font-size:.75rem}.trace-detail-value{color:var(--text-primary);font-weight:500}.searchable-dropdown{position:relative;width:100%}.dropdown-list{position:absolute;top:100%;left:0;right:0;z-index:50;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);max-height:200px;overflow-y:auto;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;margin-top:4px}.dropdown-item{padding:var(--space-sm) var(--space-md);cursor:pointer;border-bottom:1px solid var(--border-color);color:var(--text-primary);font-size:.875rem;transition:background-color .15s ease}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:var(--bg-tertiary)}.dropdown-item.no-results{color:var(--text-muted);cursor:default;font-style:italic;text-align:center;background-color:var(--bg-secondary)}.pagination-container{display:flex;justify-content:space-between;align-items:center;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #e5e7eb}.pagination-info{font-size:.875rem;color:#6b7280}.pagination-controls{display:flex;gap:.25rem;align-items:center}.btn-sm{padding:.25rem .75rem;font-size:.875rem}.btn-outline{background-color:transparent;border:1px solid #e5e7eb;color:#374151}.btn-outline:hover{background-color:#f9fafb;border-color:#d1d5db}.filters-section{background:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 2px #0000000d}
