*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg-base:#07080d;--color-bg-surface:#0d0f18;--color-bg-card:#131620;--color-bg-hover:#1a1e2e;--color-bg-elevated:#13162100;--color-border:#ffffff12;--color-border-strong:#ffffff1f;--color-text-primary:#eef0f6;--color-text-secondary:#7c8399;--color-text-tertiary:#3d4358;--color-accent:#38bdf8;--color-accent-dim:#38bdf81a;--color-accent-glow:#38bdf833;--color-danger:#f87171;--color-danger-dim:#f871711a;--color-warning:#fbbf24;--color-warning-dim:#fbbf241a;--color-success:#34d399;--color-success-dim:#34d3991a;--font-sans:"DM Sans", system-ui, sans-serif;--font-mono:"DM Mono", monospace;--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-full:9999px;--layout-sidebar-width:224px;--layout-topbar-height:52px;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-7:32px;--space-8:40px;--shadow-sm:0px 1px 2px #00000040;--shadow-md:0px 2px 6px #00000047;--shadow-lg:0px 4px 12px #00000052;--shadow-xl:0px 8px 24px #0006;--transition-fast:.12s ease;--transition-medium:.2s ease;--transition-slow:.35s ease;--z-base:0;--z-above:10;--z-dropdown:20;--z-overlay:30;--z-toast:40;--z-max:50}html,body{background:var(--color-bg-base);height:100%;color:var(--color-text-primary);font-family:var(--font-sans);-webkit-font-smoothing:antialiased;font-size:13px;line-height:1.6}button,input,select{font:inherit;cursor:pointer}input{cursor:text}.duxia-app{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--layout-sidebar-width);background:var(--color-bg-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;display:flex;overflow:hidden}.sidebar-brand{height:var(--layout-topbar-height);border-bottom:1px solid var(--color-border);flex-shrink:0;align-items:center;gap:9px;padding:0 16px;display:flex}.brand-icon{background:var(--color-accent);color:#07080d;border-radius:7px;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:flex}.brand-name{letter-spacing:.06em;color:var(--color-text-primary);font-size:14px;font-weight:600}.sidebar-nav{scrollbar-width:none;flex:1;padding:10px 8px;overflow-y:auto}.sidebar-nav::-webkit-scrollbar{display:none}.nav-section{margin-bottom:18px}.nav-label{letter-spacing:.1em;color:var(--color-text-tertiary);text-transform:uppercase;margin-bottom:3px;padding:0 8px;font-size:10px;font-weight:600}.nav-btn{border-radius:var(--radius-sm);width:100%;color:var(--color-text-secondary);text-align:left;background:0 0;border:none;align-items:center;gap:9px;padding:7px 8px;font-size:13px;transition:background .12s,color .12s;display:flex}.nav-btn:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.nav-btn.active{background:var(--color-accent-dim);color:var(--color-accent);font-weight:500}.nav-btn svg{stroke-width:1.8px;flex-shrink:0;width:15px;height:15px}.sidebar-bottom{border-top:1px solid var(--color-border);flex-shrink:0;padding:10px 8px}.user-row{border-radius:var(--radius-sm);align-items:center;gap:9px;padding:7px 8px;display:flex}.user-avatar{background:var(--color-accent-dim);width:26px;height:26px;color:var(--color-accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:flex}.user-info{flex:1;min-width:0;overflow:hidden}.user-email{color:var(--color-text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.user-role-badge{color:var(--color-text-tertiary);font-size:10px}.main-col{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.topbar{height:var(--layout-topbar-height);background:var(--color-bg-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;width:auto;max-width:none;padding:0 20px;display:flex;position:static;transform:none}.topbar-left{align-items:center;gap:8px;display:flex}.page-title{color:var(--color-text-primary);font-size:13px;font-weight:600}.page-tag{background:var(--color-accent-dim);color:var(--color-accent);letter-spacing:.04em;border-radius:99px;padding:2px 7px;font-size:10px;font-weight:500}.topbar-right{align-items:center;gap:8px;display:flex}.page-body{background:var(--color-bg-base);scrollbar-width:thin;scrollbar-color:var(--color-border-strong) transparent;flex:1;padding:20px;overflow-y:auto}.page-body::-webkit-scrollbar{width:5px}.page-body::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:99px}.btn{border-radius:var(--radius-sm);white-space:nowrap;cursor:pointer;border:1px solid #0000;align-items:center;gap:6px;padding:7px 13px;font-size:12.5px;font-weight:500;transition:all .12s;display:inline-flex}.btn svg{stroke-width:2px;width:13px;height:13px}.btn-primary{background:var(--color-accent);color:#07080d;border-color:var(--color-accent)}.btn-primary:hover:not(:disabled){opacity:.88}.btn-secondary{background:var(--color-bg-card);color:var(--color-text-primary);border-color:var(--color-border-strong)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-hover);border-color:#ffffff2e}.btn-ghost{color:var(--color-text-secondary);border-color:var(--color-border);background:0 0}.btn-ghost:hover:not(:disabled){color:var(--color-text-primary);background:var(--color-bg-card)}.btn:disabled{opacity:.38;cursor:not-allowed}.btn-sm{padding:5px 10px;font-size:11.5px}.btn-row{flex-wrap:wrap;align-items:center;gap:7px;display:flex}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:18px}.card+.card{margin-top:14px}.card-hd{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:14px;display:flex}.card-title{color:var(--color-text-primary);font-size:13px;font-weight:600}.card-sub{color:var(--color-text-tertiary);margin-top:2px;font-size:11.5px}.stat-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-bottom:16px;display:grid}.stat{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px}.stat-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:7px;font-size:10px;font-weight:600}.stat-val{color:var(--color-text-primary);font-size:24px;font-weight:600;line-height:1;font-family:var(--font-mono)}.stat-hint{color:var(--color-text-tertiary);margin-top:3px;font-size:11px}.stat.danger .stat-val{color:var(--color-danger)}.stat.success .stat-val{color:var(--color-success)}.stat.warning .stat-val{color:var(--color-warning)}.stat.accent .stat-val{color:var(--color-accent)}.score-hero{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);align-items:center;gap:16px;margin-bottom:14px;padding:16px;display:flex}.score-num{font-size:44px;font-weight:700;line-height:1;font-family:var(--font-mono)}.score-num.high{color:var(--color-danger)}.score-num.low{color:var(--color-success)}.score-num.med{color:var(--color-warning)}.score-info{flex:1;min-width:0}.score-verdict{color:var(--color-text-primary);margin-bottom:3px;font-size:13px;font-weight:600}.score-desc{color:var(--color-text-secondary);font-size:12px;line-height:1.5}.bar-wrap{background:var(--color-bg-hover);border-radius:99px;height:3px;margin:10px 0;overflow:hidden}.bar-fill{border-radius:99px;height:100%;transition:width .5s}.bar-fill.high{background:var(--color-danger)}.bar-fill.low{background:var(--color-success)}.bar-fill.med{background:var(--color-warning)}.badge{border-radius:99px;align-items:center;gap:5px;padding:3px 9px;font-size:11px;font-weight:500;display:inline-flex}.badge.high{background:var(--color-danger-dim);color:var(--color-danger);border:1px solid #f8717133}.badge.low{background:var(--color-success-dim);color:var(--color-success);border:1px solid #34d39933}.badge.med{background:var(--color-warning-dim);color:var(--color-warning);border:1px solid #fbbf2433}.badge.info{background:var(--color-accent-dim);color:var(--color-accent);border:1px solid var(--color-accent-glow)}.badge.gray{background:var(--color-bg-hover);color:var(--color-text-secondary);border:1px solid var(--color-border)}.upload-zone{border:1.5px dashed var(--color-border-strong);border-radius:var(--radius-lg);text-align:center;cursor:pointer;padding:28px 20px;transition:border-color .15s,background .15s;display:block}.upload-zone:hover,.upload-zone.dragging{border-color:var(--color-accent);background:var(--color-accent-dim)}.upload-ico{color:var(--color-text-tertiary);margin-bottom:8px;font-size:26px;display:block}.upload-ttl{color:var(--color-text-primary);margin-bottom:3px;font-size:13px;font-weight:500}.upload-hint{color:var(--color-text-tertiary);font-size:11.5px}.upload-link{color:var(--color-accent)}.file-input{display:none}.file-selected{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);align-items:center;gap:8px;margin-top:10px;padding:9px 12px;font-size:12px;display:flex}.meta-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:8px;margin-top:12px;display:grid}.meta-cell{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:10px}.meta-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:3px;font-size:10px;font-weight:600}.meta-val{color:var(--color-text-primary);font-size:11.5px;font-family:var(--font-mono);word-break:break-all}.tbl{border-collapse:collapse;width:100%}.tbl th{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);border-bottom:1px solid var(--color-border);text-align:left;padding:8px 12px;font-size:10px;font-weight:600}.tbl td{border-bottom:1px solid var(--color-border);color:var(--color-text-primary);vertical-align:middle;padding:11px 12px;font-size:12.5px}.tbl tr:last-child td{border-bottom:none}.tbl tr:hover td{background:var(--color-bg-hover)}.tbl-filename{text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-weight:500;overflow:hidden}.tbl-meta{color:var(--color-text-tertiary);font-size:11px}.input{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text-primary);padding:8px 11px;font-size:12.5px;transition:border-color .12s}.input:focus{border-color:var(--color-accent);outline:none}.input::placeholder{color:var(--color-text-tertiary)}.input-row{gap:8px;display:flex}.input-row .input{flex:1}.form-lbl{color:var(--color-text-secondary);margin-bottom:5px;font-size:11.5px;font-weight:500;display:block}.sec-hd{justify-content:space-between;align-items:center;gap:12px;margin-bottom:14px;display:flex}.sec-title{color:var(--color-text-primary);font-size:13.5px;font-weight:600}.sec-sub{color:var(--color-text-tertiary);margin-top:2px;font-size:11.5px}.list-row{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;gap:12px;padding:11px 0;display:flex}.list-row:last-child{border-bottom:none;padding-bottom:0}.list-row:first-child{padding-top:0}.row-info{flex:1;min-width:0}.row-name{color:var(--color-text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:500;overflow:hidden}.row-meta{color:var(--color-text-tertiary);margin-top:1px;font-size:11px}.row-score{font-size:18px;font-weight:600;font-family:var(--font-mono)}.row-score.high{color:var(--color-danger)}.row-score.low{color:var(--color-success)}.notif-row{border-bottom:1px solid var(--color-border);align-items:flex-start;gap:10px;padding:11px 0;display:flex}.notif-row:last-child{border-bottom:none}.ndot{background:var(--color-accent);border-radius:50%;flex-shrink:0;width:7px;height:7px;margin-top:4px}.ndot.read{background:var(--color-text-tertiary)}.ntxt{color:var(--color-text-primary);flex:1;font-size:12.5px;line-height:1.45}.nmeta{color:var(--color-text-tertiary);margin-top:2px;font-size:11px}.nact{border-radius:var(--radius-sm);border:1px solid var(--color-border);color:var(--color-text-secondary);cursor:pointer;white-space:nowrap;background:0 0;flex-shrink:0;padding:4px 8px;font-size:11px}.nact:hover{color:var(--color-text-primary);border-color:var(--color-border-strong)}.err{background:var(--color-danger-dim);border-radius:var(--radius-sm);color:var(--color-danger);border:1px solid #f8717133;padding:10px 13px;font-size:12px}.secret{background:var(--color-warning-dim);border-radius:var(--radius-sm);color:var(--color-warning);font-size:12px;font-family:var(--font-mono);word-break:break-all;border:1px solid #fbbf2433;padding:11px 13px}.hint{color:var(--color-text-tertiary);font-size:11.5px}.plan-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;display:grid}.plan-card{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:14px}.plan-card.current{border-color:var(--color-accent);background:var(--color-accent-dim)}.plan-name{color:var(--color-text-primary);margin-bottom:3px;font-size:12.5px;font-weight:600}.plan-limit{color:var(--color-text-tertiary);margin-bottom:10px;font-size:11px}.usage-row{justify-content:space-between;align-items:center;margin-bottom:5px;display:flex}.usage-count{color:var(--color-text-primary);font-size:13px;font-weight:600;font-family:var(--font-mono)}.usage-rem{color:var(--color-text-tertiary);font-size:11px}.auth-page{background:var(--color-bg-base);justify-content:center;align-items:center;min-height:100vh;display:flex}.auth-box{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:380px;padding:36px}.auth-brand{align-items:center;gap:9px;margin-bottom:28px;display:flex}.auth-brand-icon{background:var(--color-accent);color:#07080d;border-radius:9px;justify-content:center;align-items:center;width:32px;height:32px;font-size:15px;font-weight:700;display:flex}.auth-brand-name{letter-spacing:.05em;font-size:16px;font-weight:600}.auth-h{color:var(--color-text-primary);margin-bottom:6px;font-size:18px;font-weight:600}.auth-p{color:var(--color-text-secondary);margin-bottom:24px;font-size:12.5px;line-height:1.55}.auth-acts{flex-direction:column;gap:9px;display:flex}.auth-acts .btn{justify-content:center;width:100%;padding:9px;font-size:13px}.landing{background:var(--color-bg-base);flex-direction:column;min-height:100vh;display:flex}.landing-bar{height:var(--layout-topbar-height);border-bottom:1px solid var(--color-border);background:var(--color-bg-surface);z-index:30;flex-shrink:0;align-items:center;gap:32px;padding:0 32px;display:flex;position:sticky;top:0}.landing-logo{align-items:center;gap:9px;text-decoration:none;display:flex}.landing-logo-icon{background:var(--color-accent);color:#07080d;border-radius:7px;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:flex}.landing-logo-name{letter-spacing:.06em;color:var(--color-text-primary);font-size:14px;font-weight:600}.landing-nav{flex:1;gap:22px;display:flex}.landing-nav a{color:var(--color-text-secondary);font-size:13px;text-decoration:none;transition:color .12s}.landing-nav a:hover{color:var(--color-text-primary)}.landing-acts{align-items:center;gap:8px;display:flex}.lang-sw{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-sm);gap:2px;padding:3px;display:flex}.lang-btn{cursor:pointer;color:var(--color-text-secondary);background:0 0;border:none;border-radius:4px;padding:3px 8px;font-size:11.5px;font-weight:500;transition:all .12s}.lang-btn.on{background:var(--color-bg-hover);color:var(--color-text-primary)}.product-feature-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}@media (max-width:900px){.product-feature-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:560px){.product-feature-grid{grid-template-columns:1fr}}.ws-chip{background:var(--color-bg-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);padding:10px 12px}.ws-chip-lbl{text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-tertiary);margin-bottom:3px;font-size:10px;font-weight:600}.ws-chip-val{color:var(--color-text-primary);font-size:12.5px;font-weight:500}.grid-2{grid-template-columns:1fr 1fr;gap:14px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.stack{flex-direction:column;gap:10px;display:flex}.divider{border:none;border-top:1px solid var(--color-border);margin:14px 0}@media (max-width:860px){.sidebar{display:none}.grid-2,.grid-3{grid-template-columns:1fr}.topbar{padding:0 14px}.page-body{padding:14px}}
