:root{--brand-h:235;--brand-50:oklch(.97 .04 var(--brand-h));--brand-100:oklch(.93 .08 var(--brand-h));--brand-200:oklch(.87 .12 var(--brand-h));--brand-300:oklch(.8 .16 var(--brand-h));--brand-400:oklch(.72 .18 var(--brand-h));--brand-500:oklch(.62 .2 var(--brand-h));--brand-600:oklch(.52 .18 var(--brand-h));--brand-700:oklch(.42 .16 var(--brand-h));--brand-800:oklch(.32 .12 var(--brand-h));--brand-900:oklch(.22 .08 var(--brand-h));--n-0:oklch(100% 0 0);--n-25:oklch(99% .003 230);--n-50:oklch(98% .005 230);--n-75:oklch(97% .006 230);--n-100:oklch(95% .008 230);--n-150:oklch(92% .01 230);--n-200:oklch(90% .012 230);--n-300:oklch(84% .012 230);--n-400:oklch(70% .012 230);--n-500:oklch(58% .012 230);--n-600:oklch(46% .012 230);--n-700:oklch(36% .012 230);--n-800:oklch(24% .014 230);--n-900:oklch(16% .014 230);--n-950:oklch(10% .014 230);--emerald-100:oklch(93% .06 155);--emerald-500:oklch(68% .17 155);--emerald-700:oklch(48% .13 155);--amber-100:oklch(95% .06 80);--amber-500:oklch(78% .16 75);--amber-700:oklch(55% .14 60);--rose-100:oklch(95% .04 25);--rose-500:oklch(68% .18 25);--rose-700:oklch(50% .16 25);--sky-100:oklch(95% .04 230);--sky-500:oklch(70% .13 230);--sky-700:oklch(50% .12 230);--violet-100:oklch(95% .04 295);--violet-500:oklch(66% .18 295);--violet-700:oklch(48% .16 295);--bg-app:var(--n-50);--bg-surface:var(--n-0);--bg-sunken:var(--n-75);--bg-hover:var(--n-100);--border:var(--n-150);--border-strong:var(--n-200);--text:var(--n-900);--text-muted:var(--n-600);--text-subtle:var(--n-500);--accent:var(--brand-600);--accent-hover:var(--brand-700);--accent-bg:var(--brand-50);--font-sans:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-display:"Inter Tight", "Inter", sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--r-sm:6px;--r-md:10px;--r-lg:14px;--r-xl:20px;--r-full:999px;--sh-xs:0 1px 2px #0f171e0a;--sh-sm:0 1px 2px #0f171e0a, 0 2px 4px #0f171e0a;--sh-md:0 2px 4px #0f171e0a, 0 4px 12px #0f171e0f;--sh-lg:0 4px 8px #0f171e0f, 0 12px 32px #0f171e14;--sh-xl:0 8px 16px #0f171e14, 0 24px 56px #0f171e1f;--sh-focus:0 0 0 4px oklch(.62 .2 var(--brand-h) / .18);--sidebar-w:248px;--topbar-h:60px;--topbar-bg:oklch(100% 0 0/.85);--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light}:root[data-theme=dark]{--lightningcss-light: ;--lightningcss-dark:initial;color-scheme:dark;--bg-app:oklch(17% .01 230);--bg-surface:oklch(20.5% .012 230);--bg-sunken:oklch(15% .01 230);--bg-hover:oklch(26% .014 230);--border:oklch(28% .014 230);--border-strong:oklch(34% .016 230);--text:oklch(96% .006 230);--text-muted:oklch(74% .012 230);--text-subtle:oklch(60% .012 230);--topbar-bg:oklch(20.5% .012 230/.82);--brand-50:oklch(.27 .05 var(--brand-h));--brand-100:oklch(.33 .07 var(--brand-h));--brand-700:oklch(.74 .15 var(--brand-h));--accent:oklch(.7 .17 var(--brand-h));--accent-hover:oklch(.78 .15 var(--brand-h));--accent-bg:var(--brand-50);--emerald-100:oklch(30% .06 155);--emerald-700:oklch(82% .14 155);--amber-100:oklch(32% .06 75);--amber-700:oklch(84% .14 85);--rose-100:oklch(30% .07 25);--rose-700:oklch(80% .15 25);--sky-100:oklch(30% .05 230);--sky-700:oklch(82% .12 230);--violet-100:oklch(31% .07 295);--violet-700:oklch(82% .14 295);--sh-xs:0 1px 2px #00000052;--sh-sm:0 1px 2px #00000052, 0 2px 4px #00000047;--sh-md:0 2px 4px #00000052, 0 4px 12px #0000005c;--sh-lg:0 4px 8px #0000005c, 0 12px 32px #00000070;--sh-xl:0 8px 16px #0006, 0 24px 56px #00000085}:root[data-theme=dark] .badge-grey{background:var(--bg-hover);color:var(--text-muted)}:root[data-theme=dark] .pub-shell{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;--bg-app:var(--n-50);--bg-surface:var(--n-0);--bg-sunken:var(--n-75);--bg-hover:var(--n-100);--border:var(--n-150);--border-strong:var(--n-200);--text:var(--n-900);--text-muted:var(--n-600);--text-subtle:var(--n-500);--brand-50:oklch(.97 .04 var(--brand-h));--brand-100:oklch(.93 .08 var(--brand-h));--brand-700:oklch(.42 .16 var(--brand-h));--accent:oklch(.52 .18 var(--brand-h));--accent-hover:oklch(.42 .16 var(--brand-h));--accent-bg:var(--brand-50);--emerald-100:oklch(93% .06 155);--emerald-700:oklch(48% .13 155);--amber-100:oklch(95% .06 80);--amber-700:oklch(55% .14 60);--rose-100:oklch(95% .04 25);--rose-700:oklch(50% .16 25);--sky-100:oklch(95% .04 230);--sky-700:oklch(50% .12 230);--violet-100:oklch(95% .04 295);--violet-700:oklch(48% .16 295);--sh-xs:0 1px 2px #0f171e0a;--sh-sm:0 1px 2px #0f171e0a, 0 2px 4px #0f171e0a;--sh-md:0 2px 4px #0f171e0a, 0 4px 12px #0f171e0f;--sh-lg:0 4px 8px #0f171e0f, 0 12px 32px #0f171e14;--sh-xl:0 8px 16px #0f171e14, 0 24px 56px #0f171e1f}*{box-sizing:border-box}html,body{font-family:var(--font-sans);color:var(--text);background:var(--bg-app);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:-.005em;margin:0;padding:0;font-size:14px;line-height:1.5}body,#root{min-height:100vh}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;background:0 0;border:none;padding:0}a{color:var(--brand-700);text-decoration:none}a:hover{color:var(--brand-800)}svg{display:block}.app{grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh;display:grid}.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);flex-direction:column;height:100vh;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:18px 20px;display:flex}.brand-mark{background:linear-gradient(135deg, var(--brand-500), var(--brand-700));color:#fff;width:30px;height:30px;font-family:var(--font-display);box-shadow:var(--sh-sm), inset 0 1px 0 #fff3;border-radius:8px;place-items:center;font-size:15px;font-weight:700;display:grid}.brand-name{font-family:var(--font-display);letter-spacing:-.02em;font-size:16px;font-weight:600}.brand-plan{border-radius:var(--r-full);background:var(--brand-50);color:var(--brand-700);text-transform:uppercase;letter-spacing:.04em;margin-left:auto;padding:2px 7px;font-size:10px;font-weight:600}.sidebar-project{border-bottom:1px solid var(--border);padding:12px}.project-card{border-radius:var(--r-md);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .12s;display:flex}.project-card:hover{background:var(--bg-hover)}.project-avatar{background:linear-gradient(135deg, var(--violet-500), var(--rose-500));color:#fff;border-radius:7px;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:11px;font-weight:700;display:grid}.project-info{flex:1;min-width:0}.project-name{white-space:nowrap;text-overflow:ellipsis;font-size:13px;font-weight:600;overflow:hidden}.project-role{color:var(--text-muted);font-size:11px}.sidebar-nav{flex-direction:column;flex:1;gap:1px;padding:12px 8px;display:flex;overflow-y:auto}.nav-section{letter-spacing:.08em;color:var(--text-subtle);text-transform:uppercase;margin-top:14px;margin-bottom:4px;padding:0 12px;font-size:10px;font-weight:600}.nav-section:first-child{margin-top:0}.nav-item{color:var(--text-muted);cursor:pointer;border-radius:7px;align-items:center;gap:10px;padding:7px 12px;font-size:13px;font-weight:500;text-decoration:none;transition:all .12s;display:flex}.nav-item:hover{background:var(--bg-hover);color:var(--text)}.nav-item.active{background:var(--bg-hover);color:var(--text);font-weight:600}.nav-item.active .nav-icon{color:var(--brand-600)}.nav-icon{width:16px;height:16px;color:var(--text-subtle);flex-shrink:0;place-items:center;display:grid}.nav-badge{border-radius:var(--r-full);background:var(--brand-100);color:var(--brand-700);margin-left:auto;padding:1px 6px;font-size:10px;font-weight:600}.sidebar-footer{border-top:1px solid var(--border);padding:12px}.user-card{border-radius:var(--r-md);cursor:pointer;text-align:left;background:0 0;border:none;align-items:center;gap:10px;width:100%;padding:8px 10px;transition:background .12s;display:flex}.user-card:hover{background:var(--bg-hover)}.user-avatar{color:#fff;background:linear-gradient(135deg,oklch(65% .13 250),oklch(50% .15 290));border-radius:50%;flex-shrink:0;place-items:center;width:30px;height:30px;font-size:11px;font-weight:600;display:grid}.user-info{flex:1;min-width:0}.user-name{white-space:nowrap;text-overflow:ellipsis;font-size:12.5px;font-weight:600;overflow:hidden}.user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:11px;overflow:hidden}.main{flex-direction:column;min-width:0;display:flex}.topbar{height:var(--topbar-h);border-bottom:1px solid var(--border);z-index:10;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:var(--topbar-bg);align-items:center;gap:14px;padding:0 24px;display:flex;position:sticky;top:0}.crumbs{color:var(--text-muted);align-items:center;gap:8px;font-size:13px;display:flex}.crumbs .crumb-current{color:var(--text);font-weight:600}.crumbs .sep{color:var(--text-subtle)}.topbar-search{border-radius:var(--r-md);border:1px solid var(--border);background:var(--bg-sunken);cursor:pointer;flex:1;align-items:center;gap:8px;max-width:420px;margin-left:16px;padding:7px 8px 7px 11px;font-size:13px;transition:all .12s;display:flex}.topbar-search:hover{border-color:var(--border-strong);background:var(--bg-surface)}.topbar-search .search-ico{color:var(--text-subtle);flex-shrink:0}.topbar-search-placeholder{text-align:left;color:var(--text-subtle);flex:1}.topbar-search kbd{font-family:var(--font-mono);border:1px solid var(--border-strong);color:var(--text-muted);background:var(--bg-surface);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:10px}.cmdk-overlay{justify-content:center;align-items:flex-start;padding-top:12vh}.cmdk{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);width:100%;max-width:580px;box-shadow:var(--sh-lg,0 16px 48px #0000002e);flex-direction:column;display:flex;overflow:hidden}.cmdk-input-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:14px 16px;display:flex}.cmdk-input-ico{color:var(--text-subtle);flex-shrink:0}.cmdk-input{color:var(--text);background:0 0;border:none;outline:none;flex:1;font-size:15px}.cmdk-input::placeholder{color:var(--text-subtle)}.cmdk-esc{font-family:var(--font-mono);border:1px solid var(--border-strong);color:var(--text-muted);background:var(--bg-sunken);border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:10px}.cmdk-results{max-height:52vh;padding:6px;overflow-y:auto}.cmdk-group{padding:4px 0}.cmdk-group-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-subtle);padding:6px 10px 4px;font-size:10px;font-weight:600}.cmdk-item{border-radius:var(--r-md);cursor:pointer;text-align:left;width:100%;color:var(--text);background:0 0;border:none;align-items:center;gap:11px;padding:8px 10px;display:flex}.cmdk-item.selected{background:var(--bg-hover)}.cmdk-item-ico{color:var(--text-muted);flex-shrink:0;display:flex}.cmdk-item.selected .cmdk-item-ico{color:var(--brand-500)}.cmdk-item-text{flex-direction:column;flex:1;gap:1px;min-width:0;display:flex}.cmdk-item-label{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;overflow:hidden}.cmdk-item-sub{color:var(--text-subtle);white-space:nowrap;text-overflow:ellipsis;font-size:11.5px;overflow:hidden}.cmdk-item-enter{color:var(--text-subtle);flex-shrink:0}.cmdk-empty{text-align:center;color:var(--text-subtle);padding:28px 16px;font-size:13px}.topbar-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.icon-btn{border-radius:var(--r-md);width:32px;height:32px;color:var(--text-muted);background:0 0;place-items:center;transition:all .12s;display:grid;position:relative}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.content{width:100%;max-width:1480px;margin:0 auto;padding:28px 32px 60px}.h1{font-family:var(--font-display);letter-spacing:-.025em;margin:0;font-size:26px;font-weight:600}.h2{font-family:var(--font-display);letter-spacing:-.015em;margin:0;font-size:18px;font-weight:600}.h3{font-family:var(--font-display);letter-spacing:-.01em;margin:0;font-size:14px;font-weight:600}.muted{color:var(--text-muted)}.subtle{color:var(--text-subtle)}.mono{font-family:var(--font-mono)}.page-header{align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.page-header-text{flex:1;min-width:0}.page-header-text p{color:var(--text-muted);margin:4px 0 0;font-size:13px}.page-header-actions{gap:8px;display:flex}.btn{border-radius:var(--r-md);white-space:nowrap;letter-spacing:-.005em;border:1px solid #0000;justify-content:center;align-items:center;gap:6px;padding:7px 13px;font-size:13px;font-weight:600;transition:all .12s;display:inline-flex}.btn-primary{background:var(--brand-600);color:#fff;box-shadow:var(--sh-xs), inset 0 1px 0 #ffffff26}.btn-primary:hover{background:var(--brand-700);box-shadow:var(--sh-sm), inset 0 1px 0 #ffffff26;color:#fff}.btn-secondary{background:var(--bg-surface);color:var(--text);border-color:var(--border-strong);box-shadow:var(--sh-xs)}.btn-secondary:hover{background:var(--bg-hover);border-color:var(--border-strong)}.btn-ghost{color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-hover);color:var(--text)}.btn-danger{background:var(--bg-surface);color:var(--rose-700);border-color:var(--border-strong)}.btn-danger:hover{background:var(--rose-100);border-color:var(--rose-500)}.btn-sm{padding:5px 10px;font-size:12px}.btn-lg{padding:9px 16px;font-size:14px}.btn:disabled,.btn[aria-disabled=true]{opacity:.5;cursor:not-allowed;box-shadow:none;filter:saturate(.55)}.btn-primary:disabled,.btn-primary:disabled:hover,.btn-primary[aria-disabled=true]{background:var(--brand-600);color:#fff;box-shadow:none}.btn-secondary:disabled,.btn-secondary:disabled:hover,.btn-secondary[aria-disabled=true]{background:var(--bg-surface);border-color:var(--border-strong);box-shadow:none}.card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--sh-xs)}.card-pad{padding:20px}.card-pad-sm{padding:14px}.card-head{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:16px 20px;display:flex}.card-head-title{flex:1}.card-head h2{font-size:14px}.card-head p{color:var(--text-muted);margin:2px 0 0;font-size:12px}.badge{border-radius:var(--r-full);letter-spacing:.005em;white-space:nowrap;align-items:center;gap:5px;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-dot{background:currentColor;border-radius:50%;width:6px;height:6px}.badge-green{background:var(--emerald-100);color:var(--emerald-700)}.badge-amber{background:var(--amber-100);color:var(--amber-700)}.badge-rose{background:var(--rose-100);color:var(--rose-700)}.badge-sky{background:var(--sky-100);color:var(--sky-700)}.badge-violet{background:var(--violet-100);color:var(--violet-700)}.badge-grey{background:var(--n-100);color:var(--n-700)}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text);font-size:12px;font-weight:600}.field .hint{color:var(--text-muted);font-size:11.5px}.field input,.field textarea,.field select{border-radius:var(--r-md);border:1px solid var(--border-strong);background:var(--bg-surface);outline:none;padding:7px 11px;font-size:13px;transition:all .12s}.field input:focus,.field textarea:focus,.field select:focus{border-color:var(--brand-500);box-shadow:var(--sh-focus)}.field textarea{resize:vertical;min-height:70px}.table{border-collapse:separate;border-spacing:0;width:100%;font-size:13px}.table th{text-align:left;color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase;border-bottom:1px solid var(--border);background:var(--bg-sunken);padding:10px 14px;font-size:11.5px;font-weight:600}.table td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 14px}.table tr:last-child td{border-bottom:none}.table tr.row-hover:hover td{background:var(--bg-hover);cursor:pointer}.tabs{border-bottom:1px solid var(--border);gap:2px;display:flex}.tab{color:var(--text-muted);cursor:pointer;-webkit-user-select:none;user-select:none;background:0 0;border:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 14px;font-size:13px;font-weight:500;transition:all .12s}.tab:hover{color:var(--text)}.tab.active{color:var(--text);border-bottom-color:var(--brand-600);font-weight:600}.row{align-items:center;gap:8px;display:flex}.col{flex-direction:column;gap:8px;display:flex}.spacer{flex:1}.divider{background:var(--border);height:1px;margin:12px 0}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@keyframes pingloop-dot{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.4)}}.live-dot{background:var(--brand-500);width:8px;height:8px;box-shadow:0 0 0 4px var(--brand-100);border-radius:50%;animation:2s ease-in-out infinite pingloop-dot;display:inline-block}@keyframes fade-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.fade-in{animation:.3s ease-out fade-in}@keyframes spin{to{transform:rotate(360deg)}}.totp-qr>svg{width:100%;height:100%;display:block}.auth-shell{background:var(--bg-app);grid-template-columns:1fr 1fr;min-height:100vh;display:grid}.auth-form-side{background:var(--bg-surface);flex-direction:column;min-height:100vh;padding:32px 48px;display:flex}.auth-form-inner{flex-direction:column;flex:1;justify-content:center;width:100%;max-width:380px;margin:0 auto;display:flex}.auth-title{font-family:var(--font-display);letter-spacing:-.025em;margin:0 0 8px;font-size:26px;font-weight:600}.auth-subtitle{color:var(--text-muted);margin:0 0 28px;font-size:14px;line-height:1.5}.auth-brand-side{background:linear-gradient(135deg, var(--brand-700), var(--brand-900));color:#fff;flex-direction:column;justify-content:space-between;padding:48px;display:flex;position:relative;overflow:hidden}.auth-brand-side:before{content:"";background:radial-gradient(circle at 80% 10%, oklch(.5 .16 var(--brand-h) / .6), transparent 45%), radial-gradient(circle at 10% 90%, oklch(45% .18 295/.4), transparent 50%);pointer-events:none;position:absolute;inset:0}.auth-brand-side>*{z-index:1;position:relative}.auth-pitch h2{font-family:var(--font-display);letter-spacing:-.025em;max-width:420px;margin:0 0 14px;font-size:32px;font-weight:600;line-height:1.2}.auth-pitch p{opacity:.85;max-width:380px;margin:0;font-size:15px;line-height:1.55}@media (width<=900px){.auth-shell{grid-template-columns:1fr}.auth-brand-side{display:none}.auth-form-side{padding:32px 24px}}.onboarding-shell{background:var(--bg);place-items:center;min-height:100vh;padding:48px 24px;display:grid}.onboarding-inner{flex-direction:column;align-items:center;gap:40px;width:100%;max-width:720px;display:flex}.onboarding-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px;width:100%;display:grid}.onboarding-card{background:var(--card);border:1px solid var(--border);text-align:left;cursor:pointer;border-radius:14px;flex-direction:column;align-items:flex-start;gap:10px;padding:22px;transition:all .18s;display:flex}.onboarding-card:hover{border-color:var(--brand-400);transform:translateY(-1px);box-shadow:0 4px 16px #0000000d}.onboarding-card-icon{background:var(--brand-50);width:40px;height:40px;color:var(--brand-600);border-radius:10px;place-items:center;display:grid}.onboarding-card-title{color:var(--text);font-size:16px;font-weight:700}.onboarding-card-desc{color:var(--text-muted);font-size:13px;line-height:1.5}.alert{border-radius:var(--r-md);border:1px solid #0000;align-items:center;gap:10px;padding:10px 14px;font-size:13px;line-height:1.4;display:flex}.alert-danger{background:var(--rose-100);color:var(--rose-700);border-color:oklch(86% .07 25)}.alert-success{background:var(--emerald-100);color:var(--emerald-700);border-color:oklch(84% .08 155)}.alert-info{background:var(--brand-50);color:var(--brand-700,oklch(42% .18 235));border-color:var(--brand-100)}.field-error{color:var(--rose-700);font-size:11.5px;font-weight:500}.field input[aria-invalid=true],.field input.invalid{border-color:var(--rose-500)}.spin{animation:.8s linear infinite pingloop-spin}@keyframes pingloop-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.menu{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);min-width:200px;box-shadow:var(--sh-md,0 8px 24px #00000014);z-index:50;padding:4px;position:absolute;top:calc(100% + 6px);right:0}.menu-item{width:100%;color:var(--text);text-align:left;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:8px;padding:7px 10px;font-size:13px;display:flex}.menu-item:hover{background:var(--bg-hover)}.menu-item-danger{color:var(--rose-700)}.menu-divider{background:var(--border);height:1px;margin:4px 0}.uk-overlay{z-index:1000;-webkit-backdrop-filter:blur(2px);background:#14142d6b;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.uk-overlay-right{justify-content:flex-end;align-items:stretch;padding:0}.uk-modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);width:100%;box-shadow:var(--sh-xl);flex-direction:column;max-height:88vh;display:flex}.uk-drawer{background:var(--bg-surface);border-left:1px solid var(--border);flex-direction:column;height:100%;display:flex;box-shadow:-20px 0 60px -20px #14143c66}.uk-modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:20px 22px;display:flex}.uk-modal-title{font-family:var(--font-display);margin:0;font-size:18px;font-weight:600}.uk-modal-sub{color:var(--text-muted);margin-top:3px;font-size:12.5px}.uk-x{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-surface);width:32px;height:32px;color:var(--text-muted);cursor:pointer;flex:none;justify-content:center;align-items:center;display:flex}.uk-x:hover{background:var(--bg-hover);color:var(--text)}.uk-modal-body{flex-direction:column;gap:15px;padding:22px;display:flex;overflow-y:auto}.uk-drawer-body{flex-direction:column;flex:1;gap:16px;padding:22px;display:flex;overflow-y:auto}.uk-modal-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 22px;display:flex}.uk-field{flex-direction:column;gap:7px;display:flex}.uk-field-label{color:var(--text);font-size:12.5px;font-weight:700}.uk-field-hint{color:var(--text-muted);font-size:11.5px}.uk-field-err{color:var(--rose-700);font-size:11.5px;font-weight:600}.uk-input{color:var(--text);background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);outline:none;width:100%;padding:11px 13px;font-family:inherit;font-size:14px;transition:border-color .12s,box-shadow .12s}.uk-input:focus{border-color:var(--brand-500);box-shadow:var(--sh-focus)}.uk-input.invalid{border-color:var(--rose-500);box-shadow:0 0 0 3px var(--rose-100)}.uk-input::placeholder{color:var(--text-muted)}.uk-select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--text-muted) 50%), linear-gradient(135deg, var(--text-muted) 50%, transparent 50%);background-position:calc(100% - 17px) 18px,calc(100% - 12px) 18px;background-repeat:no-repeat;background-size:5px 5px,5px 5px;padding-right:34px}.uk-toast{z-index:1100;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--sh-lg);color:var(--text);align-items:center;gap:11px;padding:13px 18px;font-size:13.5px;font-weight:600;display:flex;position:fixed;bottom:24px;right:24px}.uk-toast-ic{display:flex}.uk-empty{text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:54px 30px;display:flex}.uk-empty-ic{background:var(--bg-hover);width:72px;height:72px;color:var(--text-muted);border-radius:22px;justify-content:center;align-items:center;display:flex}.uk-empty-title{font-family:var(--font-display);font-size:17px;font-weight:600}.uk-empty-text{color:var(--text-muted);max-width:320px;font-size:13.5px;line-height:1.55}.uk-skel{background:linear-gradient(90deg, var(--bg-hover) 25%, var(--border) 37%, var(--bg-hover) 63%);background-size:400% 100%;animation:1.4s infinite uk-shimmer}@keyframes uk-shimmer{0%{background-position:100% 0}to{background-position:-100% 0}}.uk-skel-row{border-bottom:1px solid var(--border);align-items:center;gap:13px;padding:14px 18px;display:flex}.uk-skel-row:last-child{border-bottom:none}.iconbtn{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-surface);width:40px;height:40px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;display:flex;position:relative}.iconbtn:hover{background:var(--bg-hover)}.iconbtn-sm{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-surface);width:30px;height:30px;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.iconbtn-sm:hover{background:var(--bg-hover);color:var(--text)}.tablecard{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-sm);overflow:auto hidden}table.tbl{border-collapse:collapse;width:100%}.tbl th{text-align:left;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);background:var(--bg-sunken);padding:13px 18px;font-size:11px;font-weight:700}.tbl td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px 18px;font-size:13.5px}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr{cursor:pointer;transition:background .1s}.tbl tbody tr:hover{background:var(--bg-hover)}.tbl tbody tr.sel{background:var(--brand-100)}.tbl tbody tr.checked{background:var(--brand-50)}.dg-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.dg-toolbar .spacer{flex:1}.dg-search{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);color:var(--text-muted);flex:0 280px;align-items:center;gap:8px;min-width:240px;padding:0 12px;display:flex}.dg-search input{color:var(--text);background:0 0;border:none;outline:none;width:100%;padding:8px 0;font-family:inherit;font-size:13px}.dg-count{color:var(--text-muted);font-size:12.5px;font-weight:600}.dg-popover-wrap{position:relative}.dg-popover{z-index:50;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--sh-lg);flex-direction:column;gap:4px;min-width:260px;padding:10px;display:flex;position:absolute;top:calc(100% + 6px);right:0}.dg-popover-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;margin-bottom:6px;padding:4px 6px 8px;display:flex}.dg-popover-head b{font-size:12.5px;font-weight:700}.dg-col-row{border-radius:var(--r-sm);cursor:pointer;align-items:center;gap:9px;padding:7px 8px;font-size:13px;display:flex}.dg-col-row:hover{background:var(--bg-hover)}.dg-col-row input{accent-color:var(--brand-500);cursor:pointer}.dg-col-search{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-surface);width:100%;color:var(--text);box-sizing:border-box;margin:2px 0 6px;padding:6px 10px;font-size:12.5px}.dg-col-search:focus{border-color:var(--brand-500);box-shadow:0 0 0 2px var(--brand-100);outline:none}.dg-col-list{flex-direction:column;gap:1px;max-height:240px;margin:0 -4px;padding:0 4px;display:flex;overflow-y:auto}.dg-col-empty{text-align:center;color:var(--text-muted);padding:12px 8px;font-size:12px}.dg-th{-webkit-user-select:none;user-select:none;position:relative}.dg-th-row{flex-wrap:nowrap;align-items:center;gap:6px;min-width:0;display:flex}.dg-th[style*="text-align: right"] .dg-th-row{justify-content:flex-end}.dg-th[style*="text-align: center"] .dg-th-row{justify-content:center}.dg-th-inner{align-items:center;gap:6px;min-width:0;display:inline-flex}.dg-th-label{white-space:nowrap;text-overflow:ellipsis;overflow:hidden}.dg-th.sortable .dg-th-inner{cursor:pointer}.dg-th-sort{color:var(--text-muted);flex-shrink:0;align-items:center;display:inline-flex}.dg-th.sort-active .dg-th-sort{color:var(--brand-500)}.dg-th-filter-wrap{flex-shrink:0;display:inline-flex;position:relative}.dg-th-filter{width:22px;height:22px;color:var(--text-muted);cursor:pointer;opacity:.7;background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;transition:opacity .12s,color .12s,background .12s;display:inline-flex}.dg-th-filter:hover{opacity:1;color:var(--text);background:var(--bg-surface)}.dg-th-filter.on{opacity:1;color:var(--brand-500);background:var(--brand-100)}.dg-filter-pop{z-index:40;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-sm);box-shadow:var(--sh-md);min-width:200px;padding:8px;position:absolute;top:calc(100% + 4px);left:0}.dg-filter-pop input{color:var(--text);background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--r-sm);outline:none;width:100%;padding:7px 10px;font-family:inherit;font-size:13px}.dg-filter-pop input:focus{border-color:var(--brand-500);box-shadow:var(--sh-focus)}.dg-filter-pop-foot{justify-content:space-between;margin-top:6px;display:flex}.dg-filter-clear{color:var(--text-muted);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:11.5px;font-weight:600}.dg-filter-clear:hover{color:var(--text)}.dg-actions{align-items:center;gap:6px;display:inline-flex}.dg-actions .iconbtn-sm.danger{color:var(--rose-500)}.dg-actions .iconbtn-sm.danger:hover{background:var(--rose-100);color:var(--rose-700);border-color:var(--rose-500)}.dg-toolbar .iconbtn.on{border-color:var(--brand-500);color:var(--brand-600);background:var(--brand-100)}.iconbtn-dot{background:var(--brand-500);border:2px solid var(--bg-surface);border-radius:999px;width:8px;height:8px;position:absolute;top:8px;right:8px}.dg-count-badge{background:var(--brand-500);color:#fff;border:2px solid var(--bg-surface);border-radius:999px;justify-content:center;align-items:center;min-width:16px;height:16px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:inline-flex;position:absolute;top:4px;right:4px}.dg-views-popover{min-width:280px}.dg-views-cols-head{margin-top:4px}.dg-view-row{align-items:center;gap:4px;margin:0 0 8px;display:flex}.dg-view-select{background-position:calc(100% - 14px),calc(100% - 9px);flex:1;min-width:0;padding:5px 28px 5px 8px;font-size:13px}.dg-view-rename-input{border:1px solid var(--brand-500);background:var(--bg-surface);color:var(--text);border-radius:4px;outline:none;flex:1;min-width:0;padding:5px 8px;font-size:13px}.iconbtn-sm.danger{color:var(--rose-500)}.iconbtn-sm.danger:hover{background:var(--rose-100);border-color:var(--rose-500)}.dg-adv{flex-direction:column;gap:12px;display:flex}.dg-adv-rule{grid-template-columns:1.2fr 1fr 1.5fr auto;align-items:center;gap:8px;display:grid}.dg-adv-rule .uk-input{padding:8px 10px;font-size:13px}.dg-adv-rule .dg-rule-del{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--bg-surface);width:32px;height:32px;color:var(--text-muted);cursor:pointer;justify-content:center;align-items:center;display:inline-flex}.dg-adv-rule .dg-rule-del:hover{background:var(--rose-100);color:var(--rose-700);border-color:var(--rose-500)}.dg-adv-empty{color:var(--text-muted);padding:8px 0;font-size:12.5px}.dg-pagination{border-top:1px solid var(--border);background:var(--bg-surface);color:var(--text-muted);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:10px 16px;font-size:12.5px;display:flex}.dg-pag-pagesize{align-items:center;gap:8px;display:inline-flex}.dg-pag-pagesize select{background-position:calc(100% - 12px),calc(100% - 7px);width:auto;padding:4px 24px 4px 8px;font-size:12.5px}.dg-pag-range{font-variant-numeric:tabular-nums}.dg-pag-nav{align-items:center;gap:4px;display:inline-flex}.dg-pag-page{font-variant-numeric:tabular-nums;color:var(--text);padding:0 8px;font-weight:600}.dg-pag-nav .iconbtn-sm:disabled{opacity:.4;cursor:not-allowed}.dg-bulkbar{background:var(--brand-100);border:1px solid var(--brand-500);border-radius:8px;align-items:center;gap:12px;margin-bottom:10px;padding:10px 14px;font-size:13px;display:flex}.dg-bulkbar .link{color:var(--brand-700);cursor:pointer;background:0 0;border:none;font-family:inherit;font-size:12.5px;font-weight:600;text-decoration:underline}.dg-mode-toggle{border:1px solid var(--border);border-radius:var(--r-sm);background:var(--bg-surface);display:inline-flex;overflow:hidden}.dg-mode-toggle button{color:var(--text-muted);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;padding:6px 10px;transition:background .12s,color .12s;display:inline-flex}.dg-mode-toggle button+button{border-left:1px solid var(--border)}.dg-mode-toggle button:hover{background:var(--bg-hover);color:var(--text)}.dg-mode-toggle button.on{background:var(--brand-100);color:var(--brand-600)}.dg-cards-wrap{padding-bottom:4px}.dg-cards{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;margin-bottom:14px;display:grid}.dg-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-sm);flex-direction:column;gap:12px;padding:16px 16px 12px;transition:box-shadow .12s,border-color .12s,transform .12s;display:flex;position:relative}.dg-card.clickable{cursor:pointer}.dg-card.clickable:hover{border-color:var(--brand-500);box-shadow:var(--sh-md)}.dg-card.sel{border-color:var(--brand-500);background:var(--brand-50)}.dg-card.checked{background:var(--brand-50)}.dg-card-body{flex-direction:column;gap:10px;min-width:0;display:flex}.dg-card-check{position:absolute;top:10px;left:10px}.dg-card-check input{accent-color:var(--brand-500);cursor:pointer}.dg-card-actions{border-top:1px solid var(--border);flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:6px;margin-top:auto;padding-top:10px;display:flex}.dg-card-actions .iconbtn-sm.danger{color:var(--rose-500)}.dg-card-actions .iconbtn-sm.danger:hover{background:var(--rose-100);color:var(--rose-700);border-color:var(--rose-500)}.docs-shell{grid-template-columns:240px minmax(0,1fr) 220px;align-items:start;gap:32px;max-width:1240px;margin:0 auto;display:grid}.docs-shell-sidebar{border-right:1px solid var(--border);max-height:calc(100vh - 100px);padding-right:6px;position:sticky;top:20px;overflow-y:auto}.docs-shell-main{min-width:0;max-width:760px}.docs-shell-toc{max-height:calc(100vh - 100px);position:sticky;top:20px;overflow-y:auto}@media (width<=1180px){.docs-shell{grid-template-columns:240px minmax(0,1fr)}.docs-shell-toc{display:none}}@media (width<=900px){.docs-shell{grid-template-columns:1fr;gap:20px}.docs-shell-sidebar{border-right:none;border-bottom:1px solid var(--border);max-height:none;padding-bottom:12px;padding-right:0;position:static}}.docs-search{margin-bottom:16px;position:relative}.docs-search-input{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-surface);width:100%;padding:8px 10px 8px 32px;font-size:12.5px;transition:border-color .15s,box-shadow .15s}.docs-search-input:focus{border-color:var(--brand-400);box-shadow:var(--sh-focus);outline:none}.docs-search-icon{color:var(--text-subtle);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.docs-search-kbd{font-family:var(--font-mono);color:var(--text-subtle);border:1px solid var(--border);background:var(--bg-sunken);pointer-events:none;border-radius:4px;padding:1px 5px;font-size:10px;position:absolute;top:50%;right:8px;transform:translateY(-50%)}.docs-search-results{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--sh-lg);z-index:20;max-height:340px;padding:4px;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow-y:auto}.docs-search-hit{border-radius:var(--r-sm);cursor:pointer;color:var(--text);padding:8px 10px;display:block}.docs-search-hit:hover,.docs-search-hit.selected{background:var(--brand-50);color:var(--text)}.docs-search-hit-title{margin-bottom:2px;font-size:12.5px;font-weight:600}.docs-search-hit-crumb{color:var(--text-muted);margin-bottom:3px;font-size:10.5px}.docs-search-hit-snippet{color:var(--text-muted);font-size:11.5px;line-height:1.45}.docs-search-hit-snippet mark{background:var(--brand-100);color:var(--brand-800);border-radius:2px;padding:0 2px}.docs-search-empty{text-align:center;color:var(--text-subtle);padding:20px 12px;font-size:12px}.docs-nav{padding:4px 0}.docs-nav-section{margin-bottom:16px}.docs-nav-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--brand-600);border-top:1px solid var(--border);padding:10px 10px 6px;font-size:11px;font-weight:700}.docs-nav-section:first-child .docs-nav-section-title{border-top:none;padding-top:0}.docs-nav-list{margin:0;padding:0;list-style:none}.docs-nav-article{color:var(--text-muted);border-radius:var(--r-sm);border-left:2px solid #0000;padding:6px 10px;font-size:12.5px;transition:background .1s,color .1s;display:block}.docs-nav-article:hover{background:var(--bg-hover);color:var(--text)}.docs-nav-article.active{color:var(--brand-700);border-left-color:var(--brand-500);background:var(--brand-50);font-weight:600}.docs-toc{padding:4px 0;font-size:12px}.docs-toc-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);padding:0 10px 8px;font-size:11px;font-weight:600}.docs-toc-list{margin:0;padding:0;list-style:none}.docs-toc-item a{color:var(--text-muted);border-left:2px solid #0000;padding:4px 10px;line-height:1.4;transition:color .1s,border-color .1s;display:block}.docs-toc-item a:hover{color:var(--text)}.docs-toc-item.active a{color:var(--brand-700);border-left-color:var(--brand-500);font-weight:500}.docs-toc-item-h3 a{padding-left:22px;font-size:11.5px}.docs-article{padding-bottom:80px}.docs-article-header{border-bottom:1px solid var(--border);margin-bottom:24px;padding-bottom:20px}.docs-article-header .h1{margin:0 0 10px}.docs-article-lede{color:var(--text-muted);max-width:68ch;margin:0;font-size:15px;line-height:1.55}.docs-h2{font-family:var(--font-display);letter-spacing:-.015em;color:var(--text);margin:40px 0 12px;scroll-margin-top:80px;font-size:20px;font-weight:600}.docs-h3{font-family:var(--font-display);color:var(--text);margin:28px 0 8px;scroll-margin-top:80px;font-size:15px;font-weight:600}.docs-p{color:var(--text);max-width:68ch;margin:0 0 14px;font-size:14px;line-height:1.7}.docs-list{max-width:68ch;margin:0 0 16px;padding-left:24px}.docs-list li{color:var(--text);margin-bottom:8px;font-size:14px;line-height:1.65}.docs-inline-code{background:var(--brand-50);color:var(--brand-800);border-radius:4px;padding:1px 6px;font-size:12.5px}.docs-code{background:var(--n-900);color:var(--n-50);border-radius:var(--r-md);margin:16px 0;padding:14px 16px;font-size:12.5px;line-height:1.55;overflow-x:auto}.docs-code code{color:inherit;background:0 0}.docs-kbd-row{align-items:center;gap:6px;margin:12px 0;font-size:13px;display:flex}.docs-kbd{font-family:var(--font-mono);color:var(--text);background:var(--bg-surface);border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:4px;align-items:center;padding:2px 8px;font-size:11px;display:inline-flex}.docs-callout{border-radius:var(--r-md);border-left:4px solid;gap:12px;max-width:68ch;margin:18px 0;padding:14px 16px;display:flex}.docs-callout-icon{flex:none;padding-top:2px}.docs-callout-body{flex:1;font-size:13.5px;line-height:1.6}.docs-callout-title{margin-bottom:4px;font-weight:600}.docs-callout-info{background:var(--sky-100);color:var(--sky-700);border-left-color:var(--sky-500)}.docs-callout-tip{background:var(--emerald-100);color:var(--emerald-700);border-left-color:var(--emerald-500)}.docs-callout-warning{background:var(--amber-100);color:var(--amber-700);border-left-color:var(--amber-500)}.docs-callout-danger{background:var(--rose-100);color:var(--rose-700);border-left-color:var(--rose-500)}.docs-screenshot{border:1px solid var(--border);border-radius:var(--r-lg);background:var(--bg-surface);box-shadow:var(--sh-sm);margin:22px 0;overflow:hidden}.docs-screenshot img{width:100%;height:auto;display:block}.docs-screenshot-caption{color:var(--text-muted);border-top:1px solid var(--border);background:var(--bg-sunken);padding:8px 14px;font-size:12px}.docs-screenshot-missing{background:var(--bg-sunken);border-style:dashed}.docs-screenshot-missing-inner{color:var(--text-subtle);flex-direction:column;align-items:center;gap:8px;padding:28px 20px;display:flex}.docs-screenshot-missing-label{letter-spacing:.03em;text-transform:uppercase;font-size:12px;font-weight:600}.docs-screenshot-missing-path{color:var(--text-muted);background:var(--bg-surface);border:1px solid var(--border);-webkit-user-select:all;user-select:all;border-radius:4px;padding:4px 8px;font-size:11.5px}.docs-screenshot-missing-hint{color:var(--text-subtle);font-size:11.5px}.docs-extension-panel{border:1px solid var(--border);border-radius:var(--r-lg);background:linear-gradient(180deg, var(--brand-50), var(--bg-surface));margin:20px 0 24px;padding:22px}.docs-extension-panel-title{font-family:var(--font-display);color:var(--text);margin:0 0 4px;font-size:15px;font-weight:600}.docs-extension-panel-version{color:var(--text-muted);margin-bottom:14px;font-size:12px}.docs-extension-download{background:var(--brand-600);color:var(--n-0);border-radius:var(--r-md);align-items:center;gap:8px;padding:10px 18px;font-size:13.5px;font-weight:600;transition:background .15s;display:inline-flex}.docs-extension-download:hover{background:var(--brand-700);color:var(--n-0)}.docs-extension-panel-size{color:var(--text-subtle);margin-left:10px;font-size:11.5px;display:inline-block}.dg-card-head{justify-content:space-between;align-items:flex-start;gap:10px;display:flex}.dg-card-title{color:var(--text);align-items:center;gap:8px;min-width:0;font-size:14px;font-weight:600;display:flex}.dg-card-title span.name{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dg-card-sub{color:var(--text-muted);font-size:12px;font-family:var(--font-mono);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.dg-card-pills{flex-wrap:wrap;gap:6px;display:flex}.dg-card-stats{border-top:1px solid var(--border);border-bottom:1px solid var(--border);grid-template-columns:repeat(3,1fr);gap:10px;padding:10px 0;display:grid}.dg-card-stat{flex-direction:column;gap:2px;min-width:0;display:flex}.dg-card-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-size:10.5px;font-weight:600}.dg-card-stat-value{color:var(--text);font-variant-numeric:tabular-nums;font-size:14px;font-weight:600}.dg-card-foot{color:var(--text-muted);justify-content:space-between;align-items:center;gap:8px;font-size:11.5px;display:flex}.pub-shell{background:var(--bg-surface);--pub-shadow-brand:0 12px 40px -12px oklch(.62 .2 var(--brand-h) / .3);--pub-shadow-float:0 30px 80px -24px #0f171e33, 0 8px 24px -12px #0f171e1a;--pub-border-soft:color-mix(in oklch, var(--n-150) 70%, transparent);--pub-mesh:radial-gradient(48% 42% at 50% -4%, color-mix(in oklch, var(--brand-100) 55%, transparent), transparent 70%), radial-gradient(30% 30% at 12% 18%, color-mix(in oklch, var(--violet-100) 45%, transparent), transparent 70%), radial-gradient(30% 30% at 88% 12%, color-mix(in oklch, var(--sky-100) 50%, transparent), transparent 70%);flex-direction:column;min-height:100vh;display:flex}.pub-main{flex:1}.pub-container{max-width:1120px;margin:0 auto;padding:0 24px}.pub-nav{z-index:40;background:color-mix(in oklch, var(--bg-surface) 72%, transparent);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid #0000;transition:border-color .2s,background-color .2s,box-shadow .2s;position:sticky;top:0}.pub-nav.scrolled{border-bottom-color:var(--pub-border-soft);background:color-mix(in oklch, var(--bg-surface) 90%, transparent);box-shadow:0 8px 24px -18px #0f171e40}.pub-nav-inner{justify-content:space-between;align-items:center;height:64px;display:flex}.pub-brand{font-family:var(--font-display);color:var(--text);letter-spacing:-.01em;align-items:center;gap:10px;font-size:17px;font-weight:600;text-decoration:none;display:inline-flex}.pub-brand-small{font-size:15px}.pub-brand-dot{background:linear-gradient(150deg, var(--brand-500), var(--brand-700));width:26px;height:26px;color:var(--n-0);box-shadow:0 0 0 4px var(--brand-50), 0 4px 10px -4px oklch(.62 .2 var(--brand-h) / .5);border-radius:999px;justify-content:center;align-items:center;display:inline-flex}.pub-nav-links{gap:4px;display:none}@media (width>=768px){.pub-nav-links{display:inline-flex}}.pub-nav-link{border-radius:var(--r-full);color:var(--text-muted);align-items:center;gap:7px;padding:7px 13px;font-size:13.5px;font-weight:500;text-decoration:none;transition:color .12s,background-color .12s;display:inline-flex}.pub-nav-link:hover{color:var(--text);background:var(--bg-hover)}.pub-nav-link.active{color:var(--brand-700);background:var(--brand-50)}.pub-nav-link.active:before{content:"";background:var(--brand-500);border-radius:999px;width:5px;height:5px}.pub-nav-link-muted{display:none}@media (width>=640px){.pub-nav-link-muted{display:inline-flex}}.pub-nav-actions{align-items:center;gap:10px;display:inline-flex}.pub-nav-burger{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-surface);width:38px;height:38px;color:var(--text);cursor:pointer;justify-content:center;align-items:center;transition:background-color .12s,border-color .12s;display:inline-flex}.pub-nav-burger:hover{background:var(--bg-hover)}@media (width>=768px){.pub-nav-burger{display:none}}.pub-nav-mobile{border-top:1px solid var(--pub-border-soft);background:var(--bg-surface);overflow:hidden}.pub-nav-mobile-inner{flex-direction:column;gap:2px;padding:12px 24px 18px;display:flex}.pub-nav-mobile-link{border-radius:var(--r-md);color:var(--text);justify-content:space-between;align-items:center;padding:11px 12px;font-size:15px;font-weight:500;text-decoration:none;display:flex}.pub-nav-mobile-link:hover{background:var(--bg-hover)}.pub-nav-mobile-link.active{color:var(--brand-700);background:var(--brand-50)}.pub-nav-mobile-actions{border-top:1px solid var(--pub-border-soft);gap:10px;margin-top:12px;padding-top:14px;display:flex}.pub-nav-mobile-actions .btn{flex:1;justify-content:center}.pub-section{padding:104px 0}.pub-section-alt{background:linear-gradient(180deg, var(--bg-app), color-mix(in oklch, var(--bg-app) 55%, var(--bg-surface)));border-top:1px solid var(--pub-border-soft);border-bottom:1px solid var(--pub-border-soft)}.pub-eyebrow{background:color-mix(in oklch, var(--brand-50) 80%, var(--bg-surface));color:var(--brand-700);border:1px solid var(--brand-100);letter-spacing:.02em;text-transform:uppercase;box-shadow:0 2px 8px -4px oklch(.62 .2 var(--brand-h) / .25);border-radius:999px;align-items:center;gap:8px;padding:5px 13px;font-size:11.5px;font-weight:600;display:inline-flex}.pub-eyebrow-dot{background:var(--brand-500);border-radius:999px;width:6px;height:6px;animation:2s ease-in-out infinite pub-pingloop}@keyframes pub-pingloop{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.pub-h1{font-family:var(--font-display);letter-spacing:-.03em;color:var(--n-950);margin:26px 0 0;font-size:clamp(40px,6vw,64px);font-weight:650;line-height:1.05}.pub-h1 .pub-accent,.pub-h2 .pub-accent{background:linear-gradient(110deg, var(--brand-600), oklch(.55 .2 calc(var(--brand-h) + 40)));color:#0000;-webkit-background-clip:text;background-clip:text}.pub-h2{font-family:var(--font-display);letter-spacing:-.022em;color:var(--n-950);margin:16px 0 0;font-size:clamp(28px,3.4vw,40px);font-weight:650;line-height:1.12}.pub-lead{color:var(--text-muted);max-width:640px;margin:22px auto 0;font-size:17.5px;line-height:1.65}.pub-lead-left{margin-left:0}.pub-heading{max-width:720px}.pub-heading.center{text-align:center;margin:0 auto}.pub-hero{text-align:center;background:var(--pub-mesh);padding:88px 0 72px;position:relative;overflow:hidden}.pub-hero-ctas{flex-wrap:wrap;justify-content:center;gap:14px;margin-top:38px;display:flex}.pub-btn-hero{box-shadow:var(--pub-shadow-brand);transition:box-shadow .2s,transform .2s,background-color .15s}.pub-btn-hero:hover{box-shadow:0 16px 48px -12px oklch(.62 .2 var(--brand-h) / .42);transform:translateY(-1px)}.pub-hero-fineprint{color:var(--text-subtle);margin-top:20px;font-size:12.5px}.pub-hero-mockup{perspective:1200px;max-width:960px;margin:64px auto 0;position:relative}.pub-hero-mockup .pub-frame{transform:rotateX(4deg)}.pub-hero-halo{background:radial-gradient(50% 50% at 50% 50%, oklch(.62 .2 var(--brand-h) / .22), transparent 70%);filter:blur(14px);pointer-events:none;border-radius:50%;width:78%;height:90px;position:absolute;bottom:-36px;left:50%;transform:translate(-50%)}@media (width<=767px){.pub-hero-mockup{perspective:none}.pub-hero-mockup .pub-frame{transform:none}}.pub-frame{background:var(--bg-surface);border:1px solid var(--pub-border-soft);box-shadow:var(--pub-shadow-float);text-align:left;border-radius:16px;overflow:hidden}.pub-frame-bar{background:color-mix(in oklch, var(--bg-app) 75%, var(--bg-surface));border-bottom:1px solid var(--pub-border-soft);align-items:center;gap:12px;padding:10px 14px;display:flex}.pub-frame-dots{gap:6px;display:inline-flex}.pub-frame-dot{background:var(--n-200);border-radius:999px;width:10px;height:10px}.pub-frame-dot:first-child{background:oklch(72% .15 25)}.pub-frame-dot:nth-child(2){background:oklch(83% .13 85)}.pub-frame-dot:nth-child(3){background:oklch(78% .14 155)}.pub-frame-url{background:var(--bg-surface);border:1px solid var(--pub-border-soft);max-width:320px;font-family:var(--font-mono);color:var(--text-subtle);text-align:center;white-space:nowrap;text-overflow:ellipsis;border-radius:999px;flex:1;margin:0 auto;padding:4px 12px;font-size:11px;overflow:hidden}.pub-frame-body{padding:0}.pub-stats{flex-wrap:wrap;justify-content:center;gap:16px 0;max-width:760px;margin:56px auto 0;display:flex}.pub-stat{text-align:center;flex:180px;padding:0 28px}.pub-stat+.pub-stat{border-left:1px solid var(--pub-border-soft)}.pub-stat-value{font-family:var(--font-display);letter-spacing:-.02em;color:var(--n-950);font-size:30px;font-weight:650}.pub-stat-label{color:var(--text-subtle);margin-top:4px;font-size:12.5px}@media (width<=559px){.pub-stat{flex-basis:100%;padding:0}.pub-stat+.pub-stat{border-left:0}}.pub-features-grid{gap:20px;margin-top:56px;display:grid}@media (width>=640px){.pub-features-grid{grid-template-columns:repeat(2,1fr)}}@media (width>=1024px){.pub-features-grid{grid-template-columns:repeat(3,1fr)}}.pub-feature-card{background:var(--bg-surface);border:1px solid var(--pub-border-soft);border-radius:var(--r-xl);box-shadow:var(--sh-xs);padding:26px;transition:border-color .18s,transform .18s,box-shadow .18s;position:relative;overflow:hidden}.pub-feature-card:before{content:"";background:linear-gradient(90deg, transparent, var(--brand-400), transparent);opacity:0;height:2px;transition:opacity .18s;position:absolute;inset:0 0 auto}.pub-feature-card:hover{border-color:var(--brand-200);box-shadow:var(--sh-md);transform:translateY(-3px)}.pub-feature-card:hover:before{opacity:1}.pub-feature-icon{background:linear-gradient(150deg, var(--brand-50), var(--brand-100));border:1px solid var(--brand-100);width:42px;height:42px;color:var(--brand-600);border-radius:13px;justify-content:center;align-items:center;margin-bottom:16px;display:inline-flex}.pub-feature-title{font-family:var(--font-display);letter-spacing:-.01em;color:var(--n-950);margin:0;font-size:17px;font-weight:600}.pub-feature-desc{color:var(--text-muted);margin:8px 0 0;font-size:13.5px;line-height:1.6}.pub-quote{text-align:center;max-width:760px;margin:0 auto;padding-top:40px;position:relative}.pub-quote-mark{font-family:var(--font-display);color:var(--brand-200);pointer-events:none;font-size:96px;line-height:1;position:absolute;top:-8px;left:50%;transform:translate(-50%)}.pub-quote-text{font-family:var(--font-display);letter-spacing:-.015em;color:var(--n-900);margin:0;font-size:clamp(20px,2.4vw,26px);font-weight:500;line-height:1.45}.pub-quote-author{color:var(--text-muted);margin-top:22px;font-size:13.5px}.pub-quote-author strong{color:var(--text);font-weight:600}.pub-pricing-grid{align-items:start;gap:20px;margin-top:56px;display:grid}@media (width>=768px){.pub-pricing-grid{grid-template-columns:repeat(3,1fr)}}.pub-plan{background:var(--bg-surface);border:1px solid var(--pub-border-soft);border-radius:var(--r-xl);box-shadow:var(--sh-xs);flex-direction:column;padding:30px;transition:transform .18s,box-shadow .18s,border-color .18s;display:flex}.pub-plan:hover{box-shadow:var(--sh-md);border-color:var(--border-strong);transform:translateY(-3px)}.pub-plan-highlight{background:linear-gradient(var(--bg-surface), var(--bg-surface)) padding-box, linear-gradient(150deg, var(--brand-400), var(--brand-600)) border-box;box-shadow:var(--pub-shadow-brand);border:1px solid #0000;position:relative}.pub-plan-highlight:hover{box-shadow:0 18px 56px -14px oklch(.62 .2 var(--brand-h) / .4);border-color:#0000}@media (width>=768px){.pub-plan-highlight{margin-top:-14px;padding-top:38px;padding-bottom:38px}}.pub-plan-badge{background:linear-gradient(120deg, var(--brand-500), var(--brand-700));color:var(--n-0);letter-spacing:.02em;box-shadow:0 4px 12px -4px oklch(.62 .2 var(--brand-h) / .5);border-radius:999px;padding:4px 14px;font-size:11px;font-weight:600;position:absolute;top:-12px;left:50%;transform:translate(-50%)}.pub-plan-name{font-family:var(--font-display);color:var(--n-950);margin:0;font-size:20px;font-weight:600}.pub-plan-price{align-items:baseline;gap:5px;margin-top:20px;display:flex}.pub-plan-price-amount{font-family:var(--font-display);color:var(--n-950);letter-spacing:-.03em;font-size:46px;font-weight:650}.pub-plan-price-suffix{color:var(--text-subtle);font-size:13.5px}.pub-plan-tagline{color:var(--text-muted);margin:6px 0 0;font-size:13.5px}.pub-plan-cta{justify-content:center;width:100%;margin-top:26px}.pub-plan-features{border-top:1px solid var(--pub-border-soft);flex-direction:column;gap:11px;margin:24px 0 0;padding:24px 0 0;list-style:none;display:flex}.pub-plan-features li{color:var(--text);align-items:flex-start;gap:10px;font-size:13.5px;display:flex}.pub-plan-features .pub-check{margin-top:1px}.pub-plan-footnote{text-align:center;color:var(--text-subtle);margin-top:28px;font-size:12.5px}.pub-check{background:var(--emerald-100);width:18px;height:18px;color:var(--emerald-700);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.pub-alt-row{align-items:center;gap:48px;margin:104px 0;display:grid}@media (width>=900px){.pub-alt-row{grid-template-columns:1fr 1fr;gap:72px}.pub-alt-row.reverse .pub-alt-copy{order:2}}.pub-alt-copy h2{font-family:var(--font-display);letter-spacing:-.02em;color:var(--n-950);margin:18px 0 0;font-size:clamp(24px,2.6vw,33px);font-weight:650;line-height:1.18}.pub-alt-copy p{color:var(--text-muted);margin:16px 0 0;font-size:15px;line-height:1.68}.pub-alt-bullets{gap:10px;margin:26px 0 0;padding:0;list-style:none;display:grid}@media (width>=560px){.pub-alt-bullets{grid-template-columns:1fr 1fr}}.pub-alt-bullets li{color:var(--text);align-items:flex-start;gap:9px;font-size:13.5px;line-height:1.5;display:flex}.pub-cta-block{text-align:center;background:radial-gradient(80% 120% at 50% -20%, oklch(.62 .18 var(--brand-h) / .55), transparent 60%), linear-gradient(135deg, var(--brand-600), var(--brand-800));color:var(--n-0);box-shadow:var(--pub-shadow-brand);border-radius:28px;padding:64px 32px;position:relative;overflow:hidden}.pub-cta-mark{color:var(--n-0);opacity:.07;pointer-events:none;position:absolute;bottom:-80px;right:-60px}.pub-cta-block h2{font-family:var(--font-display);letter-spacing:-.02em;color:var(--n-0);margin:0;font-size:clamp(26px,3vw,38px);font-weight:650;line-height:1.15;position:relative}.pub-cta-block p{color:color-mix(in oklch, var(--n-0) 82%, transparent);max-width:500px;margin:16px auto 0;font-size:15px;line-height:1.6;position:relative}.pub-cta-actions{flex-wrap:wrap;justify-content:center;gap:12px;margin-top:34px;display:flex;position:relative}.pub-cta-block .btn{background:var(--n-0);color:var(--brand-700);border-color:#0000}.pub-cta-block .btn:hover{background:var(--bg-app)}.pub-cta-block .btn.pub-cta-ghost{color:var(--n-0);border:1px solid color-mix(in oklch, var(--n-0) 40%, transparent);background:0 0}.pub-cta-block .btn.pub-cta-ghost:hover{background:color-mix(in oklch, var(--n-0) 12%, transparent)}.pub-contact-grid{align-items:start;gap:56px;display:grid}@media (width>=900px){.pub-contact-grid{grid-template-columns:1fr 1.1fr}}.pub-contact-card{background:var(--bg-surface);border:1px solid var(--pub-border-soft);border-radius:var(--r-xl);box-shadow:var(--sh-xs);align-items:flex-start;gap:16px;margin-top:24px;padding:20px;transition:border-color .15s,box-shadow .15s;display:flex}.pub-contact-card:hover{border-color:var(--brand-200);box-shadow:var(--sh-sm)}.pub-contact-tile{background:linear-gradient(150deg, var(--brand-50), var(--brand-100));border:1px solid var(--brand-100);width:42px;height:42px;color:var(--brand-600);border-radius:13px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.pub-contact-card-title{font-family:var(--font-display);color:var(--n-950);margin:0;font-size:15px;font-weight:600}.pub-contact-card-body{color:var(--text-muted);margin:4px 0 0;font-size:13.5px;line-height:1.55}.pub-contact-email{font-family:var(--font-display);color:var(--brand-600);margin-top:4px;font-size:18px;font-weight:600;text-decoration:none;display:inline-block}.pub-contact-email:hover{color:var(--brand-700)}.pub-contact-form{background:var(--bg-surface);border:1px solid var(--pub-border-soft);border-radius:var(--r-xl);box-shadow:var(--sh-lg);flex-direction:column;gap:18px;padding:32px;display:flex}.pub-contact-form label{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:500;display:block}.pub-contact-form input,.pub-contact-form textarea{border:1px solid var(--border);background:var(--bg-surface);border-radius:var(--r-md);width:100%;color:var(--text);padding:11px 13px;font-family:inherit;font-size:13.5px;transition:border-color .12s,box-shadow .12s}.pub-contact-form input:focus,.pub-contact-form textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px var(--brand-100);outline:none}.pub-contact-form-note{color:var(--text-subtle);margin:0;font-size:11.5px}.pub-contact-success{text-align:center;flex-direction:column;align-items:center;gap:6px;padding:24px 0;display:flex}.pub-contact-success-icon{background:var(--emerald-100);width:52px;height:52px;color:var(--emerald-700);border-radius:999px;justify-content:center;align-items:center;margin-bottom:10px;display:inline-flex}.pub-faq{background:var(--bg-surface);border:1px solid var(--pub-border-soft);border-radius:var(--r-xl);box-shadow:var(--sh-xs);margin-top:40px;overflow:hidden}.pub-faq-item{border-bottom:1px solid var(--pub-border-soft)}.pub-faq-item:last-child{border-bottom:0}.pub-faq-item summary{color:var(--n-950);cursor:pointer;justify-content:space-between;align-items:center;gap:16px;padding:19px 22px;font-size:14.5px;font-weight:550;list-style:none;transition:background-color .12s;display:flex}.pub-faq-item summary:hover{background:var(--bg-hover)}.pub-faq-item summary:focus-visible{outline:2px solid var(--brand-500);outline-offset:-2px}.pub-faq-item summary::-webkit-details-marker{display:none}.pub-faq-item summary .caret{color:var(--text-muted);flex-shrink:0;transition:transform .18s}.pub-faq-item[open] summary .caret{transform:rotate(45deg)}.pub-faq-item p{color:var(--text-muted);max-width:640px;margin:0;padding:0 22px 20px;font-size:13.5px;line-height:1.65}.pub-faq-prompt{text-align:center;color:var(--text-muted);margin-top:32px;font-size:13.5px}.pub-faq-prompt a{color:var(--brand-600);font-weight:550}.pub-footer{border-top:1px solid var(--pub-border-soft);background:linear-gradient(180deg, var(--bg-app), color-mix(in oklch, var(--bg-app) 70%, var(--bg-surface)));margin-top:48px;padding:64px 0 24px;position:relative}.pub-footer:before{content:"";background:linear-gradient(90deg, transparent, var(--brand-300), transparent);height:1px;position:absolute;inset:-1px 0 auto}.pub-footer-grid{gap:40px;display:grid}@media (width>=768px){.pub-footer-grid{grid-template-columns:2fr repeat(3,1fr)}}.pub-footer-tag{color:var(--text-muted);max-width:300px;margin:14px 0 0;font-size:13px;line-height:1.6}.pub-footer-cta{margin-top:18px}.pub-footer-heading{color:var(--text-subtle);text-transform:uppercase;letter-spacing:.07em;margin:0 0 16px;font-size:10.5px;font-weight:600}.pub-footer-list{flex-direction:column;gap:9px;margin:0;padding:0;list-style:none;display:flex}.pub-footer-list a{color:var(--text-muted);font-size:13px;text-decoration:none;transition:color .12s}.pub-footer-list a:hover{color:var(--brand-700)}.pub-footer-baseline{border-top:1px solid var(--pub-border-soft);color:var(--text-subtle);flex-direction:column;justify-content:space-between;align-items:center;gap:12px;margin-top:48px;padding-top:24px;font-size:11.5px;display:flex}@media (width>=640px){.pub-footer-baseline{flex-direction:row}}.pub-legal{max-width:720px}.pub-legal-updated{color:var(--text-subtle);margin:10px 0 0;font-size:12.5px}.pub-legal-lead{color:var(--text-muted);margin:26px 0 0;font-size:16px;line-height:1.7}.pub-legal-h2{border-top:1px solid var(--pub-border-soft);font-family:var(--font-display);letter-spacing:-.015em;color:var(--n-950);margin:48px 0 14px;padding-top:26px;font-size:20px;font-weight:650}.pub-legal-p{color:var(--text-muted);margin:12px 0 0;font-size:14.5px;line-height:1.75}.pub-legal-p strong,.pub-legal-list strong{color:var(--text);font-weight:600}.pub-legal-list{flex-direction:column;gap:9px;margin:12px 0 0;padding-left:22px;display:flex}.pub-legal-list li{color:var(--text-muted);font-size:14.5px;line-height:1.65}.pub-mk{color:var(--text);padding:18px;font-size:12px}.pub-mk-topbar{color:var(--text-muted);border-bottom:1px solid var(--pub-border-soft);align-items:center;gap:8px;margin-bottom:14px;padding-bottom:12px;font-size:11px;font-weight:600;display:flex}.pub-mk-topbar .pub-mk-appdot{background:var(--brand-500);border-radius:999px;width:8px;height:8px}.pub-mk-topbar .spacer{flex:1}.pub-mk-tiles{grid-template-columns:repeat(3,1fr);gap:10px;display:grid}.pub-mk-tile{background:color-mix(in oklch, var(--bg-app) 70%, var(--bg-surface));border:1px solid var(--pub-border-soft);border-radius:var(--r-md);padding:10px 12px}.pub-mk-tile-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);font-size:9.5px;font-weight:600}.pub-mk-tile-value{font-family:var(--font-display);letter-spacing:-.02em;color:var(--n-950);margin-top:3px;font-size:17px;font-weight:650}.pub-mk-tile-value.up{color:var(--emerald-700)}.pub-mk-grid{gap:12px;margin-top:12px;display:grid}@media (width>=640px){.pub-mk-grid{grid-template-columns:1.5fr 1fr}}.pub-mk-panel{background:var(--bg-surface);border:1px solid var(--pub-border-soft);border-radius:var(--r-md);padding:12px}.pub-mk-panel-title{text-transform:uppercase;letter-spacing:.05em;color:var(--text-subtle);margin-bottom:8px;font-size:10px;font-weight:600}.pub-mk-chart{width:100%;height:auto;display:block}.pub-mk-rows{flex-direction:column;gap:7px;display:flex}.pub-mk-row{background:color-mix(in oklch, var(--bg-app) 55%, var(--bg-surface));border:1px solid var(--pub-border-soft);border-radius:var(--r-sm);align-items:center;gap:9px;min-width:0;padding:8px 10px;font-size:11.5px;display:flex}.pub-mk-row .grow{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.pub-mk-row.ghost{color:var(--text-subtle);background:0 0;border-style:dashed}.pub-mk-name{color:var(--text);font-weight:550}.pub-mk-meta{color:var(--text-subtle);font-size:10.5px}.pub-mk-mono{font-family:var(--font-mono);color:var(--text-muted);font-size:10.5px}.pub-mk-badge{letter-spacing:.04em;text-transform:uppercase;border-radius:999px;flex-shrink:0;align-items:center;gap:5px;padding:2px 8px;font-size:9.5px;font-weight:700;display:inline-flex}.pub-mk-badge.up{background:var(--emerald-100);color:var(--emerald-700)}.pub-mk-badge.down{background:var(--rose-100);color:var(--rose-700)}.pub-mk-badge.info{background:var(--sky-100);color:var(--sky-700)}.pub-mk-badge.role{background:var(--violet-100);color:var(--violet-700)}.pub-mk-badge.neutral{background:var(--bg-hover);color:var(--text-muted)}.pub-mk-dot{background:currentColor;border-radius:999px;flex-shrink:0;width:6px;height:6px}.pub-mk-dot.pulse{animation:2s ease-out infinite pub-pulse-ring}@keyframes pub-pulse-ring{0%{box-shadow:0 0 0 0 color-mix(in oklch, currentColor 45%, transparent)}70%{box-shadow:0 0 0 5px #0000}to{box-shadow:0 0 #0000}}.pub-mk-bars{align-items:flex-end;gap:2px;height:34px;margin-top:10px;display:flex}.pub-mk-bar{background:oklch(78% .14 155);border-radius:2px;flex:1;min-width:2px}.pub-mk-bar.warn{background:oklch(83% .13 85)}.pub-mk-bar.fail{background:oklch(72% .15 25)}.pub-mk-steps{flex-direction:column;gap:0;margin-top:4px;display:flex}.pub-mk-step{align-items:center;gap:10px;padding:7px 0 7px 4px;display:flex;position:relative}.pub-mk-step:before{content:"";background:var(--pub-border-soft);width:1px;position:absolute;top:0;bottom:0;left:12px}.pub-mk-step:first-child:before{top:50%}.pub-mk-step:last-child:before{bottom:50%}.pub-mk-step-check{z-index:1;background:var(--emerald-100);width:17px;height:17px;color:var(--emerald-700);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex;position:relative}.pub-mk-chips{flex-wrap:wrap;gap:6px;margin-bottom:10px;display:flex}.pub-mk-chip{background:var(--brand-50);border:1px solid var(--brand-100);color:var(--brand-700);border-radius:999px;align-items:center;gap:5px;padding:3px 9px;font-size:10px;font-weight:600;display:inline-flex}.pub-mk-mail-head{border-bottom:1px solid var(--pub-border-soft);align-items:center;gap:9px;margin-bottom:10px;padding-bottom:10px;display:flex}.pub-mk-mail-avatar{background:linear-gradient(150deg, var(--brand-500), var(--brand-700));width:28px;height:28px;color:var(--n-0);border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:700;display:inline-flex}.pub-mk-mail-subject{color:var(--n-950);align-items:center;gap:7px;margin-bottom:6px;font-size:12.5px;font-weight:600;display:flex}.pub-mk-mail-subject .pub-mk-dot{background:var(--rose-500)}.pub-mk-wire{background:color-mix(in oklch, var(--bg-app) 70%, var(--bg-surface));border:1px solid var(--pub-border-soft);border-radius:var(--r-md);flex-direction:column;gap:6px;padding:10px;display:flex}.pub-mk-wire-block{background:var(--n-150);border-radius:3px;height:9px}.pub-mk-wire-block.short{width:55%}.pub-mk-wire-block.half{width:75%}.pub-mk-wire-block.tall{height:26px}.pub-mk-wire-block.fail{background:var(--rose-100);outline:2px solid var(--rose-500);outline-offset:1px}.pub-mk-rec{background:var(--n-900);color:var(--n-0);letter-spacing:.06em;border-radius:999px;align-items:center;gap:6px;padding:4px 11px;font-size:10px;font-weight:700;display:inline-flex}.pub-mk-rec .pub-mk-dot{background:oklch(65% .22 25);animation:1.2s ease-in-out infinite pub-blink}@keyframes pub-blink{0%,to{opacity:1}50%{opacity:.25}}.pub-mk-terminal{background:var(--n-900);border-radius:var(--r-md);font-family:var(--font-mono);color:var(--n-100);padding:14px 16px;font-size:11px;line-height:1.9;overflow-x:auto}.pub-mk-terminal .prompt{color:var(--brand-300)}.pub-mk-terminal .ok{color:oklch(82% .14 155)}.pub-mk-terminal .dim{color:var(--n-400)}.pub-mk-avatar{border-radius:999px;flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:9px;font-weight:700;display:inline-flex}.pub-mk-avatar.tint-0{background:var(--sky-100);color:var(--sky-700)}.pub-mk-avatar.tint-1{background:var(--violet-100);color:var(--violet-700)}.pub-mk-avatar.tint-2{background:var(--emerald-100);color:var(--emerald-700)}.pub-mk-avatar.tint-3{background:var(--amber-100);color:var(--amber-700)}.pub-mk-btn{border-radius:var(--r-sm);background:var(--brand-600);color:var(--n-0);justify-content:center;align-items:center;gap:5px;padding:5px 12px;font-size:10.5px;font-weight:600;display:inline-flex}.pub-mk-btn.ghost{background:var(--bg-surface);border:1px solid var(--border);color:var(--text)}@media (prefers-reduced-motion:reduce){.pub-eyebrow-dot,.pub-mk-dot.pulse,.pub-mk-rec .pub-mk-dot{animation:none}.pub-hero-mockup .pub-frame{transform:none}.pub-feature-card,.pub-plan,.pub-btn-hero,.pub-faq-item summary .caret{transition:none}}.pwa-toast{z-index:3000;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);max-width:320px;box-shadow:var(--sh-lg,0 10px 30px #0000001f);color:var(--text);flex-direction:column;gap:10px;padding:14px 16px;font-size:14px;display:flex;position:fixed;bottom:24px;right:24px}.pwa-toast-text{line-height:1.5}.pwa-toast-actions{gap:8px;display:flex}@media (width<=640px){.pwa-toast{max-width:none;bottom:12px;left:12px;right:12px}}.nav-toggle{border:1px solid var(--border);border-radius:var(--r-md);background:var(--bg-surface);width:34px;height:34px;color:var(--text);cursor:pointer;flex-shrink:0;justify-content:center;align-items:center;display:none}.nav-toggle:hover{background:var(--bg-hover)}.sidebar-overlay{display:none}@media (width<=899px){.app{grid-template-columns:1fr}.sidebar{z-index:1200;width:min(84vw,300px);height:100vh;box-shadow:var(--sh-lg);transition:transform .22s;position:fixed;top:0;left:0;transform:translate(-100%)}.sidebar.sidebar--open{transform:none}.sidebar-overlay{z-index:1100;-webkit-backdrop-filter:blur(1px);backdrop-filter:blur(1px);background:#0f171e6b;display:block;position:fixed;inset:0}.nav-toggle{display:inline-flex}.topbar{gap:10px;padding:0 14px}.content{padding:16px}}@media (width<=640px){.crumbs{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}.topbar-search{max-width:none;margin-left:8px}.topbar-search-placeholder,.topbar-search kbd{display:none}}@media (width<=899px){.grid-3,.grid-4{grid-template-columns:1fr 1fr}}@media (width<=640px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@media (width<=899px){.tablecard,.table-scroll{-webkit-overflow-scrolling:touch;overflow-x:auto}}@media (width<=640px){.page-header{flex-direction:column;align-items:stretch;gap:12px}.page-header-actions{flex-wrap:wrap}.page-header-actions .btn{flex:auto;justify-content:center}}.filter-bar{align-items:center;gap:14px;display:flex}@media (width<=640px){.filter-bar{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto}.filter-bar>*{flex:none}}.cur-switch{background:var(--bg-hover,#f1f5f9);border:1px solid var(--border,#e2e8f0);border-radius:999px;align-items:center;gap:2px;padding:3px;display:inline-flex}.cur-switch button{appearance:none;color:var(--text-muted,#64748b);font:inherit;cursor:pointer;white-space:nowrap;background:0 0;border:0;border-radius:999px;padding:7px 14px;font-size:13px;font-weight:600;line-height:1;transition:background .15s,color .15s}.cur-switch button:hover{color:var(--text,#0f172a)}.cur-switch button.is-active{background:var(--surface,#fff);color:var(--brand-600,#2563eb);box-shadow:0 1px 2px #0f172a14}.cur-switch-hint{color:var(--brand-600,#2563eb);margin-left:2px;font-size:11px;font-weight:700}.sp-shell{--sp-accent:#2f6bff;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;color:#0b1220;background:#f5f7fb;min-height:100vh;padding:48px 16px 64px;font-family:Inter Tight,Inter,system-ui,sans-serif}.sp-container{max-width:640px;margin:0 auto}.sp-loading,.sp-empty{text-align:center;flex-direction:column;align-items:center;gap:14px;padding-top:80px;display:flex}.sp-spinner{border:3px solid #d5dced;border-top-color:var(--sp-accent);border-radius:50%;width:26px;height:26px}.sp-empty-title{margin:4px 0 0;font-size:20px;font-weight:650}.sp-empty-text{color:#64748b;margin:0;font-size:14px}.sp-brand-dot{background:var(--sp-accent);color:#fff;border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;display:inline-flex}.sp-brand-dot-sm{border-radius:6px;width:20px;height:20px}.sp-header{align-items:center;gap:14px;margin-bottom:24px;display:flex}.sp-logo{object-fit:contain;background:#fff;border:1px solid #e5eaf3;border-radius:9px;width:40px;height:40px}.sp-title{letter-spacing:-.01em;margin:0;font-size:24px;font-weight:700}.sp-desc{color:#64748b;margin:4px 0 0;font-size:14px}.sp-global{border:1px solid #0000;border-radius:14px;align-items:center;gap:12px;margin-bottom:24px;padding:18px 20px;font-size:15.5px;font-weight:600;display:flex}.sp-global-dot{background:currentColor;border-radius:50%;flex-shrink:0;width:11px;height:11px}.sp-global.sp-tone-ok{color:#0f7a45;background:#e7f8ef;border-color:#bfe9d1}.sp-global.sp-tone-warn{color:#a8620a;background:#fef4e6;border-color:#f6dcae}.sp-global.sp-tone-down{color:#b42121;background:#fdecec;border-color:#f6c9c9}.sp-maint{flex-direction:column;gap:10px;margin-bottom:24px;display:flex}.sp-maint-item{background:#fef7ec;border:1px solid #f4dcb0;border-radius:12px;flex-direction:column;gap:2px;padding:14px 16px;font-size:13.5px;display:flex}.sp-maint-item strong{color:#a8620a;text-transform:uppercase;letter-spacing:.03em;font-size:12px}.sp-maint-when{color:#7c8598;font-size:12.5px}.sp-items{flex-direction:column;gap:12px;display:flex}.sp-item{background:#fff;border:1px solid #e5eaf3;border-radius:14px;padding:16px 18px;box-shadow:0 1px 2px #0f172a0a}.sp-item-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.sp-item-name{font-size:15px;font-weight:600}.sp-badge{border-radius:999px;padding:3px 10px;font-size:12px;font-weight:600}.sp-badge.sp-tone-ok{color:#0f7a45;background:#e7f8ef}.sp-badge.sp-tone-warn{color:#a8620a;background:#fef4e6}.sp-badge.sp-tone-down{color:#b42121;background:#fdecec}.sp-badge.sp-tone-muted{color:#5b6472;background:#eef1f6}.sp-bars{align-items:flex-end;gap:2px;height:32px;margin-top:14px;display:flex}.sp-bar{background:#e5eaf3;border-radius:2px;flex:1;min-width:2px;height:100%}.sp-bar-ok{background:var(--emerald-500,#16a34a)}.sp-bar-warn{background:var(--amber-500,#f59e0b)}.sp-bar-down{background:var(--rose-500,#ef4444)}.sp-bar-none{background:#e2e7f0}.sp-bars-legend{color:#94a0b3;justify-content:space-between;align-items:center;margin-top:8px;font-size:11.5px;display:flex}.sp-uptime{color:#475569;font-weight:600}.sp-footer{color:#94a0b3;border-top:1px solid #e5eaf3;justify-content:space-between;align-items:center;margin-top:32px;padding-top:16px;font-size:12.5px;display:flex}.sp-powered{align-items:center;gap:7px;display:inline-flex}.sp-toggle{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:9px;font-size:13.5px;display:inline-flex}.sp-toggle input{width:16px;height:16px;accent-color:var(--brand-500)}.sp-url-row{background:var(--bg-hover);border:1px solid var(--border);border-radius:var(--r-md);align-items:center;gap:8px;margin-top:12px;padding:9px 10px;display:flex}.sp-url-row code{font-family:var(--font-mono);color:var(--text);word-break:break-all;flex:1;font-size:12px}.sp-section-icon{background:var(--brand-50);width:34px;height:34px;color:var(--brand-600);border-radius:9px;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sp-selected-row{align-items:center;gap:8px;display:flex}.sp-kind{flex-shrink:0}.sp-add{border-top:1px dashed var(--border);margin-top:16px;padding-top:14px}.sp-add-title{text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);margin-bottom:10px;font-size:12px}.sp-add-list{flex-wrap:wrap;gap:8px;display:flex}.sp-add-btn{border:1px solid var(--border);background:var(--bg-surface);color:var(--text);cursor:pointer;border-radius:999px;align-items:center;gap:6px;padding:6px 11px;font-size:12.5px;transition:border-color .12s,background .12s;display:inline-flex}.sp-add-btn:hover{border-color:var(--brand-400);background:var(--brand-50)}.sp-logo-box{border:1px solid var(--border);background:var(--bg-hover);border-radius:12px;flex-shrink:0;justify-content:center;align-items:center;width:64px;height:64px;display:flex;overflow:hidden}.sp-logo-box img{object-fit:contain;width:100%;height:100%}@media (width<=560px){.sp-shell{padding:28px 12px 48px}.sp-title{font-size:20px}}.tut-grid{grid-template-columns:repeat(auto-fill,minmax(268px,1fr));gap:16px;display:grid}.tut-card{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--r-lg);color:inherit;flex-direction:column;text-decoration:none;transition:border-color .14s,box-shadow .14s,transform .14s;display:flex;overflow:hidden}a.tut-card:hover{border-color:var(--brand-400);box-shadow:var(--sh-md);transform:translateY(-2px)}.tut-card-disabled{cursor:default;opacity:.82}.tut-thumb{aspect-ratio:16/9;background:var(--bg-hover);justify-content:center;align-items:center;display:flex;position:relative;overflow:hidden}.tut-thumb-img{object-fit:cover;width:100%;height:100%;display:block;position:absolute;inset:0}.tut-thumb-placeholder{background:radial-gradient(120% 120% at 20% 0%, var(--brand-50), transparent 60%), linear-gradient(135deg, var(--brand-500), var(--brand-700));opacity:.9;position:absolute;inset:0}.tut-play{z-index:1;color:#fff;filter:drop-shadow(0 2px 6px #00000059);justify-content:center;align-items:center;transition:transform .14s;display:inline-flex;position:relative}a.tut-card:hover .tut-play{transform:scale(1.08)}.tut-soon,.tut-duration{z-index:1;border-radius:999px;align-items:center;gap:4px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex;position:absolute}.tut-soon{background:var(--amber-100);color:var(--amber-700);top:8px;right:8px}.tut-duration{color:#fff;background:#0f171eb8;bottom:8px;right:8px}.tut-body{flex-direction:column;gap:5px;padding:13px 14px 15px;display:flex}.tut-title{font-size:14.5px;font-weight:650;line-height:1.3}.tut-desc{color:var(--text-muted);-webkit-line-clamp:3;-webkit-box-orient:vertical;margin:0;font-size:12.5px;line-height:1.5;display:-webkit-box;overflow:hidden}.tut-back{color:var(--text-muted);align-items:center;gap:6px;width:fit-content;font-size:13px;text-decoration:none;display:inline-flex}.tut-back:hover{color:var(--brand-600)}.tut-embed{aspect-ratio:16/9;border-radius:var(--r-lg);background:var(--bg-hover);border:1px solid var(--border);width:100%;position:relative;overflow:hidden}.tut-embed iframe{border:0;width:100%;height:100%;position:absolute;inset:0}.tut-embed-soon{color:var(--text-muted);justify-content:center;align-items:center;display:flex}
