@import"https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@400;600;700;800;900&family=DM+Sans:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&display=swap";.project-tree{display:flex;flex-direction:column;height:100%;background:var(--surface-panel);width:100%}.tree-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--tree-border);min-height:44px}.tree-scroll{flex:1;overflow-y:auto;padding:var(--space-2) var(--space-3);padding-bottom:var(--space-6)}.tree-section{margin-bottom:var(--space-2)}.tree-section-header{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-2);font-family:var(--font-heading);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.tree-row{display:flex;align-items:center;gap:4px;min-height:48px;padding-right:8px;margin:3px 0;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);transition:all .1s;position:relative}.tree-row:hover{border-color:var(--border-strong);box-shadow:0 1px 4px #0000000f}.tree-row--selected{background:var(--surface);border-color:var(--accent);border-left:3px solid var(--accent);box-shadow:0 1px 6px #f5c4001f}.tree-chevron{background:none;border:none;color:var(--text-muted);padding:8px 4px;cursor:pointer;display:flex;align-items:center;min-width:24px;min-height:44px;justify-content:center;flex-shrink:0}.tree-chevron:hover{color:var(--text)}.tree-status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.tree-label{flex:1;display:flex;align-items:center;gap:6px;background:none;border:none;cursor:pointer;padding:8px 4px;min-height:44px;text-align:left;overflow:hidden}.tree-label-text{font-family:var(--font-heading);font-size:13px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-row--selected .tree-label-text{color:var(--accent-text);font-weight:700}.tree-label-sub{font-family:var(--font-body);font-size:10px;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-icon-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:var(--radius-sm);flex-shrink:0;transition:all .1s}.tree-icon-btn:hover{color:var(--accent-text);background:var(--accent-dim)}.tree-add-row{display:flex;gap:4px;padding:var(--space-3) var(--space-2)}.tree-text-btn{display:inline-flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);font-family:var(--font-heading);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:6px 10px;cursor:pointer;transition:all .1s}.tree-text-btn:hover{border-color:var(--accent-border);color:var(--accent-text);background:var(--accent-dim)}.action-sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000059;z-index:200;display:flex;align-items:flex-end;justify-content:center}.action-sheet{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;width:100%;max-width:420px;max-height:60vh;overflow-y:auto;padding-bottom:env(safe-area-inset-bottom,12px);box-shadow:0 -8px 32px #0000001f}.action-sheet-title{font-family:var(--font-heading);font-weight:700;font-size:14px;color:var(--text);padding:16px 20px 8px;border-bottom:1px solid var(--border-faint)}.action-sheet-scroll{max-height:40vh;overflow-y:auto}.action-sheet-btn{display:flex;align-items:center;gap:12px;width:100%;background:none;border:none;border-bottom:1px solid var(--border-faint);color:var(--text);font-family:var(--font-body);font-weight:500;font-size:14px;padding:14px 20px;cursor:pointer;text-align:left;min-height:52px;transition:background .1s}.action-sheet-btn:hover{background:var(--surface-hover)}.action-sheet-btn:active{background:var(--surface-alt)}.action-sheet-danger{color:var(--red-text)}.action-sheet-cancel{color:var(--text-muted);border-bottom:none;margin-top:4px}.add-pop{position:absolute;top:100%;right:0;z-index:150;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);box-shadow:0 4px 16px #0000001f;min-width:120px;overflow:hidden}.add-pop-btn{display:flex;align-items:center;gap:8px;background:none;border:none;border-bottom:1px solid var(--border-faint);color:var(--text);font-family:var(--font-heading);font-weight:600;font-size:12px;padding:10px 14px;cursor:pointer;text-align:left;min-height:40px;transition:background .1s}.add-pop-btn:last-child{border-bottom:none}.add-pop-btn:hover{background:var(--accent-dim);color:var(--accent-text)}.app-shell-v2{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--sidebar-bg);display:flex;flex-direction:column;flex-shrink:0;z-index:60}.sidebar-logo{padding:20px 20px 16px;border-bottom:1px solid var(--sidebar-border)}.sidebar-logo-text{font-family:var(--font-heading);font-weight:900;font-size:18px;letter-spacing:2px;color:var(--sidebar-text-bright);text-transform:uppercase}.sidebar-logo-accent{color:var(--accent)}.sidebar-project{padding:14px 20px;border-bottom:1px solid var(--sidebar-border)}.sidebar-project-name{font-family:var(--font-heading);font-weight:700;font-size:13px;color:var(--sidebar-text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-project-sub{font-family:var(--font-body);font-size:11px;color:var(--sidebar-text-muted);margin-top:2px}.sidebar-nav{flex:1;padding:12px 0;display:flex;flex-direction:column;gap:2px}.sidebar-nav-item{display:flex;align-items:center;gap:10px;padding:10px 20px;font-family:var(--font-body);font-weight:500;font-size:13px;color:var(--sidebar-text);text-decoration:none;min-height:44px;border-left:3px solid transparent;transition:all .1s}.sidebar-nav-item:hover{color:var(--sidebar-text-bright);background:var(--sidebar-hover)}.sidebar-nav-item--active{color:var(--sidebar-text-bright);background:var(--sidebar-hover);border-left-color:var(--accent)}.sidebar-nav-item--active svg{color:var(--accent)}.sidebar-footer{padding:14px 20px;border-top:1px solid var(--sidebar-border);display:flex;flex-direction:column;gap:8px}.sidebar-sync{display:flex;align-items:center;gap:8px;font-family:var(--font-body);font-weight:500;font-size:11px;color:var(--sidebar-text-muted)}.sidebar-user{display:flex;align-items:center;gap:8px;padding:8px 0;color:var(--sidebar-text)}.sidebar-user svg{flex-shrink:0;color:var(--sidebar-text-muted)}.sidebar-user-info{min-width:0}.sidebar-user-name{font-family:var(--font-body);font-weight:500;font-size:12px;color:var(--sidebar-text-bright);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-family:var(--font-heading);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--accent)}.sidebar-version{font-family:var(--font-body);font-size:10px;color:var(--sidebar-text-muted)}.sidebar-exit-btn{background:none;border:none;cursor:pointer;padding:8px 0;border-left:none;opacity:.7}.sidebar-exit-btn:hover{opacity:1}.main-area{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}.topbar{display:flex;align-items:center;justify-content:space-between;height:var(--topbar-height);padding:0 24px;background:var(--surface-topbar);border-bottom:1px solid var(--border);flex-shrink:0;z-index:50}.topbar-left{display:flex;align-items:baseline;gap:12px}.topbar-title{font-family:var(--font-heading);font-weight:800;font-size:20px;color:var(--text);line-height:1}.topbar-sub{font-family:var(--font-body);font-size:13px;color:var(--text-muted)}.topbar-right{display:flex;align-items:center;gap:var(--space-3)}.tree-toggle-btn{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-muted);padding:8px;cursor:pointer;display:flex;align-items:center;min-width:36px;min-height:36px;justify-content:center;transition:all .1s}.tree-toggle-btn:hover{color:var(--accent-text);border-color:var(--accent-border);background:var(--accent-dim)}.tree-layout{display:flex;flex:1;overflow:hidden}.tree-panel{width:380px;min-width:320px;max-width:460px;flex-shrink:0;overflow:hidden;display:flex;border-right:1px solid var(--border);background:var(--surface-panel)}.form-panel{flex:1;overflow-y:auto;background:var(--page-bg)}.page-content{flex:1;padding:var(--space-6);overflow-y:auto;background:var(--page-bg)}.node-form{padding:var(--space-5);max-width:720px}.node-form-empty{display:flex;align-items:center;justify-content:center;height:100%;padding:var(--space-8);color:var(--text-muted)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3) var(--space-3)}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.form-section{border-bottom:1px solid var(--border)}.form-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:var(--space-4) 0;cursor:pointer;color:var(--text);min-height:48px}.form-section-header:hover{color:var(--accent-text)}.form-section-header .eyebrow{pointer-events:none}.form-section-body{padding-bottom:var(--space-5)}.dashboard{max-width:1400px}.project-header{margin-bottom:var(--space-6)}.kpi-row{display:grid;grid-template-columns:repeat(5,1fr);gap:14px;margin-bottom:var(--space-6)}.widget-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:var(--space-6)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-3)}.cable-stats{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-4)}.cable-stat{display:flex;align-items:center;justify-content:space-between}.cable-count{font-family:var(--font-heading);font-weight:900;font-size:18px;color:var(--text)}.recent-list{display:flex;flex-direction:column;gap:2px;margin-top:var(--space-3)}.recent-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);cursor:pointer}.recent-row:hover{background:var(--surface-hover)}.asset-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:6px}.asset-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);cursor:pointer;display:flex;flex-direction:column;gap:4px;transition:border-color .15s ease}.asset-tile:hover{border-color:var(--accent-border)}.asset-tile--complete{border-top:3px solid var(--green)}.asset-tile--in_progress{border-top:3px solid var(--orange)}.asset-tile--not_started{border-top:3px solid var(--text-muted)}@media (max-width: 1100px){.kpi-row{grid-template-columns:repeat(3,1fr)}.widget-grid{grid-template-columns:1fr 1fr}}.incomplete-list{display:flex;flex-direction:column;gap:2px}.incomplete-row{display:flex;align-items:center;gap:12px;padding:8px 12px;border-radius:var(--radius-sm);background:var(--surface);border:1px solid var(--border);transition:border-color .15s ease}.incomplete-row:hover{border-color:var(--accent-border)}.type-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.type-dot--source{background:var(--accent)}.type-dot--board{background:var(--blue)}.type-dot--asset{background:var(--text-muted)}@media (max-width: 800px){.kpi-row{grid-template-columns:repeat(2,1fr)}.widget-grid{grid-template-columns:1fr}.incomplete-row span:last-child{display:none}}.project-files{display:flex;height:calc(100vh - 60px);margin:calc(-1 * var(--space-6));gap:1px;background:var(--border)}.pf-list-panel{width:420px;min-width:320px;display:flex;flex-direction:column;background:var(--bg);overflow-y:auto}.pf-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-5);margin:var(--space-4);border:2px dashed var(--border);border-radius:var(--radius);color:var(--text-muted);cursor:pointer;transition:border-color .15s,background .15s}.pf-dropzone:hover,.pf-dropzone--active{border-color:var(--primary);background:#0066cc0a;color:var(--primary)}.pf-dropzone-hint{font-size:.75rem;opacity:.7}.pf-offline-banner{padding:var(--space-3) var(--space-4);margin:var(--space-4);background:var(--warning-bg, #fef3cd);color:var(--warning-text, #856404);border-radius:var(--radius);font-size:.85rem;text-align:center}.pf-error{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);margin:0 var(--space-4);background:#fef2f2;color:#b91c1c;border-radius:var(--radius);font-size:.85rem}.pf-error button{background:none;border:none;color:inherit;cursor:pointer;padding:2px}.pf-file-list{flex:1;overflow-y:auto}.pf-empty{padding:var(--space-6);text-align:center;color:var(--text-muted);font-size:.9rem}.pf-file-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);cursor:pointer;transition:background .1s}.pf-file-item:hover{background:var(--hover-bg, rgba(0, 0, 0, .02))}.pf-file-item--selected{background:#0066cc0f;border-left:3px solid var(--primary)}.pf-file-icon{color:var(--text-muted);flex-shrink:0}.pf-file-info{flex:1;min-width:0}.pf-file-name{font-size:.875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pf-file-meta{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--text-muted);margin-top:2px}.pf-file-type{background:var(--badge-bg, #e5e7eb);padding:1px 6px;border-radius:3px;font-weight:600;font-size:.65rem;letter-spacing:.03em}.pf-file-node{display:inline-flex;align-items:center;gap:3px}.pf-file-actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.pf-node-select{font-size:.75rem;padding:2px 4px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg);max-width:100px}.pf-delete-btn{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:4px;border-radius:var(--radius);transition:color .1s,background .1s}.pf-delete-btn:hover{color:#b91c1c;background:#fef2f2}.pf-viewer-panel{flex:1;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.pf-viewer-empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-3);color:var(--text-muted)}.pf-viewer-content{display:flex;flex-direction:column;flex:1;overflow:hidden}.pf-viewer-toolbar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2) var(--space-4);border-bottom:1px solid var(--border);font-size:.85rem;font-weight:500}.pf-viewer-toolbar a{display:inline-flex;align-items:center;gap:4px;color:var(--primary);text-decoration:none;font-size:.8rem}.pf-viewer-toolbar a:hover{text-decoration:underline}.pf-viewer-iframe{flex:1;width:100%;border:none}.pf-viewer-image-wrap{flex:1;overflow:auto;display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.pf-viewer-image{max-width:100%;max-height:100%;object-fit:contain;border-radius:var(--radius)}.pf-download-link{display:inline-flex;align-items:center;gap:6px;margin-top:var(--space-3);padding:var(--space-2) var(--space-4);background:var(--primary);color:#fff;text-decoration:none;border-radius:var(--radius);font-size:.85rem}.pf-download-link:hover{opacity:.9}@media (max-width: 768px){.project-files{flex-direction:column}.pf-list-panel{width:100%;max-height:50vh}.pf-viewer-panel{min-height:50vh}}.project-selector{min-height:100vh;background:var(--page-bg, #F4F4F5);display:flex;align-items:center;justify-content:center;padding:24px}.project-selector-inner{width:100%;max-width:480px}.project-selector-header{text-align:center;margin-bottom:32px}.project-selector-logo{font-family:var(--font-heading, "Barlow Condensed", sans-serif);font-size:28px;font-weight:700;letter-spacing:2px;color:var(--sidebar-bg, #0A0A0A)}.project-selector-header h1{font-family:var(--font-heading, "Barlow Condensed", sans-serif);font-size:20px;font-weight:600;margin:8px 0 4px;color:#333}.project-selector-header p{font-family:var(--font-body, "DM Sans", sans-serif);font-size:14px;color:#666;margin:0}.project-selector-status{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:#666;margin-top:8px}.project-selector-loading{text-align:center;font-size:14px;color:#666;padding:40px 0}.project-selector-error{background:#fef2f2;color:#dc2626;font-size:13px;padding:10px 14px;border-radius:8px;margin-bottom:16px}.project-selector-list{display:flex;flex-direction:column;gap:8px;margin-bottom:24px}.project-card{display:flex;align-items:center;gap:14px;padding:14px 16px;background:var(--surface, #FFFFFF);border:1px solid #E4E4E7;border-radius:10px;cursor:pointer;transition:border-color .15s,box-shadow .15s;text-align:left;width:100%;font-family:var(--font-body, "DM Sans", sans-serif)}.project-card:hover{border-color:var(--accent, #F5C400);box-shadow:0 0 0 2px #f5c40026}.project-card svg{color:var(--accent-text, #92750A);flex-shrink:0}.project-card-name{font-weight:600;font-size:14px;color:#1a1a1a}.project-card-sub{font-size:12px;color:#888;margin-top:2px}.project-card-row{display:flex;align-items:center;gap:8px}.project-card-row .project-card{flex:1}.project-delete-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border:1px solid #E4E4E7;border-radius:10px;background:var(--surface, #FFFFFF);color:#999;cursor:pointer;transition:all .15s;flex-shrink:0}.project-delete-btn:hover{color:#ef4444;border-color:#ef4444;background:#fef2f2}.project-selector-create{background:var(--surface, #FFFFFF);border:1px solid #E4E4E7;border-radius:10px;padding:20px;margin-bottom:16px}.project-selector-create h3{font-family:var(--font-heading, "Barlow Condensed", sans-serif);font-size:15px;font-weight:600;color:#333;margin:0 0 14px;display:flex;align-items:center;gap:6px}.project-input{display:block;width:100%;padding:10px 12px;font-size:14px;font-family:var(--font-body, "DM Sans", sans-serif);border:1px solid #D4D4D8;border-radius:6px;margin-bottom:10px;box-sizing:border-box;outline:none;transition:border-color .15s}.project-input:focus{border-color:var(--accent, #F5C400)}.project-create-btn{width:100%;padding:10px;background:var(--accent, #F5C400);color:#1a1a1a;font-family:var(--font-heading, "Barlow Condensed", sans-serif);font-weight:600;font-size:14px;border:none;border-radius:6px;cursor:pointer;transition:opacity .15s}.project-create-btn:hover{opacity:.9}.project-create-btn:disabled{opacity:.5;cursor:not-allowed}.project-offline-btn{display:block;width:100%;padding:10px;background:transparent;color:#666;font-family:var(--font-body, "DM Sans", sans-serif);font-size:13px;border:1px dashed #D4D4D8;border-radius:6px;cursor:pointer;transition:border-color .15s,color .15s}.project-offline-btn:hover{border-color:#999;color:#333}:root{--page-bg: #F4F4F5;--surface: #FFFFFF;--surface-hover: #FAFAFA;--surface-alt: #F0F0F1;--surface-panel: #D8DAE0;--surface-topbar: #FAFBFC;--tree-border: #C5C8CE;--sidebar-bg: #0A0A0A;--sidebar-surface: #141414;--sidebar-border: rgba(255, 255, 255, .08);--sidebar-text: rgba(255, 255, 255, .7);--sidebar-text-bright: #FFFFFF;--sidebar-text-muted: rgba(255, 255, 255, .35);--sidebar-hover: rgba(255, 255, 255, .05);--text: #1A1A1A;--text-secondary: #6B7280;--text-muted: #9CA3AF;--text-faint: #D1D5DB;--border: #E5E7EB;--border-strong: #D1D5DB;--border-faint: #F3F4F6;--accent: #F5C400;--accent-hover: #E0B400;--accent-dim: rgba(245, 196, 0, .1);--accent-border: rgba(245, 196, 0, .35);--accent-text: #92750A;--green: #22C55E;--green-dim: rgba(34, 197, 94, .1);--green-text: #15803D;--red: #EF4444;--red-dim: rgba(239, 68, 68, .08);--red-text: #DC2626;--blue: #3B82F6;--blue-dim: rgba(59, 130, 246, .08);--blue-text: #2563EB;--orange: #F59E0B;--orange-dim: rgba(245, 158, 11, .1);--orange-text: #D97706;--font-heading: "Barlow Condensed", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "JetBrains Mono", monospace;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--radius-xs: 3px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-full: 99px;--sidebar-width: 220px;--topbar-height: 56px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body{height:100%;background:var(--page-bg);color:var(--text);font-family:var(--font-body);font-weight:400;font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{height:100%}a{color:var(--accent-text);text-decoration:none}a:hover{color:var(--accent-hover)}.heading{font-family:var(--font-heading);font-weight:800;letter-spacing:-.01em;color:var(--text);line-height:1.1}.eyebrow{font-family:var(--font-heading);font-weight:700;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary)}.label{font-family:var(--font-body);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.mono{font-family:var(--font-mono);font-weight:400;font-size:13px;color:var(--text-secondary)}.text-muted{color:var(--text-muted)}.text-dim{color:var(--text-secondary)}.text-accent{color:var(--accent-text)}.text-orange{color:var(--orange-text)}.text-green{color:var(--green-text)}.text-red{color:var(--red-text)}.text-blue{color:var(--blue-text)}.btn{display:inline-flex;align-items:center;gap:var(--space-2);font-family:var(--font-heading);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:1px;padding:8px 16px;border:1px solid transparent;border-radius:var(--radius-sm);cursor:pointer;transition:all .15s ease;white-space:nowrap}.btn-primary{background:var(--accent);color:#1a1a1a;border-color:var(--accent)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.btn-ghost:hover{border-color:var(--accent);color:var(--accent-text)}.btn-outline-accent{background:transparent;color:var(--accent-text);border:1px solid var(--accent-border)}.btn-outline-accent:hover{background:var(--accent-dim)}.btn-outline-orange{background:transparent;color:var(--orange-text);border:1px solid rgba(245,158,11,.35)}.btn-outline-orange:hover{background:var(--orange-dim)}.btn-danger{background:transparent;color:var(--red-text);border:1px solid rgba(239,68,68,.3)}.btn-danger:hover{background:var(--red-dim)}.btn-sm{padding:5px 12px;font-size:11px}.btn-lg{padding:10px 24px;font-size:13px}.badge{display:inline-flex;align-items:center;gap:6px;font-family:var(--font-heading);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.8px;padding:3px 9px;border-radius:var(--radius-xs);white-space:nowrap}.badge-orange{background:var(--accent-dim);color:var(--accent-text);border:1px solid var(--accent-border)}.badge-green{background:var(--green-dim);color:var(--green-text);border:1px solid rgba(34,197,94,.25)}.badge-red{background:var(--red-dim);color:var(--red-text);border:1px solid rgba(239,68,68,.25)}.badge-blue{background:var(--blue-dim);color:var(--blue-text);border:1px solid rgba(59,130,246,.25)}.badge-muted{background:var(--border-faint);color:var(--text-muted);border:1px solid var(--border)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;position:relative;overflow:hidden}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:18px;border-top:3px solid var(--accent)}.kpi-card.kpi-green{border-top-color:var(--green)}.kpi-card.kpi-red{border-top-color:var(--red)}.kpi-card.kpi-blue{border-top-color:var(--blue)}.kpi-card.kpi-muted{border-top-color:var(--text-muted)}.kpi-value{font-family:var(--font-heading);font-weight:900;font-size:32px;letter-spacing:-.02em;color:var(--text);line-height:1}.kpi-green .kpi-value{color:var(--green-text)}.kpi-red .kpi-value{color:var(--red-text)}.kpi-blue .kpi-value{color:var(--blue-text)}.kpi-muted .kpi-value{color:var(--text-muted)}.kpi-label{font-family:var(--font-heading);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);margin-top:6px}.input,.select,.textarea{width:100%;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-body);font-weight:400;font-size:14px;padding:9px 12px;transition:border-color .15s ease}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.input.error,.select.error,.textarea.error{border-color:var(--red)}.form-label{display:block;font-family:var(--font-body);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:4px}.form-group{margin-bottom:12px}.data-table{width:100%;border-collapse:collapse}.data-table th{font-family:var(--font-body);font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);background:var(--surface-alt);padding:8px 16px;text-align:left;border-bottom:1px solid var(--border)}.data-table td{font-family:var(--font-body);font-weight:400;font-size:13px;color:var(--text);padding:9px 16px;border-bottom:1px solid var(--border-faint)}.data-table tr:hover td{background:var(--surface-hover)}.data-table .clickable{cursor:pointer}.progress-track{width:100%;height:6px;background:var(--border);border-radius:var(--radius-full);overflow:hidden}.progress-fill{height:100%;background:var(--accent);border-radius:var(--radius-full);transition:width .5s ease}.progress-fill.green{background:var(--green)}.progress-fill.blue{background:var(--blue)}.callout{border-left:3px solid var(--accent);background:var(--accent-dim);padding:var(--space-4) var(--space-5);border-radius:var(--radius-sm);color:var(--accent-text)}.callout-red{border-left-color:var(--red);background:var(--red-dim);color:var(--red-text)}.callout-green{border-left-color:var(--green);background:var(--green-dim);color:var(--green-text)}.callout-blue{border-left-color:var(--blue);background:var(--blue-dim);color:var(--blue-text)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-8);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #00000026}.modal-title{font-family:var(--font-heading);font-weight:800;font-size:18px;color:var(--text);margin-bottom:var(--space-6)}.toast{position:fixed;bottom:var(--space-6);right:var(--space-6);background:var(--surface);border:1px solid var(--green);border-radius:var(--radius-md);padding:var(--space-3) var(--space-5);color:var(--green-text);font-family:var(--font-heading);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;z-index:200;box-shadow:0 8px 24px #0000001f;animation:toast-in .3s ease,toast-out .3s ease 2.7s forwards}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1}to{opacity:0}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.toggle-group{display:inline-flex;gap:2px;background:var(--surface-alt);border-radius:var(--radius-sm);padding:2px;border:1px solid var(--border)}.toggle-btn{font-family:var(--font-heading);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:.5px;padding:8px 16px;background:transparent;color:var(--text-muted);border:none;border-radius:var(--radius-xs);cursor:pointer;transition:all .15s ease}.toggle-btn.active{background:var(--accent);color:#1a1a1a}.toggle-btn:hover:not(.active){color:var(--text);background:var(--surface)}.offline-banner{background:var(--orange-dim);border-bottom:1px solid rgba(245,158,11,.3);color:var(--orange-text);font-family:var(--font-heading);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.5px;text-align:center;padding:var(--space-3) var(--space-4)}
