/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

/* ── Design tokens ── */
:root{
  --bg:#04060f;
  --surface:rgba(255,255,255,.04);
  --surface2:rgba(255,255,255,.07);
  --border:rgba(255,255,255,.08);
  --border-hover:rgba(255,255,255,.14);
  --accent:#6366f1;
  --accent-light:#818cf8;
  --accent-bg:rgba(99,102,241,.12);
  --accent-border:rgba(99,102,241,.4);
  --glow:0 0 24px rgba(99,102,241,.25);
  --green:#10b981;
  --green-bg:rgba(16,185,129,.1);
  --green-border:rgba(16,185,129,.25);
  --red:#f43f5e;
  --red-bg:rgba(244,63,94,.08);
  --red-border:rgba(244,63,94,.2);
  --yellow:#f59e0b;
  --yellow-bg:rgba(245,158,11,.08);
  --text:#e2e8f0;
  --text-2:rgba(255,255,255,.5);
  --text-3:rgba(255,255,255,.25);
  --radius:10px;
  --radius-lg:16px;
  --sidebar:64px;
  --topbar:56px;
}

/* ── Base ── */
body{
  font-family:'Inter',-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

a{color:var(--accent-light);text-decoration:none;}
a:hover{text-decoration:underline;}

/* ── Shell layout ── */
.shell{display:flex;height:100vh;overflow:hidden;}
.shell-main{flex:1;display:flex;flex-direction:column;overflow:hidden;}

/* ── Sidebar ── */
.sidebar{
  width:var(--sidebar);
  background:rgba(255,255,255,.025);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;align-items:center;
  padding:16px 0;gap:4px;flex-shrink:0;
  position:relative;z-index:10;
}
.sidebar-logo{
  width:36px;height:36px;
  background:var(--accent);border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  font-size:16px;margin-bottom:12px;
  box-shadow:var(--glow);text-decoration:none;
}
.sidebar-divider{width:32px;height:1px;background:var(--border);margin:6px 0;}
.sidebar-bottom{margin-top:auto;display:flex;flex-direction:column;align-items:center;gap:6px;}

/* ── Nav items ── */
.nav-item{
  width:40px;height:40px;border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  color:var(--text-3);cursor:pointer;transition:all .15s;
  position:relative;text-decoration:none;
}
.nav-item:hover{background:var(--surface2);color:var(--text-2);}
.nav-item.active{
  background:var(--accent-bg);color:var(--accent-light);
  border:1px solid var(--accent-border);
}
.nav-item.active::before{
  content:'';position:absolute;left:-1px;top:50%;transform:translateY(-50%);
  width:3px;height:20px;background:var(--accent);border-radius:0 3px 3px 0;
}
.nav-item svg{width:18px;height:18px;stroke:currentColor;fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}

/* ── Avatar ── */
.avatar{
  width:32px;height:32px;border-radius:50%;
  background:linear-gradient(135deg,var(--accent),#a78bfa);
  display:flex;align-items:center;justify-content:center;
  font-size:12px;font-weight:700;color:#fff;
}

/* ── Topbar ── */
.topbar{
  height:var(--topbar);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 24px;
  background:rgba(255,255,255,.015);
  flex-shrink:0;
}
.topbar-left{display:flex;align-items:center;gap:12px;}
.topbar-right{display:flex;align-items:center;gap:12px;}
.page-title{font-size:15px;font-weight:600;color:var(--text);}

/* ── Topbar components ── */
.badge{
  font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;
  background:var(--accent-bg);color:var(--accent-light);border:1px solid var(--accent-border);
}
.credit-chip{
  display:flex;align-items:center;gap:6px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:20px;padding:4px 12px;
  font-size:12px;color:var(--text-2);cursor:pointer;
  text-decoration:none;
}
.credit-chip .dot{width:6px;height:6px;border-radius:50%;background:var(--green);}
.credit-chip .dot.low{background:var(--red);}
.credit-chip strong{color:var(--text);font-weight:600;}
.credit-chip:hover{border-color:var(--border-hover);text-decoration:none;}

/* ── Buttons ── */
.btn{
  height:32px;padding:0 14px;border-radius:8px;
  font-size:13px;font-weight:600;border:none;cursor:pointer;
  display:inline-flex;align-items:center;gap:6px;
  font-family:inherit;text-decoration:none;
  transition:all .15s;
}
.btn-primary{background:var(--accent);color:#fff;}
.btn-primary:hover{background:var(--accent-light);text-decoration:none;}
.btn-ghost{background:var(--surface);border:1px solid var(--border);color:var(--text-2);}
.btn-ghost:hover{border-color:var(--border-hover);color:var(--text);text-decoration:none;}

/* ── Payment method badges ── */
.pm-badge{
  display:inline-flex;align-items:center;gap:5px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:4px 10px;font-size:11px;color:var(--text-2);
}
.pm-badge svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.7;}
.pm-row{display:flex;gap:8px;align-items:center;}

/* ── Glass card ── */
.glass-card{
  background:rgba(255,255,255,.04);
  backdrop-filter:blur(12px);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:16px;
  transition:border-color .15s;
}
.glass-card:hover{border-color:var(--border-hover);}

/* ── Section label ── */
.section-label{
  font-size:11px;font-weight:600;
  text-transform:uppercase;letter-spacing:.06em;
  color:var(--text-3);display:block;margin-bottom:-4px;
}

/* ── Drop zone ── */
.drop-zone{
  border:1.5px dashed rgba(99,102,241,.35);
  border-radius:8px;padding:20px;
  text-align:center;cursor:pointer;transition:all .2s;
  background:var(--accent-bg);
}
.drop-zone:hover{border-color:rgba(99,102,241,.6);background:rgba(99,102,241,.16);}
button.drop-zone{width:100%;font-family:inherit;font-size:inherit;background:var(--accent-bg);color:inherit;}
.drop-icon{
  width:36px;height:36px;background:rgba(99,102,241,.2);border-radius:8px;
  margin:0 auto 10px;display:flex;align-items:center;justify-content:center;
}
.drop-icon svg{width:18px;height:18px;stroke:var(--accent-light);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.drop-label{font-size:13px;font-weight:500;color:var(--text-2);margin-bottom:4px;}
.drop-hint{font-size:11px;color:var(--text-3);}

/* ── File chip (uploaded state) ── */
.file-chip{
  display:flex;align-items:center;gap:10px;
  background:var(--green-bg);border:1px solid var(--green-border);
  border-radius:8px;padding:10px 12px;
}
.file-chip-icon{
  width:28px;height:28px;background:rgba(16,185,129,.15);
  border-radius:6px;display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.file-chip-icon svg{width:14px;height:14px;stroke:var(--green);fill:none;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round;}
.file-chip-name{font-size:12px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.file-chip-meta{font-size:11px;color:var(--text-3);}
.file-chip-body{min-width:0;}


/* ── Export button ── */
.export-btn{
  width:100%;height:44px;background:var(--accent);border:none;border-radius:10px;
  font-size:14px;font-weight:700;color:#fff;cursor:pointer;
  display:flex;align-items:center;justify-content:center;gap:8px;
  box-shadow:0 4px 20px rgba(99,102,241,.4);transition:all .2s;font-family:inherit;
}
.export-btn:hover{background:var(--accent-light);box-shadow:0 6px 24px rgba(99,102,241,.5);}
.export-btn svg{width:16px;height:16px;stroke:#fff;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}

/* ── Canvas area (editor) ── */
.workspace{flex:1;display:grid;grid-template-columns:320px 1fr;overflow:hidden;}
.panel{
  border-right:1px solid var(--border);overflow-y:auto;padding:20px;
  display:flex;flex-direction:column;gap:16px;background:rgba(255,255,255,.01);
}
.panel::-webkit-scrollbar{width:4px;}
.panel::-webkit-scrollbar-track{background:transparent;}
.panel::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px;}
.canvas-area{display:flex;flex-direction:column;background:#020408;overflow:hidden;position:relative;}
.canvas-toolbar{
  height:44px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;padding:0 16px;gap:8px;
  background:rgba(255,255,255,.015);flex-shrink:0;
}
.toolbar-pill{
  display:flex;align-items:center;gap:4px;
  background:var(--surface);border:1px solid var(--border);
  border-radius:6px;padding:4px 10px;font-size:11px;color:var(--text-2);cursor:pointer;
}
.toolbar-pill:hover{border-color:var(--border-hover);color:var(--text);}
.toolbar-pill svg{width:12px;height:12px;stroke:currentColor;fill:none;stroke-width:1.7;}
.toolbar-divider{width:1px;height:20px;background:var(--border);margin:0 4px;}
.canvas-stage{
  flex:1;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.canvas-stage::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),
    linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:40px 40px;
}
.video-frame{
  position:relative;width:560px;height:315px;
  background:#0d1117;border:1px solid rgba(255,255,255,.1);
  border-radius:8px;overflow:hidden;box-shadow:0 8px 40px rgba(0,0,0,.6);
}
.video-frame::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(135deg,#0d1117 0%,#1a1f35 40%,#0d1117 100%);
}
.video-frame::after{
  content:'▶';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:28px;color:rgba(255,255,255,.15);
}
.wm-overlay{
  position:absolute;top:60px;left:40px;
  background:rgba(99,102,241,.25);border:1.5px solid rgba(99,102,241,.7);
  border-radius:4px;padding:6px 10px;
  font-size:11px;font-weight:700;color:rgba(255,255,255,.9);
  cursor:move;display:flex;align-items:center;gap:5px;
  box-shadow:0 0 12px rgba(99,102,241,.3);white-space:nowrap;
}
.canvas-hint{
  position:absolute;bottom:16px;left:50%;transform:translateX(-50%);
  font-size:11px;color:var(--text-3);
  background:rgba(0,0,0,.5);backdrop-filter:blur(8px);
  border:1px solid var(--border);border-radius:20px;
  padding:4px 14px;white-space:nowrap;
}
.status-bar{
  height:32px;border-top:1px solid var(--border);
  display:flex;align-items:center;padding:0 20px;gap:12px;
  font-size:11px;color:var(--text-3);background:rgba(255,255,255,.01);flex-shrink:0;
}
.status-dot{width:6px;height:6px;border-radius:50%;background:var(--green);box-shadow:0 0 6px rgba(16,185,129,.6);}

/* ── Login page ── */
.login-bg{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;background:var(--bg);
}
.blob{position:absolute;border-radius:50%;filter:blur(80px);pointer-events:none;}
.blob-1{
  width:500px;height:500px;top:-100px;left:-100px;
  background:radial-gradient(circle,rgba(99,102,241,.18) 0%,transparent 70%);
}
.blob-2{
  width:400px;height:400px;bottom:-80px;right:-80px;
  background:radial-gradient(circle,rgba(167,139,250,.12) 0%,transparent 70%);
}
.login-card{
  position:relative;width:100%;max-width:400px;
  background:rgba(255,255,255,.04);backdrop-filter:blur(20px);
  border:1px solid var(--border);border-radius:var(--radius-lg);padding:36px;
  box-shadow:0 8px 40px rgba(0,0,0,.5),var(--glow);
}
.login-logo{display:flex;align-items:center;justify-content:center;gap:10px;margin-bottom:28px;}
.login-logo-icon{
  width:40px;height:40px;background:var(--accent);border-radius:10px;
  display:flex;align-items:center;justify-content:center;font-size:20px;
  box-shadow:0 4px 20px rgba(99,102,241,.4);
}
.login-logo-text{font-size:16px;font-weight:700;letter-spacing:-.02em;}
.login-logo-text span{color:var(--accent-light);}
.login-title{font-size:22px;font-weight:700;letter-spacing:-.03em;text-align:center;margin-bottom:6px;}
.login-subtitle{font-size:13px;color:var(--text-2);text-align:center;margin-bottom:28px;}

/* ── Form fields (login) ── */
.field{margin-bottom:14px;}
.field-label{font-size:12px;font-weight:600;color:var(--text-2);letter-spacing:.02em;margin-bottom:6px;display:block;}
.field-input{
  width:100%;height:42px;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:9px;
  padding:0 14px;font-size:14px;color:var(--text);
  font-family:inherit;outline:none;transition:border-color .15s,box-shadow .15s;
}
.field-input:focus{
  border-color:rgba(99,102,241,.6);background:rgba(99,102,241,.06);
  box-shadow:0 0 0 3px rgba(99,102,241,.12);
}
.field-input-row{position:relative;}
.field-input-row .field-input{padding-right:40px;}
.field-eye{
  position:absolute;right:12px;top:50%;transform:translateY(-50%);
  color:var(--text-3);cursor:pointer;background:none;border:none;padding:0;
}
.field-eye svg{width:16px;height:16px;stroke:currentColor;fill:none;stroke-width:1.7;}
.forgot-row{display:flex;align-items:center;justify-content:space-between;margin-top:-6px;margin-bottom:20px;}
.checkbox-row{display:flex;align-items:center;gap:7px;cursor:pointer;}
.checkbox-box{
  width:16px;height:16px;border-radius:4px;border:1px solid var(--border);
  background:var(--surface);flex-shrink:0;display:flex;align-items:center;justify-content:center;
}
input[type=checkbox]:checked+.checkbox-box,
.checkbox-box.checked{background:var(--accent);border-color:var(--accent);}
.checkbox-label{font-size:12px;color:var(--text-2);}
.link{font-size:12px;color:var(--accent-light);cursor:pointer;}

/* ── TOTP section (inline in login) ── */
.totp-section{
  background:rgba(99,102,241,.06);border:1px solid rgba(99,102,241,.2);
  border-radius:10px;padding:16px;margin-bottom:16px;
}
.totp-hint{font-size:12px;color:var(--text-2);text-align:center;margin-bottom:12px;}
.totp-hint strong{color:var(--accent-light);}
.totp-row{display:flex;gap:6px;justify-content:center;margin-bottom:10px;}
.totp-digit{
  width:42px;height:48px;background:rgba(255,255,255,.04);
  border:1px solid var(--border);border-radius:9px;
  display:flex;align-items:center;justify-content:center;
  font-size:20px;font-weight:700;color:var(--text);transition:border-color .15s;
}
.totp-code-input{
  width:100%;background:rgba(255,255,255,.04);border:1px solid var(--border);
  border-radius:9px;height:48px;text-align:center;
  font-size:24px;font-weight:700;letter-spacing:.2em;
  color:var(--text);font-family:inherit;outline:none;transition:border-color .15s;
}
.totp-code-input:focus{border-color:rgba(99,102,241,.6);box-shadow:0 0 0 3px rgba(99,102,241,.12);}
.totp-sep{display:flex;align-items:center;color:var(--text-3);font-size:16px;padding:0 2px;}
.totp-expire{text-align:center;font-size:11px;color:var(--text-3);}

/* ── Submit button (login) ── */
.submit-btn{
  width:100%;height:44px;background:var(--accent);border:none;border-radius:10px;
  font-size:14px;font-weight:700;color:#fff;cursor:pointer;
  box-shadow:0 4px 20px rgba(99,102,241,.4);transition:all .2s;font-family:inherit;
}
.submit-btn:hover{background:var(--accent-light);box-shadow:0 6px 28px rgba(99,102,241,.55);}
.login-footer{text-align:center;margin-top:20px;font-size:12px;color:var(--text-3);}

/* ── Alerts ── */
.alert{
  display:flex;align-items:flex-start;gap:12px;
  padding:12px 16px;border-radius:var(--radius);
  font-size:13px;margin-bottom:16px;
}
.alert-error{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);}
.alert-warning{background:var(--yellow-bg);border:1px solid rgba(245,158,11,.2);color:var(--yellow);}
.alert-info{background:var(--accent-bg);border:1px solid var(--accent-border);color:var(--accent-light);}

/* ── Credits page ── */
.page-content{flex:1;overflow-y:auto;padding:32px;}
.page-content::-webkit-scrollbar{width:4px;}
.page-content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.1);border-radius:4px;}

.balance-hero{
  background:linear-gradient(135deg,rgba(99,102,241,.15) 0%,rgba(167,139,250,.08) 100%);
  border:1px solid var(--accent-border);border-radius:var(--radius-lg);
  padding:28px 32px;display:flex;align-items:center;justify-content:space-between;
  margin-bottom:28px;position:relative;overflow:hidden;
}
.balance-hero::before{
  content:'';position:absolute;top:-60px;right:-60px;
  width:200px;height:200px;
  background:radial-gradient(circle,rgba(99,102,241,.2) 0%,transparent 70%);
  border-radius:50%;
}
.balance-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--accent-light);margin-bottom:6px;}
.balance-amount{font-size:52px;font-weight:800;letter-spacing:-.04em;line-height:1;}
.balance-sub{font-size:13px;color:var(--text-2);margin-top:6px;}
.balance-hero-aside{display:flex;flex-direction:column;align-items:flex-end;gap:8px;}
.usage-ring{width:80px;height:80px;position:relative;}
.usage-ring svg{width:80px;height:80px;transform:rotate(-90deg);}
.usage-ring-label{
  position:absolute;inset:0;display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  font-size:11px;font-weight:700;color:var(--text);
}
.usage-ring-sub{font-size:9px;color:var(--text-3);margin-top:1px;}
.usage-ring-note{font-size:11px;color:var(--text-3);text-align:right;margin-top:6px;}

.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;}
.section-title{font-size:13px;font-weight:600;color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;}

/* Plan cards */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:32px;}
.plan-card{
  background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);
  padding:20px;cursor:pointer;transition:all .18s;position:relative;
}
.plan-card:hover{border-color:var(--border-hover);background:var(--surface2);}
.plan-card.featured{
  background:var(--accent-bg);border-color:var(--accent-border);
  box-shadow:0 0 0 1px rgba(99,102,241,.15),var(--glow);
}
.plan-badge{
  position:absolute;top:-1px;right:14px;background:var(--accent);
  color:#fff;font-size:10px;font-weight:700;padding:2px 8px;
  border-radius:0 0 6px 6px;letter-spacing:.04em;text-transform:uppercase;
}
.plan-name{font-size:13px;font-weight:700;margin-bottom:4px;}
.plan-credits{font-size:28px;font-weight:800;letter-spacing:-.03em;line-height:1;}
.plan-credits-label{font-size:11px;color:var(--text-3);font-weight:500;}
.plan-price{font-size:20px;font-weight:700;color:var(--accent-light);margin-top:10px;}
.plan-price span{font-size:12px;font-weight:400;color:var(--text-3);}
.plan-perks{margin-top:12px;display:flex;flex-direction:column;gap:5px;}
.plan-perk{font-size:11px;color:var(--text-2);display:flex;align-items:center;gap:5px;}
.plan-perk svg{width:11px;height:11px;stroke:var(--green);fill:none;stroke-width:2.5;flex-shrink:0;}
.plan-btn{
  width:100%;margin-top:14px;height:36px;border-radius:8px;
  font-size:13px;font-weight:700;border:none;cursor:pointer;font-family:inherit;transition:all .15s;
}
.plan-btn-primary{background:var(--accent);color:#fff;box-shadow:0 2px 12px rgba(99,102,241,.4);}
.plan-btn-primary:hover{background:var(--accent-light);}
.plan-btn-ghost{background:var(--surface2);color:var(--text-2);border:1px solid var(--border);}
.plan-btn-ghost:hover{border-color:var(--accent-border);color:var(--accent-light);}
.plan-btn:disabled{opacity:.5;cursor:not-allowed;}

/* Transaction history */
.history-table{width:100%;}
.history-row{display:flex;align-items:center;gap:12px;padding:11px 0;border-bottom:1px solid var(--border);}
.history-row:last-child{border-bottom:none;}
.history-icon{
  width:30px;height:30px;border-radius:7px;flex-shrink:0;
  display:flex;align-items:center;justify-content:center;
}
.history-icon svg{width:14px;height:14px;stroke:currentColor;fill:none;stroke-width:1.7;}
.history-icon.credit{background:var(--green-bg);border:1px solid var(--green-border);color:var(--green);}
.history-icon.debit{background:var(--red-bg);border:1px solid var(--red-border);color:var(--red);}
.history-desc{flex:1;}
.history-label{font-size:13px;font-weight:500;}
.history-meta{font-size:11px;color:var(--text-3);}
.history-amount{font-size:13px;font-weight:700;}
.history-amount.plus{color:var(--green);}
.history-amount.minus{color:var(--text-3);}

/* ── Utilities ── */
.hidden{display:none !important;}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}
.mt-8{margin-top:8px;}
.mt-10{margin-top:10px;}
.mt-12{margin-top:12px;}
.credit-notice{font-size:11px;color:var(--text-3);display:flex;align-items:center;gap:4px;margin-top:10px;}
.hint{font-size:11px;color:var(--text-3);}
.text-input{
  width:100%;background:var(--surface);border:1px solid var(--border);
  border-radius:8px;padding:8px 12px;font-size:13px;color:var(--text);
  font-family:inherit;outline:none;box-sizing:border-box;
}
.text-input:focus{border-color:var(--accent);}

/* ── Upload progress ── */
#upload-progress{margin-top:16px;display:flex;flex-direction:column;gap:8px;}
.upload-pct-label{font-size:11px;color:var(--text-2);text-align:center;}

/* ── Progress bar ── */
.progress-bar-bg{background:var(--surface2);border-radius:999px;height:8px;overflow:hidden;}
.progress-bar-fill{height:100%;background:linear-gradient(135deg,var(--accent),var(--accent-light));border-radius:999px;width:0%;transition:width .3s ease;}
#progress-label{color:var(--text-2);font-size:12px;}

/* ── Watermark items ── */
.wm-item{
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  padding:12px;display:flex;flex-direction:column;gap:10px;transition:border-color .15s;
}
.wm-item.selected{border-color:var(--accent);box-shadow:0 0 0 1px rgba(99,102,241,.25);}
.wm-item-top{display:flex;align-items:center;gap:10px;}
.wm-thumb{width:40px;height:40px;object-fit:contain;border-radius:4px;background:#111;border:1px solid var(--border);flex-shrink:0;}
.wm-name{flex:1;font-size:12px;color:var(--text-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.wm-controls{display:flex;flex-direction:column;gap:8px;}

/* ── Preset buttons (3×3 grid) ── */
.preset-btns{display:grid;grid-template-columns:repeat(3,1fr);gap:4px;}
.preset{
  background:var(--surface);border:1px solid var(--border);color:var(--text);
  border-radius:6px;padding:5px;cursor:pointer;font-size:14px;line-height:1;transition:background .15s;
}
.preset:hover,.preset.active{background:var(--accent);border-color:var(--accent);}

/* ── X/Y inputs ── */
.xy-row{display:flex;gap:8px;}
.xy-row label{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-2);flex:1;}
.xy-input{
  width:100%;background:var(--surface);border:1px solid var(--border);
  color:var(--text);border-radius:6px;padding:4px 6px;font-size:11px;
}
.xy-input:focus{outline:none;border-color:var(--accent);}

/* ── Sliders ── */
.slider-row label{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--text-2);}
.slider{flex:1;accent-color:var(--accent);cursor:pointer;}
.slider-val{min-width:36px;text-align:right;font-size:11px;color:var(--text);}

/* ── Export buttons row ── */
.export-buttons{display:flex;flex-wrap:wrap;gap:10px;align-items:center;}

/* ── Drive setup ── */
.drive-setup{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:14px 18px;}
.drive-setup summary{cursor:pointer;font-size:13px;color:var(--text-2);user-select:none;}
.drive-inner{margin-top:12px;display:flex;flex-direction:column;gap:10px;font-size:13px;}
.cred-row{display:flex;align-items:center;gap:12px;}
#cred-status{font-size:11px;color:var(--green);}

/* ── n8n section ── */
.n8n-setup{background:var(--surface2);border:1px solid var(--border);border-radius:8px;padding:14px 18px;border-left:3px solid #f97316;}
.n8n-setup summary{cursor:pointer;font-size:13px;color:var(--text);user-select:none;display:flex;align-items:center;gap:8px;}
.n8n-icon{font-size:14px;}
.n8n-inner{margin-top:14px;display:flex;flex-direction:column;gap:14px;font-size:13px;}
.n8n-save-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap;}
#defaults-status{font-size:11px;color:var(--green);}
.n8n-endpoint-block,.n8n-fields-block,.n8n-workflow-block{display:flex;flex-direction:column;gap:8px;}
.n8n-label{font-size:11px;font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;}
.n8n-hint{font-size:11px;color:var(--text-3);}
.endpoint-row{display:flex;align-items:center;gap:8px;background:var(--surface);border:1px solid var(--border);border-radius:6px;padding:8px 12px;}
.endpoint-row code{flex:1;font-family:'SF Mono','Fira Code',monospace;font-size:12px;color:#a78bfa;word-break:break-all;}
.n8n-table{width:100%;border-collapse:collapse;font-size:12px;}
.n8n-table th,.n8n-table td{text-align:left;padding:6px 10px;border:1px solid var(--border);}
.n8n-table th{background:var(--surface);color:var(--text-3);font-weight:600;}
.n8n-table td:last-child{font-family:'SF Mono','Fira Code',monospace;font-size:11px;color:#a78bfa;}
.n8n-steps{padding-left:20px;display:flex;flex-direction:column;gap:6px;color:var(--text);}
.n8n-steps li{line-height:1.5;}
.n8n-steps code{background:var(--surface);border:1px solid var(--border);padding:1px 5px;border-radius:4px;font-size:11px;color:#a78bfa;}

/* ── Buttons ── */
.btn-secondary{
  background:var(--surface2);color:var(--text);border:1px solid var(--border);border-radius:8px;
  padding:8px 16px;font-size:13px;font-weight:500;cursor:pointer;transition:background .15s,border-color .15s;
  font-family:inherit;text-decoration:none;display:inline-flex;align-items:center;gap:6px;
}
.btn-secondary:hover{background:var(--surface2);border-color:var(--border-hover);}
.btn-drive{
  background:#fff;color:#444;border:1px solid #ddd;border-radius:8px;
  padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;
  display:flex;align-items:center;gap:8px;transition:background .15s;
}
.btn-drive:hover{background:#f4f4f4;}
.btn-drive:disabled{opacity:.5;cursor:not-allowed;}
.btn-icon{background:none;border:none;cursor:pointer;color:var(--text-3);font-size:14px;padding:2px 6px;border-radius:4px;transition:color .15s;margin-left:auto;}
.btn-icon.btn-remove:hover{color:var(--red);}
.btn-n8n{background:#f97316;color:#fff;border:none;border-radius:8px;padding:8px 16px;font-size:13px;font-weight:600;cursor:pointer;transition:background .15s;font-family:inherit;}
.btn-n8n:hover{background:#ea6c0a;}
.btn-copy{background:none;border:1px solid var(--border);color:var(--text-3);border-radius:4px;padding:3px 8px;cursor:pointer;font-size:13px;transition:color .15s,border-color .15s;flex-shrink:0;}
.btn-copy:hover{color:var(--text);border-color:var(--accent);}

/* ── Language switcher ── */
.lang-switcher{position:relative;}
.lang-btn{
  background:none;border:1px solid var(--border);border-radius:6px;color:var(--text-2);
  cursor:pointer;font-size:12px;padding:4px 10px;display:flex;align-items:center;gap:4px;
  white-space:nowrap;transition:border-color .15s,color .15s;font-family:inherit;
}
.lang-btn:hover{border-color:var(--border-hover);color:var(--text);}
.lang-menu{
  display:none;position:absolute;top:calc(100% + 6px);right:0;
  background:var(--surface2);border:1px solid var(--border);border-radius:8px;
  box-shadow:0 8px 32px rgba(0,0,0,.5);min-width:160px;z-index:999;overflow:hidden;
}
.lang-menu.open{display:block;}
.lang-option{
  display:block;width:100%;background:none;border:none;color:var(--text-2);
  cursor:pointer;font-size:13px;padding:9px 16px;text-align:left;
  transition:background .12s;font-family:inherit;
}
.lang-option:hover{background:var(--surface2);color:var(--text);}
.lang-option.active{color:var(--accent);font-weight:600;}
.lang-switcher--centered .lang-menu{right:auto;left:50%;transform:translateX(-50%);}
[dir="rtl"] .lang-menu{right:auto;left:0;}
[dir="rtl"] .lang-option{text-align:right;}

/* ── Jobs page ── */
.panel-scroll{flex:1;overflow-y:auto;padding:24px;}
.jobs-wrap{max-width:900px;margin:0 auto;}
.jobs-empty{
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:16px;padding:80px 24px;color:var(--text-3);text-align:center;
}
.jobs-empty svg{opacity:.4;}
.jobs-empty p{font-size:15px;margin:0;}
.jobs-empty a{color:var(--accent);text-decoration:none;}
.jobs-empty a:hover{text-decoration:underline;}
.jobs-table{width:100%;border-collapse:collapse;font-size:13.5px;}
.jobs-table th{
  text-align:left;padding:10px 14px;color:var(--text-3);font-weight:500;
  border-bottom:1px solid var(--border);font-size:12px;letter-spacing:.04em;text-transform:uppercase;
}
.jobs-table td{padding:12px 14px;border-bottom:1px solid var(--border);vertical-align:middle;}
.job-row:last-child td{border-bottom:none;}
.job-id .mono{font-family:ui-monospace,monospace;font-size:12px;color:var(--text-2);}
.job-badge{
  display:inline-flex;align-items:center;gap:5px;
  font-size:12px;font-weight:600;padding:3px 8px;border-radius:99px;
}
.job-badge--done{background:var(--green-bg);color:var(--green);border:1px solid var(--green-border);}
.job-badge--error{background:var(--red-bg);color:var(--red);border:1px solid var(--red-border);}
.job-badge--processing{background:var(--accent-bg);color:var(--accent);border:1px solid var(--accent-border);}
.job-badge--pending{background:var(--surface2);color:var(--text-2);border:1px solid var(--border);}
.job-actions{display:flex;align-items:center;gap:8px;}
.job-error-msg{font-size:12px;color:var(--red);font-family:ui-monospace,monospace;}
.text-muted{color:var(--text-3);}
.topbar-right .btn{gap:6px;}
