*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --color-primary:#3b82f6;--color-secondary:#6c8fff;--font-size-base:14px;
  --bg:#0a0c10;--bg2:#111318;--bg3:#1a1d24;--bg4:#22262f;
  --border:#2a2e38;--border2:#363b48;
  --input-bg:#18181b;--input-border:#27272a;
  --text:#e8eaf0;--text2:#9098a8;--text3:#6f7680;
  --accent:#6c8fff;--accent2:#3b82f6;--accent-dim:#1a2340;--accent3:#9b6cff;--blue-500-rgb:59,130,246;
  --accent-glow:rgba(59,130,246,0.3);
  --green:#3ddc84;--green-dim:#0f2d1e;
  --red:#ff5c5c;--red-dim:#2d0f0f;--red-border:rgba(255,92,92,0.2);
  --yellow:#f5c542;--yellow-dim:#2d2200;--yellow-border:rgba(245,197,66,0.2);
  --auth-glow:#162040;
  --spinner-track:rgba(255,255,255,0.2);--spinner-tip:#fff;
  --radius:10px;--radius-sm:6px;--radius-lg:14px;
  --font:-apple-system,BlinkMacSystemFont,'Inter','Segoe UI',sans-serif;
  --mono:'SF Mono','Fira Code','Cascadia Code',monospace;
  --transition:0.15s ease;
  --space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:24px;--space-6:32px;--space-7:40px;--space-8:48px;
}
[data-theme="light"]{
  --color-primary:#6540a3;--color-secondary:#7c5cbf;--font-size-base:14px;
  --bg:#f5f5f5;--bg2:#ffffff;--bg3:#e8e8e8;--bg4:#dddddd;
  --border:#dddddd;--border2:#cccccc;
  --text:#1a1a1a;--text2:#555555;--text3:#999999;
  --accent:#7c5cbf;--accent2:#3b82f6;--accent-dim:#e8e0fa;--accent3:#8b5cf6;
  --accent-glow:rgba(101,64,163,0.2);
  --green:#16a34a;--green-dim:#dcfce7;
  --red:#dc2626;--red-dim:#fee2e2;--red-border:rgba(220,38,38,0.25);
  --yellow:#ca8a04;--yellow-dim:#fef9c3;--yellow-border:rgba(202,138,4,0.25);
  --auth-glow:#e8d8ff;
  --spinner-track:rgba(0,0,0,0.12);--spinner-tip:var(--accent2);
}
html{overflow-x:hidden;max-width:100%}
body{font-family:var(--font);background:var(--bg);color:var(--text);min-height:100vh;font-size:var(--font-size-base);line-height:1.5;-webkit-font-smoothing:antialiased;overflow-x:hidden;max-width:100%}

/* ── Semantic Headings ── */
h1{font-size:36px;font-weight:700;letter-spacing:-0.03em;margin:0 0 12px;line-height:1.2}
h2{font-size:28px;font-weight:700;letter-spacing:-0.02em;margin:0 0 10px;line-height:1.3}
h3{font-size:22px;font-weight:700;letter-spacing:-0.02em;margin:0 0 8px;line-height:1.3}
h4{font-size:18px;font-weight:700;letter-spacing:-0.01em;margin:0 0 6px;line-height:1.4}
h5{font-size:16px;font-weight:700;margin:0 0 6px;line-height:1.4}
h6{font-size:14px;font-weight:700;margin:0 0 4px;line-height:1.4}

/* ── Scrollbar ── */
::-webkit-scrollbar{width:8px;height:8px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:var(--text3)}

/* ── Auth screen ── */
.auth-screen{position:fixed;inset:0;z-index:999;overflow-y:auto;display:none;flex-direction:column;padding:0;background:radial-gradient(ellipse 60% 50% at 50% -10%,var(--auth-glow),transparent)}
.auth-screen>header{flex-shrink:0;border-bottom:1px solid var(--border)}
.auth-screen>main{display:flex;align-items:center;justify-content:center;padding:24px;flex:1;overflow-y:auto}
.auth-card{width:100%;max-width:400px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-7)}
@media(max-width:767px){.auth-card{padding:var(--space-6)}}
@media(max-width:480px){.auth-card{padding:var(--space-5)}}
@media(max-width:320px){.auth-screen{padding:var(--space-3)}.auth-card{padding:var(--space-4)}.auth-title{font-size:21px}.auth-sub{font-size:12px}.auth-logo-name{font-size:17px}}
@media(max-width:480px){.link-btn{padding:12px 16px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}}
#login-form,#tfa-form,#reg-form,#forgot-card form,#reset-card form{display:flex;flex-direction:column;width:100%}
.auth-logo{display:flex;align-items:center;gap:12px;margin-bottom:32px}
.auth-logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent2),var(--accent3));border-radius:10px;display:flex;align-items:center;justify-content:center}
.auth-logo-icon svg{width:18px;height:18px;fill:none;stroke:#fff;stroke-width:2}
.auth-logo-name{font-size:18px;font-weight:600;color:var(--text);letter-spacing:-0.02em}
.auth-logo-name span{color:var(--accent)}
.auth-title{font-size:22px;font-weight:600;letter-spacing:-0.03em;margin:0 0 6px}
.auth-sub{font-size:13px;color:var(--text2);margin-bottom:28px}
.field-group{margin-bottom:16px}
.field-label{display:block;font-size:13px;font-weight:500;color:var(--text2);margin-bottom:4px}
.field-hint{display:block;font-size:11px;font-weight:400;color:var(--text3);text-transform:none;letter-spacing:0;margin-bottom:8px}.field-hint-secure{color:var(--green)}.field-hint.field-hint-below{margin-top:4px;margin-bottom:0}
.pw-wrap{position:relative;display:flex;align-items:stretch}
.pw-wrap input{padding-right:44px!important;flex:1}
.pw-toggle{position:absolute;right:0;top:0;bottom:0;width:44px;background:none;border:none;cursor:pointer;color:var(--text2);display:flex;align-items:center;justify-content:center;padding:0;transition:color var(--transition)}
.pw-toggle:hover{color:var(--accent)}
.pw-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:0 var(--radius-sm) var(--radius-sm) 0}
.pw-toggle svg{pointer-events:none}
input[type=text],input[type=email],input[type=password],textarea,select{
  width:100%;background:var(--input-bg);border:1px solid var(--input-border);border-radius:var(--radius-sm);
  color:var(--text);padding:8px 16px;min-height:44px;font-size:16px;font-family:inherit;transition:border-color var(--transition),background var(--transition);outline:none
}
input[type=text]:focus,input[type=email]:focus,input[type=password]:focus,textarea:focus,select:focus{background:var(--bg3);border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
input[type=text]:focus-visible,input[type=email]:focus-visible,input[type=password]:focus-visible,textarea:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
input::placeholder,textarea::placeholder{color:var(--text2)}
input:-webkit-autofill,input:-webkit-autofill:hover,input:-webkit-autofill:focus{-webkit-text-fill-color:var(--text);-webkit-box-shadow:0 0 0px 1000px var(--input-bg) inset;transition:background-color 5000s ease-in-out 0s}
#tfa-code:valid{border-color:var(--green);}
textarea{resize:vertical;min-height:100px;line-height:1.6}
select{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%236f7680' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:var(--radius-sm);padding:12px 16px;min-height:44px;min-width:auto;font-size:13px;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition);white-space:nowrap;position:relative;text-decoration:none}
.btn::before{content:'';position:absolute;inset:-4px;border-radius:inherit;background:radial-gradient(ellipse at center,var(--accent) 0%,transparent 70%);opacity:0;pointer-events:none;z-index:-1}
.btn:hover:not(:disabled)::before{animation:pulse-glow 1.5s ease-in-out infinite}
@keyframes pulse-glow{0%,100%{opacity:0.2}50%{opacity:0.6}}
.btn-primary{background:#3b82f6;color:#fff;font-weight:600}
.btn-primary:hover:not(:disabled){background:var(--accent);filter:brightness(1.1);box-shadow:0 4px 16px var(--accent-glow)}
.btn-primary:disabled{background:var(--bg4);color:var(--text2);cursor:not-allowed}
.btn-enter{background:rgba(var(--blue-500-rgb),0.25);color:#3b82f6;border:1px solid rgba(var(--blue-500-rgb),0.3)}
.btn-enter:hover:not(:disabled){background:rgba(var(--blue-500-rgb),0.35);box-shadow:0 4px 16px rgba(var(--blue-500-rgb),0.2)}
.btn-enter:disabled{background:rgba(var(--blue-500-rgb),0.1);color:rgba(59,130,246,0.4);border-color:rgba(var(--blue-500-rgb),0.15);cursor:not-allowed;opacity:0.65}
.btn-ghost{background:transparent;color:var(--text);border:1px solid var(--border)}
.btn-ghost:hover:not(:disabled){background:rgba(255,255,255,0.08);color:var(--text);border-color:var(--border2)}
.btn-ghost:disabled{background:var(--bg4);border-color:var(--border);color:var(--text3);cursor:not-allowed}
.btn-danger{background:var(--red-dim);color:var(--red);border:1px solid var(--red-border)}
.btn-danger:hover:not(:disabled){background:var(--red-border)}
.btn-danger:disabled{background:var(--red-dim);border-color:var(--red-border);color:var(--red);opacity:0.5;cursor:not-allowed}
.btn-full{width:100%}
.btn-sm{padding:8px 12px;min-width:44px;min-height:44px;overflow:hidden;text-overflow:ellipsis;font-size:12px}
.btn-icon{width:44px;height:44px;min-height:44px;padding:0;border-radius:var(--radius-sm)}
.link-btn{background:var(--accent-dim);border:1px solid var(--border);color:var(--accent);font-size:13px;cursor:pointer;padding:12px 16px;min-height:44px;display:inline-flex;align-items:center;justify-content:center;font-family:inherit;text-decoration:underline;border-radius:var(--radius-sm)}
.link-btn:hover{color:var(--text);background:var(--bg3);border-color:var(--accent);text-decoration:underline}
.link-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;text-decoration:underline}
.forgot-password-btn{background:none;border-color:transparent;color:var(--accent);font-size:13px;min-height:44px;padding:12px 16px}
.forgot-password-btn:hover{background:none;border-color:transparent;color:var(--text);text-decoration:underline}
.forgot-password-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px;text-decoration:underline}
button:focus-visible,.btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
details>summary:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.err-msg{color:var(--red);font-size:13px;font-weight:600;line-height:1.4;margin-top:8px;display:none;background:var(--red-dim);border:1px solid var(--red-border);border-radius:var(--radius-sm);padding:8px 12px 8px 30px;min-height:44px;position:relative;animation:err-slide-in 0.2s ease}
.err-msg::before{content:"⚠";position:absolute;left:10px;top:50%;transform:translateY(-50%);font-size:13px}
@keyframes err-slide-in{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}

/* ── App shell ── */
.app{display:flex;height:100vh;flex-direction:column}

/* ── Top bar ── */
.topbar{height:52px;background:var(--bg2);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 20px;gap:16px;flex-shrink:0;position:relative;z-index:50}
.topbar-logo{display:flex;align-items:center;gap:8px;margin-right:8px}
.topbar-logo-icon{width:28px;height:28px;background:linear-gradient(135deg,var(--accent2),var(--accent3));border-radius:8px;display:flex;align-items:center;justify-content:center}
.topbar-logo-icon svg{width:14px;height:14px;fill:none;stroke:#fff;stroke-width:2}
.topbar-brand{font-size:15px;font-weight:600;letter-spacing:-0.02em}
.topbar-brand span{color:var(--accent)}
.topbar-sep{width:1px;height:20px;background:var(--border);margin:0 4px}
.tab-nav{display:flex;gap:2px}
.tab-nav-btn{background:none;border:none;padding:8px 16px;min-height:44px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;color:var(--text2);cursor:pointer;transition:all var(--transition);font-family:inherit}
.tab-nav-btn:hover{background:var(--bg3);color:var(--text)}
.tab-nav-btn.active{background:var(--bg3);color:var(--text);box-shadow:inset 0 -2px 0 var(--accent)}
.tab-nav-btn:focus-visible{outline:2px solid var(--accent);outline-offset:-2px}
.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px}
.topbar-user-sep{width:1px;height:20px;background:var(--border)}
.user-pill{background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:4px 12px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2)}
.utilities-menu{position:relative}
.utilities-dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--border);border-radius:8px;min-width:160px;box-shadow:0 4px 16px rgba(0,0,0,.15);z-index:200;padding:4px 0}
.utilities-dropdown.open{display:block}
.utilities-item{background:none;border:none;color:var(--text);padding:8px 16px;text-align:left;font-size:13px;cursor:pointer;font-family:inherit;width:100%;display:flex;align-items:center;gap:8px;white-space:nowrap}
.utilities-item:hover{background:var(--bg3)}
.utilities-divider{height:1px;background:var(--border);margin:4px 0}
.user-menu{position:relative}
.user-menu-btn{background:var(--bg3);border:1px solid var(--border);border-radius:99px;padding:4px 12px;display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text2);cursor:pointer;transition:all var(--transition);font-family:inherit;min-height:44px}
.user-menu-btn:hover{background:var(--bg4);color:var(--text)}
.user-menu-btn[aria-expanded="true"]{background:var(--bg4);color:var(--text)}
.user-dropdown{display:none;position:absolute;top:calc(100% + 8px);right:0;background:var(--bg2);border:1px solid var(--border);border-radius:8px;min-width:180px;box-shadow:0 4px 16px rgba(0,0,0,.15);z-index:200;padding:4px 0}
.user-dropdown.open{display:block}
.user-dropdown-item{background:none;border:none;color:var(--text);padding:8px 16px;text-align:left;font-size:13px;cursor:pointer;font-family:inherit;width:100%;display:flex;align-items:center;gap:8px;white-space:nowrap;transition:all var(--transition)}
.user-dropdown-item:hover{background:var(--bg3);color:var(--text)}
.user-dropdown-divider{height:1px;background:var(--border);margin:4px 0}
.user-avatar{width:20px;height:20px;border-radius:50%;background:linear-gradient(135deg,var(--accent2),var(--accent3));display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:600;color:#fff}

/* ── App body ── */
.app-body{flex:1;overflow:hidden;display:flex;min-height:0}
.app:not(.visible) .app-body{display:none}

/* ── Tabs ── */
.tab-pane{display:none;width:100%;height:100%;overflow:auto}
.tab-pane.active{display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden}

/* ── Jobs layout ── */
.jobs-layout{display:flex;width:100%;height:100%;min-height:0}
.sidebar{width:260px;flex-shrink:0;border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;background:var(--bg2)}
.sidebar-header{padding:16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between}
.sidebar-title{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.07em}
.sidebar-body{flex:1;overflow-y:auto;padding:8px}
.hist-item{padding:10px 12px;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--transition);border:1px solid transparent;margin-bottom:2px}
.hist-item:hover{background:var(--bg3);border-color:var(--border)}
.hist-item.active{background:var(--bg3);border-color:var(--accent)}
.hist-obj{font-size:12px;color:var(--text);white-space:normal;overflow-wrap:break-word;word-break:break-word;line-height:1.4;margin-bottom:5px;font-weight:500}
.hist-meta{display:flex;align-items:center;justify-content:space-between;gap:6px}
.hist-time{font-size:11px;color:var(--text3)}
/* Mobile sidebar overlay and toggle button */
.sidebar-overlay{display:none;position:fixed;inset:52px 0 0 0;background:rgba(0,0,0,0.55);z-index:89}
.sidebar-overlay.visible{display:block}
.sidebar-mobile-btn{display:none}
.hist-del{display:none;background:none;border:none;cursor:pointer;padding:2px 4px;border-radius:3px;color:var(--text3);line-height:1;flex-shrink:0}.hist-del:hover{color:var(--red);background:var(--red-dim)}.hist-item:hover .hist-del,.hist-item.active .hist-del{display:inline-flex;align-items:center}
.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 7px;border-radius:4px;font-size:11px;font-weight:500}
.badge-done{background:var(--green-dim);color:var(--green)}
.badge-running{background:var(--accent-dim);color:var(--accent)}
.badge-fail{background:var(--red-dim);color:var(--red)}
.badge-pending{background:var(--bg4);color:var(--text2)}
.badge-cancelled{background:var(--bg4);color:var(--text3)}

/* ── Shimmer ── */
.shimmer{position:relative;overflow:hidden;background:var(--bg3);border-radius:4px;height:12px}
.shimmer::after{content:'';position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,var(--bg4) 50%,transparent 100%);animation:shimmer 1.5s infinite;transform:translateX(-100%)}
@keyframes shimmer{to{transform:translateX(200%)}}
.shimmer-item{padding:10px 12px;border-radius:var(--radius-sm);border:1px solid transparent;margin-bottom:2px}
.shimmer-item .shimmer:first-child{width:75%;margin-bottom:8px}
.shimmer-item .shimmer:last-child{width:40%;height:10px}
.sidebar-empty-state{display:flex;flex-direction:column;align-items:center;text-align:center;padding:32px 16px;gap:10px}
.sidebar-empty-icon{width:40px;height:40px;background:var(--bg3);border:1px solid var(--border);border-radius:10px;display:flex;align-items:center;justify-content:center;margin-bottom:4px}
.sidebar-empty-icon svg{width:20px;height:20px;stroke:var(--text3);fill:none;stroke-width:1.5}
.sidebar-empty-title{font-size:13px;font-weight:500;color:var(--text);line-height:1.4}
.sidebar-empty-sub{font-size:12px;color:var(--text2);line-height:1.6;max-width:180px}

/* ── Main panel ── */
.main-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;min-width:0}
.compose-area{padding:24px;border-bottom:1px solid var(--border);background:var(--bg2)}
.compose-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:8px;display:block}
.compose-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);padding:14px 14px 28px;font-size:13px;color:var(--text);font-family:inherit;resize:none;outline:none;transition:border-color var(--transition);line-height:1.6}
.compose-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
.compose-footer{display:flex;align-items:center;justify-content:space-between;margin-top:12px;gap:12px}
.compose-footer-left{display:flex;align-items:center;gap:8px}
.textarea-wrapper{position:relative;width:100%}
.char-counter{display:block;text-align:right;font-size:11px;color:var(--text3);position:absolute;bottom:8px;right:10px;pointer-events:none;background:transparent;line-height:1}
.char-counter.warn{color:#f59e0b}
.input-hint{font-size:12px;color:var(--text2);margin-top:6px;line-height:1.5}

/* ── Status area ── */
.status-area{flex:1;overflow-y:auto;overflow-x:hidden;position:relative}
.status-content-wrapper{position:relative;padding:20px 24px;min-height:100%}
.status-empty{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;text-align:center;padding:40px}
.empty-icon{width:48px;height:48px;background:var(--bg3);border:1px solid var(--border);border-radius:12px;display:flex;align-items:center;justify-content:center}
.empty-icon svg{width:22px;height:22px;stroke:var(--text3);fill:none;stroke-width:1.5}
.empty-title{font-size:16px;font-weight:500;color:var(--text);letter-spacing:-0.02em}
.empty-sub{font-size:13px;color:var(--text2);max-width:320px;line-height:1.6}
.examples{display:flex;flex-direction:column;gap:8px;width:100%;max-width:360px;margin-top:4px}
.example-card{background:var(--bg2);border:1px solid var(--border);border-left:4px solid var(--border);border-radius:var(--radius);padding:12px 14px;cursor:pointer;text-align:left;transition:all var(--transition);width:100%}
.example-card:hover{border-color:var(--accent);border-left-color:var(--accent);background:var(--bg3)}
.example-card-tag{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:0.07em;margin-bottom:6px;padding:2px 7px;border-radius:99px;border:1px solid rgba(108,143,255,0.35);background:rgba(108,143,255,0.12);color:#818cf8}
.example-card-text{font-size:13px;color:var(--text2)}
.example-card[data-tag="Script"]{border-left-color:#818cf8}
.example-card[data-tag="Script"] .example-card-tag{background:rgba(129,140,248,0.12);color:#818cf8;border-color:rgba(129,140,248,0.35)}
.example-card[data-tag="Project"]{border-left-color:#a78bfa}
.example-card[data-tag="Project"] .example-card-tag{background:rgba(167,139,250,0.12);color:#a78bfa;border-color:rgba(167,139,250,0.35)}
.example-card[data-tag="Scraper"]{border-left-color:#fbbf24}
.example-card[data-tag="Scraper"] .example-card-tag{background:rgba(251,191,36,0.12);color:#fbbf24;border-color:rgba(251,191,36,0.35)}
.example-card[data-tag="Dashboard"]{border-left-color:#4ade80}
.example-card[data-tag="Dashboard"] .example-card-tag{background:rgba(74,222,128,0.12);color:#4ade80;border-color:rgba(74,222,128,0.35)}
.example-card[data-tag="Tool"]{border-left-color:#94a3b8}
.example-card[data-tag="Tool"] .example-card-tag{background:rgba(148,163,184,0.12);color:#94a3b8;border-color:rgba(148,163,184,0.35)}
.example-card[data-tag="API"]{border-left-color:#22d3ee}
.example-card[data-tag="API"] .example-card-tag{background:rgba(34,211,238,0.12);color:#22d3ee;border-color:rgba(34,211,238,0.35)}
.example-card[data-tag="Web App"]{border-left-color:#fb7185}
.example-card[data-tag="Web App"] .example-card-tag{background:rgba(251,113,133,0.12);color:#fb7185;border-color:rgba(251,113,133,0.35)}
.example-card[data-tag="Game"]{border-left-color:#facc15}
.example-card[data-tag="Game"] .example-card-tag{background:rgba(250,204,21,0.12);color:#facc15;border-color:rgba(250,204,21,0.35)}
[data-theme="light"] .example-card-tag{border-color:rgba(124,92,191,0.4);background:rgba(124,92,191,0.1);color:#6540a3}
[data-theme="light"] .example-card[data-tag="Script"] .example-card-tag{background:rgba(99,102,241,0.1);color:#4f46e5;border-color:rgba(99,102,241,0.35)}
[data-theme="light"] .example-card[data-tag="Project"] .example-card-tag{background:rgba(139,92,246,0.1);color:#7c3aed;border-color:rgba(139,92,246,0.35)}
[data-theme="light"] .example-card[data-tag="Scraper"] .example-card-tag{background:rgba(245,158,11,0.1);color:#b45309;border-color:rgba(245,158,11,0.35)}
[data-theme="light"] .example-card[data-tag="Dashboard"] .example-card-tag{background:rgba(22,163,74,0.1);color:#15803d;border-color:rgba(22,163,74,0.35)}
[data-theme="light"] .example-card[data-tag="Tool"] .example-card-tag{background:rgba(71,85,105,0.1);color:#475569;border-color:rgba(71,85,105,0.35)}
[data-theme="light"] .example-card[data-tag="API"] .example-card-tag{background:rgba(8,145,178,0.1);color:#0e7490;border-color:rgba(8,145,178,0.35)}
[data-theme="light"] .example-card[data-tag="Web App"] .example-card-tag{background:rgba(225,29,72,0.1);color:#be123c;border-color:rgba(225,29,72,0.35)}
[data-theme="light"] .example-card[data-tag="Game"] .example-card-tag{background:rgba(202,138,4,0.1);color:#a16207;border-color:rgba(202,138,4,0.35)}

/* ── Job status card ── */
.job-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:16px;overflow:hidden}
.job-card-header{padding:14px 16px;border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;gap:12px}
.job-card-id{font-family:var(--mono);font-size:11px;color:var(--text2);background:var(--bg3);padding:3px 8px;border-radius:4px}
.job-card-status{display:flex;align-items:center;gap:8px}
.stat-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;background:var(--border)}
.stat-cell{background:var(--bg2);padding:12px 16px}
.stat-cell-label{font-size:11px;color:var(--text3);margin-bottom:3px}
.stat-cell-value{font-size:20px;font-weight:600;color:var(--text);letter-spacing:-0.03em;font-variant-numeric:tabular-nums}

/* ── Error reason banner ── */
.error-reason-banner{display:none;padding:12px 16px;border-top:1px solid var(--border);background:var(--red-dim);gap:10px;align-items:flex-start}
.error-reason-banner.visible{display:flex}
.error-reason-icon{flex-shrink:0;color:var(--red);margin-top:1px}
.error-reason-text{flex:1;min-width:0}
.error-reason-title{font-size:12px;font-weight:600;color:var(--red);margin-bottom:2px}
.error-reason-detail{font-size:11px;color:var(--text2);line-height:1.5;word-break:break-word}
.error-reason-hint{font-size:11px;color:var(--text2);line-height:1.5;margin-top:6px;padding-top:6px;border-top:1px solid var(--border);font-style:italic}

/* ── Unblock action banner ── */
.unblock-action-banner{display:none;padding:12px 16px;border-top:1px solid var(--border);background:var(--yellow-dim,#fffbeb);gap:10px;align-items:flex-start}
.unblock-action-banner.visible{display:flex}
.unblock-action-icon{flex-shrink:0;color:var(--yellow,#d97706);margin-top:1px}
.unblock-action-text{flex:1;min-width:0}
.unblock-action-title{font-size:12px;font-weight:600;color:var(--yellow,#d97706);margin-bottom:2px}
.unblock-action-detail{font-size:11px;color:var(--text2);line-height:1.5;word-break:break-word}
.unblock-action-link{display:inline-block;margin-top:6px;font-size:11px;font-weight:500;color:var(--accent);text-decoration:none}
.unblock-action-link:hover{text-decoration:underline}

/* ── Live log ── */
.live-log{padding:12px 16px;font-family:var(--mono);font-size:11px;line-height:1.7;max-height:160px;overflow-y:auto;border-top:1px solid var(--border);display:none}
.log-row{display:flex;gap:8px;align-items:baseline}
.log-ts{color:var(--text3);flex-shrink:0}
.log-evt{color:var(--accent);flex-shrink:0}
.log-step{color:var(--text2)}

/* ── Output ── */
.output-bar{display:none;padding:12px 16px;border-top:1px solid var(--border);background:var(--green-dim)}
.output-bar.visible{display:flex;align-items:center;justify-content:space-between;gap:12px}
.output-bar-text{font-size:12px;color:var(--green);display:flex;align-items:center;gap:6px}
.output-bar-text svg{width:14px;height:14px;stroke:var(--green);fill:none;stroke-width:2}

/* ── File browser ── */
.filebrowser{border-top:1px solid var(--border)}
.fb-toggle-row{padding:10px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;font-size:12px;font-weight:500;color:var(--text2);transition:background var(--transition)}
.fb-toggle-row:hover{background:var(--bg3)}
.fb-toggle-chevron{transition:transform var(--transition)}
.fb-toggle-chevron.open{transform:rotate(90deg)}
.fb-content{display:none}
.fb-content.open{display:flex;max-height:320px}
.fb-tree{width:180px;flex-shrink:0;border-right:1px solid var(--border);overflow-y:auto;padding:6px}
.fb-file{font-family:var(--mono);font-size:11px;color:var(--text2);padding:5px 8px;border-radius:4px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:all var(--transition)}
.fb-file:hover{background:var(--bg3);color:var(--text)}
.fb-file.active{background:var(--accent-dim);color:var(--accent)}
.fb-preview{flex:1;overflow:auto;padding:12px 14px;font-family:var(--mono);font-size:11px;color:var(--text);white-space:pre;background:var(--bg);min-width:0}

/* ── Progress bar ── */
.progress-bar-wrap{padding:10px 16px;border-top:1px solid var(--border);display:none}
.progress-bar-label{font-size:11px;color:var(--text2);margin-bottom:6px}
.progress-bar{height:3px;background:var(--bg4);border-radius:99px;overflow:hidden}
.progress-bar-fill{height:100%;background:var(--accent2);border-radius:99px;transition:width 0.35s ease}

/* ── API key warning ── */
.apikey-warn{background:var(--yellow-dim);border:1px solid var(--yellow-border);border-radius:var(--radius-sm);padding:10px 14px;font-size:12px;color:var(--yellow);margin-bottom:12px;display:none;align-items:center;gap:8px}
.apikey-warn svg{width:14px;height:14px;stroke:var(--yellow);fill:none;stroke-width:2;flex-shrink:0}

/* ── Launch App panel ── */
.launch-bar{padding:12px 16px;border-top:1px solid var(--border);display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.app-iframe-wrap{padding:0 16px 16px}
.app-iframe-wrap iframe{width:100%;height:480px;border:1px solid var(--border);border-radius:var(--radius);display:block}

/* ── Continue project panel ── */
.continue-bar{padding:14px 16px;border-top:1px solid var(--border)}
.continue-bar-label{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:0.07em;margin-bottom:8px}

/* ── Settings/Admin layout ── */
.content-pane{flex:1;min-height:0;overflow-y:auto;padding:32px;background:var(--bg)}
.section-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:32px;overflow:hidden}
.section-card-header{padding:18px 20px;border-bottom:1px solid var(--border);background:var(--bg3)}
.section-card-title{font-size:16px;font-weight:700;letter-spacing:-0.02em;display:flex;align-items:center;gap:8px}
.section-card-title .section-icon{font-size:18px;line-height:1;flex-shrink:0}
.section-card-sub{font-size:12px;color:var(--text3);margin-top:4px}
.section-card-body{padding:24px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
.inline-actions{display:flex;gap:8px;margin-top:12px}

/* ── Admin ── */
.health-grid{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.health-chip{display:flex;align-items:center;gap:7px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:6px 12px;font-size:12px}
.health-dot{width:7px;height:7px;border-radius:50%}
.health-dot.ok{background:var(--green)}
.health-dot.err{background:var(--red)}
.health-dot.loading{background:var(--text3);animation:pulse 1.2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:0.3}}
.data-table{width:100%;border-collapse:collapse;font-size:12px}
.data-table th{text-align:left;padding:8px 12px;color:var(--text2);font-weight:500;font-size:11px;text-transform:uppercase;letter-spacing:0.06em;border-bottom:1px solid var(--border)}
.data-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text)}
.data-table tr:last-child td{border-bottom:none}
.data-table tr:hover td{background:var(--bg3)}
.mono-sm{font-family:var(--mono);font-size:11px;color:var(--text2)}
.invite-code-display{font-family:var(--mono);font-size:12px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;color:var(--accent);word-break:break-all;margin-top:12px;display:none}

/* ── Digest / pace-dial ── */
.pace-dial{background:transparent;color:var(--text2);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;min-width:44px;min-height:44px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all var(--transition)}
.pace-dial:hover{background:var(--bg3);color:var(--text);border-color:var(--border2)}
.pace-dial.active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent)}

/* ── Info buttons ── */
.info-btn{min-width:44px;min-height:44px;padding:0;border-radius:50%;background:var(--bg4);border:1px solid var(--border);color:var(--text2);font-size:9px;font-weight:700;cursor:help;display:inline-flex;align-items:center;justify-content:center;margin-left:5px;transition:all var(--transition);vertical-align:middle;line-height:1;flex-shrink:0;opacity:0.65}
.info-btn:focus,.info-wrap:hover .info-btn{opacity:1}
.info-btn:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.info-btn:hover{background:var(--border2);color:var(--text);border-color:var(--accent)}
.info-wrap{position:relative;display:inline-block}
.info-tooltip{display:none;position:absolute;left:0;top:calc(100% + 4px);background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 12px;font-size:12px;color:var(--text2);max-width:220px;z-index:100;box-shadow:0 4px 12px rgba(0,0,0,0.3);line-height:1.5}
.info-tooltip.active{display:block}

/* ── Spinner ── */
.spinner{width:14px;height:14px;border:2px solid var(--spinner-track);border-top-color:var(--spinner-tip);border-radius:50%;animation:spin 0.8s linear infinite;flex-shrink:0}
.spin{animation:spin 1s linear infinite;display:inline-block}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── Toast ── */
#toast-wrap{position:fixed;bottom:20px;right:20px;display:flex;flex-direction:column;gap:8px;z-index:9999;pointer-events:none}
.toast{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:10px 14px;font-size:12px;max-width:300px;pointer-events:auto;animation:slideup 0.2s ease;border-left:3px solid var(--border2)}
@keyframes slideup{from{transform:translateY(8px);opacity:0}to{transform:none;opacity:1}}
.toast.s{border-left-color:var(--green)}
.toast.e{border-left-color:var(--red)}
.toast.i{border-left-color:var(--accent)}

/* ── Modal ── */
.modal-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.7);display:none;align-items:center;justify-content:center;z-index:200;padding:20px}
.modal-backdrop.open{display:flex}
.modal{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px;width:100%;max-width:500px;max-height:80vh;overflow-y:auto;position:relative}
.modal-close{position:absolute;top:14px;right:14px;background:none;border:none;color:var(--text2);font-size:18px;cursor:pointer;line-height:1;padding:0;min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
.modal-close:hover{color:var(--text)}
.modal-title{font-size:17px;font-weight:600;letter-spacing:-0.02em;margin-bottom:20px}
.modal-step{display:flex;gap:12px;margin-bottom:16px}
.modal-step-num{width:24px;height:24px;border-radius:50%;background:var(--accent2);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:1px}
.modal-step-body h4{font-size:13px;font-weight:500;margin-bottom:3px}
.modal-step-body p{font-size:12px;color:var(--text2);line-height:1.6}
code{font-family:var(--mono);font-size:11px;background:var(--bg3);padding:1px 5px;border-radius:3px;color:var(--accent)}
.divider{border:none;border-top:1px solid var(--border);margin:16px 0}

/* ── Inline msg ── */
.inline-msg{font-size:12px;margin-top:8px;display:none}
.inline-msg.ok{color:var(--green)}
.inline-msg.err{color:var(--red)}

/* Hamburger menu */
.hamburger{display:none;background:none;border:none;color:var(--text);font-size:24px;cursor:pointer;padding:0;line-height:1;border-radius:var(--radius-sm);transition:background var(--transition)}
.hamburger:hover{background:var(--bg3)}
.hamburger:active{background:var(--bg4)}
.mobile-menu{display:none;position:fixed;top:52px;left:0;right:0;background:var(--bg2);border-bottom:1px solid var(--border);z-index:100;flex-direction:column;padding:4px 0}
.mobile-menu.open{display:flex}
.mobile-menu-item{background:none;border:none;border-left:3px solid transparent;color:var(--text);padding:12px 20px;text-align:left;font-size:14px;cursor:pointer;font-family:inherit;min-height:44px;min-width:44px;display:flex;align-items:center}
.mobile-menu-item:hover{background:var(--bg3)}
.mobile-menu-item.active{background:var(--bg3);border-left-color:var(--accent);color:var(--text);font-weight:500}

@media(max-width:700px){
  .hamburger{display:flex;align-items:center;justify-content:center;min-width:44px;min-height:44px}
  .tab-nav{flex:1;overflow-x:auto;scrollbar-width:none;min-width:0;-webkit-overflow-scrolling:touch}
  .tab-nav::-webkit-scrollbar{display:none}
  .tab-nav-btn{white-space:nowrap;min-height:44px;flex-shrink:0;font-size:12px;padding:4px 8px}
  .topbar-sep{display:none}
  .topbar-brand{display:none}
  .topbar-right>button{display:none}
  .utilities-menu{display:none}
  .topbar-user-sep{display:none}
  .topbar-right{gap:12px}
  .user-pill{min-height:44px;padding:0 12px}
  .topbar{padding:0 12px;gap:8px}
  .home-title{font-size:22px}
  .home-subtitle{font-size:13px}
  .home-guide{font-size:12px}
  .compose-area{padding:12px}
  .section-card{padding:12px}
  .content-pane{padding:12px}
  .field-row{grid-template-columns:1fr}
  /* Sidebar: off-canvas drawer instead of hidden */
  .sidebar{position:fixed;top:52px;left:0;width:85%;max-width:320px;height:calc(100vh - 52px);z-index:90;transform:translateX(-100%);transition:transform 0.25s ease;border-right:1px solid var(--border)}
  .sidebar.mobile-open{transform:translateX(0)}
  /* Show toggle button on mobile */
  .sidebar-mobile-btn{display:inline-flex;margin-bottom:12px;gap:8px}
  /* Improved history items for mobile touch targets and readability */
  .hist-item{padding:12px 12px;min-height:52px;margin-bottom:4px;border:1px solid var(--border);background:var(--bg2)}
  .hist-item:hover,.hist-item.active{background:var(--bg3)}
  .hist-obj{font-size:14px;white-space:normal;overflow-wrap:break-word;word-break:break-word;line-height:1.4;margin-bottom:8px}
  .hist-meta{gap:8px}
  .hist-time{font-size:12px}
  .stat-grid{grid-template-columns:1fr 1fr 1fr}
  .stat-cell{padding:8px 10px}
  .stat-cell-value{font-size:16px}
  .fb-content.open{flex-direction:column;max-height:none}
  .fb-tree{width:100%;max-height:140px;border-right:none;border-bottom:1px solid var(--border)}
  .fb-preview{max-height:200px;overflow-x:auto}
  #job-status-card{max-width:100vw}
  .job-card{max-width:100%;overflow:hidden}
  #stream-panel{max-width:100%}
  .btn-icon{min-width:44px;min-height:44px}
  .modal-close{min-width:44px;min-height:44px;display:flex;align-items:center;justify-content:center}
  #feedback-btn{bottom:16px;right:16px;padding:14px 18px;min-width:44px}
  .provider-chips{flex-direction:column}
  .provider-chips .btn{width:100%}
  .section-card-body{padding:16px}
  .section-card{margin-bottom:20px}
  .example-card{padding:14px 16px;min-height:44px}
  .examples .example-card-text{font-size:14px}
}
@media(max-width:480px){
  #feedback-btn{width:44px;height:44px;padding:0;right:12px;bottom:16px;font-size:20px;display:flex;align-items:center;justify-content:center}
  #feedback-btn .feedback-label{display:none}
  /* Move toast stack above the feedback FAB (16px gap + 44px button + 16px clearance = 76px) */
  #toast-wrap{bottom:76px;right:12px;max-width:calc(100vw - 24px)}
  /* Prevent page content from being hidden behind the fixed feedback button */
  #tab-home.active{padding-bottom:76px}
  .content-pane{padding-bottom:76px}
}
@media(max-width:375px){
  .topbar{padding:0 4px;gap:2px}
  .topbar-logo{margin-right:2px}
  .topbar-logo-icon{width:24px;height:24px}
  .topbar-brand{font-size:13px}
  .tab-nav-btn{padding:4px 8px;font-size:10px;min-width:44px}
  .topbar-sep{display:none}
  .modal-backdrop{padding:12px}
  .modal{padding:16px;max-width:none}
  .status-content-wrapper{padding:12px 16px}
  .section-card-body{padding:16px}
  /* Public nav on 375px viewport */
  #public-screen > nav{padding:12px 8px!important;gap:4px!important}
  #public-screen > nav > div:last-child{gap:4px!important;flex-wrap:wrap}
  /* Dashboard text overflow fixes for 375px viewport */
  ._s-audit-status{word-break:break-word;overflow-wrap:break-word;white-space:normal;word-wrap:break-word;font-size:12px}
  ._s-digest-stats-strip{word-break:break-word;overflow-wrap:break-word;flex-direction:column;gap:12px;font-size:12px;padding:8px 12px}
  ._s-digest-stats-strip span{display:block;margin-bottom:0;word-break:break-word;overflow-wrap:break-word}
  .digest-worker-card{padding:10px;gap:8px;flex-direction:column}
  .digest-worker-info strong{font-size:12px}
  .digest-worker-info span{font-size:10px}
  .digest-worker-card .btn{white-space:nowrap;flex-shrink:0;align-self:flex-start}
}

/* Home tab */
#tab-home.active{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:calc(100vh - 56px);padding:40px 20px;text-align:center;position:relative;overflow-x:hidden;overflow-y:auto}
/* Scrollable content tabs — block layout so content is always visible */
#tab-faq.active,#tab-settings.active,#tab-admin.active,#tab-digest.active{display:block;min-height:calc(100vh - 52px);overflow-y:auto}
/* Static radial-gradient atmosphere — previously animated (rotate+scale+blur(30px))
   which caused constant repaints + compositing cost on every frame. The motion
   was barely visible under opacity:0.05 and wasn't worth the perf hit. */
#tab-home::before{content:'';position:absolute;inset:-10%;background:radial-gradient(circle at 20% 30%,var(--accent) 0%,transparent 40%),radial-gradient(circle at 80% 70%,var(--accent3) 0%,transparent 40%);opacity:0.05;pointer-events:none;z-index:0}
@media(prefers-reduced-motion:reduce){.shimmer::after{animation:none}.sparkle{animation:none}.btn:hover:not(:disabled)::before{animation:none}}
.home-logo,.home-title,.home-subtitle,.home-guide,.home-form,.example-chips,.apikey-warn{position:relative;z-index:1}
.home-logo{width:72px;height:72px;background:linear-gradient(135deg,var(--accent2),var(--accent3));border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:36px;margin:0 auto 24px;box-shadow:0 8px 32px var(--accent-glow)}
.home-title{font-size:32px;font-weight:700;margin-bottom:8px}
.home-subtitle{color:var(--text2);margin-bottom:8px;font-size:16px}
.home-guide{color:var(--text3);font-size:13px;margin-bottom:20px}
.home-form{width:100%;max-width:600px}
.home-input-header{display:flex;align-items:center;margin-bottom:8px}
.home-input-label{font-size:13px;font-weight:600;color:var(--text2);letter-spacing:0.03em}
.home-textarea{width:100%;min-height:120px;padding:16px 16px 28px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-family:var(--font);font-size:15px;resize:vertical;line-height:1.6;outline:none;transition:border-color var(--transition)}
.home-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-glow)}
/* Inside the demo card, the surrounding card background is var(--bg2) — same as the textarea — which made the textarea blend into the card and appear invisible/non-interactive. Use a darker shade for contrast. */
._s-content-card-mb32 .home-textarea{background:var(--bg);border-color:var(--border2)}
.home-submit{margin-top:12px;width:100%;padding:14px;font-size:16px;font-weight:600}
.home-submit:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.home-form .char-counter{font-size:11px}
.home-form .input-hint{font-size:12px;text-align:center}
.home-activity{width:100%;max-width:600px;margin-top:32px;text-align:left}
.home-section-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text3);margin:0 0 10px}
.home-recent-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.home-recent-item{padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:border-color var(--transition)}
.home-recent-item:hover{border-color:var(--accent)}
.home-recent-obj{font-size:13px;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:4px}
.home-recent-meta{display:flex;align-items:center;gap:8px}
.home-links{margin-top:16px;display:flex;gap:12px;justify-content:center}
.home-plan-hint{margin-top:14px;padding:12px 16px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);text-align:left}
.home-plan-hint-steps{display:flex;align-items:center;gap:6px;margin-bottom:8px;flex-wrap:wrap}
.plan-step{font-size:11px;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--bg3);color:var(--text2);border:1px solid var(--border)}
.plan-step-done{background:var(--green-dim);color:var(--green);border-color:transparent}
.plan-step-active{background:var(--accent-dim);color:var(--accent);border:1px solid var(--accent)}
.plan-step-arrow{font-size:11px;color:var(--text3)}
.home-plan-hint-desc{font-size:12px;color:var(--text2);margin:0;line-height:1.5}
.budget-bar{margin-top:12px;padding:10px 14px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);font-size:12px;color:var(--text2)}
.budget-bar-row{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}
.budget-bar-label{font-size:11px;color:var(--text3);text-transform:uppercase;letter-spacing:.04em}
.budget-bar-vals{display:flex;align-items:center;gap:12px;font-size:12px}
.budget-bar-spent{color:var(--text2)}
.budget-bar-remaining{color:var(--green);font-weight:500}
.budget-bar-remaining.warn{color:var(--yellow)}
.budget-bar-remaining.critical{color:var(--red)}
.budget-bar-track{height:4px;border-radius:2px;background:var(--bg4);overflow:hidden;margin-bottom:6px}
.budget-bar-fill{height:100%;border-radius:2px;background:var(--green);transition:width .35s ease,background .35s ease;width:var(--budget-width,0%)}
.budget-bar-fill.warn{background:var(--yellow)}
.budget-bar-fill.critical{background:var(--red)}
.budget-bar-hint{font-size:11px;color:var(--text3)}
.budget-bar-warn-msg{display:flex;align-items:center;gap:6px;margin-top:6px;padding:6px 10px;background:var(--yellow-dim);border:1px solid var(--yellow-border);border-radius:var(--radius-sm);font-size:11px;color:var(--yellow)}
.budget-bar-err-msg{display:flex;align-items:center;gap:6px;margin-top:6px;padding:6px 10px;background:var(--red-dim);border:1px solid var(--red-border);border-radius:var(--radius-sm);font-size:11px;color:var(--red)}
.example-chips{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:24px}
.example-chip{padding:6px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:99px;font-size:13px;cursor:pointer;transition:all var(--transition);color:var(--text2)}
.example-chip:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim);transform:scale(1.04)}
.home-examples{display:grid;grid-template-columns:repeat(2,1fr);gap:10px;width:100%;max-width:600px;margin-bottom:24px}
@media(max-width:600px){.home-examples{grid-template-columns:1fr;gap:8px}.home-examples .example-card{padding:16px 18px;min-height:44px}.example-card-text{font-size:14px}.example-card-tag{font-size:11px}}
.home-examples .example-card{padding:14px 16px}
.example-card-header{display:flex;align-items:center;gap:7px;margin-bottom:6px}
.example-card-icon{flex-shrink:0;opacity:0.75;color:var(--text)}
.example-card-icon svg{width:13px;height:13px;stroke-width:2;fill:none;stroke:currentColor;display:block}
.example-card-badge{margin-left:auto;font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:0.08em;padding:2px 6px;border-radius:99px;background:rgba(251,191,36,0.18);color:#fbbf24;border:1px solid rgba(251,191,36,0.4)}
[data-theme="light"] .example-card-badge{background:rgba(180,83,9,0.1);color:#b45309;border-color:rgba(180,83,9,0.35)}

/* ── Features page ── */
.features-list{list-style:none;display:flex;flex-direction:column;gap:24px;margin-bottom:32px}
.feature-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px 24px;display:flex;gap:16px;align-items:flex-start}
.feature-icon{font-size:32px;line-height:1;flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center}
@media(max-width:600px){.features-list{gap:16px}.feature-item{padding:16px 18px;gap:12px}.feature-icon{font-size:28px;width:40px;height:40px}}

/* Stream panel */
#stream-panel{display:none;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);margin-top:12px;overflow:hidden}
#stream-panel.visible{display:block}
.stream-header{padding:8px 14px;border-bottom:1px solid var(--border);font-size:12px;color:var(--text3);font-weight:500;letter-spacing:0.05em;text-transform:uppercase}
#stream-out{padding:14px;font-family:var(--mono);font-size:12px;line-height:1.7;white-space:pre-wrap;word-break:break-all;max-height:320px;overflow-x:auto;overflow-y:auto;color:var(--text2)}
#stream-out::after{content:'\25CC';animation:blink 1s step-end infinite;color:var(--accent)}
#stream-out.done::after{display:none}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0}}

/* Changelog */
.changelog-content{max-height:400px;overflow-y:auto;padding:4px 0}
.changelog-version{font-weight:600;color:var(--accent);margin:16px 0 8px}
.changelog-version:first-child{margin-top:0}
.changelog-item{color:var(--text2);padding:3px 0 3px 16px;position:relative;font-size:13px}
.changelog-item::before{content:'\2022';position:absolute;left:4px;color:var(--accent)}

/* Feedback button */
#feedback-btn{position:fixed;bottom:24px;right:24px;left:auto;z-index:900;background:var(--bg3);border:1px solid var(--border2);border-radius:99px;padding:14px 20px;min-height:44px;font-size:13px;cursor:pointer;color:var(--text2);transition:all var(--transition);box-shadow:0 4px 16px rgba(0,0,0,0.3);backdrop-filter:blur(8px)}
#feedback-btn:hover{color:var(--text);border-color:var(--accent);background:var(--accent-dim);transform:scale(1.04)}
#feedback-btn:active{transform:scale(0.98)}
@media(max-width:700px){#feedback-btn{bottom:16px;right:16px;padding:14px 18px;min-width:44px}}
@media(max-width:480px){#feedback-btn{width:44px;height:44px;padding:0;right:12px;bottom:16px;font-size:20px;display:flex;align-items:center;justify-content:center}#feedback-btn .feedback-label{display:none}}

/* Provider chips */
.provider-chips .btn{min-width:70px;min-height:44px}

/* Badge for done_with_errors */
.badge-warn{background:var(--yellow-dim);color:var(--yellow)}

/* Sparkle animation */
@keyframes sparkle{0%,100%{transform:scale(1)}25%,75%{transform:scale(1.05)}}
.sparkle{animation:sparkle 1s ease}

/* FAQ */
.faq-container{display:flex;flex-direction:column;gap:12px;width:100%}
.faq-item{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition)}
.faq-item:hover{border-color:var(--border2)}
.faq-item summary{padding:16px 20px;font-size:14px;font-weight:600;color:var(--text);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;user-select:none;background:var(--bg2)}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-family:var(--mono);font-size:18px;color:var(--accent);transition:transform var(--transition);line-height:1}
.faq-item[open]{background:var(--bg3);border-color:var(--border2);box-shadow:inset 3px 0 0 var(--accent)}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item[open] summary{background:var(--bg3);border-bottom:1px solid var(--border2)}
.faq-content{padding:16px 20px;font-size:13px;color:var(--text2);line-height:1.6;background:var(--bg)}
.faq-content strong{color:var(--text);font-weight:600}
/* ── How-to-Run Tutorial ── */
.tutorial-modal .os-selector{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}
.tutorial-modal .os-btn{padding:8px 14px;border:2px solid var(--border);border-radius:8px;background:var(--bg2);color:var(--text);cursor:pointer;font-size:13px;font-weight:500;transition:all var(--transition)}
.tutorial-modal .os-btn.active{border-color:var(--accent);background:var(--accent);color:#fff}
.tutorial-modal .os-pane{display:none}
.tutorial-modal .os-pane.active{display:block}
.tutorial-step{display:flex;gap:12px;align-items:flex-start;margin-bottom:14px}
.tutorial-step-num{min-width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}
.tutorial-step-body h4{margin:0 0 4px;font-size:13px;color:var(--text)}
.tutorial-step-body p{margin:0;font-size:12px;color:var(--text2);line-height:1.5}
.tutorial-cmd{display:block;background:var(--bg4);border:1px solid var(--border);border-radius:6px;padding:8px 12px;font-family:var(--mono);font-size:12px;color:var(--text);margin-top:6px;white-space:pre}
.run-guide-btn{margin-top:8px;display:inline-block;padding:4px 10px;font-size:11px;border:1px solid var(--accent);border-radius:4px;background:transparent;color:var(--accent);cursor:pointer;transition:all var(--transition)}

/* ── 404 not-found page ── */
.not-found-wrap{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:16px;text-align:center;padding:40px}
.not-found-code{font-size:80px;font-weight:700;color:var(--border2);line-height:1;letter-spacing:-0.05em;border-left:4px solid var(--accent);padding-left:16px}
.not-found-title{font-size:28px;font-weight:700;letter-spacing:-0.03em;color:var(--text);margin:0}
.not-found-sub{font-size:14px;color:var(--text2);max-width:320px;margin:0}
.run-guide-btn:hover{background:var(--accent);color:#fff}

/* ── Auth input border contrast improvements ── */
.auth-card input[type=text],
.auth-card input[type=password]{
  border-width:2px;
  border-color:rgb(100,120,150);
}
.auth-card input[type=text]:focus,
.auth-card input[type=password]:focus{
  background:rgba(66,135,245,0.06);
}

/* ── Tablet (701–820px) — topbar compact mode ─────────────────────────
   At 768px the desktop topbar requires ~819px minimum (5 nav buttons at
   6px/14px padding, 16px gaps, 20px side padding). Without a compact
   breakpoint the topbar overflows the viewport by ~51px. These rules
   reclaim ~80px by: tightening side padding (-8px), removing the
   topbar separator (-9px+1 gap), reducing gaps (-12px), and narrowing
   nav-button padding (-40px). Total saved ≈ 81px — topbar now fits
   comfortably inside 768px. The mobile hamburger layout (<= 700px) is
   unaffected. */
@media(min-width:701px) and (max-width:820px){
  .topbar{padding:0 16px;gap:12px}
  .topbar-sep{display:none}
  .tab-nav-btn{padding:4px 8px;font-size:12px}
}
@media(min-width:768px) and (max-width:1199px){
  .content-pane{padding:var(--space-5)}
  .compose-area{padding:var(--space-4)}
  .status-content-wrapper{padding:var(--space-4) var(--space-5)}
  .section-card-body{padding:var(--space-4)}
  .section-card{margin-bottom:var(--space-5)}
}


/* ── Utility classes: extracted from inline styles (CSP safe) ── */
._s-accent{color:var(--accent)}
._s-accordion-trigger{padding:8px 16px;cursor:pointer;display:flex;align-items:center;justify-content:space-between;list-style:none;-webkit-appearance:none;user-select:none}
._s-badge-passed{margin-left:auto;padding:3px 10px;background:var(--green-dim);color:var(--green);border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
._s-bg4-text2{background:var(--bg4);color:var(--text2)}
._s-body-mb14{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:14px}
._s-body-mb18{font-size:14px;color:var(--text2);line-height:1.75;margin-bottom:18px}
._s-btn-block-mt16{display:block;margin-top:16px;text-decoration:none}
._s-btn-green{background:var(--green,#27ae60);color:#111;border-color:var(--green,#27ae60)}
._s-caption{font-size:13px;color:var(--text3);line-height:1.6}
._s-card-body{font-size:15px;color:var(--text2);line-height:1.65;margin:0}
._s-card-heading{font-size:15px;font-weight:700;margin-bottom:10px}
._s-center-mt16{text-align:center;margin-top:16px}
._s-center-mt20{text-align:center;margin-top:20px}
._s-center-mt8{text-align:center;margin-top:8px}
._s-center-pt20{text-align:center;padding:12px 0 20px}
._s-chevron-icon{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;transition:transform 0.2s}
._s-code-tag{font-size:11px;background:var(--bg3);border:1px solid var(--border);border-radius:3px;color:var(--text2);padding:2px 6px}
._s-container-660{max-width:660px;margin:0 auto;width:100%}
._s-container-720{max-width:720px;margin:0 auto;width:100%}
._s-container-800{max-width:800px;margin:0 auto;width:100%}
._s-content-card{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px}
._s-content-card-mb32{background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-lg);padding:28px 24px;margin-bottom:32px}
._s-debug-panel{display:none;font-size:10px;color:var(--text3);background:var(--bg3);padding:6px 8px;border-radius:4px;margin:0 0 8px;word-break:break-all;white-space:pre-wrap;max-height:120px;overflow-y:auto}
._s-demo-code-block{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:14px;margin-bottom:12px}
._s-demo-gate{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:14px}
._s-demo-gate-body{background:var(--bg3);padding:14px 20px;font-size:12px;font-family:var(--mono);color:var(--text2);line-height:1.8}
._s-demo-gate-body2{background:var(--bg3);padding:14px 20px;font-size:12px;font-family:var(--mono);color:var(--text2);line-height:1.9}
._s-demo-gate-header{background:var(--bg2);padding:14px 20px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--border)}
._s-demo-gate-italic{background:var(--bg3);padding:14px 20px;font-size:13px;color:var(--text2);font-style:italic;line-height:1.65}
._s-demo-gate-last{border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:36px}
._s-demo-gate-num{width:28px;height:28px;background:var(--accent-dim);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--accent);flex-shrink:0}
._s-demo-gate-num-done{width:28px;height:28px;background:var(--green-dim);border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:var(--green);flex-shrink:0}
._s-demo-notice{display:none;background:var(--accent-dim);border:1px solid var(--accent);border-radius:var(--radius);padding:12px 16px;font-size:13px;color:var(--text2)}
._s-divider-margin{margin:20px 0}
._s-divider-mt8{margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
._s-eyebrow{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:0.08em;color:var(--text3);margin-bottom:20px}
._s-feature-desc{font-size:15px;color:var(--text2);line-height:1.6;display:inline-block}
._s-features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;margin-bottom:48px}
._s-file-link{font-size:13px;color:var(--green);font-weight:500;word-break:break-all;text-decoration:underline}
._s-flex-afs-gap10{display:flex;align-items:flex-start;gap:10px}
._s-flex-ai-gap10{display:flex;align-items:center;gap:10px}
._s-flex-ai-gap10-mb14{display:flex;align-items:center;gap:10px;margin-bottom:14px}
._s-flex-ai-gap12{display:flex;align-items:center;gap:12px}
._s-flex-ai-gap6{display:flex;align-items:center;gap:6px}
._s-flex-ai-gap7{display:flex;align-items:center;gap:7px}
._s-flex-ai-gap8{display:flex;align-items:center;gap:8px}
._s-flex-ai-gap8-mt8{display:flex;align-items:center;gap:8px;margin-top:8px}
._s-flex-center-border-top{display:flex;justify-content:center;padding-top:16px;border-top:1px solid var(--border)}
._s-flex-end-border-top{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;border-top:1px solid var(--border)}
._s-flex-end-border-top-mt16{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;margin-top:16px;border-top:1px solid var(--border)}
._s-flex-end-border-top-mt8{display:flex;justify-content:flex-end;gap:8px;padding-top:16px;margin-top:8px;border-top:1px solid var(--border)}
._s-flex-gap12{display:flex;gap:12px}
._s-flex-gap12-wrap{display:flex;gap:12px;flex-wrap:wrap}
._s-flex-gap6-mt4{display:flex;gap:6px;flex-wrap:wrap;margin-top:4px}
._s-flex-gap8{display:flex;gap:8px;align-items:center}
._s-flex-gap8-ai{display:flex;gap:8px;align-items:center}
._s-flex-sb{display:flex;align-items:center;justify-content:space-between}
._s-flex-sb-mb20{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}
._s-flex-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
._s-flex1{flex:1;min-width:0}
._s-footer-links{margin-top:8px;display:flex;justify-content:center;gap:20px;flex-wrap:wrap}
._s-fs10-text3{font-size:10px;color:var(--text3)}
._s-fs11-break{font-size:11px;word-break:break-all}
._s-fs11-text2{font-size:11px;color:var(--text2)}
._s-fs11-text2-mv{font-size:11px;color:var(--text2);margin:4px 0 2px 0}
._s-fs12-fw4-text2{font-size:12px;font-weight:400;color:var(--text2)}
._s-fs12-minheight60{font-size:12px;min-height:60px}
._s-fs12-text-mb3{font-size:12px;color:var(--text);margin-bottom:3px}
._s-fs12-text2{font-size:12px;color:var(--text2)}
._s-fs12-text2-border-top{font-size:12px;color:var(--text2);margin-top:8px;border-top:1px solid var(--border);padding-top:8px}
._s-fs12-text2-mb10{font-size:12px;color:var(--text2);margin-bottom:10px}
._s-fs12-text2-mb6{font-size:12px;color:var(--text2);margin-bottom:6px}
._s-fs13{font-size:13px}
._s-fs13-text2-mb14{font-size:13px;color:var(--text2);margin:0 0 14px}
._s-fs13-text2-mb16{font-size:13px;color:var(--text2);margin:0 0 16px}
._s-fw4-plain-text3{font-weight:400;text-transform:none;letter-spacing:0;color:var(--text3)}
._s-fw4-text3{font-weight:400;color:var(--text3)}
._s-fw5-text{font-weight:500;color:var(--text)}
._s-fw6{font-weight:600}
._s-fw6-mb8{font-weight:600;margin-bottom:8px}
._s-fw6-mb8-green{font-weight:600;margin-bottom:8px;color:var(--green)}
._s-gap10{gap:10px}
._s-gate-title{font-weight:600;font-size:14px}
._s-green-fw6{color:var(--green);font-weight:600}
._s-green-fw6-mb6{color:var(--green);font-weight:600;margin-bottom:6px}
._s-hero-sub{font-size:17px;color:var(--text2);margin-bottom:48px;line-height:1.75}
._s-hero-sub2{font-size:16px;color:var(--text2);margin-bottom:32px;line-height:1.7}
._s-hero-sub3{font-size:16px;color:var(--text2);margin-bottom:40px;line-height:1.75}
._s-hero-title{font-size:36px;font-weight:700;letter-spacing:-0.03em;margin-bottom:12px}
._s-hero-title-mb16{font-size:36px;font-weight:700;letter-spacing:-0.03em;margin-bottom:16px}
._s-hidden-border-top{display:none;border-top:1px solid var(--border)}
._s-hidden-mb14{display:none;margin-bottom:14px}
._s-home-heading{font-size:20px;font-weight:700;letter-spacing:-0.02em}
._s-home-heading-mb20{font-size:20px;font-weight:700;margin-bottom:20px;letter-spacing:-0.02em}
._s-icon-40{width:40px;height:40px;font-size:16px}
._s-icon-center{display:block;margin:0 auto 12px}
._s-icon-shrink0{flex-shrink:0;margin-top:1px}
._s-info-panel{display:none;padding:10px 16px;border-top:1px solid var(--border)}
._s-inline-code{font-size:11px;background:var(--bg3);padding:1px 5px;border-radius:3px}
._s-label-sm{font-size:11px;font-weight:600;color:var(--text2);text-transform:uppercase;letter-spacing:.05em}
._s-mb12{margin-bottom:12px}
._s-mb12-text2-sm{margin-bottom:12px;color:var(--text2);font-size:13px}
._s-mb20-text2{margin-bottom:20px;color:var(--text2)}
._s-mb8{margin-bottom:8px}
._s-meta-sm{font-size:12px;color:var(--text3)}
._s-mono-code{font-family:monospace;font-size:13px;line-height:1.8}
._s-mt0{margin-top:0}
._s-mt10{margin-top:10px}
._s-mt12-mb8{margin-top:12px;margin-bottom:8px}
._s-mt14{margin-top:14px}
._s-mt16{margin-top:16px}
._s-mt4{margin-top:4px}
._s-mt6-preline{margin-top:6px;white-space:pre-line}
._s-mt8{margin-top:8px}
._s-mt8-fs11-text3{margin-top:8px;font-size:11px;color:var(--text3)}
._s-mw140{max-width:140px}
._s-mw180{max-width:180px}
._s-mw400{max-width:400px}
._s-mw420{max-width:420px}
._s-mw440{max-width:440px}
._s-mw480{max-width:480px}
._s-mw520-mb12{max-width:520px;margin-bottom:12px}
._s-mw560{max-width:560px}
._s-ol-styled{font-size:14px;color:var(--text2);line-height:2.1;padding-left:20px;margin-bottom:16px}
._s-ol-decimal{margin:0;padding-left:16px;list-style:decimal}
._s-p0{padding:0}
._s-p0-8-8{padding:0 8px 8px}
._s-p4-8{padding:4px 8px}
._s-pointer{cursor:pointer}
._s-public-landing{max-width:800px;margin:60px auto;padding:0 32px 80px;width:100%}
._s-landing-hero{text-align:center;margin-bottom:64px}
._s-landing-title{font-size:48px;font-weight:700;letter-spacing:-0.03em;margin-bottom:16px;line-height:1.2}
._s-landing-subtitle{font-size:20px;color:var(--text2);margin-bottom:32px;line-height:1.6}
._s-landing-ctas{margin-bottom:16px}
._s-cta-large{padding:16px 32px;font-size:16px;min-height:auto;font-weight:600}
._s-cta-subtext{font-size:14px;color:var(--text3);margin-top:12px}
._s-landing-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:24px;margin-bottom:48px}
._s-feature-item{padding:20px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);text-align:center;transition:all 0.2s ease}
._s-feature-item:hover{border-color:var(--accent);box-shadow:0 4px 12px rgba(91,141,238,0.1)}
._s-feature-icon{font-size:32px;margin-bottom:12px}
._s-feature-name{font-size:14px;font-weight:600;color:var(--text);margin-bottom:8px}
._s-feature-desc{font-size:13px;color:var(--text2);line-height:1.5}
._s-landing-links{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
@media(max-width:767px){._s-public-landing{margin:40px auto;padding:0 16px 60px}._s-landing-title{font-size:32px}._s-landing-subtitle{font-size:16px;margin-bottom:24px}._s-cta-large{padding:14px 24px;font-size:14px}._s-landing-features{grid-template-columns:repeat(2,1fr);gap:16px}._s-landing-links{gap:8px}}
@media(max-width:480px){._s-public-landing{margin:32px auto;padding:0 12px 40px}._s-landing-title{font-size:24px}._s-landing-subtitle{font-size:14px}._s-landing-features{grid-template-columns:1fr}._s-landing-links{flex-direction:column}}
._s-public-about{max-width:720px;margin:80px auto;padding:0 32px;width:100%}
._s-public-demo{max-width:760px;margin:48px auto;padding:0 32px 64px;width:100%}
._s-public-features{max-width:720px;margin:60px auto;padding:0 24px;width:100%}
._s-features-signin{width:100%;margin-top:24px;padding-top:24px;border-top:1px solid var(--border)}
._s-features-signin .field-label{display:block;margin-bottom:8px;font-size:1rem;color:var(--text2)}
._s-features-signin .field-input{flex:1;min-width:0;padding:8px 12px;min-height:44px;border:1px solid var(--border);border-radius:var(--radius);background:var(--bg2);color:var(--text);font-size:1rem}
._s-public-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-bottom:1px solid var(--border);pointer-events:auto}
@media(max-width:480px){._s-public-nav{padding:16px 12px;flex-wrap:wrap;gap:8px;row-gap:8px}._s-public-nav>div:last-child{flex-wrap:wrap;gap:8px}._s-public-nav .btn{padding:8px 12px;font-size:12px}}
._s-auth-header{width:100%;border-bottom:1px solid var(--border);pointer-events:auto}
._s-auth-nav{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;pointer-events:auto}
@media(max-width:480px){._s-auth-nav{padding:16px 12px;flex-wrap:wrap;gap:8px;row-gap:8px}._s-auth-nav>div:last-child{flex-wrap:wrap;gap:8px}._s-auth-nav .btn{padding:8px 12px;font-size:12px}}
._s-public-screen{position:fixed;inset:0;z-index:999;overflow-x:hidden;overflow-y:auto;display:flex;flex-direction:column;background:radial-gradient(ellipse 60% 50% at 50% -10%,var(--auth-glow),transparent);pointer-events:none}
._s-public-screen>main,._s-public-screen>header{pointer-events:auto}
._s-qr-wrap{display:inline-block;background:#fff;padding:8px;border-radius:6px;border:1px solid var(--border)}
._s-red{color:var(--red)}
._s-scrollbox{max-height:360px;overflow-y:auto;border:1px solid var(--border);border-radius:var(--radius-sm)}
._s-section-heading{font-size:17px;font-weight:700;margin-bottom:10px}
._s-sent-state{display:none;text-align:center;padding:12px 0 8px}
._s-sm-info-panel{display:none;padding:8px 16px;font-size:12px;color:var(--text2);border-top:1px solid var(--border)}
._s-status-done{font-size:10px;font-weight:700;color:var(--green);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
._s-status-error{font-size:10px;font-weight:700;color:var(--red,#e74c3c);text-transform:uppercase;letter-spacing:.05em;margin-bottom:2px}
._s-status-running{font-size:11px;font-weight:700;color:var(--yellow,#f39c12);text-transform:uppercase;letter-spacing:.05em;margin-bottom:6px}
._s-success-panel{display:none;padding:10px 16px;border-top:1px solid var(--border);background:var(--green-dim)}
._s-tag-row{padding:4px 0 6px;display:flex;gap:6px;align-items:center}
._s-text{color:var(--text)}
._s-text-right-mt6{text-align:right;margin-top:6px}
._s-text2{color:var(--text2)}
._s-text2-sm{font-size:13px;color:var(--text2)}
._s-text3{color:var(--text3)}
._s-text3-mb6{color:var(--text3);margin-bottom:6px}
._s-text3-mb8{color:var(--text3);margin-bottom:8px}
._s-text3-mt4{color:var(--text3);margin-top:4px}
._s-text3-sm{color:var(--text3);font-size:13px}
._s-textarea-min{min-height:100px;resize:vertical}
._s-tfa-input{letter-spacing:0.2em;font-size:18px;text-align:center}
._s-w100-jsb{width:100%;justify-content:space-between}
._s-w5pct{width:5%}
._s-warn-panel{display:none;padding:12px 16px;border-top:1px solid var(--border);background:rgba(243,156,18,0.07)}
._s-warn-text-sm{display:none;font-size:10px;color:var(--yellow);margin-top:2px}
.d-none{display:none !important}

/* ── CSP-safe utility classes (replaces all remaining inline style= attributes) ── */

/* Margin / padding */
._s-mb4{margin-bottom:4px}
._s-mb8{margin-bottom:8px}
._s-mb16{margin-bottom:16px}
._s-p14{padding:14px}

/* Typography */
._s-text3-xs{color:var(--text3);font-size:11px}
._s-text3-2xs{color:var(--text3);font-size:12px}
._s-text3-xs-mt4{color:var(--text3);font-size:11px;margin-top:4px}
._s-text3-xs-ml8{color:var(--text3);font-size:11px;margin-left:8px}
._s-text2-sm-prewrap{color:var(--text2);font-size:13px;white-space:pre-wrap}
._s-text2-sm-mb12{font-size:13px;color:var(--text2);margin-bottom:12px}
._s-red-sm{color:var(--red);font-size:13px}
._s-red-xs{color:var(--red);font-size:13px}
._s-fw500-sm{font-weight:500;font-size:13px}
._s-spin-sm{font-size:10px}
._s-opacity-half{opacity:0.5}

/* Flexbox layout */
._s-flex-wrap-g8{display:flex;gap:8px;flex-wrap:wrap}
._s-flex-wrap-g6{display:flex;gap:6px;flex-wrap:wrap}
._s-flex-wrap-g8-ac{display:flex;gap:8px;flex-wrap:wrap;align-items:center}
._s-flex-g8-center{display:flex;gap:8px;align-items:center}
._s-flex-g8-noshrink{display:flex;gap:8px;align-items:center;flex-shrink:0}
._s-flex-jsb-mb4{display:flex;justify-content:space-between;margin-bottom:4px}
._s-flex-jsb-g6-wrap{display:flex;align-items:center;justify-content:space-between;gap:6px;flex-wrap:wrap}
._s-flex-g5-f1{display:flex;align-items:center;gap:5px;min-width:0;flex:1}

/* Card / entry patterns */
._s-card-entry{background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:8px}
._s-err-td{color:var(--red);padding:12px}
._s-code-cell{word-break:break-all;cursor:pointer}
._s-scrollbox-lg{max-height:500px;overflow-y:auto}
._s-fb-loading{padding:8px;font-size:11px;color:var(--text2)}
._s-audit-empty{padding:12px 16px;font-size:12px;color:var(--text3)}

/* Digest tab */
._s-digest-h2{margin:0;font-size:18px;font-weight:600}
._s-digest-subtitle{margin:4px 0 0;font-size:13px;color:var(--text3)}
._s-digest-stats-strip{display:flex;gap:20px;flex-wrap:wrap;font-size:13px;margin-bottom:20px;padding:10px 14px;background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius-sm)}
._s-audit-status{display:none;margin-top:10px;font-size:13px;padding:8px 12px;background:var(--bg3);border-radius:var(--radius-sm);border:1px solid var(--border)}
._s-digest-worker-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border)}
._s-worker-name{font-weight:500;font-size:13px}
._s-worker-jobs{color:var(--text3);font-size:11px;margin-left:8px}
.digest-worker-card{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;padding:12px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;min-width:0}
.digest-worker-info{flex:1;min-width:0}
.digest-worker-info strong{display:block;font-weight:600;font-size:13px;margin-bottom:6px;word-break:break-word;overflow-wrap:break-word}
.digest-worker-info .badge{margin-right:6px;margin-bottom:4px}
.digest-worker-info span{display:block;font-size:11px;color:var(--text3);margin-top:3px;word-break:break-word;overflow-wrap:break-word}

/* ── Public landing pipeline ── */
._s-section-label{font-size:11px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text3);margin-bottom:14px;margin-top:48px}
._s-pipeline-flow{display:flex;align-items:center;gap:8px;margin-bottom:12px;overflow-x:auto;-webkit-overflow-scrolling:touch;padding-bottom:6px}
._s-pipeline-gate{flex:1;min-width:108px;background:var(--bg2);border:1px solid var(--border);border-radius:var(--radius);padding:14px 10px;text-align:center}
._s-pipeline-gate-num{width:24px;height:24px;background:var(--accent-dim);border-radius:6px;font-size:11px;font-weight:700;color:var(--accent);display:inline-flex;align-items:center;justify-content:center;margin:0 auto 8px}
._s-pipeline-gate-name{font-size:12px;font-weight:700;letter-spacing:0.06em;color:var(--text);margin-bottom:5px}
._s-pipeline-gate-desc{font-size:11px;color:var(--text3);line-height:1.5}
._s-pipeline-gate-ship ._s-pipeline-gate-num{background:var(--green-dim);color:var(--green)}
._s-pipeline-arrow{color:var(--text3);font-size:14px;flex-shrink:0}
._s-pipeline-sub{font-size:13px;color:var(--text3);margin-bottom:40px}
._s-pipeline-link{background:none;border:none;color:var(--accent);font-size:13px;cursor:pointer;padding:18px 20px;font-family:inherit;text-decoration:underline;display:flex;align-items:center;line-height:1.2;min-height:44px}
._s-pipeline-link:hover{color:var(--text)}
@media(max-width:767px){._s-pipeline-flow{flex-direction:column;overflow-x:visible}._s-pipeline-gate{min-width:0;width:100%;display:flex;align-items:flex-start;gap:12px;text-align:left;padding:12px 14px}._s-pipeline-gate-num{flex-shrink:0;margin:0}._s-pipeline-gate-desc{margin-bottom:0}._s-pipeline-arrow{transform:rotate(90deg);align-self:center}}

/* Storage section */
._s-storage-stats{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;margin-bottom:12px}
._s-progress-track{height:6px;background:var(--bg4);border-radius:3px;overflow:hidden}
._s-progress-fill{height:100%;border-radius:3px;transition:width 0.5s ease}
._s-warn-disk{color:var(--yellow);font-size:12px;margin-top:8px}

/* Audit timeline (job detail) */
._s-audit-row{display:flex;gap:0;border-bottom:1px solid var(--border)}
._s-row-failed{background:rgba(231,76,60,0.04)}
._s-audit-dot-col{width:28px;flex-shrink:0;display:flex;flex-direction:column;align-items:center;padding-top:11px}
._s-audit-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}
._s-dot-red{background:var(--red,#e74c3c)}
._s-dot-green{background:var(--green,#27ae60)}
._s-dot-accent{background:var(--accent)}
._s-dot-border{background:var(--border)}
._s-audit-connector{width:1px;background:var(--border);flex:1;min-height:6px;margin-top:2px}
._s-audit-body{flex:1;min-width:0;padding:7px 10px 7px 4px}
._s-event-tag{font-size:9px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;padding:1px 5px;border-radius:3px;background:var(--bg3);color:var(--text2)}
._s-audit-step{font-size:11px;color:var(--text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}
._s-result-ok{font-size:10px;font-weight:600;color:var(--green,#27ae60)}
._s-result-fail{font-size:10px;font-weight:600;color:var(--red,#e74c3c)}
._s-audit-ts{font-size:10px;color:var(--text3);font-family:var(--mono)}
._s-stderr-snippet{margin-top:5px;padding:4px 8px;background:rgba(231,76,60,0.07);border-left:2px solid var(--red,#e74c3c);border-radius:2px;font-size:10px;color:var(--text2);font-family:var(--mono);word-break:break-all;white-space:pre-wrap}

/* Projects tab */
._s-proj-body{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}
._s-proj-info{min-width:0;flex:1}
._s-proj-title{font-weight:600;font-size:14px;margin-bottom:6px;word-break:break-word}
._s-proj-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
._s-proj-actions{display:flex;gap:8px;align-items:center;flex-shrink:0}
._s-proj-rel-time{font-size:11px;color:var(--text3)}
._s-proj-empty-state{text-align:center;padding:32px 0}
._s-proj-state-msg{font-size:13px;color:var(--text3)}
._s-proj-err-msg{font-size:13px;color:var(--red)}
._s-proj-card{margin-bottom:12px}
.badge-inactive{background:var(--bg4);color:var(--text2)}
/* Plan step list states */
._s-step-li{font-size:12px;margin-bottom:2px}
._s-step-done{color:var(--green,#2ecc71)}
._s-step-active{color:var(--accent,#5b8dee)}
._s-step-pending{color:var(--text2)}

/* Gates pipeline (job execution progress) */
._s-gates-pipeline{margin-top:12px;padding:10px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
._s-gates-label{font-size:10px;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--text3);margin-bottom:8px;padding:0 16px}
._s-gates-flow{display:flex;align-items:center;gap:6px;margin:0;padding:0 16px;overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:4px}
._s-gate-item{display:flex;flex-direction:column;align-items:center;gap:4px;flex-shrink:0;min-width:fit-content}
._s-gate-badge{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:4px;font-size:11px;font-weight:700;flex-shrink:0}
._s-gate-name{font-size:10px;font-weight:600;color:var(--text2);white-space:nowrap;letter-spacing:0.03em}
._s-gate-item._s-gate-done ._s-gate-badge{background:var(--green-dim);color:var(--green)}
._s-gate-item._s-gate-done ._s-gate-name{color:var(--green)}
._s-gate-item._s-gate-active ._s-gate-badge{background:var(--accent-dim);color:var(--accent);box-shadow:0 0 0 2px var(--accent)}
._s-gate-item._s-gate-active ._s-gate-name{color:var(--accent);font-weight:700}
._s-gate-item._s-gate-failed ._s-gate-badge{background:var(--red-dim);color:var(--red)}
._s-gate-item._s-gate-failed ._s-gate-name{color:var(--red)}

/* Gate status display */
._s-gate-status-container{padding:12px 16px;background:var(--accent-dim);border:1px solid var(--accent);border-radius:6px;margin-bottom:12px}
._s-gate-current-status{display:flex;flex-direction:column;gap:6px}
._s-gate-progress{font-size:11px;font-weight:600;color:var(--accent);text-transform:uppercase;letter-spacing:0.05em}
._s-gate-current-name{font-size:13px;font-weight:600;color:var(--text);line-height:1.4}

/* File browser states */
._s-fb-error{padding:8px;font-size:11px;color:var(--red)}

/* Security visibility callout */
._s-security-callout{background:linear-gradient(135deg, rgba(91,141,238,0.08) 0%, rgba(46,204,113,0.08) 100%);border:1px solid var(--accent);border-radius:6px;padding:12px 16px;margin-bottom:12px}
._s-security-header{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:600;color:var(--accent);margin-bottom:8px;text-transform:uppercase;letter-spacing:0.05em}
._s-security-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}
._s-security-item{padding:8px;background:rgba(91,141,238,0.04);border:1px solid var(--accent-dim);border-radius:4px}
._s-security-label{font-size:10px;font-weight:700;color:var(--text3);text-transform:uppercase;letter-spacing:0.1em;margin-bottom:4px}
._s-security-value{font-size:11px;color:var(--text);font-weight:500}

/* Audit trail summary styling */
._s-audit-summary{display:flex;flex-direction:column;gap:4px;padding:12px;background:var(--bg2)}
._s-audit-desc{font-size:11px;color:var(--text2);font-weight:400;letter-spacing:0.02em}

/* Security promise callout (homepage) */
._s-security-promise{background:linear-gradient(135deg, rgba(91,141,238,0.12) 0%, rgba(46,204,113,0.12) 100%);border:2px solid var(--accent);border-radius:8px;padding:32px;margin-bottom:32px}
._s-security-promise-title{font-size:18px;font-weight:700;color:var(--text);margin-bottom:24px;letter-spacing:-0.02em}
._s-security-promise-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
._s-security-promise-item{padding:20px;background:var(--bg1);border:1px solid var(--accent);border-radius:6px;transition:all 0.2s ease}
._s-security-promise-item:hover{background:var(--bg2);border-color:var(--accent);box-shadow:0 4px 12px rgba(91,141,238,0.15)}
._s-security-promise-icon{font-size:28px;margin-bottom:12px;display:block}
._s-security-promise-label{font-size:13px;font-weight:600;color:var(--text);margin-bottom:8px;letter-spacing:-0.01em}
._s-security-promise-desc{font-size:12px;color:var(--text2);line-height:1.5;letter-spacing:-0.01em}

/* Demo simulation styling - replaces inline styles in auth.js */
._demo-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-top:14px;margin-bottom:6px}
._demo-line{font-family:var(--mono);font-size:12px;line-height:1.9;color:var(--text2)}
._demo-line-green{font-family:var(--mono);font-size:12px;line-height:1.9;color:var(--green)}
._demo-line-red{font-family:var(--mono);font-size:12px;line-height:1.9;color:var(--red)}
._demo-box{font-family:var(--mono);font-size:12px;line-height:1.9;color:var(--text2);margin-bottom:6px}
._demo-box-ship{margin-bottom:14px!important}
._demo-divider{padding-top:12px;border-top:1px solid var(--accent)}
._demo-note{font-size:13px;margin-bottom:10px;line-height:1.5}
._demo-badge-sim{display:inline-block;padding:3px 10px;background:var(--accent-dim);color:var(--accent);border-radius:20px;font-size:11px;font-weight:700;letter-spacing:.05em;margin-bottom:10px}
._demo-spec-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:6px}
._demo-spec-text{font-style:italic;line-height:1.65;margin-bottom:10px}
._demo-category-row{display:flex;align-items:center;gap:10px;margin-bottom:14px;flex-wrap:wrap}
._demo-category-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;background:var(--accent-dim,rgba(99,102,241,.15));color:var(--accent);border-radius:4px;padding:2px 8px}
._demo-something-else-link{background:none;border:none;padding:0;font-size:11px;color:var(--text3,#888);cursor:pointer;text-decoration:underline;text-underline-offset:2px}
._demo-hint{font-size:12px;color:var(--text2);background:var(--bg3,#1e1e2e);border-radius:4px;padding:8px 12px;margin-top:6px}
._demo-plan-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.07em;color:var(--accent);margin-bottom:6px}
._demo-plan-list{font-family:var(--mono);font-size:12px;line-height:1.9;color:var(--text2)}
._demo-notice-box{background:var(--bg2);border:1px solid var(--accent);border-radius:var(--radius);padding:16px 20px;font-size:13px;color:var(--text2);display:block}
/* CSP-safe utility classes — migrated from inline styles */
._s-w100{width:100%}
._s-fw500{font-weight:500}
._s-summary-flex{display:flex;align-items:center;width:100%}
._s-deploy-status-divider{margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}

/* Display utilities for CSP compliance */
.d-block{display:block !important}
.d-inline-block{display:inline-block !important}
.d-flex{display:flex !important}
.d-inline-flex{display:inline-flex !important}
.d-grid{display:grid !important}
.visible{visibility:visible !important}

/* Timeout warning styles (migrated from inline styles) */
._warn-title{color:var(--orange,#f39c12);font-weight:500}
._warn-subtitle{color:var(--orange,#f39c12);font-size:0.9em}
