@import "https://fonts.googleapis.com/css2?family=Manrope:wght@400;500;600;700;800&display=swap";:root{font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Manrope,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}body{color:#112433;background:#f4f7fb}:root{--bg:#f1f5f9;--panel:#fff;--panel-soft:#f8fafc;--line:#e2e8f0;--line-mid:#cbd5e1;--text:#0f172a;--text-2:#334155;--muted:#64748b;--brand:#1d4ed8;--brand-2:#2563eb;--brand-soft:#eff6ff;--brand-mid:#bfdbfe;--danger:#dc2626;--danger-soft:#fee2e2;--ok:#16a34a;--ok-soft:#dcfce7;--warn:#d97706;--warn-soft:#fef3c7;--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000d;--shadow-md:0 4px 12px #00000014, 0 2px 6px #0000000d;--shadow-lg:0 12px 32px #0000001f, 0 4px 12px #00000012;--radius-sm:8px;--radius-md:12px;--radius-lg:16px;--radius-xl:20px}.login-page{background:linear-gradient(135deg,#f0f9ff 0%,#e0f2fe 40%,#ede9fe 100%);place-items:center;min-height:100vh;display:grid}.login-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);width:min(480px,100% - 40px);box-shadow:var(--shadow-lg);gap:14px;padding:36px 32px;display:grid}.login-logo{width:160px;max-width:55%;height:auto}.login-brand{letter-spacing:.12em;color:var(--muted);text-transform:uppercase;font-size:11px;font-weight:600}.login-card h1{letter-spacing:-.025em;color:var(--text);margin:0;font-size:30px;font-weight:700}.login-card p{color:var(--muted);margin:0 0 6px;font-size:14px}label{gap:5px;display:grid}label>span{color:var(--text-2);letter-spacing:.02em;text-transform:uppercase;font-size:12px;font-weight:600}.app-shell{background:var(--bg);grid-template-columns:240px minmax(0,1fr);min-height:100vh;display:grid}.sidebar{color:#cbd5e1;background:#0f172a;border-right:1px solid #1e293b;flex-direction:column;gap:6px;height:100vh;padding:20px 12px;display:flex;position:sticky;top:0;overflow:auto}.brand-sub{letter-spacing:.1em;text-transform:uppercase;color:#475569;margin-bottom:12px;padding:0 4px;font-size:10px;font-weight:600}.sidebar-logo{border-radius:6px;width:148px;max-width:90%;height:auto;margin-bottom:4px}.company-mini-logo{object-fit:contain;width:26px;height:26px}.company-preview-logo{object-fit:contain;border:1px solid var(--line);border-radius:var(--radius-md);background:var(--panel-soft);width:120px;max-width:100%;padding:8px}.sidebar nav{flex:1;gap:2px;display:grid}.nav-btn{color:#94a3b8;border-radius:var(--radius-sm);text-align:left;letter-spacing:.01em;background:0 0;border:none;padding:9px 12px;font-size:14px;font-weight:500;transition:background .12s,color .12s;position:relative}.nav-btn:hover{color:#e2e8f0;background:#1e293b}.nav-btn.active{color:#93c5fd;background:#1e3a5f;font-weight:600;box-shadow:inset 3px 0 #3b82f6}.logout-btn{color:#fca5a5;border-radius:var(--radius-sm);background:#1c0a0a;border:1px solid #3f1f1f;margin-top:auto;padding:9px 12px;font-size:14px;font-weight:500;transition:background .12s}.logout-btn:hover{filter:none;background:#2d1010}.main{align-content:start;gap:16px;min-width:0;padding:24px;display:grid}.main>*{min-width:0}.topbar{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 20px;display:flex}.topbar-main h2{letter-spacing:-.02em;color:var(--text);margin:0;font-size:22px;font-weight:700;line-height:1.2}.topbar-main p{color:var(--muted);margin:3px 0 0;font-size:13px}.topbar-meta{align-items:center;gap:8px;display:flex}.pill{background:var(--brand-soft);border:1px solid var(--brand-mid);color:var(--brand);border-radius:999px;padding:5px 12px;font-size:12px;font-weight:600}.context-panel{padding:14px 16px}.context-grid{grid-template-columns:repeat(3,minmax(180px,1fr));gap:10px;display:grid}.context-hint{color:var(--muted);margin-top:10px;font-size:12px;font-weight:500}.grid{align-items:start;gap:16px;display:grid}.hero-band{border-radius:var(--radius-xl);color:#fff;background:linear-gradient(135deg,#312e81 0%,#4f46e5 40%,#6366f1 70%,#818cf8 100%);border:none;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;padding:32px 36px;display:flex;position:relative;overflow:hidden;box-shadow:0 8px 32px #4f46e540}.hero-band:before{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff14 0%,#0000 70%);width:400px;height:400px;position:absolute;top:-50%;right:-20%}.hero-band:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff0d 0%,#0000 70%);width:300px;height:300px;position:absolute;bottom:-30%;left:-10%}.hero-band h3{letter-spacing:-.03em;color:#fff;margin:0;font-size:24px;font-weight:800;position:relative}.hero-band p{color:#ffffffb3;max-width:420px;margin:6px 0 0;font-size:14px;line-height:1.5;position:relative}.hero-actions{flex-wrap:wrap;gap:10px;display:flex;position:relative}.hero-actions button{color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff26;border:1px solid #ffffff40;border-radius:10px;min-width:150px;padding:10px 18px;font-size:13px;font-weight:600;transition:all .2s}.hero-actions button:hover{filter:none;background:#ffffff47;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.stats-grid{grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.two-col{grid-template-columns:1fr 1fr}.assets-grid{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--line);background:var(--panel);grid-template-columns:340px 1fr;gap:0;height:calc(100vh - 140px);overflow:hidden}.stat-card{background:var(--panel);border-radius:var(--radius-lg);border-top:none;border-left:none;border:1px solid var(--line);box-shadow:var(--shadow-sm);cursor:pointer;flex-direction:row;align-items:center;gap:16px;transition:all .2s;display:flex;padding:18px 20px!important}.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.stat-card-icon{border-radius:14px;flex-shrink:0;place-items:center;width:52px;height:52px;font-size:24px;display:grid}.stat-icon-blue{background:#eff6ff}.stat-icon-red{background:#fef2f2}.stat-icon-amber{background:#fffbeb}.stat-icon-green{background:#f0fdf4}.stat-icon-violet{background:#f5f3ff}.stat-card-body{flex-direction:column;gap:2px;min-width:0;display:flex}.stat-card-body strong{color:var(--text);letter-spacing:-.03em;font-size:28px;font-weight:800;line-height:1}.stat-card-body span{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:12px;font-weight:600}.stat-card h3{display:none!important}.asset-tabs{background:var(--panel-soft);border:1px solid var(--line);border-radius:10px;gap:0;margin-bottom:0;padding:3px;display:flex}.asset-tab{color:var(--muted);cursor:pointer;text-align:center;background:0 0;border:0;border-radius:8px;flex:1;padding:8px 14px;font-size:13px;font-weight:600;transition:all .2s}.asset-tab:hover{background:var(--line);color:var(--text);filter:none}.asset-tab.active{color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#6366f1 100%);box-shadow:0 2px 8px #4f46e540}.asset-controls{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.asset-controls button{background:var(--panel-soft);color:var(--brand);border:1px solid var(--brand-mid);font-size:13px}.asset-controls button:hover{background:var(--brand-soft);filter:none}.breadcrumbs{border:1px solid var(--line);background:var(--panel-soft);color:var(--muted);border-radius:8px;margin-bottom:10px;padding:8px 14px;font-size:12px;font-weight:500;line-height:1.5}.assets-sidebar{border-right:1px solid var(--line);flex-direction:column;height:100%;display:flex;overflow:hidden}.assets-sidebar .panel{box-shadow:none;border:none;border-radius:0;min-height:0;padding:16px 18px;overflow-y:auto}.assets-sidebar .panel:first-child{border-bottom:1px solid var(--line);flex-shrink:0;max-height:40%}.assets-sidebar .panel:last-child{flex:1;min-height:0}.assets-sidebar .panel::-webkit-scrollbar{width:5px}.assets-sidebar .panel::-webkit-scrollbar-track{background:0 0}.assets-sidebar .panel::-webkit-scrollbar-thumb{background:var(--line-mid);border-radius:3px}.assets-sidebar .panel .list{align-content:start}.assets-main{background:var(--bg);flex-direction:column;gap:16px;height:100%;padding:20px 24px;display:flex;overflow:hidden}.assets-main::-webkit-scrollbar{width:6px}.assets-main::-webkit-scrollbar-track{background:0 0}.assets-main::-webkit-scrollbar-thumb{background:var(--line-mid);border-radius:3px}.asset-context-bar{border:1px solid var(--brand-mid);border-left:4px solid var(--brand);border-radius:var(--radius-md);background:linear-gradient(135deg, var(--brand-soft) 0%, #ede9fe 100%);color:var(--text);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:8px;padding:10px 14px;font-size:13px;display:flex;box-shadow:0 1px 4px #4f46e514}.asset-context-bar strong{font-weight:700}.asset-folder-head{justify-content:space-between;align-items:center;margin-bottom:10px;display:flex}.asset-folder-head-title{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);margin:0;font-size:12px;font-weight:700}.asset-upload-zone{border:2px dashed var(--line-mid);border-radius:var(--radius-lg);background:var(--panel);flex-shrink:0;padding:14px 18px;transition:all .25s;position:relative}.asset-upload-zone:before{content:"";border-radius:var(--radius-lg);pointer-events:none;background:linear-gradient(135deg,#4f46e508 0%,#6366f108 100%);position:absolute;inset:0}.asset-upload-zone:hover{background:var(--panel);border-color:#6366f1;box-shadow:0 0 0 3px #6366f114}.asset-upload-zone h3{color:var(--text);align-items:center;gap:6px;margin:0 0 10px;font-size:14px;font-weight:700;display:flex}.asset-upload-zone .form-grid{grid-template-columns:1fr 1fr;gap:6px}.asset-upload-zone .form-grid textarea{resize:vertical;min-height:36px;max-height:60px}.asset-upload-zone .form-grid .form-label{margin-bottom:2px;font-size:10px}.asset-upload-zone .form-grid input,.asset-upload-zone .form-grid select,.asset-upload-zone .form-grid textarea{padding:6px 8px;font-size:13px}.asset-file-list{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--panel);box-shadow:var(--shadow-sm);flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.asset-file-list .table-wrap{flex:1;min-height:0;overflow-y:auto}.asset-file-list .table-wrap::-webkit-scrollbar{width:6px}.asset-file-list .table-wrap::-webkit-scrollbar-track{background:0 0}.asset-file-list .table-wrap::-webkit-scrollbar-thumb{background:var(--line-mid);border-radius:3px}.asset-file-list-head{border-bottom:1px solid var(--line);background:var(--panel);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.asset-file-list-head h3{align-items:center;gap:8px;margin:0;font-size:15px;font-weight:700;display:flex}.asset-file-count{color:#4f46e5;background:linear-gradient(135deg,#ede9fe 0%,#e0e7ff 100%);border-radius:20px;align-items:center;gap:4px;padding:4px 12px;font-size:12px;font-weight:700;display:inline-flex}.asset-file-list table{margin:0}.asset-action-btns{flex-wrap:wrap;gap:6px;display:flex}.asset-nav-btns{gap:4px;display:flex}.asset-nav-btns button{background:var(--panel-soft);color:#4f46e5;cursor:pointer;border:1px solid #c7d2fe;border-radius:8px;padding:5px 10px;font-size:12px;transition:all .15s}.asset-nav-btns button:hover{filter:none;background:#ede9fe}.panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--panel);min-width:0;box-shadow:var(--shadow-sm);padding:16px;overflow:hidden}.panel h3{color:var(--text);letter-spacing:-.01em;margin:0 0 14px;font-size:16px;font-weight:700}.panel h4{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);border-top:1px solid var(--line);margin:16px 0 8px;padding-top:12px;font-size:13px;font-weight:600}.list{gap:4px;max-height:420px;display:grid;overflow:auto}.list-item{border:1px solid var(--line);background:var(--panel-soft);color:var(--text);border-radius:var(--radius-sm);text-align:left;gap:2px;padding:10px 12px;transition:border-color .12s,background .12s;display:grid}.list-item>div{color:var(--text);font-weight:600;line-height:1.3}.list-item small{color:#475569;font-size:12px}.list-item.active{background:var(--brand-soft);border-color:var(--brand-mid)}.list-item:hover{border-color:var(--brand-mid)}.form-grid{gap:8px;display:grid}.inline-form{grid-template-columns:minmax(0,1fr) auto;gap:8px;margin-bottom:10px;display:grid}.inline-edit{color:var(--text);border-radius:var(--radius-sm);background:0 0;border:1px solid #0000;width:100%;padding:4px 6px;font-size:13px;transition:border-color .15s,background .15s}.inline-edit:hover{border-color:var(--line);background:var(--panel-soft)}.inline-edit:focus{border-color:var(--brand-mid);background:var(--panel);box-shadow:0 0 0 2px var(--brand-soft);outline:none}input,select,textarea,button{font:inherit}input,select,textarea{border:1px solid var(--line-mid);background:var(--panel);border-radius:var(--radius-sm);color:var(--text);padding:8px 10px;font-size:14px;transition:border-color .12s,box-shadow .12s}input:focus,select:focus,textarea:focus{border-color:var(--brand-2);outline:none;box-shadow:0 0 0 3px #3b82f626}textarea{resize:vertical;min-height:80px}button{border:1px solid var(--brand);background:var(--brand);color:#fff;border-radius:var(--radius-sm);cursor:pointer;padding:8px 14px;font-size:14px;font-weight:600;transition:background .12s,border-color .12s,color .12s,opacity .12s}button:hover{filter:none;background:#1e40af;border-color:#1e40af}button:disabled{opacity:.5;cursor:not-allowed}.notice{border-radius:var(--radius-sm);border:1px solid #0000;padding:10px 14px;font-size:14px;font-weight:500}.notice.info{background:var(--brand-soft);border-color:var(--brand-mid);color:var(--brand)}.notice.success{background:var(--ok-soft);color:var(--ok);border-color:#86efac}.notice.error{background:var(--danger-soft);color:var(--danger);border-color:#fca5a5}.table-wrap{border:1px solid var(--line);border-radius:var(--radius-md);min-width:0;overflow:auto}table{border-collapse:collapse;width:100%}th,td{border-bottom:1px solid var(--line);text-align:left;white-space:normal;overflow-wrap:anywhere;padding:9px 12px;font-size:13px}th{background:var(--panel-soft);color:var(--muted);text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--line-mid);font-size:11px;font-weight:700}tbody tr:last-child td{border-bottom:none}tbody tr:hover td{background:var(--brand-soft)}.simple-list{gap:4px;margin:0;padding:0;list-style:none;display:grid}.simple-list li{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel-soft);justify-content:space-between;align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.simple-list li button{padding:4px 8px;font-size:12px}.row-actions{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:12px;display:flex}.messages-list{gap:6px;max-height:380px;margin-bottom:10px;display:grid;overflow:auto}.messages-list li{background:var(--panel-soft);border:1px solid var(--line);border-radius:var(--radius-sm);gap:3px;padding:8px 10px;font-size:13px;display:grid}.service-filter-bar{background:var(--panel-soft);border:1px solid var(--line);border-radius:var(--radius-md);grid-template-columns:minmax(200px,1.5fr) repeat(3,minmax(120px,1fr));gap:10px;margin-bottom:16px;padding:14px;display:grid}.service-filter-bar input,.service-filter-bar select{font-size:13px}.service-overview{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:18px;display:grid}.service-kpi{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--panel);box-shadow:var(--shadow-sm);flex-direction:column;gap:4px;padding:16px 18px;transition:box-shadow .15s,border-color .15s;display:flex}.service-kpi:hover{box-shadow:var(--shadow-md)}.service-kpi-icon{margin-bottom:4px;font-size:20px;line-height:1}.service-kpi small{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-weight:700;display:block}.service-kpi strong{color:var(--text);font-size:28px;font-weight:800;line-height:1.1}.service-desc{white-space:nowrap;text-overflow:ellipsis;max-width:300px;font-size:13px;line-height:1.4;overflow:hidden}.service-pagination{background:var(--panel-soft);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--muted);justify-content:space-between;align-items:center;gap:10px;margin-top:14px;padding:10px 14px;font-size:13px;display:flex}.service-pagination button{padding:6px 14px;font-size:13px}.service-page-info{font-weight:600}.service-actions-cell{align-items:center;gap:6px;display:flex}.service-actions-cell select{border-radius:6px;padding:4px 8px;font-size:12px}.folder-tree{gap:3px;max-height:180px;margin-bottom:10px;display:grid;overflow:auto}.folder-node-row{align-items:center;gap:4px;display:flex}.folder-node{text-align:left;border:1px solid var(--line);background:var(--panel-soft);border-radius:var(--radius-sm);min-width:0;color:var(--text-2);flex:1;align-items:center;gap:8px;padding:7px 10px;font-size:13px;transition:border-color .12s,background .12s;display:flex}.folder-delete-btn{width:22px;height:22px;color:var(--text-3);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:15px;line-height:1;transition:opacity .15s,background .15s,color .15s;display:flex}.folder-node-row:hover .folder-delete-btn{opacity:1}.folder-delete-btn:hover{background:var(--error,#e53935);color:#fff}.folder-node:hover{border-color:var(--brand-mid);background:var(--brand-soft);filter:none}.folder-node.active{border-color:var(--brand-mid);background:var(--brand-soft);color:var(--brand);font-weight:600}.folder-icon{flex-shrink:0;font-size:14px;line-height:1}.folder-branch{color:var(--text-3);opacity:.5;flex-shrink:0;font-family:monospace;font-size:13px}.check{color:var(--text-2);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#0f172a8c;place-items:center;padding:20px;animation:.15s ease-out fadeIn;display:grid;position:fixed;inset:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.modal{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-xl);width:min(520px,100% - 40px);box-shadow:var(--shadow-lg);flex-direction:column;max-height:calc(100vh - 60px);animation:.2s ease-out slideUp;display:flex;overflow:hidden}.modal-lg{width:min(680px,100% - 40px)}.modal-header{border-bottom:1px solid var(--line);justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 24px 16px;display:flex}.modal-header h3{color:var(--text);letter-spacing:-.02em;margin:0;font-size:18px;font-weight:700}.modal-header-sub{color:var(--muted);margin:2px 0 0;font-size:13px}.modal-close-btn{background:var(--panel-soft);border:1px solid var(--line);width:32px;min-width:32px;height:32px;color:var(--muted);cursor:pointer;border-radius:50%;flex-shrink:0;place-items:center;padding:0;font-size:16px;transition:background .12s,color .12s,border-color .12s;display:grid}.modal-close-btn:hover{background:var(--danger-soft);color:var(--danger);filter:none;border-color:#fca5a5}.modal-body{flex:1;padding:20px 24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--line);background:var(--panel-soft);border-radius:0 0 var(--radius-xl) var(--radius-xl);justify-content:flex-end;gap:8px;padding:16px 24px;display:flex}.btn-secondary{background:var(--panel);border:1px solid var(--line-mid);color:var(--text-2);font-weight:600}.btn-secondary:hover{background:var(--panel-soft);border-color:var(--text-2);filter:none}.btn-small{border-radius:6px;padding:4px 10px;font-size:12px;font-weight:600}.btn-small.btn-danger{background:var(--error,#e53935);color:#fff;border-color:var(--error,#e53935)}.btn-small.btn-danger:hover{background:#c62828;border-color:#c62828}.form-group{margin-bottom:14px}.form-group:last-child{margin-bottom:0}.form-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:5px;font-size:11px;font-weight:600;display:block}.form-row{grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px;display:grid}.form-row:last-child,.form-row .form-group{margin-bottom:0}.detail-grid{gap:16px;display:grid}.detail-row{align-items:baseline;gap:8px;display:flex}.detail-label{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0;min-width:90px;font-size:11px;font-weight:700}.detail-value{color:var(--text);font-size:14px;line-height:1.4}.badge-group{flex-wrap:wrap;gap:6px;display:flex}.issue-text-box{white-space:pre-wrap;overflow-wrap:anywhere;border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel-soft);max-height:220px;color:var(--text);padding:12px 14px;font-size:14px;line-height:1.6;overflow-y:auto}.photo-thumb-grid{flex-wrap:wrap;gap:8px;display:flex}.photo-thumb-btn{border-radius:var(--radius-sm);border:1px solid var(--line-mid);background:var(--panel-soft);width:64px;height:64px;color:var(--muted);cursor:pointer;place-items:center;padding:0;font-size:11px;font-weight:600;transition:border-color .12s,background .12s,color .12s;display:grid}.photo-thumb-btn:hover{border-color:var(--brand-mid);background:var(--brand-soft);color:var(--brand);filter:none}.select-list{gap:4px;max-height:280px;display:grid;overflow-y:auto}.select-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel-soft);cursor:pointer;text-align:left;color:var(--text);align-items:center;gap:10px;padding:10px 12px;font-size:14px;transition:border-color .12s,background .12s;display:flex}.select-card:hover{border-color:var(--brand-mid);background:var(--brand-soft);filter:none}.select-card.selected{border-color:var(--brand);background:var(--brand-soft);color:var(--brand)}.step-info{background:var(--brand-soft);border:1px solid var(--brand-mid);border-radius:var(--radius-sm);color:var(--brand);justify-content:space-between;align-items:center;gap:8px;margin-bottom:16px;padding:10px 14px;font-size:13px;display:flex}.step-info strong{color:var(--text)}.step-info button{border:1px solid var(--brand-mid);color:var(--brand);background:0 0;padding:2px 10px;font-size:12px}.step-info button:hover{background:var(--brand-soft);filter:none}.modal-content{border-radius:var(--radius-lg);max-width:90vw;max-height:90vh;box-shadow:var(--shadow-lg);background:#0f172a;animation:.2s ease-out slideUp;position:relative;overflow:hidden}.modal-content img{object-fit:contain;width:100%;height:auto;max-height:85vh;display:block}.modal-close{cursor:pointer;width:36px;height:36px;color:var(--text);box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#ffffffeb;border:none;border-radius:50%;place-items:center;font-size:18px;transition:background .12s,transform .12s;display:grid;position:absolute;top:12px;right:12px}.modal-close:hover{filter:none;background:#fff;transform:scale(1.08)}.project-row{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:6px;padding:6px 4px;transition:background .1s;display:flex}.project-row:last-child{border-bottom:none}.project-row.active{background:var(--brand-soft);border-radius:var(--radius-sm)}.project-row-btn{text-align:left;cursor:pointer;color:var(--text);background:0 0;border:none;flex:1;gap:3px;padding:4px 8px;display:grid}.project-row-btn:hover{color:var(--brand);filter:none;background:0 0}.project-row.active .project-row-btn{color:var(--brand);font-weight:600}.btn-icon{border:1px solid var(--line-mid);background:var(--panel-soft);color:var(--muted);border-radius:var(--radius-sm);place-items:center;min-width:32px;height:30px;padding:4px 8px;font-size:13px;display:grid}.btn-icon:hover{background:var(--brand-soft);border-color:var(--brand-mid);color:var(--brand);filter:none}.badge{letter-spacing:.04em;white-space:nowrap;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-ok{background:var(--ok-soft);color:var(--ok);border:1px solid #86efac}.badge-warn{background:var(--warn-soft);color:#92400e;border:1px solid #fcd34d}.badge-info{background:var(--brand-soft);color:var(--brand);border:1px solid var(--brand-mid)}.badge-danger{background:var(--danger-soft);color:var(--danger);border:1px solid #fca5a5}.badge-neutral{color:var(--muted);border:1px solid var(--line-mid);background:#f1f5f9}.td-nowrap{white-space:nowrap}.td-muted-sm{color:var(--muted);font-size:12px}.td-muted-center{text-align:center;color:var(--muted)}.text-brand{color:var(--brand);font-weight:600}.asset-context{margin-bottom:10px}.asset-context-bar{background:var(--panel-soft);border:1px solid var(--line);border-radius:var(--radius-sm);color:var(--text-2);padding:8px 12px;font-size:13px}.section-head{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-head h3{margin:0}.section-sub{color:var(--muted);margin:2px 0 0;font-size:13px;font-weight:400}.section-head .btn-secondary,.section-head button{flex-shrink:0}.sub-head{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);border-bottom:1px solid var(--line);margin:0 0 12px;padding-bottom:8px;font-size:12px;font-weight:700}.stat-card-danger .stat-card-icon{background:#fef2f2}.stat-card-warn .stat-card-icon{background:#fffbeb}.stat-card-ok .stat-card-icon{background:#f0fdf4}.stat-card-info .stat-card-icon{background:#eff6ff}.kpi-warn{border-left:3px solid var(--warn)}.kpi-info{border-left:3px solid var(--brand-2)}.kpi-ok{border-left:3px solid var(--ok)}.kpi-danger{border-left:3px solid var(--danger)}.qa-section{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 24px}.qa-section-title{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin:0 0 14px;font-size:12px;font-weight:700}.quick-actions{flex-wrap:wrap;gap:8px;display:flex}.qa-card{border:1px solid var(--line);background:var(--panel-soft);color:var(--text);cursor:pointer;white-space:nowrap;border-radius:10px;align-items:center;gap:8px;padding:10px 18px;font-size:13px;font-weight:600;transition:all .15s;display:inline-flex}.qa-card:hover{filter:none;background:#f5f3ff;border-color:#c7d2fe;box-shadow:0 2px 8px #6366f11a}.qa-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.dashboard-bottom-row{grid-template-columns:1fr 1fr;gap:20px;display:grid}.dashboard-notepad{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);flex-direction:column;padding:20px 24px;display:flex}.notepad-textarea{resize:vertical;border:1px solid var(--line);border-radius:var(--radius-md);min-height:120px;color:var(--text);background:var(--bg);flex:1;padding:14px 16px;font-family:inherit;font-size:14px;line-height:1.6;transition:border-color .2s,box-shadow .2s}.notepad-textarea:focus{border-color:#6366f1;outline:none;box-shadow:0 0 0 3px #6366f11a}.notepad-textarea::placeholder{color:var(--muted)}.dashboard-recent-files{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:20px 24px}.recent-files-empty{color:var(--muted);margin:0;font-size:13px}.recent-files-list{flex-direction:column;gap:2px;display:flex}.recent-file-row{border-radius:var(--radius-md);color:inherit;align-items:center;gap:12px;padding:10px 12px;text-decoration:none;transition:background .15s;display:flex}.recent-file-row:hover{background:var(--bg)}.recent-file-icon{border-radius:10px;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:16px;display:grid}.rf-img{background:#eff6ff}.rf-doc{background:#f5f3ff}.recent-file-info{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.recent-file-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.recent-file-meta{color:var(--muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.recent-file-badge{border-radius:50%;flex-shrink:0;place-items:center;width:22px;height:22px;font-size:12px;font-weight:700;display:grid}.rf-approved{color:#16a34a;background:#dcfce7}.rf-pending{color:#d97706;background:#fef3c7}@media (width<=900px){.dashboard-bottom-row{grid-template-columns:1fr}}.qa-icon{background:linear-gradient(135deg,#ede9fe 0%,#e0e7ff 100%);border-radius:14px;place-items:center;width:48px;height:48px;font-size:22px;line-height:1;transition:transform .2s;display:grid}.qa-label{color:var(--text);letter-spacing:-.01em;font-size:13px;font-weight:700}.chat-layout{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);border:1px solid var(--line);background:var(--panel);grid-template-columns:360px 1fr;gap:0;height:calc(100vh - 140px);overflow:hidden}.chat-sidebar{background:var(--panel);border-right:1px solid var(--line);height:100%;box-shadow:none;border:none;border-radius:0;flex-direction:column;padding:0;display:flex;overflow:hidden}.chat-sidebar .section-head{margin-bottom:0;padding:20px 20px 0}.chat-sidebar .check{margin:8px 0 4px;padding:0 20px}.chat-sidebar .list{flex:1;align-content:start;gap:2px;max-height:none;padding:8px 12px;overflow-y:auto}.chat-sidebar .list-item{border-radius:var(--radius-sm);border:none;padding:12px 14px;transition:all .15s;position:relative}.chat-sidebar .list-item:hover{background:var(--brand-soft);border:none}.chat-sidebar .list-item.active{background:var(--brand);color:#fff;border:none;box-shadow:0 2px 8px #1d4ed84d}.chat-sidebar .list-item.active small{color:#ffffffb3}.chat-sidebar .list-item.active .chat-list-dot{background-color:#fff}.chat-sidebar-footer{border-top:1px solid var(--line);background:var(--panel-soft);margin:0;padding:12px 16px}.chat-main{background:var(--bg);height:100%;box-shadow:none;border:none;border-radius:0;flex-direction:column;padding:0;display:flex;overflow:hidden}.chat-conv-header{background:var(--panel);border-bottom:1px solid var(--line);align-items:center;gap:14px;margin:0;padding:16px 24px;display:flex}.chat-conv-header-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.chat-conv-header-actions .chat-status-pill{border-radius:20px;align-items:center;gap:6px;padding:4px 12px;font-size:12px;font-weight:600;display:inline-flex}.chat-status-active{background:var(--ok-soft);color:var(--ok)}.chat-status-archived{background:var(--warn-soft);color:var(--warn)}.chat-status-dot{background:currentColor;border-radius:50%;width:7px;height:7px}.chat-avatar{color:#fff;text-transform:uppercase;background:linear-gradient(135deg,#6366f1 0%,#8b5cf6 100%);border-radius:50%;flex-shrink:0;place-items:center;width:42px;height:42px;font-size:17px;font-weight:700;display:grid;box-shadow:0 2px 8px #6366f14d}.chat-conv-title{color:var(--text);letter-spacing:-.01em;font-size:15px;font-weight:700}.chat-conv-sub{color:var(--muted);margin-top:2px;font-size:12px}.chat-messages{flex-direction:column;flex:1;justify-content:flex-end;gap:6px;min-height:0;padding:20px 24px;display:flex;overflow-y:auto}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:0 0}.chat-messages::-webkit-scrollbar-thumb{background:var(--line-mid);border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:var(--muted)}.chat-date-divider{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:12px;margin:16px 0 8px;font-size:11px;font-weight:600;display:flex}.chat-date-divider:before,.chat-date-divider:after{content:"";background:var(--line);flex:1;height:1px}.chat-bubble{border-radius:18px;max-width:72%;padding:10px 16px;font-size:14px;line-height:1.55;animation:.2s ease-out chatBubbleIn;position:relative}@keyframes chatBubbleIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.chat-bubble-meta{color:var(--muted);letter-spacing:.01em;margin-bottom:4px;font-size:11px;font-weight:600}.chat-bubble-them{background:var(--panel);border:1px solid var(--line);color:var(--text);border-bottom-left-radius:6px;align-self:flex-start;box-shadow:0 1px 3px #0000000a}.chat-bubble-me{color:#fff;background:linear-gradient(135deg,#4f46e5 0%,#6366f1 100%);border:none;border-bottom-right-radius:6px;align-self:flex-end;box-shadow:0 2px 8px #4f46e540}.chat-bubble-me .chat-bubble-meta{color:#ffffffa6}.chat-bubble img{border-radius:var(--radius-sm);transition:transform .15s}.chat-bubble img:hover{transform:scale(1.02)}.chat-bubble-attachment{border-radius:var(--radius-sm);color:inherit;background:#0000000d;align-items:center;gap:8px;margin-top:8px;padding:8px 14px;font-size:13px;font-weight:500;text-decoration:none;transition:background .15s;display:inline-flex}.chat-bubble-attachment:hover{background:#00000014}.chat-bubble-me .chat-bubble-attachment{background:#ffffff26}.chat-bubble-me .chat-bubble-attachment:hover{background:#ffffff40}.chat-input-area{background:var(--panel);border-top:1px solid var(--line);padding:16px 24px 20px}.chat-input-form{background:var(--panel-soft);border:1px solid var(--line);border-radius:24px;align-items:center;gap:10px;padding:4px 4px 4px 18px;transition:border-color .2s,box-shadow .2s;display:flex}.chat-input-form:focus-within{border-color:var(--brand-mid);box-shadow:0 0 0 3px #6366f11a}.chat-input-form input{color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:10px 0;font-size:14px}.chat-input-form input::placeholder{color:var(--muted)}.chat-send-btn{color:#fff;cursor:pointer;background:linear-gradient(135deg,#4f46e5 0%,#6366f1 100%);border:none;border-radius:50%;flex-shrink:0;place-items:center;width:40px;height:40px;font-size:16px;transition:transform .15s,box-shadow .15s;display:grid}.chat-send-btn:hover{transform:scale(1.08);box-shadow:0 3px 12px #6366f159}.chat-send-btn:active{transform:scale(.95)}.chat-empty{text-align:center;flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;padding:40px;display:flex}.chat-empty-icon{background:linear-gradient(135deg,#ede9fe 0%,#e0e7ff 100%);border-radius:50%;place-items:center;width:72px;height:72px;margin-bottom:4px;font-size:32px;display:grid}.chat-empty-title{color:var(--text);font-size:16px;font-weight:700}.chat-empty-hint{color:var(--muted);max-width:280px;font-size:13px;line-height:1.5}.profile-grid{grid-template-columns:320px 1fr}.profile-info{text-align:center;flex-direction:column;align-items:center;gap:10px;display:flex;padding:28px 20px!important}.profile-avatar{background:linear-gradient(135deg, var(--brand) 0%, #6366f1 100%);color:#fff;text-transform:uppercase;border-radius:50%;place-items:center;width:72px;height:72px;font-size:26px;font-weight:700;display:grid;box-shadow:0 4px 16px #1d4ed840}.profile-name{color:var(--text);margin:0;font-size:18px;font-weight:700}.profile-details{text-align:left;width:100%;margin-top:8px}.profile-detail-row{border-bottom:1px solid var(--line);justify-content:space-between;gap:8px;padding:8px 0;font-size:13px;display:flex}.profile-detail-row:last-child{border-bottom:none}.profile-detail-label{color:var(--muted);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:600}.profile-detail-value{color:var(--text);text-align:right;font-weight:500}.empty-state{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:8px;min-height:200px;padding:40px 20px;display:flex}.empty-state-icon{opacity:.5;font-size:36px}.empty-state-text{font-size:14px;font-weight:500}.empty-state-hint{color:var(--line-mid);font-size:12px}.user-summary-strip{grid-template-columns:repeat(4,1fr);gap:10px;display:grid}.user-summary-card{border:1px solid var(--line);border-radius:var(--radius-sm);background:var(--panel);text-align:center;box-shadow:var(--shadow-sm);padding:12px 14px}.user-summary-card strong{color:var(--text);font-size:22px;font-weight:700;line-height:1.2;display:block}.user-summary-card small{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-top:2px;font-size:11px;font-weight:600;display:block}.vehicle-layout{gap:16px;display:grid}.vehicle-summary-strip{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.vehicle-summary-card{border:1px solid var(--line);border-radius:var(--radius-md);background:var(--panel);text-align:center;box-shadow:var(--shadow-sm);padding:14px 16px}.vehicle-summary-card strong{color:var(--text);font-size:24px;font-weight:800;line-height:1.2;display:block}.vehicle-summary-card small{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;margin-top:2px;font-size:11px;font-weight:700;display:block}.vehicle-tab-bar{background:var(--panel-soft);border:1px solid var(--line);border-radius:var(--radius-md);gap:4px;padding:4px;display:inline-flex}.vehicle-tab{color:var(--muted);border-radius:var(--radius-sm);background:0 0;border:0;padding:8px 16px;font-size:13px;font-weight:600;transition:background .15s,color .15s,box-shadow .15s}.vehicle-tab:hover{background:var(--line);color:var(--text);filter:none}.vehicle-tab.active{background:var(--brand);color:#fff;box-shadow:0 2px 6px #1d4ed84d}.vehicle-content-grid{grid-template-columns:300px 1fr;gap:16px;display:grid}.vehicle-sidebar-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--panel);box-shadow:var(--shadow-sm);flex-direction:column;gap:14px;padding:16px;display:flex}.vehicle-main-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--panel);box-shadow:var(--shadow-sm);padding:20px}.vehicle-detail-header{border-bottom:1px solid var(--line);align-items:center;gap:14px;margin-bottom:16px;padding-bottom:14px;display:flex}.vehicle-icon{border-radius:var(--radius-md);background:linear-gradient(135deg, var(--brand) 0%, #6366f1 100%);color:#fff;flex-shrink:0;place-items:center;width:48px;height:48px;font-size:22px;display:grid;box-shadow:0 3px 10px #1d4ed833}.vehicle-detail-name{color:var(--text);font-size:16px;font-weight:700}.vehicle-detail-meta{color:var(--muted);margin-top:2px;font-size:12px}.vehicle-tab-single-panel{border:1px solid var(--line);border-radius:var(--radius-lg);background:var(--panel);box-shadow:var(--shadow-sm);padding:20px}.company-form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.company-form-grid .form-group:last-of-type{grid-column:1/-1}@media (width<=1260px){.app-shell{grid-template-columns:1fr}.sidebar{border-bottom:1px solid #1e293b;border-right:0;flex-flow:wrap;height:auto;padding:12px;position:static}.sidebar nav{flex-flow:wrap;flex:none;gap:4px;display:flex}.logout-btn{margin-top:0}.assets-grid,.two-col,.stats-grid,.chat-layout,.profile-grid{grid-template-columns:1fr;height:auto}.assets-sidebar,.chat-sidebar{border-right:none;border-bottom:1px solid var(--line);height:auto}.assets-main,.chat-main{height:auto;max-height:none}.service-filter-bar,.service-overview,.context-grid,.user-summary-strip,.vehicle-summary-strip{grid-template-columns:repeat(2,1fr)}.vehicle-content-grid,.company-form-grid,.inline-form{grid-template-columns:1fr}}@media (width<=760px){.main{padding:12px}.topbar{padding:12px 14px}.topbar-main h2{font-size:18px}.login-card{padding:24px 20px}}
