:root{--bg:#0d1117;--bg2:#121820;--bg3:#161d28;--surface:#1c2333;--surface2:#212940;--surface3:#263048;--border:#ffffff12;--border-light:#ffffff1c;--border-focus:#3b82f659;--text:#ffffffe6;--text2:#fff9;--text3:#ffffff61;--muted:#ffffff4d;--primary:#3b82f6;--primary-light:#60a5fa;--primary-dark:#2563eb;--primary2:#818cf8;--accent:#0ea5e9;--accent-light:#38bdf8;--success:#22c55e;--success-light:#4ade80;--warning:#eab308;--warning-light:#facc15;--danger:#ef4444;--danger-light:#f87171;--info:#3b82f6;--sidebar-w:220px;--topbar-h:52px;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--space-xs:4px;--space-sm:8px;--space-md:12px;--space-lg:16px;--space-xl:20px;--space-2xl:28px;--shadow-sm:0 1px 3px #0003;--shadow-md:0 2px 8px #00000047;--shadow-lg:0 4px 16px #0000005c;--shadow-xl:0 8px 32px #00000070;--transition-fast:.12s ease-out;--transition-base:.2s ease-out;--transition-slow:.28s ease-out}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:13px;line-height:1.55;overflow:hidden}input,button,textarea,select{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#fff3}.nhub-layout{background:var(--bg);flex-direction:column;height:100vh;display:flex}.nhub-body{flex:1;display:flex;overflow:hidden}.nhub-sidebar{width:var(--sidebar-w);border-right:1px solid var(--border);transition:all var(--transition-base);background:#111827;flex-direction:column;flex-shrink:0;display:flex;overflow-y:auto}.nhub-main{background:var(--bg);flex-direction:column;flex:1;display:flex;overflow:hidden}.nhub-content{padding:var(--space-xl) var(--space-2xl);background:var(--bg);flex:1;overflow-y:auto}@media (width<=900px){.nhub-sidebar{left:-240px;top:var(--topbar-h);z-index:100;transition:left .2s;position:fixed;bottom:0}.nhub-sidebar.open{left:0}.nhub-main{width:100%}}.splash-page{z-index:9999;background:#04060f;justify-content:center;align-items:center;animation:.8s cubic-bezier(.16,1,.3,1) both splash-in;display:flex;position:fixed;inset:0;overflow:hidden}.splash-page.splash-leaving{animation:.68s cubic-bezier(.7,0,1,1) forwards splash-out}@keyframes splash-in{0%{opacity:0}to{opacity:1}}@keyframes splash-out{0%{opacity:1;filter:blur();transform:scale(1)}to{opacity:0;filter:blur(10px);transform:scale(1.06)}}.splash-3d-canvas{z-index:0;position:absolute;inset:0}.splash-3d-canvas canvas{display:block;width:100%!important;height:100%!important}.splash-orb{filter:blur(100px);pointer-events:none;z-index:0;border-radius:50%;animation:14s ease-in-out infinite orb-drift;position:absolute}.splash-orb-1{background:radial-gradient(circle,#6366f166 0%,#0000 68%);width:560px;height:560px;top:-160px;left:5%}.splash-orb-2{background:radial-gradient(circle,#a855f752 0%,#0000 68%);width:440px;height:440px;animation-delay:-5s;bottom:-110px;right:4%}.splash-orb-3{background:radial-gradient(circle,#22d3ee38 0%,#0000 68%);width:320px;height:320px;animation-delay:-9s;bottom:30%;left:2%}@keyframes orb-drift{0%,to{transform:translate(0)scale(1)}33%{transform:translate(22px,-32px)scale(1.06)}66%{transform:translate(-16px,18px)scale(.96)}}.splash-content{z-index:2;text-align:center;-webkit-backdrop-filter:blur(18px)saturate(140%);backdrop-filter:blur(18px)saturate(140%);background:#04060f85;border:1px solid #6366f129;border-radius:28px;flex-direction:column;align-items:center;gap:24px;padding:48px 64px;animation:.95s cubic-bezier(.16,1,.3,1) .25s both splash-rise;display:flex;position:relative;box-shadow:0 0 60px #6366f11a,0 24px 80px #00000073}.splash-logo{width:56px;height:56px;color:var(--accent);justify-content:center;align-items:center;animation:3s ease-in-out infinite logo-float;display:flex}.splash-logo svg{stroke:currentColor;width:100%;height:100%}@keyframes logo-float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.splash-text-group{flex-direction:column;gap:8px;display:flex}@keyframes splash-rise{0%{opacity:0;transform:translateY(30px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.splash-eyebrow{letter-spacing:.22em;text-transform:uppercase;color:#a78bfab3;margin:0;font-size:10.5px;font-weight:600}.splash-title{letter-spacing:-.026em;background:linear-gradient(130deg,#fff 0%,#c4b5fd 28%,#818cf8 55%,#22d3ee 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 24px #6366f18c);-webkit-background-clip:text;background-clip:text;margin:0;font-size:52px;font-weight:900;line-height:1.04}.splash-sub{color:#ffffff73;max-width:340px;margin:0;font-size:14.5px;line-height:1.65}.splash-btn{letter-spacing:.11em;text-transform:uppercase;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#6366f129;border:1px solid #6366f173;border-radius:50px;align-items:center;gap:10px;margin-top:6px;padding:14px 46px;font-size:12.5px;font-weight:700;transition:transform .3s cubic-bezier(.16,1,.3,1),box-shadow .3s,border-color .3s;display:inline-flex;position:relative;overflow:hidden}.splash-btn:before{content:"";border-radius:inherit;opacity:0;background:linear-gradient(135deg,#6366f199,#22d3ee4d);transition:opacity .32s;position:absolute;inset:0}.splash-btn:hover{border-color:#6366f1e6;transform:translateY(-3px)scale(1.04);box-shadow:0 0 0 1px #6366f133,0 8px 32px #6366f159,0 0 65px #6366f124}.splash-btn:hover:before{opacity:1}.splash-btn:active{transform:translateY(-1px)scale(1.01)}.splash-btn>span,.splash-btn-arrow{z-index:1;position:relative}.splash-btn-arrow{transition:transform .3s cubic-bezier(.16,1,.3,1)}.splash-btn:hover .splash-btn-arrow{transform:translate(5px)}.splash-version{color:#ffffff29;letter-spacing:.07em;z-index:2;font-size:10.5px;position:absolute;bottom:20px;right:24px}@media (width<=560px){.splash-title{font-size:34px}.splash-content{padding:32px 28px 36px}.splash-btn{padding:13px 34px}}.auth-page{background:var(--bg);height:100vh;display:flex}.auth-left{background:var(--bg);flex-direction:column;flex:1;justify-content:center;align-items:center;padding:40px;display:flex;position:relative;overflow:hidden}.auth-left:after{content:"";pointer-events:none;z-index:1;background:linear-gradient(120deg,#0000 0%,#fff0 28%,#ffffff0d 40%,#ffffff1a 46%,#ffffff0d 52%,#fff0 65%,#0000 100%);border-right:1px solid #ffffff0d;position:absolute;inset:0}.auth-left>*{z-index:2;position:relative}.auth-right{flex-direction:column;flex:1;justify-content:center;padding:40px 60px;display:flex;position:relative;overflow:hidden}.auth-right:before{content:"";z-index:0;background-image:url(/static/bg-login.jpeg);background-position:50%;background-size:cover;position:absolute;inset:0;transform:scaleX(-1)}.auth-right:after{content:"";z-index:1;background:linear-gradient(#06081ae8 0%,#06081ad1 100%),linear-gradient(115deg,#0000 0%,#ffffff0a 25%,#ffffff1a 38%,#ffffff08 50%,#0000 65%),linear-gradient(90deg,#6366f14d 0%,#06081a1a 45%,#22d3ee1f 100%);border-left:1px solid #ffffff14;position:absolute;inset:0}.auth-right>*{z-index:2;position:relative}.auth-right h2{background:linear-gradient(135deg, #fff 0%, var(--primary2) 50%, var(--accent) 100%);-webkit-text-fill-color:transparent;filter:drop-shadow(0 2px 12px #6366f166);-webkit-background-clip:text;margin-bottom:16px;font-size:34px;font-weight:900;line-height:1.2}.auth-right p{color:#ffffffbf;text-shadow:0 1px 4px #0009;max-width:420px;margin-bottom:28px;font-size:15px;line-height:1.65}.auth-features{flex-direction:column;gap:10px;list-style:none;display:flex}.auth-features li{color:#fffc;text-shadow:0 1px 3px #00000080;align-items:center;gap:10px;font-size:13px;display:flex}.auth-features li:before{content:"";background:var(--primary2);border-radius:50%;flex-shrink:0;width:6px;height:6px;box-shadow:0 0 6px #6366f1cc}.auth-brand{text-align:center;margin-bottom:40px}.auth-brand-icon{width:48px;height:48px;color:var(--primary);margin-bottom:12px}.auth-brand h1{font-size:28px;font-weight:900}.auth-brand p{color:var(--muted);margin-top:4px;font-size:13px}.auth-card{width:100%;max-width:380px}.auth-tabs{background:var(--surface2);border-radius:10px;gap:0;margin-bottom:24px;padding:3px;display:flex}.auth-tab{color:var(--text2);cursor:pointer;background:0 0;border:none;border-radius:8px;flex:1;padding:10px 16px;font-size:13px;font-weight:600;transition:all .2s}.auth-tab.active{background:var(--primary);color:#fff}.auth-error{color:var(--danger);background:#ef44441f;border:1px solid #ef44444d;border-radius:8px;margin-bottom:16px;padding:10px 14px;font-size:12px;display:none}.field{margin-bottom:var(--space-lg)}.field label{letter-spacing:.04em;color:var(--text2);margin-bottom:var(--space-sm);text-transform:uppercase;align-items:center;gap:4px;font-size:11px;font-weight:600;display:flex}.input{background:var(--surface2);border:1px solid var(--border-light);border-radius:var(--radius-md);width:100%;color:var(--text);transition:border-color var(--transition-fast);outline:none;padding:9px 12px;font-size:13px}.input:hover{border-color:#ffffff2e}.input:focus{border-color:var(--primary);background:var(--surface2)}.input::placeholder{color:var(--muted)}.btn{justify-content:center;align-items:center;gap:var(--space-sm);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);border:1.5px solid #0000;width:100%;padding:11px 20px;font-size:13px;font-weight:600;text-decoration:none;display:inline-flex;position:relative;overflow:hidden}.btn:before{content:"";background:radial-gradient(circle at var(--mouse-x,50%) var(--mouse-y,50%), #ffffff1a 0%, transparent 80%);opacity:0;pointer-events:none;position:absolute;inset:0}.btn-primary{background:var(--primary);color:#fff}.btn-primary:hover{background:var(--primary-light)}.btn-primary:active{background:var(--primary-dark)}.btn-secondary{background:var(--surface2);border-color:var(--border-light);color:var(--text)}.btn-secondary:hover{background:var(--surface3);border-color:#3b82f666}.btn-google{border:1.5px solid var(--border-light);color:var(--text);background:0 0}.btn-google:hover{border-color:var(--border-focus);background:#ffffff08;transform:translateY(-1px)}.btn-link{color:var(--primary);background:0 0;width:auto;padding:0;font-size:13px;font-weight:500}.btn-link:hover{color:var(--primary-light);text-decoration:underline}.btn-danger{color:#ef4444;box-shadow:none;background:#ef44441f;border:1.5px solid #ef444440}.btn-danger:hover{box-shadow:none;background:#ef444433;border-color:#ef444480;transform:translateY(-1px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.divider{align-items:center;gap:var(--space-lg);margin:var(--space-xl) 0;color:var(--muted);letter-spacing:.04em;text-transform:uppercase;font-size:11px;font-weight:500;display:flex}.divider:before,.divider:after{content:"";background:linear-gradient(90deg, var(--border) 0%, #fff0 50%, var(--border) 100%);flex:1;height:1px}.sidebar-brand{padding:14px var(--space-lg);border-bottom:1px solid var(--border);align-items:center;gap:10px;display:flex}.sidebar-logo{width:28px;height:28px;color:var(--primary-light);flex-shrink:0}.sidebar-name{color:#fff;letter-spacing:-.01em;font-size:14px;font-weight:700}.nav-section{padding:14px var(--space-lg) 4px;letter-spacing:.06em;color:#ffffff38;text-transform:uppercase;font-size:10px;font-weight:600}.nav-item{color:#ffffffd9;cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-fast), color var(--transition-fast);text-align:left;background:0 0;border:none;align-items:center;gap:9px;width:calc(100% - 16px);margin:1px 8px;padding:7px 12px;font-size:12.5px;font-weight:500;display:flex;position:relative}.nav-item:before{content:"";background:var(--primary);transform-origin:0;width:2px;transition:transform var(--transition-fast);border-radius:0 2px 2px 0;position:absolute;top:4px;bottom:4px;left:0;transform:scaleX(0)}.nav-item:hover{color:#fff;background:#ffffff12}.nav-item.active{color:#fff;background:#3b82f626;font-weight:600}.nav-item.active:before{transform:scaleX(1)}.nav-icon{opacity:.9;flex-shrink:0;width:16px;height:16px}.nav-item.active .nav-icon,.nav-item:hover .nav-icon{opacity:1}.nav-badge{color:var(--primary2);background:#6366f133;border-radius:99px;margin-left:auto;padding:2px 6px;font-size:9px;font-weight:700}.nav-badge-pending{color:#ef4444;background:#ef44442e;animation:2s ease-in-out infinite badge-pulse}@keyframes badge-pulse{0%,to{opacity:1}50%{opacity:.55}}.sidebar-footer{border-top:1px solid var(--border);margin-top:auto;padding:10px 8px}.user-row{align-items:center;gap:10px;display:flex}.user-avatar{background:var(--primary);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:14px;font-weight:800;display:flex}.user-info{flex:1;min-width:0}.user-name{text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:700;overflow:hidden}.user-role{color:var(--muted);font-size:10px}.user-role-badge{letter-spacing:.03em;align-items:center;gap:5px;font-size:10px;font-weight:600;display:flex}.user-role-dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.pending-page{background:var(--bg);justify-content:center;align-items:center;min-height:100vh;padding:24px;display:flex}.pending-card{background:var(--surface);border:1px solid var(--border);text-align:center;border-radius:20px;width:100%;max-width:480px;padding:48px 40px;box-shadow:0 8px 40px #0000004d}.pending-icon-wrap{justify-content:center;align-items:center;width:80px;height:80px;margin-bottom:24px;display:inline-flex;position:relative}.pending-icon{color:#f59e0b;z-index:1;width:44px;height:44px;animation:8s linear infinite pending-spin;position:relative}@keyframes pending-spin{to{transform:rotate(360deg)}}.pending-icon-ring{background:#f59e0b1f;border:1px solid #f59e0b40;border-radius:50%;animation:2.5s ease-in-out infinite pending-pulse;position:absolute;inset:0}@keyframes pending-pulse{0%,to{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.1)}}.pending-title{color:var(--text);margin:0 0 12px;font-size:22px;font-weight:800}.pending-sub{color:var(--text2);margin:0 0 28px;font-size:14px;line-height:1.6}.pending-sub strong{color:var(--primary2)}.pending-steps{text-align:left;flex-direction:column;gap:10px;margin-bottom:24px;display:flex}.pending-step{color:var(--muted);align-items:center;gap:12px;font-size:13px;display:flex}.pending-step.done{color:#10b981}.pending-step.active{color:var(--text);font-weight:600}.pending-step-dot{background:var(--surface2);border:1px solid var(--border);width:26px;height:26px;color:var(--muted);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.pending-step.done .pending-step-dot{color:#10b981;background:#10b98126;border-color:#10b98166}.pending-step.active .pending-step-dot{color:#f59e0b;background:#f59e0b26;border-color:#f59e0b66}.pending-hint{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:8px;margin:0 0 24px;padding:10px 14px;font-size:12px}.pending-logout-btn{color:var(--text2);background:var(--surface2);border:1px solid var(--border);cursor:pointer;border-radius:8px;align-items:center;gap:8px;padding:10px 24px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.pending-logout-btn:hover{color:#ef4444;background:#ef44441a;border-color:#ef444466}.rbac-stats{flex-wrap:wrap;gap:12px;margin-bottom:16px;display:flex}.rbac-stat{background:var(--surface2);border:1px solid var(--border);border-radius:10px;flex-direction:column;flex:1;align-items:center;gap:2px;min-width:80px;padding:12px 14px;display:flex}.rbac-stat-num{color:var(--text);font-size:24px;font-weight:800;line-height:1}.rbac-stat span:last-child{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;font-size:10px}.rbac-flash{border-radius:8px;margin-bottom:12px;padding:10px 14px;font-size:12px;font-weight:600}.rbac-flash.ok{color:#10b981;background:#10b9811a;border:1px solid #10b98140}.rbac-flash.err{color:#ef4444;background:#ef44441a;border:1px solid #ef444440}.rbac-confirm{color:var(--text);background:#ef444414;border:1px solid #ef444440;border-radius:10px;margin-bottom:14px;padding:14px 16px;font-size:13px}.rbac-table-wrap{border:1px solid var(--border);border-radius:10px;margin-bottom:14px;overflow-x:auto}.rbac-table{border-collapse:collapse;width:100%;font-size:13px}.rbac-table th{background:var(--surface2);text-align:left;text-transform:uppercase;letter-spacing:.07em;color:var(--muted);border-bottom:1px solid var(--border);white-space:nowrap;padding:10px 14px;font-size:10px;font-weight:700}.rbac-table td{border-bottom:1px solid var(--border);color:var(--text2);vertical-align:middle;padding:11px 14px}.rbac-table tbody tr:last-child td{border-bottom:none}.rbac-table tbody tr:hover td{background:#6366f10a}.rbac-row-self td{background:#6366f10d}.rbac-user-cell{align-items:center;gap:10px;display:flex}.rbac-avatar{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:13px;font-weight:700;display:flex}.rbac-username{color:var(--text);font-weight:600}.rbac-you-tag{color:var(--primary2);letter-spacing:.04em;background:#6366f126;border-radius:4px;padding:2px 6px;font-size:10px;font-weight:700}.rbac-email{color:var(--muted);font-size:12px}.rbac-no-email{color:var(--border)}.rbac-auth-badge{border-radius:5px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.rbac-auth-badge.google{color:#4285f4;background:#4285f41a;border:1px solid #4285f433}.rbac-auth-badge.local{background:var(--surface2);color:var(--muted);border:1px solid var(--border)}.rbac-role-badge{background:rgba(var(--rc,99,102,241), .12);color:var(--rc);border:1px solid color-mix(in srgb, var(--rc) 30%, transparent);border-radius:20px;padding:3px 10px;font-size:11px;font-weight:700;display:inline-block}.rbac-role-select{background:var(--surface2);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:6px;padding:5px 8px;font-size:12px;font-weight:600}.rbac-role-select:hover{border-color:var(--primary)}.rbac-role-select:disabled{opacity:.5;cursor:not-allowed}.rbac-del-btn{cursor:pointer;color:var(--muted);background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:all .15s;display:flex}.rbac-del-btn:hover{color:#ef4444;background:#ef44441a}.rbac-note{color:var(--muted);align-items:center;gap:6px;margin:0;font-size:11px;display:flex}.btn-danger{color:#ef4444;background:#ef444426;border:1px solid #ef44444d}.btn-danger:hover{background:#ef444440}.spinner-sm{background:conic-gradient(from 0deg, transparent 0deg, var(--primary) 120deg, var(--primary2) 240deg, var(--accent) 360deg);vertical-align:middle;border-radius:50%;width:12px;height:12px;animation:.65s cubic-bezier(.45,0,.35,1) infinite spin;display:inline-block;-webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 2px),#fff calc(100% - 2px));mask:radial-gradient(farthest-side,#0000 calc(100% - 2px),#fff calc(100% - 2px))}.logout-btn{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:6px;padding:6px;display:flex}.logout-btn:hover{color:var(--danger);background:#ef44441a}.topbar{height:var(--topbar-h);z-index:200;background:#2563eb;border-bottom:1px solid #0000002e;flex-shrink:0;justify-content:space-between;align-items:center;gap:12px;padding:0 14px;display:flex;box-shadow:0 2px 8px #00000047}.topbar-left{flex-shrink:0;align-items:center;gap:8px;min-width:0;display:flex}.topbar-center{flex:1;justify-content:center;align-items:center;display:flex}.topbar-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.topbar-hamburger{color:#fffc;cursor:pointer;background:0 0;border:none;border-radius:5px;padding:4px;display:none}.topbar-hamburger:hover{color:#fff;background:#ffffff1f}@media (width<=900px){.topbar-hamburger{align-items:center;display:flex}}.topbar-brand{-webkit-user-select:none;user-select:none;align-items:center;gap:8px;display:flex}.topbar-logo-wrap{background:#ffffff26;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;display:flex}.topbar-brand-name{color:#fff;letter-spacing:-.01em;white-space:nowrap;font-size:18px}.topbar-brand-ver{color:#ffffff8c;letter-spacing:.03em;background:#ffffff1f;border-radius:4px;padding:1px 5px;font-size:10px;font-weight:600}.topbar-section-crumb{color:#ffffffbf;white-space:nowrap;text-overflow:ellipsis;max-width:200px;font-size:13px;font-weight:500;overflow:hidden}.topbar-status-group{align-items:center;gap:6px;display:flex}.topbar-status-pill{color:#ffffffbf;white-space:nowrap;background:#0000002e;border:1px solid #ffffff1f;border-radius:6px;align-items:center;gap:5px;padding:4px 9px;font-size:11px;transition:background .12s;display:flex}.topbar-status-pill:hover{background:#00000047}.topbar-status-label{color:#ffffff73;text-transform:uppercase;letter-spacing:.04em;font-size:10px}.topbar-status-val{color:#ffffffe6;font-weight:600}.status-dot{background:#ffffff4d;border-radius:50%;flex-shrink:0;width:6px;height:6px}.status-dot.ok{background:#4ade80;box-shadow:0 0 5px #4ade8099}.status-dot.active{background:#fbbf24;animation:1.8s ease-in-out infinite pulse;box-shadow:0 0 6px #fbbf24b3}.status-dot.warn{background:#f87171}.topbar-user-btn{cursor:pointer;color:#ffffffd9;background:#0000002e;border:1px solid #ffffff24;border-radius:8px;align-items:center;gap:8px;padding:4px 8px 4px 5px;transition:background .12s,border-color .12s;display:flex}.topbar-user-btn:hover{color:#fff;background:#00000047;border-color:#ffffff38}.topbar-avatar{color:#fff;background:#ffffff38;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:26px;height:26px;font-size:12px;font-weight:700;display:flex}.topbar-avatar-lg{width:36px;height:36px;font-size:15px}.topbar-username{color:#fff;font-size:12px;font-weight:600;line-height:1}.topbar-role-badge{font-size:10px;font-weight:500;line-height:1}.topbar-user-menu{z-index:500;background:#1e293b;border:1px solid #ffffff1a;border-radius:10px;width:210px;animation:.12s ease-out fadeDown;position:absolute;top:calc(100% + 6px);right:0;overflow:hidden;box-shadow:0 8px 24px #00000073}@keyframes fadeDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.topbar-user-menu-header{align-items:center;gap:10px;padding:12px 14px;display:flex}.topbar-user-menu-sep{background:#ffffff12;height:1px;margin:0}.topbar-user-menu-item{color:#ffffffb3;text-align:left;cursor:pointer;background:0 0;border:none;align-items:center;gap:9px;width:100%;padding:9px 14px;font-size:12.5px;transition:background .1s,color .1s;display:flex}.topbar-user-menu-item:hover{color:#fff;background:#ffffff0f}.topbar-user-menu-logout:hover{color:#f87171;background:#ef44441a}.topbar-logo-wrap{display:none}.topbar-notif-btn{color:#ffffffb3;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:5px 6px;transition:background .1s,color .1s;display:flex;position:relative}.topbar-notif-btn:hover{color:#fff;background:#ffffff1f}.notif-badge{color:#fff;background:#ef4444;border:2px solid #2563eb;border-radius:99px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 3px;font-size:9px;font-weight:700;line-height:1;animation:.2s ease-out badgePop;display:flex;position:absolute;top:2px;right:2px}@keyframes badgePop{0%{opacity:0;transform:scale(.5)}to{opacity:1;transform:scale(1)}}.notif-panel{z-index:600;background:#1e293b;border:1px solid #ffffff1a;border-radius:12px;flex-direction:column;width:340px;max-height:480px;animation:.12s ease-out fadeDown;display:flex;position:absolute;top:calc(100% + 8px);right:0;overflow:hidden;box-shadow:0 12px 32px #00000080}.notif-panel-header{border-bottom:1px solid #ffffff12;flex-shrink:0;justify-content:space-between;align-items:center;padding:12px 14px 10px;display:flex}.notif-panel-title{color:#fff;font-size:13px;font-weight:700}.notif-action-btn{color:#ffffff8c;cursor:pointer;background:#ffffff12;border:1px solid #ffffff1a;border-radius:5px;padding:3px 8px;font-size:10.5px;transition:background .1s,color .1s}.notif-action-btn:hover{color:#fff;background:#ffffff1f}.notif-empty{color:#ffffff40;flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:40px 20px;font-size:12px;display:flex}.notif-list{flex:1;overflow-y:auto}.notif-item{border-bottom:1px solid #ffffff0d;align-items:flex-start;gap:10px;padding:10px 14px;transition:background .1s;display:flex}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:#ffffff0a!important}.notif-item-icon{flex-shrink:0;margin-top:2px}.notif-item-body{flex:1;min-width:0}.notif-item-title{margin-bottom:3px;font-size:12px;font-weight:600;line-height:1.3}.notif-item-msg{color:#ffffff73;word-break:break-word;font-size:11px;line-height:1.45}.notif-item-time{color:#ffffff4d;white-space:nowrap;font-size:10px}.notif-dismiss{color:#ffffff40;cursor:pointer;background:0 0;border:none;border-radius:3px;align-items:center;padding:2px;transition:color .1s;display:flex}.notif-dismiss:hover{color:#ffffffb3}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.85)}}.page{display:none}.page.active{display:block}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-xl);transition:border-color var(--transition-fast)}.card:hover{border-color:var(--border-light)}.card-title{margin-bottom:var(--space-lg);color:var(--text);align-items:center;gap:9px;font-size:13px;font-weight:600;display:flex}.card-title svg{width:15px;height:15px;color:var(--primary);flex-shrink:0}.card-sub{color:var(--text2);margin-bottom:var(--space-lg);font-size:12px}.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-lg);transition:border-color var(--transition-fast)}.stat-card:hover{border-color:var(--border-light)}.stat-label{letter-spacing:.04em;color:var(--text2);text-transform:uppercase;margin-bottom:var(--space-sm);font-size:10px;font-weight:600}.stat-val{color:var(--text);font-family:JetBrains Mono,Fira Code,SF Mono,monospace;font-size:28px;font-weight:700}.stat-sub{color:var(--text2);margin-top:2px;font-size:11px}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=800px){.grid-4{grid-template-columns:repeat(2,1fr)}.grid-2{grid-template-columns:1fr}}.empty-state{color:var(--muted);text-align:center;padding:40px 20px;font-size:13px}.tag{align-items:center;gap:var(--space-xs);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:all var(--transition-fast);border:1px solid;border-radius:99px;padding:4px 12px;font-size:10px;font-weight:700;display:inline-flex}.tag:hover{transform:translateY(-1px)}.tag-primary{color:var(--primary-light);background:#6366f11f;border-color:#6366f140}.tag-success{color:var(--success);background:#10b9811f;border-color:#10b98140}.tag-warn{color:var(--warning);background:#f59e0b1f;border-color:#f59e0b40}.dropzone{border:2px dashed var(--border-light);border-radius:var(--radius-lg);padding:var(--space-2xl);text-align:center;cursor:pointer;transition:all var(--transition-base);background:linear-gradient(135deg,#6366f105 0%,#0000 100%);flex-direction:column;justify-content:center;align-items:center;min-height:240px;display:flex;position:relative;overflow:hidden}.dropzone:before{content:"";opacity:0;transition:opacity var(--transition-base);pointer-events:none;background:radial-gradient(circle,#6366f11a 0%,#0000 70%);position:absolute;inset:0}.dropzone:hover,.dropzone.drag-over{border-color:var(--primary);background:linear-gradient(135deg,#6366f114 0%,#22d3ee0a 100%)}.dropzone:hover:before,.dropzone.drag-over:before{opacity:1}.dropzone-icon{width:44px;height:44px;color:var(--primary);margin-bottom:var(--space-lg);animation:3s ease-in-out infinite float}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.dropzone-title{margin-bottom:var(--space-sm);font-size:15px;font-weight:700}.dropzone-sub{color:var(--muted);font-size:12px}.progress-bar{background:#ffffff0f;border-radius:99px;height:6px;overflow:hidden;box-shadow:inset 0 2px 4px #0003}.progress-fill{background:var(--primary);border-radius:99px;height:100%;transition:width .4s}.spinner{background:conic-gradient(from 0deg, transparent 0deg, var(--primary) 120deg, var(--primary2) 240deg, var(--accent) 360deg);border-radius:50%;width:24px;height:24px;margin:0 auto;animation:.9s cubic-bezier(.45,0,.35,1) infinite spin;-webkit-mask:radial-gradient(farthest-side,#0000 calc(100% - 3px),#fff calc(100% - 3px));mask:radial-gradient(farthest-side,#0000 calc(100% - 3px),#fff calc(100% - 3px))}@keyframes spin{to{transform:rotate(360deg)}}.model-test-page{flex-direction:column;gap:16px;height:100%;padding:20px 24px;display:flex}.model-test-header{justify-content:space-between;align-items:center;display:flex}.model-test-header-left{align-items:center;gap:12px;display:flex}.model-test-title{margin:0;font-size:18px;font-weight:800}.model-test-status{text-transform:uppercase;letter-spacing:.04em;color:var(--danger);background:#ef44441f;border-radius:99px;padding:3px 10px;font-size:10px;font-weight:700}.model-test-status.ready{color:var(--success);background:#10b9811f}.model-test-classes{color:var(--muted);background:var(--bg2);border-radius:99px;padding:3px 10px;font-size:11px}.model-test-body{flex:1;grid-template-columns:180px 1fr 1fr;gap:16px;min-height:0;display:grid}@media (width<=1000px){.model-test-body{grid-template-columns:140px 1fr}}@media (width<=700px){.model-test-body{grid-template-columns:1fr}}.model-test-sidebar{flex-direction:column;gap:4px;display:flex}.model-test-section-label{letter-spacing:.08em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-size:9px;font-weight:700}.model-test-type-list{flex-direction:column;gap:3px;display:flex}.model-test-type-btn{color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.model-test-type-btn:hover{background:var(--bg2);border-color:var(--border)}.model-test-type-btn.active{border-color:var(--primary);color:var(--primary2);background:#6366f11a}.model-test-type-icon{flex-shrink:0;width:16px;height:16px}.model-test-model-select{flex-direction:column;gap:3px;display:flex}.model-test-model-btn{color:var(--text2);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:space-between;align-items:center;width:100%;padding:8px 12px;font-size:11px;transition:all .15s;display:flex}.model-test-model-btn:hover:not(:disabled){background:var(--bg2);border-color:var(--border)}.model-test-model-btn.active{background:var(--surface);border-color:var(--border)}.model-test-model-btn.coming-soon{opacity:.5;cursor:not-allowed}.model-test-model-name{font-weight:600}.model-test-model-badge{text-transform:uppercase;letter-spacing:.04em;color:var(--primary2);background:#6366f11a;border-radius:99px;padding:2px 8px;font-size:8px;font-weight:700}.model-test-info-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;margin-top:12px;padding:12px}.model-test-info-row{flex-direction:column;gap:1px;margin-top:6px;display:flex}.model-test-info-row:first-of-type{margin-top:6px}.model-test-info-label{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:9px;font-weight:600}.model-test-info-val{color:var(--text2);word-break:break-all;font-size:11px}.model-test-history{flex-direction:column;gap:2px;max-height:200px;margin-top:16px;display:flex;overflow-y:auto}.model-test-history-item{cursor:pointer;border-radius:6px;justify-content:space-between;align-items:center;padding:5px 8px;font-size:11px;transition:background .1s;display:flex}.model-test-history-item:hover{background:var(--bg2)}.model-test-history-type{color:var(--text2);text-transform:capitalize;font-weight:600}.model-test-history-time{color:var(--muted);font-size:10px}.model-test-input-area,.model-test-result-area{flex-direction:column;gap:12px;min-height:0;display:flex;overflow-y:auto}.model-test-panel-header{color:var(--text2);border-bottom:1px solid var(--border);align-items:center;gap:8px;padding-bottom:8px;font-size:13px;font-weight:700;display:flex}.model-test-panel-icon{width:16px;height:16px;color:var(--primary)}.model-test-panel-desc{color:var(--muted);margin-left:auto;font-size:11px;font-weight:400}.test-dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;min-height:180px;padding:32px 20px;transition:all .2s;display:flex}.test-dropzone:hover,.test-dropzone.drag-over{border-color:var(--primary);background:#6366f10d}.test-dropzone.has-preview{border-style:solid;border-color:var(--border);cursor:default;min-height:auto;padding:8px}.test-dropzone-body{flex-direction:column;align-items:center;gap:8px;display:flex}.test-dropzone-icon{width:36px;height:36px;color:var(--primary);opacity:.7}.test-dropzone-title{font-size:14px;font-weight:700}.test-dropzone-sub{color:var(--muted);font-size:11px}.test-preview-img{border-radius:8px;max-width:100%;max-height:260px;display:block}.test-file-info{flex-direction:column;align-items:center;gap:6px;padding:12px;display:flex}.test-input-actions{gap:8px;display:flex}.test-btn{cursor:pointer;border:none;border-radius:8px;justify-content:center;align-items:center;gap:6px;padding:8px 16px;font-size:12px;font-weight:600;transition:all .15s;display:inline-flex}.test-btn-primary{background:var(--primary);color:#fff;width:100%}.test-btn-primary:hover:not(:disabled){opacity:.85}.test-btn-primary:disabled{opacity:.4;cursor:not-allowed}.test-btn-outline{border:1px solid var(--border);color:var(--text2);background:0 0}.test-btn-outline:hover{border-color:var(--primary);color:var(--primary2)}.test-btn-ghost{color:var(--muted);background:0 0;padding:4px 8px}.test-btn-ghost:hover{color:var(--text2);background:var(--bg2)}.test-text-area{flex-direction:column;gap:8px;display:flex}.test-text-toolbar{gap:4px;display:flex}.test-text-mode-btn{border:1px solid var(--border);color:var(--muted);cursor:pointer;background:0 0;border-radius:6px;padding:4px 12px;font-size:11px;font-weight:600;transition:all .15s}.test-text-mode-btn.active{background:var(--surface);border-color:var(--primary);color:var(--primary2)}.test-text-mode-btn:hover:not(.active){color:var(--text2)}.test-textarea{border:1px solid var(--border);background:var(--bg2);width:100%;min-height:160px;color:var(--text2);resize:vertical;border-radius:8px;padding:12px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.6;transition:border-color .15s}.test-textarea:focus{border-color:var(--primary);outline:none}.test-textarea::placeholder{color:var(--muted);font-style:italic}.test-text-stats{color:var(--muted);justify-content:space-between;font-size:10px;display:flex}.test-audio-player,.test-video-player{margin-top:8px}.test-result-loading{flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.test-result-loading-text{color:var(--muted);font-size:13px}.test-result-error{background:#ef44440a;border:1px solid #ef44441a;border-radius:12px;flex-direction:column;justify-content:center;align-items:center;gap:8px;padding:40px 20px;display:flex}.test-result-error-icon{width:36px;height:36px;color:var(--danger);background:#ef44441a;border-radius:50%;justify-content:center;align-items:center;font-size:18px;font-weight:900;display:flex}.test-result-error-text{color:var(--danger);text-align:center;font-size:13px}.test-result-empty{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;font-size:13px;display:flex}.test-result-empty-icon{opacity:.4;width:36px;height:36px}.test-result-content{flex-direction:column;gap:16px;display:flex}.test-result-prediction{text-align:center;background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:24px 16px}.test-result-label{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px;font-size:10px;font-weight:700}.test-result-class{color:var(--primary2);margin-bottom:4px;font-size:26px;font-weight:900;line-height:1.2}.test-result-confidence{justify-content:center;align-items:center;gap:6px;display:flex}.test-result-conf-pct{color:var(--text2);font-family:JetBrains Mono,monospace;font-size:20px;font-weight:800}.test-result-conf-label{color:var(--muted);font-size:12px}.test-result-bars{padding:12px 0}.test-result-bars-title{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px;font-size:11px;font-weight:700}.test-bar-item{margin-bottom:8px}.test-bar-header{justify-content:space-between;margin-bottom:3px;display:flex}.test-bar-label{font-size:12px;font-weight:600}.test-bar-pct{color:var(--primary2);font-family:JetBrains Mono,monospace;font-size:11px}.test-bar-track{background:#ffffff14;border-radius:99px;height:6px}.test-bar-fill{background:linear-gradient(90deg, var(--primary), var(--accent));border-radius:99px;height:100%;transition:width .5s}.test-bar-fill.top{background:linear-gradient(90deg, var(--primary2), var(--accent))}.test-result-meta{color:var(--muted);justify-content:space-between;align-items:center;gap:8px;padding:8px 0;font-size:11px;display:flex}.test-result-raw{background:var(--bg2);border:1px solid var(--border);color:var(--text2);white-space:pre-wrap;word-break:break-all;border-radius:8px;max-height:200px;padding:12px;font-family:JetBrains Mono,monospace;font-size:11px;overflow-y:auto}.test-code-templates{flex-direction:column;gap:6px;display:flex}.test-code-templates-label{text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-size:10px;font-weight:700}.test-code-templates-list{flex-wrap:wrap;gap:4px;display:flex}.test-code-template-btn{background:var(--surface);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:6px;padding:4px 10px;font-size:10px;font-weight:600;transition:all .15s}.test-code-template-btn:hover{border-color:var(--primary);color:var(--primary2);background:#6366f10f}.test-textarea-code{tab-size:2;font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;line-height:1.5}.test-code-lang-hint{color:var(--muted);font-size:10px}.test-code-prompt-hint{color:var(--muted);background:#6366f10a;border:1px solid #6366f11a;border-radius:8px;align-items:center;gap:6px;padding:8px 12px;font-size:11px;display:flex}.test-web-url-row{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;align-items:center;gap:10px;margin-bottom:10px;padding:10px 14px;transition:border-color .15s;display:flex}.test-web-url-row:focus-within{border-color:var(--accent)}.test-url-input{color:var(--text);font-size:13px;font-family:var(--font-mono,monospace);background:0 0;border:none;outline:none;flex:1}.test-url-input::placeholder{color:var(--muted)}.test-web-examples{flex-wrap:wrap;align-items:center;gap:6px;margin-bottom:10px;display:flex}.test-multimodal-label{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:6px;margin-bottom:6px;font-size:11px;font-weight:600;display:flex}.test-dropzone-sm{min-height:100px;padding:12px}.test-dropzone-sm .test-dropzone-body{gap:6px}.chart-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px}.chart-title{color:var(--text2);justify-content:space-between;align-items:center;margin-bottom:12px;font-size:12px;font-weight:700;display:flex}.chart-canvas{width:100%;height:200px}.dataset-grid{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;display:grid}.img-thumb{aspect-ratio:1;cursor:pointer;border:1px solid var(--border);border-radius:8px;transition:border-color .2s;position:relative;overflow:hidden}.img-thumb:hover{border-color:var(--primary)}.img-thumb img{object-fit:cover;width:100%;height:100%}.img-thumb-del{color:#fff;cursor:pointer;z-index:2;background:#dc2626d9;border:none;border-radius:50%;justify-content:center;align-items:center;width:22px;height:22px;font-size:11px;line-height:1;transition:background .15s;display:none;position:absolute;top:4px;right:4px}.img-thumb:hover .img-thumb-del{display:flex}.img-thumb-del:hover{background:#b91c1c}.ds-file-list{flex-direction:column;gap:4px;margin-top:8px;display:flex}.ds-file-row{background:var(--bg2);border:1px solid var(--border);color:var(--text2);border-radius:6px;align-items:center;gap:8px;padding:6px 10px;font-size:12px;display:flex}.ds-file-row:hover{border-color:var(--primary);color:var(--text)}.ds-file-ext{letter-spacing:.04em;color:var(--primary);text-align:center;background:#6366f11f;border-radius:3px;min-width:36px;padding:1px 4px;font-size:10px;font-weight:600}.ds-file-name{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.ds-file-size{color:var(--text3);text-align:right;min-width:50px;font-size:10px}.ds-file-del{width:22px;height:22px;color:var(--text3);cursor:pointer;background:0 0;border:none;border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;transition:background .15s,color .15s;display:flex}.ds-file-del:hover{color:#ef4444;background:#dc262626}.model-item{background:var(--bg2);border-radius:10px;align-items:center;gap:12px;margin-bottom:8px;padding:12px;display:flex}.model-icon{width:36px;height:36px;color:var(--primary);background:#6366f11a;border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.model-info{flex:1;min-width:0}.model-name{font-size:13px;font-weight:700}.model-meta{color:var(--muted);font-size:11px}.model-badge{border-radius:99px;padding:3px 8px;font-size:9px;font-weight:700}.model-badge.active{color:var(--success);background:#10b98126}.model-badge.idle{color:var(--text2);background:#ffffff14}.weight-item{background:var(--surface);border:1px solid var(--border);border-radius:12px;margin-bottom:12px;padding:16px}.weight-name{margin-bottom:8px;font-size:13px;font-weight:700}.weight-stats{flex-wrap:wrap;gap:16px;margin-bottom:10px;display:flex}.weight-stat{color:var(--text2);font-size:11px}.weight-stat span{color:var(--primary2);font-family:JetBrains Mono,monospace}.weight-hist{align-items:flex-end;gap:2px;height:60px;display:flex}.hist-bar{background:var(--primary);opacity:.6;border-radius:2px 2px 0 0;flex:1}.train-layout{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=700px){.train-layout{grid-template-columns:1fr}}.epoch-stats{gap:12px;margin-top:12px;display:flex}.epoch-stat{text-align:center;flex:1}.epoch-val{color:var(--text);font-family:JetBrains Mono,monospace;font-size:20px;font-weight:900}.epoch-lbl{color:var(--muted);text-transform:uppercase;font-size:10px}.sc-page{flex-direction:column;gap:16px;display:flex}.sc-panels{grid-template-columns:1fr 1fr;gap:16px;display:grid}@media (width<=860px){.sc-panels{grid-template-columns:1fr}}.sc-panel{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:16px;padding:20px;display:flex}.sc-panel-header{justify-content:space-between;align-items:center;display:flex}.sc-panel-title{color:var(--text);align-items:center;gap:7px;font-size:14px;font-weight:700;display:flex}.sc-panel-icon{font-size:17px;line-height:1}.sc-panel-sub{color:var(--muted);font-size:11px;font-weight:400}.sc-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.sc-dot-idle{background:var(--muted);opacity:.5}.sc-dot-active{background:#f59e0b;animation:1.2s ease-in-out infinite dot-pulse}.sc-dot-done{background:var(--success)}.sc-dot-error{background:var(--danger)}@keyframes dot-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.8)}}.sc-form{flex-direction:column;gap:10px;display:flex}.sc-label{letter-spacing:.06em;text-transform:uppercase;color:var(--text2);align-items:center;gap:6px;margin-bottom:5px;font-size:10px;font-weight:700;display:flex}.sc-field{flex-direction:column;display:flex}.sc-row{align-items:flex-end;gap:10px;display:flex}.sc-checkbox{color:var(--text2);cursor:pointer;white-space:nowrap;align-items:center;gap:6px;padding-bottom:10px;font-size:12px;display:flex}.sc-range-ticks{color:var(--muted);justify-content:space-between;margin-top:2px;font-size:10px;display:flex}.sc-range-ticks .active{color:var(--primary2);font-weight:700}.sc-qty-badge{color:var(--primary2);background:#6366f126;border-radius:99px;margin-left:auto;padding:1px 7px;font-size:11px;font-weight:700}.sc-btn-row{gap:8px;display:flex}.sc-mode-toggle{background:var(--surface2);border:1px solid var(--border);border-radius:10px;gap:4px;margin-bottom:4px;padding:4px;display:flex}.sc-mode-btn{cursor:pointer;color:var(--text2);background:0 0;border:none;border-radius:7px;flex:1;justify-content:center;align-items:center;gap:6px;padding:7px 10px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.sc-mode-btn:hover:not(:disabled){color:var(--text);background:var(--surface3)}.sc-mode-btn.active{background:var(--surface);color:var(--primary2);box-shadow:0 1px 4px #00000040}.sc-mode-btn:disabled{opacity:.45;cursor:not-allowed}.sc-url-tags-wrap{border:1px solid var(--border);background:var(--surface2);cursor:text;border-radius:10px;flex-wrap:wrap;align-items:center;gap:6px;min-height:42px;padding:7px 10px;transition:border-color .2s;display:flex}.sc-url-tags-wrap:focus-within{border-color:var(--primary)}.sc-url-tag{color:var(--primary2);white-space:nowrap;text-overflow:ellipsis;background:#6366f11f;border:1px solid #6366f14d;border-radius:6px;align-items:center;gap:5px;max-width:220px;padding:3px 8px 3px 7px;font-size:11px;font-weight:600;display:inline-flex;overflow:hidden}.sc-url-tag-host{text-overflow:ellipsis;overflow:hidden}.sc-url-tag-rm{cursor:pointer;color:var(--primary2);opacity:.6;background:0 0;border:none;border-radius:3px;flex-shrink:0;justify-content:center;align-items:center;padding:1px;display:flex}.sc-url-tag-rm:hover{opacity:1;background:#6366f133}.sc-url-inline-input{min-width:180px;color:var(--text);background:0 0;border:none;outline:none;flex:1;font-family:inherit;font-size:13px}.sc-url-inline-input::placeholder{color:var(--muted)}.sc-field-hint{color:var(--muted);margin:5px 0 0;font-size:11px;line-height:1.5}.sc-stats-row{flex-wrap:wrap;gap:8px;display:flex}.sc-chip{background:var(--surface2);border:1px solid var(--border);border-radius:8px;flex-direction:column;align-items:center;min-width:60px;padding:6px 12px;display:flex}.sc-chip-val{color:var(--text);font-family:JetBrains Mono,monospace;font-size:16px;font-weight:800}.sc-chip-label{color:var(--muted);margin-top:1px;font-size:10px}.sc-progress-wrap{flex-direction:column;gap:6px;display:flex}.sc-progress-bar{background:var(--surface2);border-radius:99px;flex:1;height:8px;overflow:hidden}.sc-progress-fill{background:linear-gradient(90deg, var(--primary), #818cf8);border-radius:99px;height:100%;transition:width .4s}.sc-progress-fill.done{background:linear-gradient(90deg, var(--success), #34d399)}.sc-progress-row{align-items:center;gap:8px;display:flex}.sc-progress-pct{color:var(--primary2);text-align:right;min-width:44px;font-family:JetBrains Mono,monospace;font-size:15px;font-weight:800}.sc-progress-label{color:var(--text2);font-size:12px}.sc-preview-wrap{border:1px solid var(--border);background:var(--surface);border-radius:10px;padding:12px}.sc-preview-header{color:var(--text);align-items:center;gap:7px;margin-bottom:10px;font-size:12px;font-weight:700;display:flex}.sc-preview-count{color:var(--primary2);background:#6366f11a;border-radius:99px;margin-left:auto;padding:1px 8px;font-size:11px;font-weight:600}.sc-preview-grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:6px;max-height:200px;display:grid;overflow-y:auto}.sc-preview-card{background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:8px;padding:8px 10px;font-size:10px;transition:border-color .15s;position:relative;overflow:hidden}.sc-preview-card:hover{border-color:var(--primary)}.sc-preview-type{text-transform:uppercase;letter-spacing:.04em;color:var(--primary2);margin-bottom:4px;font-size:9px;font-weight:700}.sc-preview-score{border-radius:3px;padding:0 5px;font-family:JetBrains Mono,monospace;font-size:9px;font-weight:800;position:absolute;top:6px;right:6px}.sc-preview-score.good{color:var(--success);background:#22c55e26}.sc-preview-score.mid{color:#f59e0b;background:#f59e0b26}.sc-preview-score.low{color:var(--danger);background:#ef444426}.sc-preview-text{color:var(--muted);text-overflow:ellipsis;word-break:break-all;max-height:60px;font-family:JetBrains Mono,monospace;font-size:9px;line-height:1.4;overflow:hidden}.sc-preview-lang{color:var(--primary2);background:#6366f11f;border-radius:3px;margin-top:4px;padding:0 5px;font-size:9px;font-weight:600;display:inline-block}.sc-preview-wm{opacity:.6;font-size:12px;position:absolute;bottom:4px;right:6px}.sc-live-feed{background:var(--bg);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:5px;max-height:140px;padding:10px 12px;display:flex;overflow:hidden auto}.sc-live-row{align-items:center;gap:7px;min-width:0;font-family:JetBrains Mono,monospace;font-size:11px;display:flex}.sc-live-text{color:var(--text2);text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.sc-live-text.muted{color:var(--muted)}.sc-live-row.feed-done .sc-live-text{color:var(--success)}.sc-live-row.feed-warn .sc-live-text{color:#f59e0b}.sc-live-row.feed-error .sc-live-text{color:var(--danger)}.sc-results{border-top:1px solid var(--border);flex-direction:column;gap:10px;padding-top:14px;display:flex}.sc-results-header{color:var(--text);align-items:center;gap:7px;font-size:13px;font-weight:600;display:flex}.sc-results-title{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.sc-source-tag{color:var(--primary2);background:#6366f11f;border-radius:99px;flex-shrink:0;padding:2px 7px;font-size:10px}.sc-img-grid{grid-template-columns:repeat(auto-fill,minmax(60px,1fr));gap:5px;display:grid}.sc-img-thumb{aspect-ratio:1;object-fit:cover;border:1px solid var(--border);border-radius:6px;width:100%}.sc-img-more{aspect-ratio:1;background:var(--surface2);border:1px solid var(--border);color:var(--muted);border-radius:6px;justify-content:center;align-items:center;font-size:11px;font-weight:700;display:flex}.sc-markdown-box{color:var(--muted);font-size:11px}.sc-markdown-box summary{cursor:pointer;color:var(--text2);margin-bottom:6px;font-weight:600}.sc-markdown-box pre{background:var(--bg);white-space:pre-wrap;word-break:break-word;border-radius:6px;max-height:160px;padding:10px;overflow:auto}.sc-error-msg{color:var(--danger);align-items:center;gap:7px;font-size:13px;display:flex}.sc-sendbar{background:var(--surface);border:1px solid var(--border);border-radius:14px;flex-direction:column;gap:14px;padding:18px 20px;display:flex}.sc-sendbar-title{color:var(--text);align-items:center;gap:7px;font-size:13px;font-weight:700;display:flex}.sc-sendbar-actions{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}@media (width<=680px){.sc-sendbar-actions{grid-template-columns:1fr}}.sc-dest{border:1px solid var(--border);background:var(--surface2);border-radius:10px;flex-direction:column;gap:12px;padding:14px 16px;transition:border-color .2s;display:flex}.sc-dest.configured{border-color:#6366f140}.sc-dest.unconfigured{opacity:.6}.sc-dest-info{color:var(--text2);align-items:flex-start;gap:10px;display:flex}.sc-dest-name{color:var(--text);font-size:12px;font-weight:700;line-height:1.3}.sc-dest-status{color:var(--muted);text-overflow:ellipsis;align-items:center;gap:5px;margin-top:2px;font-size:11px;display:flex;overflow:hidden}.sc-flash{border-radius:8px;align-items:center;gap:8px;padding:10px 14px;font-size:12px;font-weight:600;display:flex}.sc-flash.ok{color:var(--success);background:#22c55e1a;border:1px solid #22c55e33}.sc-flash.err{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.layer-table{border-collapse:collapse;width:100%}.layer-table th{color:var(--muted);text-align:left;border-bottom:1px solid var(--border);padding:8px;font-size:10px}.layer-table td{border-top:1px solid #ffffff0a;padding:8px;font-size:12px}.colab-btn{color:#000;background:linear-gradient(135deg,#f9ab00,#e37400)}.cm-wrap{overflow-x:auto}.cm-table{border-collapse:collapse;font-size:12px}.cm-table th,.cm-table td{border:1px solid var(--border);text-align:center;padding:6px 10px}.cm-table th{color:var(--muted);font-size:10px;font-weight:600}input[type=range]{appearance:none;background:var(--surface2);border-radius:3px;outline:none;width:100%;height:6px}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;background:var(--primary);cursor:pointer;border-radius:50%;width:16px;height:16px}.toast-container{z-index:9999;flex-direction:column;gap:10px;display:flex;position:fixed;top:20px;right:20px}.toast{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:12px;align-items:flex-start;gap:10px;min-width:280px;padding:14px 18px;animation:.35s cubic-bezier(.34,1.56,.64,1) toast-in;display:flex;box-shadow:0 8px 32px #00000080}@keyframes toast-in{0%{opacity:0;transform:translateY(16px)scale(.96)}to{opacity:1;transform:translateY(0)scale(1)}}.hamburger{cursor:pointer;color:var(--text2);background:0 0;border:none;padding:4px;display:none}@media (width<=900px){.hamburger{display:block}}.react-flow__node{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:10px;font-size:12px}.react-flow__node-input,.react-flow__node-default,.react-flow__node-output{border-radius:8px;padding:10px}.react-flow__handle{background:var(--primary);width:8px;height:8px}.notebook-page{gap:0;height:100%;display:flex;position:relative}.nb-sidebar{border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;width:240px;display:flex;overflow:hidden}.nb-sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.nb-sidebar-title{text-transform:uppercase;letter-spacing:.05em;color:var(--muted);font-size:11px;font-weight:700}.nb-btn-sm{background:var(--surface2);width:28px;height:28px;color:var(--text2);cursor:pointer;border:none;border-radius:6px;justify-content:center;align-items:center;font-size:16px;transition:all .15s;display:flex}.nb-btn-sm:hover,.nb-btn-sm.primary{background:var(--primary);color:#fff}.nb-new-form{border-bottom:1px solid var(--border);padding:8px 12px}.nb-new-input{background:var(--bg2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:6px;outline:none;padding:8px 10px;font-size:12px}.nb-new-input:focus{border-color:var(--primary)}.nb-new-actions{gap:6px;margin-top:6px;display:flex}.nb-new-actions .nb-btn-sm{flex:1;font-size:11px;font-weight:600}.nb-list{flex:1;padding:8px;overflow-y:auto}.nb-item{cursor:pointer;border-radius:8px;align-items:center;gap:8px;margin-bottom:2px;padding:8px 10px;transition:all .15s;display:flex}.nb-item:hover{background:#ffffff0a}.nb-item.active{background:#6366f11f}.nb-item-icon{width:16px;height:16px;color:var(--primary2);flex-shrink:0}.nb-item-info{flex:1;min-width:0}.nb-item-name{text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.nb-item-meta{color:var(--muted);font-size:10px}.nb-item-del{color:var(--muted);cursor:pointer;opacity:0;background:0 0;border:none;border-radius:4px;padding:2px 4px;font-size:11px;transition:all .15s}.nb-item:hover .nb-item-del{opacity:1}.nb-item-del:hover{color:var(--danger);background:#ef44441a}.nb-empty{color:var(--muted);text-align:center;padding:32px 16px;font-size:12px}.nb-main{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.nb-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 20px;display:flex}.nb-toolbar-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.nb-title-input{color:var(--text);background:0 0;border:1px solid #0000;border-radius:6px;outline:none;width:auto;min-width:120px;max-width:300px;padding:4px 8px;font-size:16px;font-weight:700}.nb-title-input:focus{border-color:var(--border);background:var(--bg2)}.nb-kernel-badge{color:var(--muted);white-space:nowrap;white-space:nowrap;background:#ffffff0d;border-radius:99px;align-items:center;gap:5px;padding:3px 8px;font-size:10px;font-weight:600;display:inline-flex}.nb-kernel-badge:before{content:"";opacity:.4;background:currentColor;border-radius:50%;width:6px;height:6px}.nb-kernel-badge.active{color:var(--success);background:#10b9811f}.nb-kernel-badge.active:before{content:"";opacity:1;background:#22c55e;animation:2s ease-in-out infinite pulse-dot;box-shadow:0 0 6px #22c55e}.nb-toolbar-right{align-items:center;gap:6px;display:flex}.nb-cell-count{color:var(--muted);white-space:nowrap;margin-right:8px;font-size:11px}.nb-tool-btn{background:var(--surface2);color:var(--text2);cursor:pointer;white-space:nowrap;border:none;border-radius:6px;padding:6px 12px;font-size:11px;font-weight:600;transition:all .15s}.nb-tool-btn:hover{color:var(--text);background:#ffffff14}.nb-tool-btn.colab{color:#000;background:linear-gradient(135deg,#f9ab00,#e37400)}.nb-tool-btn:disabled{opacity:.5;cursor:default}.nb-colab-url{background:#10b98114;border-bottom:1px solid #10b98133;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 20px;font-size:12px;display:flex}.nb-colab-url a{color:var(--primary2);font-family:JetBrains Mono,monospace;font-size:11px}.nb-cells{flex-direction:column;flex:1;align-items:center;gap:16px;padding:20px 24px 40px;display:flex;overflow-y:auto}.nb-cells>*{width:100%;max-width:900px}.nb-export-row{justify-content:center;align-items:center;gap:12px;width:100%;max-width:900px;margin:0 auto;padding:16px 24px 8px;display:flex}.nb-export-hint{color:var(--muted);font-size:12px}.code-cell{background:var(--surface);border:1px solid var(--border);border-radius:12px;transition:border-color .2s,box-shadow .2s}.code-cell>.cell-body>.cell-gutter:first-child{border-top-left-radius:11px;border-bottom-left-radius:11px}.code-cell>.cell-output:last-child{border-bottom-right-radius:11px;border-bottom-left-radius:11px}.code-cell:hover{border-color:#ffffff1f;box-shadow:0 2px 12px #0003}.code-cell.is-running{border-color:#6366f180;box-shadow:0 0 0 3px #6366f114}.cell-body{align-items:stretch;display:flex}.cell-gutter{background:var(--bg2);border-right:1px solid var(--border);flex-direction:column;flex-shrink:0;align-items:center;gap:8px;width:52px;padding:12px 0 8px;display:flex;overflow:visible}.cell-run-btn{border:2px solid var(--primary);width:32px;height:32px;color:var(--primary2);cursor:pointer;background:0 0;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:11px;transition:color .2s,background .2s,border-color .2s,transform .15s;display:flex;position:relative}.cell-run-btn:hover:not(:disabled){background:#6366f126;transform:scale(1.08)}.cell-run-btn.ok{color:var(--success);border-color:var(--success)}.cell-run-btn.error{color:var(--danger);border-color:var(--danger)}.cell-run-btn.idle{color:var(--muted);border-color:var(--border)}.cell-run-btn.running{color:#0000;cursor:default;border-color:#0000}.cell-run-btn.running:before{content:"";border:2px solid #6366f140;border-top-color:var(--primary2);z-index:1;border-radius:50%;animation:.7s linear infinite spin;position:absolute;inset:0}.cell-run-btn.running:after{content:"■";color:var(--primary2);z-index:2;font-size:9px;position:absolute}.cell-exec-count{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700}.cell-content{flex-direction:column;flex:1;min-width:0;display:flex}.cell-topbar{border-bottom:1px solid #ffffff0a;justify-content:space-between;align-items:center;min-height:30px;padding:4px 10px 4px 12px;display:flex}.cell-topbar-right{flex-shrink:0;align-items:center;gap:6px;display:flex}.cell-title-input{color:var(--text2);background:0 0;border:none;border-radius:4px;outline:none;flex:1;min-width:0;padding:2px 6px;font-size:12px;font-weight:500}.cell-title-input:focus{color:var(--text);background:#ffffff0a}.cell-title-input::placeholder{color:var(--muted)}.cell-elapsed{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:10px}.cell-btn{cursor:pointer;border:none;border-radius:5px;padding:4px 10px;font-size:11px;font-weight:600;transition:all .15s}.cell-btn.del{color:var(--muted);background:0 0;padding:4px 6px}.cell-btn.del:hover{color:var(--danger);background:#ef44441a}.cell-editor{min-height:80px}.cell-editor .cm-editor{height:auto!important}.cell-editor .cm-scroller{height:auto!important;max-height:none!important;overflow:auto!important}.cell-editor .cm-content{min-height:64px}.cell-output{background:#0000002e;border-top:2px solid #6366f12e;animation:.18s output-appear;display:flex}@keyframes output-appear{0%{opacity:0;transform:translateY(-3px)}to{opacity:1;transform:translateY(0)}}.cell-output-gutter{border-right:1px solid #ffffff0d;flex-direction:column;flex-shrink:0;align-items:center;width:52px;padding:10px 0 8px;display:flex}.cell-output-num{color:var(--muted);font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700}.cell-output-num.ok{color:var(--success)}.cell-output-num.err{color:var(--danger)}.cell-output-body{flex:1;min-width:0;max-height:600px;font-family:JetBrains Mono,monospace;font-size:13px;line-height:1.65;overflow:auto}.cell-stdout{color:#e8eaed;white-space:pre-wrap;word-break:break-word;margin:0;padding:10px 16px}.cell-stderr{color:var(--warning);white-space:pre-wrap;word-break:break-word;background:#f59e0b0d;margin:0;padding:10px 16px}.cell-error{color:#f28b82;white-space:pre-wrap;word-break:break-word;background:#ef444412;border-left:3px solid #ef444480;margin:0;padding:10px 16px}.cell-empty-msg{color:var(--success);opacity:.75;padding:10px 16px;font-size:12px}.nb-empty-cells{color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:60px 20px;display:flex}.nb-empty-icon{opacity:.5;margin-bottom:12px;font-size:48px}.nb-sidebar-section{border-top:1px solid var(--border);padding:8px}.nb-sidebar-section-header{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;justify-content:space-between;align-items:center;padding:4px 6px;font-size:11px;font-weight:700;display:flex}.nb-elems-stats{padding:4px 6px}.nb-elem-row{color:var(--text2);justify-content:space-between;padding:3px 0;font-size:11px;display:flex}.nb-elem-val{color:var(--primary2);font-family:JetBrains Mono,monospace;font-weight:700}.nb-elem-source{color:var(--muted);font-size:10px}.nb-dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--bg2);border-radius:12px;width:calc(100% - 48px);max-width:900px;margin:8px auto;padding:16px 20px;transition:all .2s}.nb-dropzone:hover,.nb-dropzone.drag-over{border-color:var(--primary);background:#6366f10f}.nb-dropzone-icon{margin-bottom:8px;font-size:32px}.nb-dropzone-title{color:var(--text2);margin-bottom:4px;font-size:13px;font-weight:700}.nb-dropzone-sub{color:var(--muted);margin-bottom:12px;font-size:11px}.nb-empty-main{height:100%;color:var(--muted);text-align:center;flex-direction:column;justify-content:center;align-items:center;padding:40px;display:flex}.nb-empty-main h3{color:var(--text2);margin-bottom:8px;font-size:18px}.nb-empty-main p{max-width:360px;font-size:13px}.toast-nb{z-index:9999;background:var(--surface);color:var(--success);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid #10b9814d;border-radius:10px;padding:12px 20px;font-size:13px;font-weight:600;animation:.35s cubic-bezier(.34,1.56,.64,1) toast-in;position:fixed;top:20px;right:20px;box-shadow:0 8px 32px #00000080}.toast-nb.toast-error{color:var(--danger);border-color:#ef44444d}.nb-colab-panel{border-top:2px solid var(--primary);background:var(--surface);flex-shrink:0}.nb-colab-panel-header{background:var(--bg2);justify-content:space-between;align-items:center;padding:10px 20px;font-size:13px;font-weight:700;display:flex}.nb-colab-close{color:var(--muted);cursor:pointer;background:0 0;border:none;border-radius:4px;padding:2px 6px;font-size:14px}.nb-colab-close:hover{color:var(--text)}.nb-colab-panel-body{padding:16px 20px}.nb-colab-actions{flex-direction:column;gap:12px;display:flex}.nb-colab-desc{color:var(--text2);font-size:13px;line-height:1.5}.nb-colab-buttons{gap:8px;display:flex}.nb-colab-progress{flex-direction:column;gap:6px;display:flex}.nb-colab-status-row{align-items:center;gap:8px;font-size:12px;display:flex}.nb-colab-label{color:var(--muted);min-width:70px;font-weight:600}.nb-colab-value{color:var(--text2);font-family:JetBrains Mono,monospace}.nb-colab-value.active{color:var(--warning)}.nb-colab-value.done{color:var(--success)}@media (width<=900px){.nb-sidebar{display:none}.nb-toolbar{flex-direction:column;align-items:stretch}.nb-toolbar-right{flex-wrap:wrap}}.sc-url-tags-wrap.disabled{opacity:.6;pointer-events:none}.sc-two-col{grid-template-columns:1fr 1fr;gap:12px;display:grid}@media (width<=600px){.sc-two-col{grid-template-columns:1fr}}.input-mono{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px}.input-sm{width:70px;padding:5px 9px;font-size:12px}.sc-tipo-grid{grid-template-columns:repeat(4,1fr);gap:6px;display:grid}.sc-tipo-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:8px;flex-direction:column;align-items:center;gap:5px;padding:10px 8px;font-size:11px;font-weight:600;transition:all .15s;display:flex}.sc-tipo-btn:hover{border-color:var(--primary);color:var(--text)}.sc-tipo-btn.active{border-color:var(--primary);color:var(--primary2);background:#6366f11f}.sc-tipo-btn span:first-child{font-size:18px}.sc-delay-row{align-items:center;gap:8px;margin-top:4px;display:flex}.sc-delay-input{align-items:center;gap:6px;display:flex}.sc-delay-label{color:var(--muted);font-size:11px}.sc-delay-sep{color:var(--muted);font-size:14px}.sc-options-row{flex-direction:column;gap:8px;display:flex}.sc-export-btns{gap:6px;display:flex}.sc-export-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text2);cursor:pointer;border-radius:7px;padding:6px 16px;font-family:JetBrains Mono,monospace;font-size:12px;font-weight:700;transition:all .15s}.sc-export-btn:hover{border-color:var(--primary);color:var(--text)}.sc-export-btn.active{border-color:var(--primary);color:var(--primary2);background:#6366f11f}.sc-search-label-row{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.sc-caps-badges{flex-wrap:wrap;gap:5px;display:flex}.sc-cap-badge{letter-spacing:.02em;border-radius:999px;align-items:center;gap:4px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-flex}.sc-cap-trad{color:#818cf8;background:#6366f126;border:1px solid #6366f14d}.sc-cap-clip{color:#34d399;background:#10b9811f;border:1px solid #10b9814d}.sc-cap-js{color:#fb923c;background:#fb923c1f;border:1px solid #fb923c4d}.sc-cap-off{color:var(--muted);background:#64748b1a;border:1px solid #64748b33}.sc-search-wrap{align-items:center;display:flex;position:relative}.sc-search-icon{color:var(--muted);pointer-events:none;flex-shrink:0;position:absolute;left:11px}.sc-search-input{width:100%;padding-left:34px!important;padding-right:32px!important}.sc-search-clear{color:var(--muted);cursor:pointer;background:0 0;border:none;padding:0 2px;font-size:16px;line-height:1;position:absolute;right:10px}.sc-search-clear:hover{color:var(--text)}.sc-search-hint{color:var(--primary2);opacity:.85;margin-top:5px;font-size:11px}.sc-export-done{color:var(--success);background:#22c55e14;border:1px solid #22c55e33;border-radius:7px;align-items:center;gap:6px;padding:6px 12px;font-size:11px;display:flex}.sc-export-done code{color:var(--text2);font-family:JetBrains Mono,monospace}.ds-page{flex-direction:column;gap:14px;display:flex}.cdlg-backdrop{z-index:9999;background:#00000059;justify-content:center;align-items:center;animation:.15s both cdlg-in;display:flex;position:fixed;inset:0}@keyframes cdlg-in{0%{opacity:0}to{opacity:1}}.cdlg{background:var(--card,#0d1117);border:1px solid var(--border,#ffffff14);border-radius:14px;flex-direction:column;gap:18px;width:360px;max-width:calc(100vw - 32px);padding:28px 28px 22px;animation:.18s cubic-bezier(.16,1,.3,1) both cdlg-up;display:flex;box-shadow:0 24px 60px #0009}@keyframes cdlg-up{0%{opacity:0;transform:translateY(10px)scale(.97)}to{opacity:1;transform:translateY(0)scale(1)}}.cdlg-icon{color:#ef4444;background:#ef44441f;border:1px solid #ef444438;border-radius:50%;justify-content:center;align-items:center;width:44px;height:44px;display:flex}.cdlg-body{flex-direction:column;gap:6px;display:flex}.cdlg-title{color:var(--text);font-size:15px;font-weight:600}.cdlg-msg{color:var(--text2);font-size:13px;line-height:1.55}.cdlg-fname{color:var(--text);word-break:break-all;background:#ffffff0f;border-radius:4px;padding:1px 5px;font-family:monospace;font-size:12px}.cdlg-sub{color:var(--text3);font-size:12px}.cdlg-actions{justify-content:flex-end;gap:8px;display:flex}.cdlg-btn{cursor:pointer;border:1px solid #0000;border-radius:8px;padding:7px 18px;font-size:13px;font-weight:500;transition:background .15s,border-color .15s}.cdlg-btn-cancel{border-color:var(--border,#ffffff1a);color:var(--text2);background:0 0}.cdlg-btn-cancel:hover{color:var(--text);background:#ffffff0f}.cdlg-btn-del{color:#fff;background:#ef4444;border-color:#ef4444}.cdlg-btn-del:hover{background:#dc2626;border-color:#dc2626}.ds-type-tabs{background:var(--surface);border:1px solid var(--border);border-radius:12px;gap:3px;padding:4px;display:flex;overflow-x:auto}.ds-type-tab{cursor:pointer;white-space:nowrap;min-width:0;color:var(--muted);background:0 0;border:none;border-radius:8px;flex:1;justify-content:center;align-items:center;gap:5px;padding:8px 10px;font-size:12px;font-weight:600;transition:all .15s;display:flex}.ds-type-tab.active{color:var(--primary2);background:#6366f126}.ds-type-tab.soon{opacity:.5}.ds-soon-badge{letter-spacing:.07em;color:#6366f18c;margin-left:2px;font-size:7px;font-weight:800}.ds-summary{background:var(--surface);border:1px solid var(--border);border-radius:12px;justify-content:space-between;align-items:center;gap:14px;padding:14px 18px;display:flex}.ds-summary-left{align-items:center;gap:13px;display:flex}.ds-summary-icon{width:40px;height:40px;color:var(--primary2);background:#6366f11a;border:1px solid #6366f12e;border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;display:flex}.ds-summary-name{color:var(--text);font-size:14px;font-weight:700}.ds-summary-meta{color:var(--muted);flex-wrap:wrap;align-items:center;gap:5px;margin-top:3px;font-size:12px;display:flex}.ds-meta-dot{color:var(--border)}.ds-dl-btn{cursor:pointer;background:var(--primary);color:#fff;border:none;border-radius:8px;flex-shrink:0;align-items:center;gap:6px;padding:8px 18px;font-size:12px;font-weight:700;transition:opacity .15s;display:inline-flex}.ds-dl-btn:hover:not(:disabled){opacity:.85}.ds-dl-btn:disabled{opacity:.5;cursor:default}.ds-main-grid{grid-template-columns:1fr 300px;align-items:start;gap:14px;display:grid}@media (width<=900px){.ds-main-grid{grid-template-columns:1fr}}.ds-class-pills{flex-wrap:wrap;gap:6px;margin-bottom:14px;display:flex}.ds-class-pill-wrap{border:1px solid var(--border);background:var(--surface);border-radius:99px;align-items:center;gap:0;transition:border-color .18s;display:inline-flex;overflow:hidden}.ds-class-pill-wrap:hover{border-color:#6366f166}.ds-class-pill-wrap.active{border-color:var(--primary);background:#6366f126}.ds-class-pill-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;align-items:center;gap:6px;padding:5px 10px 5px 14px;font-size:11px;font-weight:600;transition:color .18s;display:inline-flex}.ds-class-pill-wrap:hover .ds-class-pill-btn,.ds-class-pill-wrap.active .ds-class-pill-btn{color:var(--primary2)}.ds-class-pill-del{color:var(--muted);cursor:pointer;opacity:0;background:0 0;border:none;justify-content:center;align-items:center;padding:5px 9px 5px 3px;transition:color .15s,opacity .15s;display:flex}.ds-class-pill-wrap:hover .ds-class-pill-del{opacity:1}.ds-class-pill-del:hover{color:#f87171}.ds-class-count{background:var(--surface2);color:var(--muted);border-radius:99px;padding:1px 7px;font-size:10px;font-weight:700}.ds-class-pill-wrap.active .ds-class-count{color:var(--primary2);background:#6366f138}.ds-explorer-meta{color:var(--muted);margin-bottom:10px;font-size:12px}.ds-coming-soon{text-align:center;flex-direction:column;align-items:center;padding:50px 20px;display:flex}.ds-coming-emoji{opacity:.35;margin-bottom:12px;font-size:42px}.ds-coming-title{color:var(--text);margin-bottom:6px;font-size:14px;font-weight:700}.ds-coming-sub{color:var(--muted);max-width:220px;font-size:12px;line-height:1.65}.ds-explorer-card{flex-direction:column;gap:0;display:flex}.ds-exp-header{border-bottom:1px solid var(--border);flex-direction:column;gap:5px;margin-bottom:14px;padding-bottom:14px;display:flex}.ds-exp-title{color:var(--text);align-items:center;gap:7px;font-size:13px;font-weight:700;display:flex}.ds-exp-stats{color:var(--muted);align-items:center;gap:6px;font-size:11px;display:flex}.ds-exp-stat strong{color:var(--text2)}.ds-exp-stat-sep{color:var(--border)}.ds-exp-stat-active{color:var(--primary2);font-weight:600}.ds-exp-classes-label{letter-spacing:.07em;text-transform:uppercase;color:var(--muted);align-items:center;gap:8px;margin-bottom:8px;font-size:9px;font-weight:700;display:flex}.ds-exp-pagination{align-items:center;gap:4px;margin-left:auto;display:flex}.ds-page-btn{background:var(--surface2);width:22px;height:22px;color:var(--text2);cursor:pointer;border:none;border-radius:4px;justify-content:center;align-items:center;transition:all .12s;display:flex}.ds-page-btn:hover:not(:disabled){background:var(--surface3);color:var(--text)}.ds-page-btn:disabled{opacity:.35;cursor:default}.ds-page-info{color:var(--text);text-align:center;min-width:36px;font-family:JetBrains Mono,monospace;font-size:10px;font-weight:700}.ds-exp-empty{color:var(--muted);text-align:center;flex-direction:column;align-items:center;gap:10px;padding:40px 16px;font-size:12px;display:flex}.ds-exp-loading{justify-content:center;padding:32px 0;display:flex}.ds-upload-card{flex-direction:column;gap:12px;display:flex}.ds-field{flex-direction:column;gap:5px;display:flex}.ds-field-label{color:var(--muted);letter-spacing:.06em;text-transform:uppercase;font-size:10px;font-weight:700}.ds-input{box-sizing:border-box;background:var(--bg2);border:1px solid var(--border);width:100%;color:var(--text);border-radius:8px;outline:none;padding:8px 12px;font-size:13px;transition:border-color .15s}.ds-input:focus{border-color:var(--primary)}.ds-dropzone{border:2px dashed var(--border);text-align:center;cursor:pointer;background:var(--bg2);-webkit-user-select:none;user-select:none;border-radius:10px;padding:26px 16px;transition:all .2s}.ds-dropzone.drag{border-color:var(--primary);background:#6366f10f}.ds-drop-emoji{margin-bottom:8px;font-size:26px}.ds-drop-icon{color:var(--muted);opacity:.6;margin-bottom:10px}.ds-drop-title{color:var(--text2);margin-bottom:4px;font-size:13px;font-weight:700}.ds-drop-formats{color:var(--muted);font-size:10px}.ds-type-grid{grid-template-columns:repeat(3,1fr);gap:5px;display:grid}.ds-type-card{border:1px solid var(--border);background:var(--surface);color:var(--muted);cursor:pointer;letter-spacing:.02em;border-radius:8px;flex-direction:column;align-items:center;gap:5px;padding:9px 6px;font-size:10px;font-weight:600;transition:all .15s;display:flex}.ds-type-card:hover{color:var(--text2);border-color:#6366f166}.ds-type-card.active{border-color:var(--primary);color:var(--primary2);background:#6366f11f}.ds-type-card svg{opacity:.65;transition:opacity .15s}.ds-type-card:hover svg,.ds-type-card.active svg{opacity:1}.ds-import-hint{color:var(--muted);background:var(--surface2);border:1px solid var(--border);border-radius:7px;align-items:flex-start;gap:6px;padding:8px 10px;font-size:11px;line-height:1.5;display:flex}.ds-import-hint svg{opacity:.6;flex-shrink:0;margin-top:1px}.ds-uploading-row{color:var(--muted);align-items:center;gap:8px;font-size:12px;display:flex}.ds-feedback{border-radius:7px;padding:8px 12px;font-size:12px;font-weight:600}.ds-feedback.ok{color:var(--success);background:#10b9811a;border:1px solid #10b98133}.ds-feedback.err{color:var(--danger);background:#ef44441a;border:1px solid #ef444433}.ds-formats-info{background:var(--surface2);border:1px solid var(--border);border-radius:8px;margin-top:2px;padding:10px 12px}.ds-formats-label{letter-spacing:.07em;text-transform:uppercase;color:var(--muted);margin-bottom:4px;font-size:9px;font-weight:700}.ds-formats-list{color:var(--text2);font-size:11px;line-height:1.6}.ds-scraper-banner{color:var(--primary2);background:#6366f114;border:1px solid #6366f133;border-radius:8px;align-items:center;gap:8px;margin-bottom:12px;padding:8px 12px;font-size:12px;font-weight:500;display:flex}.ds-scraper-clase{background:#6366f126;border-radius:99px;margin-left:4px;padding:2px 8px;font-size:11px}.ds-scraper-live-badge{color:var(--success);letter-spacing:.05em;background:#22c55e1a;border:1px solid #22c55e40;border-radius:99px;align-items:center;gap:5px;margin-left:8px;padding:2px 8px;font-size:10px;font-weight:700;display:inline-flex}.toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:10px;align-items:center;gap:10px;min-width:260px;max-width:420px;padding:12px 18px;font-size:13px;font-weight:500;animation:.25s toast-in;display:flex;box-shadow:0 4px 24px #00000059}.toast-icon{flex-shrink:0;font-size:14px}.toast-msg{line-height:1.4}.toast-done{color:#34d399;background:#10b9812e;border:1px solid #10b98166}.toast-error{color:#f87171;background:#ef44442e;border:1px solid #ef444466}.toast-warn{color:#fbbf24;background:#f59e0b2e;border:1px solid #f59e0b66}.toast-info{color:#a5b4fc;background:#6366f12e;border:1px solid #6366f166}.skeleton{background:linear-gradient(110deg, var(--surface2) 22%, #ffffff14 42%, var(--surface2) 62%);border-radius:var(--radius-md);background-size:300% 100%;animation:2s ease-in-out infinite skeleton-shimmer}.skeleton-card{border-radius:10px}.skeleton-chart{border-radius:var(--radius-md)}.skeleton-graph{border-radius:var(--radius-lg)}.skeleton-image{border-radius:8px}@keyframes skeleton-shimmer{0%{background-position:300% 0}to{background-position:-300% 0}}.sk-inner{flex-direction:column;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.sk-card-accent{background:linear-gradient(90deg, var(--primary), var(--primary2), var(--accent));opacity:.35;border-radius:10px 10px 0 0;height:3px;position:absolute;top:0;left:0;right:0}.sk-card-body{flex:1;justify-content:space-between;align-items:center;gap:16px;padding:16px 20px;display:flex}.sk-card-left{flex-direction:column;flex:1;gap:10px;display:flex}.sk-card-icon{background:#ffffff0f;border-radius:10px;flex-shrink:0;width:38px;height:38px}.sk-line{background:#ffffff12;border-radius:6px;height:10px}.sk-line-sm{width:40%;height:8px}.sk-line-md{width:70%;height:10px}.sk-line-lg{width:55%;height:24px}.sk-line-label{width:30%;height:8px}.sk-line-value{width:50%;height:24px}.sk-line-sub{height:9px}.sk-chart-y{flex-direction:column;justify-content:space-between;width:24px;display:flex;position:absolute;top:8%;bottom:10%;left:6px}.sk-tick{background:#ffffff12;border-radius:2px;width:16px;height:3px}.sk-chart-main{flex:1;margin:6% 6px 0 32px;position:relative;overflow:hidden}.sk-grid-line{background:#ffffff0d;height:1px;position:absolute;left:0;right:0}.sk-chart-wave{width:100%;height:100%;position:absolute;inset:0}.sk-chart-x{justify-content:space-between;padding:4px 6px 0 32px;display:flex}.sk-chart-x .sk-tick{width:3px;height:8px}.sk-graph-wrap{justify-content:center;align-items:center;gap:0;padding:0 12%;display:flex;position:relative}.sk-graph-col{z-index:1;flex-direction:column;align-items:center;gap:14px;display:flex}.sk-circle{background:#ffffff14;border:1px solid #ffffff0f;border-radius:50%;width:28px;height:28px}.sk-circle-sm{width:20px;height:20px}.sk-circle-xs{width:16px;height:16px}.sk-graph-lines{flex:1;min-width:40px;height:120px;position:relative}.sk-graph-line{background:#ffffff14;height:1px;position:absolute;left:0;right:0}.sk-graph-label{color:#ffffff26;text-transform:uppercase;letter-spacing:.06em;font-size:9px;font-weight:600;position:absolute;bottom:10%}.sk-image-icon{justify-content:center;align-items:center;width:100%;height:100%;display:flex}.sk-image-icon svg{opacity:.3;width:36px;height:36px}.sk-table-row{flex-direction:row;align-items:center;gap:12px;padding:0 16px}.status-dot.loading{background:linear-gradient(135deg, var(--primary), var(--primary2));box-shadow:0 0 6px var(--primary);animation:1.2s ease-in-out infinite pulse-dot}@keyframes pulse-dot{0%,to{opacity:.35;transform:scale(.7)}50%{opacity:1;transform:scale(1.1)}}.react-flow{direction:ltr}.react-flow__container{width:100%;height:100%;position:absolute;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1px;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;animation:.5s linear infinite dashdraw}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{-webkit-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:0 0;pointer-events:none}.react-flow__nodesselection-rect{pointer-events:all;cursor:-webkit-grab;cursor:grab;position:absolute}.react-flow__handle{pointer-events:none;background:#1a192b;border:1px solid #fff;border-radius:100%;width:6px;min-width:5px;height:6px;min-height:5px;position:absolute}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;bottom:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-top{top:-4px;left:50%;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{top:50%;right:-4px;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{z-index:5;margin:15px;position:absolute}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{background:#ffffff80;margin:0;padding:2px 3px;font-size:10px}.react-flow__attribution a{color:#999;text-decoration:none}@keyframes dashdraw{0%{stroke-dashoffset:10px}}.react-flow__edgelabel-renderer{pointer-events:none;-webkit-user-select:none;user-select:none;width:100%;height:100%;position:absolute}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{color:#222;text-align:center;background-color:#fff;border:1px solid #1a192b;border-radius:3px;width:150px;padding:10px;font-size:12px}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted #0059dccc}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{box-sizing:content-box;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fefefe;border:none;border-bottom:1px solid #eee;justify-content:center;align-items:center;width:16px;height:16px;padding:5px;display:flex}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{background-color:#3367d9;border:1px solid #fff;border-radius:1px;width:4px;height:4px;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{top:50%;left:0}.react-flow__resize-control.handle.right{top:50%;left:100%}.react-flow__resize-control.handle.top{top:0;left:50%}.react-flow__resize-control.handle.bottom{top:100%;left:50%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border:0 solid #3367d9}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;height:100%;top:0;transform:translate(-50%)}.react-flow__resize-control.line.left{border-left-width:1px;left:0}.react-flow__resize-control.line.right{border-right-width:1px;left:100%}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{width:100%;height:1px;left:0;transform:translateY(-50%)}.react-flow__resize-control.line.top{border-top-width:1px;top:0}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}
