:root{--bg-primary: #f0f2f5;--bg-secondary: #ffffff;--bg-card: #ffffff;--bg-card-hover: #fafafa;--bg-input: #ffffff;--bg-sidebar: #ffffff;--text-primary: #303133;--text-secondary: #606266;--text-muted: #909399;--accent-primary: #409eff;--accent-secondary: #337ecc;--accent-gradient: #409eff;--success: #67c23a;--warning: #e6a23c;--danger: #f56c6c;--info: #909399;--border: #dcdfe6;--border-hover: #c0c4cc;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .08);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .1);--shadow-glow: 0 2px 12px 0 rgba(0, 0, 0, .1);--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--sidebar-width: 260px;--transition: all .25s cubic-bezier(.4, 0, .2, 1)}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;overflow:hidden}#app{display:flex;height:100vh}#sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);background:var(--bg-sidebar);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:0;z-index:10}.sidebar-header{padding:24px 20px 20px;border-bottom:1px solid var(--border)}.logo{display:flex;align-items:center;gap:10px;margin-bottom:4px}.logo-icon{font-size:24px}.logo-text{font-size:18px;font-weight:700;color:var(--text-primary)}.version{font-size:11px;color:var(--text-muted);font-weight:500}.nav-links{list-style:none;padding:12px 10px;flex:1}.nav-link{display:flex;align-items:center;gap:10px;padding:11px 16px;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:14px;font-weight:500;transition:var(--transition);margin-bottom:4px}.nav-link:hover{background:#6c5ce71a;color:var(--text-primary)}.nav-link.active{background:#409eff1a;color:var(--accent-primary);font-weight:600}.nav-icon{font-size:18px;width:24px;text-align:center}.sidebar-footer{padding:16px 20px;border-top:1px solid var(--border)}.drive-status{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted)}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--success);box-shadow:0 0 6px var(--success)}.status-dot.offline{background:var(--danger)}#mainContent{flex:1;overflow-y:auto;overflow-x:hidden;padding:32px;scroll-behavior:smooth}#mainContent::-webkit-scrollbar{width:6px}#mainContent::-webkit-scrollbar-thumb{background:#6c5ce74d;border-radius:3px}.page-header{margin-bottom:28px}.page-header h1{font-size:28px;font-weight:700;margin-bottom:6px;color:var(--text-primary)}.page-header p{color:var(--text-secondary);font-size:14px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;transition:var(--transition)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.card-title{font-size:16px;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px;margin-bottom:28px}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:20px;text-align:center;transition:var(--transition)}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-glow)}.stat-value{font-size:36px;font-weight:700;color:var(--accent-primary)}.stat-label{font-size:12px;color:var(--text-muted);text-transform:uppercase;letter-spacing:1px;margin-top:4px}.search-bar{display:flex;align-items:center;gap:12px;margin-bottom:20px}.search-input{flex:1;padding:10px 16px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;font-family:inherit;transition:var(--transition)}.search-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #6c5ce726}.search-input::placeholder{color:var(--text-muted)}.module-table{width:100%;border-collapse:collapse;font-size:13px}.module-table th{text-align:left;padding:12px 16px;color:var(--text-muted);font-weight:600;font-size:11px;text-transform:uppercase;letter-spacing:1px;border-bottom:1px solid var(--border)}.module-table td{padding:12px 16px;border-bottom:1px solid rgba(108,92,231,.06);color:var(--text-secondary)}.module-table tr{cursor:pointer;transition:var(--transition)}.module-table tbody tr:hover{background:#409eff0d}.module-table .sn-cell{font-weight:600;color:var(--accent-secondary);font-family:SF Mono,Fira Code,monospace}.badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600}.badge-il{background:#67c23a26;color:var(--success)}.badge-pdl{background:#409eff26;color:var(--accent-primary)}.badge-wdl{background:#e6a23c26;color:var(--warning)}.btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;border:none;transition:var(--transition)}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--text-secondary)}.btn-outline:hover{border-color:var(--accent-primary);color:var(--accent-secondary)}.btn-sm{padding:6px 12px;font-size:12px}.btn-back{background:transparent;border:1px solid var(--border);color:var(--text-secondary);margin-bottom:20px}.btn-back:hover{border-color:var(--accent-primary);color:var(--accent-secondary)}.detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.detail-meta{display:flex;gap:24px;flex-wrap:wrap;margin-bottom:24px}.meta-item{font-size:13px}.meta-label{color:var(--text-muted);margin-right:6px}.meta-value{color:var(--text-primary);font-weight:500}.tabs{display:flex;gap:4px;margin-bottom:24px;border-bottom:1px solid var(--border);padding-bottom:0}.tab{padding:10px 20px;border:none;background:transparent;color:var(--text-muted);font-size:14px;font-weight:500;cursor:pointer;font-family:inherit;border-bottom:2px solid transparent;transition:var(--transition);margin-bottom:-1px}.tab:hover{color:var(--text-primary)}.tab.active{color:var(--accent-secondary);border-bottom-color:var(--accent-primary)}.chart-container{position:relative;height:400px;margin-bottom:24px}.chart-container canvas{width:100%!important;height:100%!important}.wl-selector{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.wl-btn{padding:6px 16px;border:1px solid var(--border);border-radius:20px;background:transparent;color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;transition:var(--transition)}.wl-btn:hover{border-color:var(--accent-primary)}.wl-btn.active{background:var(--accent-primary);border-color:var(--accent-primary);color:#fff}.data-table{width:100%;border-collapse:collapse;font-size:12px;font-family:SF Mono,Fira Code,monospace}.data-table th{padding:8px 12px;text-align:right;color:var(--text-muted);font-weight:600;border-bottom:1px solid var(--border);position:sticky;top:0;background:var(--bg-card)}.data-table td{padding:6px 12px;text-align:right;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03)}.data-table td:first-child,.data-table th:first-child{text-align:left}.data-scroll{max-height:400px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-md)}.comparison-selector{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:flex-end}.select-wrapper{display:flex;flex-direction:column;gap:4px}.select-wrapper label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}.select-wrapper select{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:inherit;cursor:pointer}.select-wrapper select:focus{outline:none;border-color:var(--accent-primary)}.comparison-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.chip{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:#409eff1a;border:1px solid var(--border);border-radius:20px;font-size:12px;color:var(--accent-secondary)}.chip-remove{cursor:pointer;opacity:.6;transition:opacity .2s}.chip-remove:hover{opacity:1}.agent-info{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:16px;margin-bottom:24px}.agent-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px}.agent-card h3{font-size:14px;color:var(--text-muted);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.agent-card .value{font-size:20px;font-weight:600;color:var(--text-primary)}.loading{display:flex;align-items:center;justify-content:center;padding:60px;color:var(--text-muted)}.spinner{width:32px;height:32px;border:3px solid var(--border);border-top-color:var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite;margin-right:12px}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:60px 20px;color:var(--text-muted)}.empty-state .icon{font-size:48px;margin-bottom:16px}.empty-state h3{font-size:18px;margin-bottom:8px;color:var(--text-secondary)}.diag-section{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;margin-bottom:16px}.diag-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.diag-section-header h3{font-size:15px;font-weight:600;color:var(--text-primary)}.diag-result-section{animation:diagFadeIn .3s ease}@keyframes diagFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.connection-status{font-size:13px;font-weight:600;color:var(--danger)}.connection-status.connected{color:var(--success)}.diag-row{display:flex;gap:16px;align-items:flex-start;flex-wrap:wrap}.diag-field{display:flex;flex-direction:column;gap:6px}.diag-field label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.diag-field select,.diag-field input[type=text]{padding:8px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:inherit}.diag-field select:focus,.diag-field input:focus{outline:none;border-color:var(--accent-primary)}.diag-radio-group{display:flex;gap:16px;padding:8px 0}.diag-radio-group label{font-size:13px;font-weight:500;text-transform:none;letter-spacing:0;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;gap:4px}.diag-action-bar{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.diag-spacer{flex:1}.btn-success{background:var(--success);color:#fff}.btn-success:hover{transform:translateY(-1px);box-shadow:var(--shadow-sm)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important}.diag-progress-container{margin-top:12px}.diag-progress-text{font-size:12px;color:var(--accent-primary);margin-bottom:6px;font-weight:500}.diag-progress-bar{height:6px;background:var(--border);border-radius:3px;overflow:hidden}.diag-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--success));border-radius:3px;transition:width .3s ease;position:relative}.diag-progress-fill:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);animation:progressShimmer 1.5s infinite}@keyframes progressShimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.diag-info-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}.diag-info-item{padding:12px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border)}.diag-info-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}.diag-info-value{font-size:14px;font-weight:600;color:var(--text-primary);font-family:SF Mono,Fira Code,monospace;word-break:break-all}.diag-config-block{margin-top:8px;padding:12px;background:var(--bg-primary);border-radius:var(--radius-sm);border:1px solid var(--border)}.diag-config-block pre{font-size:11px;font-family:SF Mono,Fira Code,monospace;color:var(--text-secondary);white-space:pre-wrap;word-break:break-all;margin-top:4px}.diag-flash-slot{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:6px;overflow:hidden}.diag-flash-slot-header{padding:10px 14px;background:var(--bg-primary);font-size:13px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:8px;transition:background .2s}.diag-flash-slot-header:hover{background:#409eff0d}.tag-empty{font-size:11px;color:var(--text-muted);font-weight:400;font-style:italic}.diag-flash-slot-body{display:none;padding:8px 14px}.diag-flash-slot.open .diag-flash-slot-body{display:block}.diag-flash-wl{padding:6px 0;border-bottom:1px solid rgba(0,0,0,.05);display:flex;align-items:center;gap:12px;flex-wrap:wrap}.diag-flash-wl:last-child{border-bottom:none}.diag-flash-wl-label{font-size:13px;font-weight:600;color:var(--accent-secondary);min-width:80px}.diag-flash-wl-status{font-size:12px}.diag-flash-data-preview{font-size:10px;font-family:SF Mono,Fira Code,monospace;color:var(--text-muted);background:var(--bg-primary);padding:4px 8px;border-radius:4px;word-break:break-all;flex:1;min-width:200px}.diag-table-wrapper{overflow-x:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}.diag-table{width:100%;border-collapse:collapse;font-size:12px;font-family:SF Mono,Fira Code,monospace;white-space:nowrap}.diag-table th{padding:8px 10px;text-align:center;color:var(--text-muted);font-weight:600;font-size:10px;text-transform:uppercase;background:var(--bg-primary);border-bottom:1px solid var(--border);position:sticky;top:0}.diag-table td{padding:6px 10px;text-align:center;color:var(--text-secondary);border-bottom:1px solid rgba(0,0,0,.03)}.diag-td-label{font-weight:600;color:var(--text-primary)!important;text-align:left!important}.diag-td-nonzero{color:var(--accent-primary)!important;font-weight:600}.diag-calib-info{font-size:13px;color:var(--text-secondary);margin-bottom:12px}.diag-calib-pds{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px}.diag-calib-pd-card{border:1px solid var(--border);border-radius:var(--radius-sm);padding:12px;background:var(--bg-primary)}.diag-calib-pd-title{font-size:13px;font-weight:600;color:var(--accent-secondary);margin-bottom:4px}.diag-calib-pd-info{font-size:11px;color:var(--text-muted);margin-bottom:8px}.diag-calib-pd-card details summary{font-size:12px;color:var(--accent-primary);cursor:pointer;font-weight:500}.diag-calib-pd-table{max-height:200px;overflow-y:auto;margin-top:8px;font-family:SF Mono,Fira Code,monospace;font-size:11px}.diag-calib-row{display:flex;justify-content:space-between;padding:2px 6px;border-bottom:1px solid rgba(0,0,0,.03)}.diag-calib-row span:first-child{color:var(--text-muted)}.diag-calib-row span:last-child{color:var(--text-primary);font-weight:500}.diag-terminal{background:#1e1e2e;color:#cdd6f4;font-family:SF Mono,Fira Code,Consolas,monospace;font-size:12px;padding:12px;border-radius:var(--radius-sm);height:200px;overflow-y:auto;margin-bottom:8px}#terminalSection.terminal-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:var(--bg-primary, #1a1a2e);margin:0;border-radius:0;display:flex;flex-direction:column;padding:16px;overflow:hidden}#terminalSection.terminal-fullscreen #terminalBody{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}#terminalSection.terminal-fullscreen .diag-terminal{height:0;flex:1;font-size:13px;overflow-y:auto}#terminalSection.terminal-fullscreen .diag-section-header{margin-bottom:8px}.diag-terminal::-webkit-scrollbar{width:4px}.diag-terminal::-webkit-scrollbar-thumb{background:#cdd6f433;border-radius:2px}.log-entry{padding:2px 0;line-height:1.5;border-bottom:1px solid rgba(205,214,244,.05)}.log-time{color:#6c7086;margin-right:8px}.log-tx{color:#89b4fa}.log-rx{color:#a6e3a1}.diag-terminal-input{display:flex;gap:8px}.diag-terminal-input input{flex:1;padding:8px 12px;background:#1e1e2e;border:1px solid var(--border);border-radius:var(--radius-sm);color:#cdd6f4;font-family:SF Mono,Fira Code,monospace;font-size:12px}.diag-terminal-input input:focus{outline:none;border-color:var(--accent-primary)}.diag-toggle{display:inline-flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;padding:4px 0}.diag-toggle input{display:none}.diag-toggle-slider{position:relative;width:44px;height:24px;background:var(--border);border-radius:12px;transition:background .3s ease;flex-shrink:0}.diag-toggle-slider:after{content:"";position:absolute;top:3px;left:3px;width:18px;height:18px;background:#fff;border-radius:50%;transition:transform .3s ease;box-shadow:0 1px 3px #0003}.diag-toggle input:checked+.diag-toggle-slider{background:var(--success)}.diag-toggle input:checked+.diag-toggle-slider:after{transform:translate(20px)}.diag-toggle-label{font-size:13px;font-weight:600;color:var(--text-secondary);text-transform:none;letter-spacing:0}.diag-calib-slot-group{margin-bottom:20px}.diag-calib-chart-container{position:relative;width:100%;height:300px;background:#fafbfc;border:1px solid var(--border);border-radius:8px;padding:12px}.diag-module-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:12px;padding:12px 0}.diag-mod-card{background:#fff;border:2px solid var(--border);border-radius:10px;padding:14px;cursor:pointer;transition:all .2s ease;position:relative}.diag-mod-card:hover{border-color:var(--primary);box-shadow:0 2px 8px #00000014;transform:translateY(-1px)}.diag-mod-card.selected{border-color:var(--success);background:#f0fdf4;box-shadow:0 0 0 3px #22c55e26}.diag-mod-card.selected .diag-mod-select-hint{color:var(--success);font-weight:600}.diag-mod-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.diag-mod-code{font-size:16px;font-weight:700;color:var(--primary)}.diag-mod-addr{font-size:11px;color:var(--text-secondary);background:var(--bg-secondary);padding:2px 8px;border-radius:4px}.diag-mod-sn{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;font-family:Courier New,monospace}.diag-mod-details{font-size:11px;color:var(--text-secondary);display:flex;gap:12px;margin-bottom:8px}.diag-mod-devices{display:flex;flex-wrap:wrap;gap:4px;margin-bottom:6px}.diag-mod-tag{font-size:10px;padding:2px 6px;border-radius:3px;background:#e8f0fe;color:#1a56db;font-weight:500}.diag-mod-select-hint{font-size:11px;color:var(--text-secondary);text-align:center;margin-top:4px}@media (max-width: 768px){#sidebar{width:60px;min-width:60px}.logo-text,.version,.sidebar-footer span:last-child{display:none}.nav-link{justify-content:center;padding:11px}.nav-link span:not(.nav-icon){display:none}#mainContent{padding:20px}.diag-row{flex-direction:column}.diag-action-bar{flex-direction:column;align-items:stretch}}.logo-icon-img{border-radius:6px;flex-shrink:0}.header-controls{display:flex;align-items:center;gap:8px}.btn-icon{background:none;border:1px solid var(--border);border-radius:var(--radius-sm);padding:4px 8px;font-size:12px;cursor:pointer;color:var(--text-secondary);transition:var(--transition)}.btn-icon:hover{background:var(--bg-card-hover);border-color:var(--accent-primary);color:var(--accent-primary)}.diag-calib-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(480px,1fr));gap:16px;margin:12px 0}.diag-calib-slot-group{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);padding:12px}.diag-calib-chart-container{position:relative;height:280px}.diag-calib-slot-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.diag-calib-slot-header h5{margin:0;color:var(--text-secondary)}.btn-chart-maximize{padding:2px 6px!important;font-size:14px!important;line-height:1}.diag-calib-slot-group.chart-maximized{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;background:var(--bg-card, #fff);margin:0;border-radius:0;padding:20px;display:flex;flex-direction:column}.diag-calib-slot-group.chart-maximized .diag-calib-chart-container{flex:1;height:0}@media (max-width: 1024px){.diag-calib-grid{grid-template-columns:1fr}}.toast-notification{position:fixed;bottom:24px;right:24px;z-index:99999;background:var(--bg-card, #fff);border:1px solid var(--accent-primary, #409eff);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000026;padding:16px 20px;display:flex;flex-direction:column;gap:12px;min-width:320px;max-width:420px;transform:translateY(120%);opacity:0;transition:all .4s cubic-bezier(.4,0,.2,1)}.toast-notification.show{transform:translateY(0);opacity:1}.toast-content{display:flex;align-items:flex-start;gap:12px}.toast-icon{font-size:1.5rem;flex-shrink:0}.toast-text{display:flex;flex-direction:column;gap:4px}.toast-title{font-weight:600;font-size:14px;color:var(--text-primary)}.toast-msg{font-size:13px;color:var(--text-secondary)}.toast-actions{display:flex;justify-content:flex-end;gap:8px}.btn-close-toast{padding:4px 10px!important;font-size:12px!important}.login-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:9999;display:flex;justify-content:center;align-items:center;background:linear-gradient(135deg,#0a1628,#1a2332,#0d1820)}.login-box{width:440px;max-width:92vw;background:#141e32d9;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid rgba(74,144,217,.15);border-radius:20px;padding:40px;box-shadow:0 25px 50px #00000080,0 0 40px #4a90d914;text-align:center}.login-logo-section{margin-bottom:28px}.login-logo{border-radius:12px;margin-bottom:12px;filter:drop-shadow(0 0 12px rgba(74,144,217,.4))}.login-title{font-size:1.4em;color:#fff;margin:8px 0 0;font-weight:600;letter-spacing:1px}.login-divider{width:60px;height:2px;background:linear-gradient(90deg,transparent,var(--primary),transparent);margin:16px auto}.login-form-section{display:flex;flex-direction:column;align-items:center}.login-welcome{font-size:1.6em;color:#fff;margin:0 0 6px;font-weight:500}.login-subtitle{color:#ffffff80;font-size:.85em;margin-bottom:24px;line-height:1.5}.login-btn-google{width:100%;display:flex;align-items:center;justify-content:center;gap:12px;padding:14px 24px;background:linear-gradient(135deg,#4a90d933,#28508c4d);border:1px solid rgba(74,144,217,.25);border-radius:12px;color:#fffffff2;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease}.login-btn-google:hover:not(:disabled){background:linear-gradient(135deg,#4a90d959,#28508c73);border-color:#4a90d966;box-shadow:0 0 20px #4a90d926;transform:translateY(-2px)}.login-btn-google:disabled{opacity:.5;cursor:not-allowed}.login-google-icon{width:20px;height:20px}.login-fallback-hidden{display:none;margin-top:12px}.login-error{color:#ff6b6b;font-size:.85em;margin-top:12px;padding:10px;background:#ff64641a;border:1px solid rgba(255,100,100,.2);border-radius:8px;white-space:pre-line;max-width:320px}.login-domain-info{margin-top:24px;padding-top:20px;border-top:1px solid rgba(255,255,255,.08);width:100%}.login-domain-info p{font-size:.73rem;color:#fff6;margin-bottom:10px}.login-domain-list{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.login-domain-badge{font-size:.7rem;padding:4px 10px;background:#4a90d91a;border:1px solid rgba(74,144,217,.2);border-radius:15px;color:#4a90d9b3}.user-info{display:flex;align-items:center;gap:8px;padding:8px 0;border-top:1px solid var(--border-light);margin-bottom:8px}.user-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover}.user-avatar-placeholder{width:28px;height:28px;border-radius:50%;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600}.user-name{flex:1;font-size:.75rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-logout{font-size:14px!important;padding:2px 6px!important;opacity:.6;transition:opacity .2s}.btn-logout:hover{opacity:1}.archive-file-list{max-height:600px;overflow-y:auto}.archive-table{width:100%;border-collapse:collapse}.archive-table th,.archive-table td{padding:10px 14px;text-align:left;border-bottom:1px solid var(--border-light)}.archive-table th{font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);font-weight:600;position:sticky;top:0;background:var(--bg-card);z-index:1}.archive-table tr:hover{background:var(--bg-hover)}.archive-file-name{font-weight:500;color:var(--primary)}.archive-file-time{color:var(--text-secondary);font-size:.85em}.loading-spinner{padding:40px;text-align:center;color:var(--text-muted)}
