:root{--primary:#2563eb;--primary-hover:#1d4ed8;--primary-light:#3b82f6;--primary-50:#eff6ff;--primary-700:#1d4ed8;--accent:#0ea5e9;--bg:#fafafa;--surface:#fff;--border:#e4e4e7;--text:#52525b;--text-h:#09090b;--text-muted:#71717a;--ink-900:#09090b;--ink-700:#27272a;--ink-500:#52525b;--ink-400:#71717a;--ink-300:#a1a1aa;--line:#e4e4e7;--line-soft:#f4f4f5;--success:#16a34a;--success-bg:#16a34a1a;--success-50:#f0fdf4;--warning:#d97706;--warning-bg:#d977061a;--danger:#dc2626;--danger-bg:#dc26261a;--danger-50:#fef2f2;--info:#0ea5e9;--info-bg:#0ea5e91a;--shadow-sm:0 1px 2px #0000000a;--shadow:0 1px 3px #0000000f;--shadow-lg:0 4px 12px #00000014;--sans:"Geist", ui-sans-serif, system-ui, -apple-system, "Segoe UI", sans-serif;--mono:"Geist Mono", ui-monospace, "SF Mono", Menlo, monospace;--radius:8px;--radius-lg:10px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:15px;line-height:1.5}#root{min-height:100vh}.layout{min-height:100vh;display:flex}.sidebar{background:var(--surface);border-right:1px solid var(--line);z-index:10;flex-direction:column;align-items:center;width:56px;padding:14px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-brand{justify-content:center;align-items:center;margin-bottom:16px;display:flex}.sidebar-brand svg{width:16px;height:16px}.brand-mark{background:var(--ink-900);color:#fff;border-radius:8px;place-items:center;width:32px;height:32px;display:grid}.sidebar-nav{border-top:1px solid var(--line);flex-direction:column;flex:1;align-items:center;gap:4px;width:100%;padding-top:10px;display:flex}.nav-item{width:36px;height:36px;color:var(--ink-400);cursor:pointer;border-radius:8px;place-items:center;text-decoration:none;transition:all .15s;display:grid;position:relative}.nav-item:hover{color:var(--ink-900);background:var(--line-soft)}.nav-item.active{color:var(--primary);background:var(--primary-50)}.nav-item svg{flex-shrink:0;width:18px;height:18px}.nav-item span{display:none}.nav-item:after{content:attr(title);background:var(--ink-900);color:#fff;white-space:nowrap;z-index:50;pointer-events:none;opacity:0;border-radius:6px;padding:6px 10px;font-size:12px;font-weight:500;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 12px);transform:translateY(-50%);box-shadow:0 4px 16px #0000001f}.nav-item:hover:after{opacity:1}.sidebar-footer{border-top:1px solid var(--line);flex-direction:column;align-items:center;gap:4px;width:100%;margin-top:auto;padding-top:10px;display:flex}.sidebar-user{display:none}.user-avatar-sm{color:#fff;background:linear-gradient(135deg,#2563eb,#0ea5e9);border-radius:50%;flex-shrink:0;place-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:grid}.user-details{display:none}.user-name-sm{color:var(--text-h);font-size:13px;font-weight:600}.user-role-sm{color:var(--text);font-size:11px}.logout-btn-sm{cursor:pointer;width:36px;height:36px;color:var(--ink-400);background:0 0;border:none;border-radius:8px;place-items:center;transition:all .15s;display:grid}.logout-btn-sm:hover{background:var(--danger-50);color:var(--danger)}.logout-btn-sm svg{width:18px;height:18px}.top-bar{border-bottom:1px solid var(--line);background:var(--surface);z-index:9;align-items:center;gap:16px;height:52px;padding:0 24px;display:flex;position:fixed;top:0;left:56px;right:0}.top-bar-crumb{color:var(--ink-400);align-items:center;gap:8px;font-size:13px;display:flex}.top-bar-crumb svg{width:12px;height:12px;color:var(--ink-300)}.top-bar-crumb b{color:var(--ink-900);font-weight:500}.top-bar-search{border:1px solid var(--line);background:var(--surface);width:260px;height:32px;color:var(--ink-400);border-radius:6px;align-items:center;gap:8px;margin-left:auto;padding:0 10px;font-size:13px;display:flex}.top-bar-search svg{flex-shrink:0;width:14px;height:14px}.top-bar-search span{white-space:nowrap;text-overflow:ellipsis;flex:1;overflow:hidden}.top-bar-search .kbd{font-family:var(--mono);color:var(--ink-400);border:1px solid var(--line);border-radius:3px;flex-shrink:0;margin-left:auto;padding:1px 4px;font-size:10px}.top-bar-actions{align-items:center;gap:4px;display:flex}.top-bar-btn{width:32px;height:32px;color:var(--ink-500);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:6px;place-items:center;display:grid;position:relative}.top-bar-btn:hover{background:var(--line-soft)}.top-bar-btn svg{width:16px;height:16px}.top-bar-btn .pip{background:var(--primary);width:6px;height:6px;box-shadow:0 0 0 2px var(--surface);border-radius:50%;position:absolute;top:6px;right:6px}.main-content{background:var(--bg);flex:1;min-height:100vh;margin-left:56px;padding:76px 28px 28px}.page-header{justify-content:space-between;align-items:center;margin-bottom:24px;display:flex}.page-header h1{color:var(--text-h);margin:0;font-size:24px;font-weight:700}.btn{border-radius:var(--radius);cursor:pointer;border:none;align-items:center;gap:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .15s;display:inline-flex}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-danger{background:var(--danger-bg);color:var(--danger)}.btn-danger:hover{background:var(--danger);color:#fff}.btn-sm{padding:5px 10px;font-size:13px}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.data-table{border-collapse:collapse;width:100%;font-size:14px}.data-table th{text-align:left;color:var(--text);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg);padding:12px 16px;font-size:12px;font-weight:600}.data-table td{border-bottom:1px solid var(--border);color:var(--text-h);padding:12px 16px}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg)}.table-actions{gap:6px;display:flex}.pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:8px;padding:16px;display:flex}.pagination button{border:1px solid var(--border);background:var(--surface);cursor:pointer;color:var(--text-h);border-radius:6px;padding:6px 12px;font-size:13px}.pagination button:disabled{opacity:.5;cursor:default}.pagination span{color:var(--text);font-size:13px}.form-group{margin-bottom:16px}.form-group label{color:var(--text-h);margin-bottom:6px;font-size:13px;font-weight:600;display:block}.form-group input,.form-group select,.form-group textarea{border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--text-h);background:var(--surface);box-sizing:border-box;padding:8px 12px;font-size:14px}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:var(--primary);outline:none;box-shadow:0 0 0 3px #2563eb1a}.form-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.form-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.form-actions .btn-cancel{background:var(--bg);color:var(--text);border:1px solid var(--border)}.alert{border-radius:var(--radius);margin-bottom:16px;padding:10px 14px;font-size:13px}.alert-error{background:var(--danger-bg);color:var(--danger)}.alert-success{background:var(--success-bg);color:var(--success)}.status-badge{border-radius:20px;padding:3px 10px;font-size:12px;font-weight:600;display:inline-flex}.empty-state{text-align:center;color:var(--text);padding:48px 24px}.empty-state p{margin-top:8px;font-size:14px}.loading{text-align:center;color:var(--text);padding:48px;font-size:14px}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-bottom:24px;display:grid}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.stat-card .stat-label{color:var(--text);font-size:13px;font-weight:500}.stat-card .stat-value{color:var(--text-h);margin-top:4px;font-size:28px;font-weight:700}.modal-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border-radius:var(--radius-lg);min-width:400px;max-width:90vw;max-height:90vh;box-shadow:var(--shadow-lg);padding:24px;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.modal-header h2{color:var(--text-h);font-size:18px;font-weight:600}.modal-close{cursor:pointer;color:var(--text-muted);background:0 0;border:none;border-radius:4px;padding:4px}.modal-close:hover{color:var(--text-h);background:var(--line-soft)}@media (width<=768px){.sidebar{display:none}.top-bar{left:0}.main-content{margin-left:0}}.dash-header{margin-bottom:24px}.dash-header h1{color:var(--text-h);margin:0;font-size:24px;font-weight:700}.dash-header p{color:var(--ink-400);margin:4px 0 0;font-size:13px}.kpi-strip{background:var(--surface);border:1px solid var(--border);border-radius:10px;grid-template-columns:repeat(4,1fr);margin-bottom:20px;display:grid}.kpi-strip-item{border-right:1px solid var(--border);padding:18px 22px}.kpi-strip-item:last-child{border-right:none}.kpi-strip-label{color:var(--ink-500);align-items:center;gap:8px;font-size:12px;font-weight:500;display:flex}.kpi-strip-label .dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.kpi-strip-row{align-items:baseline;gap:10px;margin-top:6px;display:flex}.kpi-strip-num{color:var(--ink-900);letter-spacing:-.02em;font-size:28px;font-weight:600;line-height:1.1}.kpi-strip-num .suffix{color:var(--ink-400);font-size:18px}.kpi-strip-sub{color:var(--ink-400);font-size:11px;font-family:var(--mono);margin-top:4px}.kpi-delta{font-size:12px;font-weight:600;font-family:var(--mono);align-items:center;gap:2px;display:inline-flex}.kpi-delta.positive{color:var(--success)}.kpi-delta.negative{color:var(--danger)}.kpi-delta.neutral{color:var(--ink-400)}.kpi-sparkline{margin-top:8px}.dashboard-grid{grid-template-columns:1.4fr 1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.dashboard-grid .full-width{grid-column:1/-1}.dashboard-grid-r2{grid-template-columns:1fr 1fr 1.4fr}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:20px}.chart-card-head{justify-content:space-between;align-items:flex-start;margin-bottom:16px;display:flex}.chart-card-title{color:var(--text-h);margin-bottom:4px;font-size:14px;font-weight:600}.chart-card-sub{color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-family:var(--mono);font-weight:500}.css-funnel{flex-direction:column;gap:10px;display:flex}.css-funnel-row{align-items:center;gap:12px;display:flex}.css-funnel-name{width:120px;color:var(--ink-700);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:12px;font-weight:500;overflow:hidden}.css-funnel-bar{background:var(--line-soft);border-radius:4px;flex:1;height:22px;position:relative;overflow:hidden}.css-funnel-fill{background:var(--primary);color:#fff;height:100%;font-size:10px;font-weight:600;font-family:var(--mono);border-radius:4px;justify-content:flex-end;align-items:center;min-width:32px;padding:0 8px;transition:width .6s;display:flex}.css-funnel-num{text-align:right;width:48px;color:var(--ink-900);font-size:12px;font-weight:600;font-family:var(--mono);flex-shrink:0}.css-funnel-drop{text-align:right;width:40px;color:var(--ink-400);font-size:11px;font-family:var(--mono);flex-shrink:0}.css-funnel-drop.has-drop{color:var(--danger)}.css-donut-wrap{align-items:center;gap:24px;display:flex}.css-donut{border-radius:50%;flex-shrink:0;width:140px;height:140px;position:relative}.css-donut-hole{background:var(--surface);border-radius:50%;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:24px}.css-donut-total{color:var(--ink-900);letter-spacing:-.02em;font-size:20px;font-weight:700;line-height:1}.css-donut-total-label{color:var(--ink-400);text-transform:uppercase;letter-spacing:.08em;font-size:9px;font-family:var(--mono);margin-top:2px}.css-donut-legend{flex-direction:column;flex:1;gap:10px;display:flex}.css-donut-legend-row{align-items:center;gap:8px;font-size:13px;display:flex}.css-donut-legend-row .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.css-donut-legend-row .name{color:var(--ink-500);flex:1}.css-donut-legend-row .value{color:var(--ink-900);font-weight:600;font-family:var(--mono);font-size:12px}.css-donut-legend-row .pct{color:var(--ink-400);font-family:var(--mono);text-align:right;width:30px;font-size:11px}.css-bars{flex-direction:column;gap:12px;display:flex}.css-bar{align-items:center;gap:12px;display:flex}.css-bar-name{width:110px;color:var(--ink-700);white-space:nowrap;text-overflow:ellipsis;flex-shrink:0;font-size:12px;font-weight:500;overflow:hidden}.css-bar-track{background:var(--line-soft);border-radius:4px;flex:1;height:8px;overflow:hidden}.css-bar-fill{background:var(--primary);border-radius:4px;height:100%;transition:width .6s}.css-bar-fill.danger{background:var(--danger)}.css-bar-num{text-align:right;width:48px;color:var(--ink-900);font-size:12px;font-weight:600;font-family:var(--mono);flex-shrink:0}.funnel-header{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.funnel-select{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:6px;min-width:140px;padding:5px 10px;font-size:13px}.funnel-select:focus{border-color:var(--primary);outline:none}.alert-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-bottom:20px;overflow:hidden}.alert-card-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.alert-card-title{color:var(--text-h);font-size:14px;font-weight:600}.alert-count{background:var(--danger-50);color:var(--danger);font-size:11px;font-weight:500;font-family:var(--mono);border-radius:4px;align-items:center;gap:6px;padding:2px 8px;display:inline-flex}.feed-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;max-height:400px;padding:20px;overflow-y:auto}.feed-title{color:var(--text-h);margin-bottom:4px;font-size:14px;font-weight:600}.feed-sub{color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-family:var(--mono);margin-bottom:16px;font-weight:500}.feed-item{border-bottom:1px solid var(--border);gap:12px;padding:10px 0;display:flex}.feed-item:last-child{border-bottom:none}.feed-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:12px;font-weight:600;display:flex}.feed-icon.aprobacion{background:var(--success-50);color:var(--success)}.feed-icon.rechazo{background:var(--danger-50);color:var(--danger)}.feed-icon.otro{background:var(--info-bg);color:var(--info)}.feed-content{flex:1;min-width:0}.feed-desc{color:var(--text-h);white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:500;overflow:hidden}.feed-meta{color:var(--text-muted);margin-top:2px;font-size:12px}.operator-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;overflow:hidden}.operator-card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;padding:16px 20px;display:flex}.operator-card-title{color:var(--text-h);font-size:14px;font-weight:600}.operator-card-sub{color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-family:var(--mono);margin-top:2px;font-weight:500}.progress-bar-bg{background:var(--line-soft);border-radius:3px;width:100%;height:6px;overflow:hidden}.progress-bar-fill{background:var(--success);border-radius:3px;height:100%;transition:width .3s}.advanced-section{border-top:2px solid var(--border);margin-top:12px;padding-top:24px}.section-header{justify-content:space-between;align-items:center;margin-bottom:20px;display:flex}.section-title{color:var(--text-h);align-items:center;gap:10px;margin:0;font-size:18px;font-weight:700;display:flex}.section-title:before{content:"";background:var(--primary);border-radius:2px;width:3px;height:18px}.section-sub{color:var(--ink-400);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-family:var(--mono);margin-top:4px;margin-left:13px;font-weight:500}.custom-tooltip{background:var(--surface);border:1px solid var(--border);box-shadow:var(--shadow-lg);border-radius:8px;padding:10px 14px;font-size:12px;line-height:1.5}.custom-tooltip p{margin:0}.heatmap-wrapper{width:100%}.heatmap-grid{grid-template-rows:repeat(7,1fr);gap:3px;width:100%;display:grid}.heatmap-cell{aspect-ratio:1;border-radius:3px;width:100%;max-height:28px}.heatmap-day-label{color:var(--text-muted);justify-content:center;align-items:center;font-size:11px;font-weight:500;display:flex}.heatmap-legend{justify-content:flex-end;align-items:center;gap:4px;margin-top:12px;display:flex}.heatmap-legend .heatmap-cell{aspect-ratio:auto;width:14px;height:14px}.heatmap-legend-label{color:var(--text-muted);margin:0 4px;font-size:11px}.scatter-legend{color:var(--ink-500);justify-content:center;gap:16px;margin-top:12px;font-size:12px;display:flex}.scatter-legend .dot{border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}@media (width<=1200px){.dashboard-grid,.dashboard-grid-r2{grid-template-columns:1fr 1fr}.kpi-strip{grid-template-columns:repeat(2,1fr)}.kpi-strip-item:nth-child(2){border-right:none}.kpi-strip-item:first-child,.kpi-strip-item:nth-child(2){border-bottom:1px solid var(--border)}}@media (width<=900px){.dashboard-grid,.dashboard-grid-r2{grid-template-columns:1fr}.kpi-strip{grid-template-columns:1fr 1fr}}@media (width<=600px){.kpi-strip{grid-template-columns:1fr}.kpi-strip-item{border-right:none;border-bottom:1px solid var(--border)}.kpi-strip-item:last-child{border-bottom:none}.css-donut-wrap{flex-direction:column}.css-funnel-name{width:80px}}.modal-overlay{z-index:100;background:#00000080;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal-content{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:520px;max-height:85vh;box-shadow:var(--shadow-lg);overflow-y:auto}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.modal-header h3{color:var(--text-h);margin:0;font-size:16px;font-weight:600}.modal-close{cursor:pointer;color:var(--text);background:0 0;border:none;padding:0 4px;font-size:22px;line-height:1}.modal-close:hover{color:var(--text-h)}.modal-body{padding:20px}.reportes-page h1{color:var(--text-h);margin:0 0 20px;font-size:22px;font-weight:700}.reportes-filtros{background:var(--surface);border:1px solid var(--border);border-radius:4px;flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:20px;padding:16px 20px;display:flex}.reportes-filtro-group{flex-direction:column;gap:4px;min-width:140px;display:flex}.reportes-filtro-group label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.reportes-filtro-group select,.reportes-filtro-group input[type=date]{border:1px solid var(--border);background:var(--bg);color:var(--text-h);cursor:pointer;border-radius:4px;padding:6px 10px;font-size:13px}.reportes-filtro-group select:focus,.reportes-filtro-group input[type=date]:focus{border-color:var(--primary);outline:none}.reportes-btn-generar{color:#fff;background:var(--primary);cursor:pointer;white-space:nowrap;border:none;border-radius:4px;align-self:flex-end;padding:7px 20px;font-size:13px;font-weight:600}.reportes-btn-generar:hover{opacity:.9}.reportes-btn-generar:disabled{opacity:.5;cursor:not-allowed}.reportes-kpi-row{grid-template-columns:repeat(6,1fr);gap:12px;margin-bottom:20px;display:grid}.reportes-kpi-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:4px;padding:16px}.reportes-kpi-value{color:var(--text-h);font-size:22px;font-weight:700;line-height:1}.reportes-kpi-label{color:var(--text-muted);margin-top:6px;font-size:12px;font-weight:500}.reportes-kpi-sub{color:var(--text-muted);margin-top:2px;font-size:11px}.reportes-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:20px;display:grid}.reportes-grid .full-width{grid-column:1/-1}.reportes-tabla-wrapper{background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden}.reportes-tabla-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px 20px;display:flex}.reportes-tabla-title{color:var(--text-h);font-size:14px;font-weight:600}.reportes-tabla-count{color:var(--text-muted);font-size:12px}.reportes-table{border-collapse:collapse;width:100%;font-size:13px}.reportes-table th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--border);background:var(--bg);white-space:nowrap;padding:10px 12px;font-size:11px;font-weight:600}.reportes-table td{border-bottom:1px solid var(--border);color:var(--text);padding:10px 12px}.reportes-table tr:last-child td{border-bottom:none}.reportes-table .status-dot{vertical-align:middle;border-radius:50%;width:8px;height:8px;margin-right:6px;display:inline-block}.reportes-table .rango-ok{color:var(--success);font-weight:600}.reportes-table .rango-fail{color:var(--danger);font-weight:600}.reportes-pagination{border-top:1px solid var(--border);justify-content:center;align-items:center;gap:12px;padding:12px 20px;display:flex}.reportes-pagination button{border:1px solid var(--border);background:var(--surface);color:var(--text);cursor:pointer;border-radius:4px;padding:5px 14px;font-size:13px}.reportes-pagination button:disabled{opacity:.4;cursor:not-allowed}.reportes-pagination span{color:var(--text-muted);font-size:13px}.reportes-empty{text-align:center;color:var(--text-muted);padding:60px 20px;font-size:14px}.reportes-loading{text-align:center;color:var(--text-muted);padding:40px 20px;font-size:14px}@media (width<=1200px){.reportes-kpi-row{grid-template-columns:repeat(3,1fr)}}@media (width<=900px){.reportes-grid{grid-template-columns:1fr}.reportes-kpi-row{grid-template-columns:repeat(2,1fr)}}@media (width<=600px){.reportes-kpi-row{grid-template-columns:1fr}.reportes-filtros{flex-direction:column}.reportes-filtro-group{width:100%}}.login-wrapper{background:var(--surface);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.login-left{flex-direction:column;padding:48px 64px;display:flex;position:relative}.login-brand{color:var(--ink-900);letter-spacing:-.01em;align-items:center;gap:10px;font-size:15px;font-weight:600;display:inline-flex}.login-brand-mark{background:var(--ink-900);color:#fff;border-radius:7px;place-items:center;width:26px;height:26px;display:grid}.login-brand-mark svg{width:14px;height:14px}.login-center{flex-direction:column;flex:1;justify-content:center;width:100%;max-width:380px;display:flex}.login-eyebrow{color:var(--ink-400);text-transform:uppercase;letter-spacing:.08em;font-size:12px;font-weight:500;font-family:var(--mono);margin-bottom:12px}.login-title{letter-spacing:-.03em;color:var(--ink-900);margin-bottom:10px;font-size:32px;font-weight:600;line-height:1.1}.login-subtitle{color:var(--ink-500);margin-bottom:36px;font-size:14px;line-height:1.5}.login-form{flex-direction:column;gap:0;display:flex}.login-field{margin-bottom:18px}.login-field label{color:var(--ink-700);letter-spacing:-.005em;margin-bottom:6px;font-size:12px;font-weight:500;display:block}.login-input{width:100%;height:40px;font:14px var(--sans);color:var(--ink-900);background:var(--surface);border:1px solid var(--line);border-radius:8px;outline:none;padding:0 14px;transition:border-color .15s,box-shadow .15s}.login-input:focus{border-color:var(--ink-700);box-shadow:0 0 0 4px #09090b0f}.login-input::placeholder{color:var(--ink-300)}.login-row{justify-content:space-between;align-items:center;margin:6px 0 22px;display:flex}.login-check{color:var(--ink-500);cursor:pointer;align-items:center;gap:8px;font-size:13px;display:flex}.login-check input{accent-color:var(--primary)}.login-forgot{color:var(--ink-700);font-size:13px;font-weight:500;text-decoration:none}.login-forgot:hover{color:var(--primary)}.login-btn{background:var(--ink-900);color:#fff;width:100%;height:42px;font:500 14px var(--sans);letter-spacing:-.005em;cursor:pointer;border:0;border-radius:8px;justify-content:center;align-items:center;gap:8px;transition:background .15s;display:inline-flex}.login-btn:hover:not(:disabled){background:var(--ink-700)}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-btn svg{width:14px;height:14px}.login-error{color:var(--danger);background:var(--danger-50);text-align:center;border:1px solid #dc262626;border-radius:8px;margin-bottom:18px;padding:10px 14px;font-size:13px}.login-divider{color:var(--ink-400);align-items:center;gap:12px;margin:22px 0;font-size:12px;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--line);flex:1;height:1px}.login-sso{background:var(--surface);border:1px solid var(--line);width:100%;height:40px;font:500 13px var(--sans);color:var(--ink-700);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;gap:10px;transition:background .15s;display:inline-flex}.login-sso:hover{background:var(--line-soft)}.login-sso .kbd{font-family:var(--mono);color:var(--ink-400);border:1px solid var(--line);border-radius:4px;margin-left:4px;padding:1px 5px;font-size:11px}.login-footer{color:var(--ink-400);justify-content:space-between;align-items:center;font-size:12px;display:flex}.login-footer a{color:var(--ink-500);text-decoration:none}.login-footer a:hover{color:var(--ink-900)}.login-right{color:#e4e4e7;background-color:#0b1220;background-image:radial-gradient(120% 80% at 100% 0,#2563eb59 0%,#2563eb00 50%),radial-gradient(100% 80% at 0 100%,#0ea5e92e 0%,#0ea5e900 60%);background-position:0 0;background-repeat:repeat;background-size:auto;background-attachment:scroll;background-origin:padding-box;background-clip:border-box;flex-direction:column;justify-content:space-between;padding:48px;display:flex;position:relative;overflow:hidden}.login-right:before{content:"";pointer-events:none;background-image:linear-gradient(90deg,#ffffff0a 1px,#0000 1px),linear-gradient(#ffffff0a 1px,#0000 1px);background-size:56px 56px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(#000 30%,#0000 75%);mask-image:radial-gradient(#000 30%,#0000 75%)}.login-visual-top{z-index:1;font-family:var(--mono);color:#ffffff73;letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;font-size:11px;display:flex;position:relative}.login-visual-top .dot{background:#22c55e;border-radius:50%;width:6px;height:6px;margin-right:6px;display:inline-block;box-shadow:0 0 0 3px #22c55e26}.login-visual-mid{z-index:1;flex-direction:column;flex:1;justify-content:center;max-width:460px;display:flex;position:relative}.login-quote{letter-spacing:-.025em;color:#fff;font-size:28px;font-weight:500;line-height:1.25}.login-quote span{color:#ffffff8c}.login-visual-meta{color:#fff9;align-items:center;gap:12px;margin-top:28px;font-size:13px;display:flex}.login-avatar{color:#fff;background:linear-gradient(135deg,#2563eb 0%,#0ea5e9 100%);border-radius:50%;place-items:center;width:32px;height:32px;font-size:12px;font-weight:600;display:grid}.login-tile{z-index:1;-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);background:#ffffff0a;border:1px solid #ffffff14;border-radius:12px;padding:16px;position:relative}.login-tile-head{font-family:var(--mono);color:#ffffff80;letter-spacing:.06em;text-transform:uppercase;justify-content:space-between;align-items:center;margin-bottom:14px;font-size:11px;display:flex}.login-tile-stats{grid-template-columns:repeat(3,1fr);gap:18px;display:grid}.login-stat-num{color:#fff;letter-spacing:-.02em;font-size:22px;font-weight:600}.login-stat-num.ok{color:#4ade80}.login-stat-num.bad{color:#f87171}.login-stat-lbl{color:#ffffff80;text-transform:uppercase;letter-spacing:.06em;font-size:11px;font-family:var(--mono);margin-top:4px}.login-tile-spark{width:100%;height:36px;margin-top:14px;display:block}@media (width<=900px){.login-wrapper{grid-template-columns:1fr}.login-right{display:none}.login-left{padding:32px 24px}}
