:root{--bg:#0b1020;--bg-grad-1:#141a33;--bg-grad-2:#151a35;--primary:#5b7cff;--primary-2:#7c5bff;--accent:#f59e0b;--danger:#fc6262;--ok:#10b981;--text:#e6e8ee;--muted:#a8b0c7;--muted-2:#cbd5e1;--border:#24304f;--input:rgba(0,0,0,0.2);--input-hover:rgba(255,255,255,0.03);--select-list-bg:#0E121E;--hover-bg:rgba(255,255,255,0.02);--sidebar-bg:#0b1020;--sidebar-grad-1:rgba(255,255,255,.03);--sidebar-grad-2:rgba(255,255,255,.02);--brand-bg-1:#0e1330;--brand-bg-2:#0a0f24;--brand-bg-3:#434868;--card-grad-1:rgba(255,255,255,.03);--card-grad-2:rgba(255,255,255,.02);--shadow:0 20px 50px rgba(0,0,0,.35);--radius:16px;--radius-sm:12px;--radius-xs:10px;--gap:18px}
[data-theme="light"]{--bg:#f1f5f9;--bg-grad-1:#e2e8f0;--bg-grad-2:#f1f5f9;--text:#1e293b;--muted:#64748b;--border:#cbd5e1;--input:#ffffff;--input-hover:#f8fafc;--hover-bg:rgba(0,0,0,0.05);--sidebar-bg:#ffffff;--sidebar-grad-1:rgba(255,255,255,0.8);--sidebar-grad-2:rgba(255,255,255,0.4);--brand-bg-1:#ffffff;--brand-bg-2:#f1f5f9;--brand-bg-3:#ffffff;--card-grad-1:#ffffff;--card-grad-2:#f8fafc;--shadow:0 10px 30px rgba(0,0,0,0.06)}
*{box-sizing:border-box}
html,body{height:100%}
body{margin:0;background:radial-gradient(1200px 600px at 10% 10%,var(--bg-grad-1) 0%,var(--bg) 70%),radial-gradient(1200px 600px at 90% 90%,var(--bg-grad-2) 0%,var(--bg) 70%);color:var(--text);font-family:ui-sans-serif,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans","Apple Color Emoji","Segoe UI Emoji";transition:background 0.3s, color 0.3s}
.layout{display:grid;grid-template-columns:1fr;gap:0;min-height:100vh}
.sidebar{position:fixed;inset:0 auto 0 0;width:260px;z-index:100;transform:translateX(-100%);transition:transform 0.3s cubic-bezier(0.4, 0, 0.2, 1);background:var(--sidebar-bg);border-right:1px solid var(--border);padding:20px 16px;display:flex;flex-direction:column;gap:24px}
.sidebar.open{transform:translateX(0);box-shadow:0 0 100px rgba(0,0,0,0.8)}
.overlay{position:fixed;inset:0;background:rgba(0,0,0,0.7);z-index:90;opacity:0;pointer-events:none;transition:opacity 0.3s;backdrop-filter:blur(4px)}
.overlay.open{opacity:1;pointer-events:auto}
.mobile-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;justify-content:space-between}
.mobile-header-left{display:flex;align-items:center;gap:16px}
.menu-btn{width:40px;height:40px;border-radius:10px;border:1px solid var(--border);background:var(--input);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:5px;color:var(--text);cursor:pointer}
.menu-line{width:18px;height:2px;background:currentColor;border-radius:2px}
.brand-card{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:center;padding:12px;border:1px solid var(--border);border-radius:var(--radius-sm);background:linear-gradient(135deg,var(--brand-bg-1),var(--brand-bg-2));box-shadow:var(--shadow)}
.brand-logo{width:36px;height:36px;border-radius:10px;background:linear-gradient(135deg,var(--primary),var(--primary-2));box-shadow:0 0 24px rgba(123,92,255,.65);overflow:hidden}
.brand-logo img{width:100%;height:100%;object-fit:cover;display:block;border-radius:10px}
[data-theme="light"] .brand-logo{box-shadow:0 2px 4px rgba(0,0,0,0.15)}
.brand-info{display:grid}
.brand-title{font-weight:700;font-size:15px}
.brand-sub{color:var(--muted);font-size:11px}
.section-title{display:flex;align-items: center;margin-top:0;margin-bottom:8px;padding:0 12px}
.section-title span{color:var(--muted);font-size:12px;font-weight:600;letter-spacing:0.5px;opacity:0.7;margin-right:auto}
.nav{display:grid;gap:6px}
.nav-item{display:flex;align-items:center;justify-content:space-between;padding:10px 12px;border-radius:8px;color:var(--text);text-decoration:none;border:1px solid transparent;font-size:14.5px;font-weight:500;transition:all 0.2s ease;min-height:40px}
.nav-item:hover{border-color:var(--border);background:var(--hover-bg)}
.nav-item.active{background:linear-gradient(135deg,rgba(91,124,255,.15),rgba(124,91,255,.15));border-color:rgba(91,124,255,.35);box-shadow:none}
.nav-left{display:flex;align-items:center;gap:12px}
.nav-icon{width:6px;height:6px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-2));opacity:0.6}
.nav-item.active .nav-icon{opacity:1;box-shadow:0 0 6px var(--primary)}
.nav-vip{margin-bottom: auto;}
.badge{padding:6px 8px;border-radius:10px;border:1px solid var(--border);color:var(--muted);font-size:11px}
.badge.new{color:#8fb0ff;border-color:#3a4a77}
[data-theme="light"] .badge.new{color:#3b82f6;border-color:#bfdbfe;background:#eff6ff}
.badge.vip{color:#ffd580;border-color:#946300;font-weight: 500;}
[data-theme="light"] .badge.vip{color:#b45309;border-color:#fcd34d;background:#fffbeb}
.sidebar-foot{display:grid;gap:10px;font-size:12px}
.version{padding:14px;border:1px solid var(--border);border-radius:12px;background:var(--input);text-align:center;color: var(--muted);text-decoration: none;}
.content{display:flex;flex-direction:column;gap:20px;padding:24px}
.header{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-shrink:0;}
@media(max-width:1000px){.header{display:none}}
.header-mobile-group{display:flex;align-items:center;gap:10px}
.header-tools{display:flex;align-items:center;gap:10px;margin-left:auto}
.chip{display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:20px;border:1px solid var(--border);background:var(--input);color:var(--text);font-size:12px}
.avatar{width:28px;height:28px;border-radius:50%;background:linear-gradient(135deg,var(--primary),var(--primary-2));display:grid;place-items:center;font-weight:700}
.logo-img{width:20px;height:20px;border-radius:6px;display:block}
.banner{padding:14px 16px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(239,68,68,.1));display:flex;align-items:center;justify-content:space-between;flex-shrink:0;}
.header-banner{display:none;flex:1;padding:6px 16px;border-radius:14px;border:1px solid var(--border);background:linear-gradient(135deg,rgba(245,158,11,.15),rgba(239,68,68,.1));display:flex;align-items:center;justify-content:space-between;}
.banner-left{display:flex;align-items:center;gap:12px}
.banner-dot{width:12px;height:12px;border-radius:50%;background:linear-gradient(135deg,#fb923c,#ef4444)}
.banner-action{display:inline-flex;align-items:center;gap:8px;padding:2px 10px;border-radius:12px;border:1px solid rgba(239,68,68,.45);background:rgba(239,68,68,.12);color:#ffb4b4;cursor:pointer;white-space: nowrap;font-size: 14px;}
.full-width-cards{display:grid;grid-template-columns:1fr;gap:20px;}
.double-column-cards{display:grid;grid-template-columns:1fr;gap:20px;flex:1}
.card{border:1px solid var(--border);border-radius:var(--radius);background:linear-gradient(180deg,var(--card-grad-1),var(--card-grad-2));box-shadow:var(--shadow);padding:24px;display:flex;flex-direction:column;gap:20px}
.card-title{font-weight:700;font-size:20px;margin-bottom:4px}
.input{display:flex;align-items:center;gap:10px;background:var(--input);border:1px solid var(--border);border-radius:12px;padding:14px 16px;width:100%;transition:border-color 0.2s, box-shadow 0.2s}
.input:focus-within{border-color:var(--primary);box-shadow:0 0 0 2px rgba(91,124,255,0.15)}
.input input{flex:1;background:transparent;border:0;outline:none;color:var(--text);font-size:15px;width:100%}
.input input::placeholder{color:#556585;opacity:1}
.input-row{ width: 100%;display: flex; gap: 10px; align-items: center; }
.textarea{background:var(--input);border:1px solid var(--border);border-radius:12px;padding:14px;color:var(--text);min-height:160px;width:100%;resize:vertical;font-family:inherit;line-height:1.6}
.textarea::placeholder{color:#556585;opacity:1}
.hint{color:var(--muted);font-size:12px;margin-top:4px}
.controls{display:grid;gap:16px;margin-top: 12px;}
.control-row{display:flex;flex-direction:column;align-items:flex-start;gap:8px}
.control-name{color:var(--muted);font-size:13px;margin-left: 4px;}
.controls-group{display:grid;gap:16px;width:100%}
@media(min-width:1000px){.controls-group{grid-template-columns:1fr 1fr 1fr}}
.select-head .icon{color:var(--muted);font-size:10px}
.segmented{display:grid;grid-template-columns:repeat(2, 1fr);gap:10px;width:100%}
.seg-item{text-align:center;padding:10px;border-radius:12px;border:1px solid var(--border);background:var(--input);color:var(--text);cursor:pointer;font-size:13px}
.seg-item.active{background:linear-gradient(135deg,rgba(91,124,255,.15),rgba(124,91,255,.15));border-color:rgba(91,124,255,.35)}
.select{position:relative;width:100%}
.select-head{display:flex;align-items:center;justify-content:space-between;padding:14px 14px;border-radius:12px;border:1px solid var(--border);background:var(--input);cursor:pointer}
.select.show .select-head{background: linear-gradient(135deg,rgba(91,124,255,.15),rgba(124,91,255,.15));border-color: rgba(91,124,255,.35)}
.select-list{width:100%;position:absolute;top:calc(100% + 6px);left:0;border:1px solid var(--border);border-radius:12px;background:var(--select-list-bg);display:none;flex-direction:column;z-index:10}
.select-head span,.select-list div{font-size: 14px;}
.select.show .select-list{display:flex}
.select-item{padding:10px;color:var(--text);cursor:pointer}
.select-item:hover{background:var(--input-hover)}
.button{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:600;font-size:0.95rem;white-space: nowrap;height: 100%;}
.button-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}
.button-primary:hover{filter:brightness(1.05)}
.button-ghost{border-color:var(--border);background:var(--input);color:var(--text)}
.button-ghost:hover{border-color:#3a4a77}
[data-theme="light"] .button-ghost:hover{border-color:#94a3b8;background:#f1f5f9}
.upload-area{display:flex;flex-direction:column;gap:12px}
.upload-grid{display:grid;grid-template-columns:repeat(auto-fill, minmax(80px, 1fr));gap:10px;margin-top:10px}
.upload-item{position:relative;aspect-ratio:1;border-radius:12px;overflow:hidden;border:1px solid var(--border);background:var(--input);cursor:grab}
.upload-item:active{cursor:grabbing}
.upload-item img{width:100%;height:100%;object-fit:cover;display:block}
.upload-del{position:absolute;top:4px;right:4px;width:20px;height:20px;background:rgba(0,0,0,0.6);border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:14px;cursor:pointer;backdrop-filter:blur(2px);opacity:0;transition:opacity 0.2s}
.upload-item:hover .upload-del{opacity:1}
.upload-add{aspect-ratio:1;border-radius:12px;border:1px dashed var(--border);background:rgba(255,255,255,0.02);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;gap:4px;transition:all 0.2s}
.upload-add:hover{border-color:var(--primary);color:var(--primary);background:rgba(91,124,255,0.05)}
.upload-add-icon{font-size:24px}
.upload-add-text{font-size:11px}
.upload-hint{font-size:12px;color:var(--danger);min-height:18px;display:none}
.upload-hint.show{display:block}
.lightbox{position:fixed;inset:0;z-index:200;background:rgba(0,0,0,0.9);display:none;place-items:center;cursor:zoom-out;backdrop-filter:blur(10px)}
.lightbox.show{display:grid}
.lightbox img{max-width:90vw;max-height:90vh;border-radius:8px;box-shadow:0 0 50px rgba(0,0,0,0.5)}
.style-grid{display: grid;grid-template-columns: repeat(auto-fit, minmax(70px, 1fr));gap: 10px;padding: 8px 0;max-width: 100%;}
/* .style-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px} */
.style-card{position:relative;display:flex;flex-direction:column;gap:8px;border:1px solid var(--border);border-radius:12px;background:var(--input);cursor:pointer;padding:8px;transition:all .2s}
.style-card.active{border-color:rgba(91,124,255,.35);box-shadow:0 0 0 2px rgba(91,124,255,.15)}
.style-thumb{height:110px;border-radius:8px;background:#1a223f;background-size:cover;background-position:center}
.style-label{text-align:center;font-size:13px;color:var(--text)}
.style-sub{text-align:center;font-size:12px;color:var(--muted)}
[data-theme="light"] .style-default{background:rgba(0,0,0,0.02)}
.style-default{display:grid;align-content:center;justify-items:center;gap:6px;padding:16px;border:1px dashed var(--border);background:rgba(255,255,255,0.02)}
.style-check{position:absolute;top:6px;right:6px;width:18px;height:18px;border-radius:50%;display:grid;place-items:center;background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff;font-weight:700;font-size:12px;box-shadow:0 4px 12px rgba(0,0,0,0.25);opacity:0;transition:opacity .2s}
.style-card.active .style-check{opacity:1}
.style-anime{background-image:url('/static/imgs/动漫.jpg')}
.style-comic{background-image:url('/static/imgs/漫画.jpg')}
.style-selfie{background-image:url('/static/imgs/自拍.jpg')}
.style-retro{background-image:url('/static/imgs/复古.jpg')}
.style-news{background-image:url('/static/imgs/新闻.jpg')}
.style-winter{background-image:url('/static/imgs/冬天.jpg')}
.preview{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;flex:1;min-height:300px;background:rgba(0,0,0,0.2);border-radius:12px;border:2px dashed var(--border);color:var(--muted);text-align:center}
[data-theme="light"] .preview{background:rgba(0,0,0,0.02);border-color:#cbd5e1}
.preview-icon{width:80px;height:80px;border-radius:24px;background:linear-gradient(135deg,#203055,#1a223f);display:grid;place-items:center;color:#8fb0ff;font-size:32px;box-shadow:0 10px 30px rgba(0,0,0,0.2)}
[data-theme="light"] .preview-icon{background:#fff;color:#cbd5e1;border:1px solid #e2e8f0;box-shadow:0 2px 4px rgba(0,0,0,0.08)}
.filter-card{display:flex;flex-direction:column;gap:16px;padding:0;background:transparent;border:0;border-radius:0;margin-bottom:20px;height:auto}
.filter-head{display:flex;align-items:center;justify-content:space-between;color:var(--text);font-weight:700;font-size:16px;margin-bottom:0}
.filter-row{display:grid;grid-template-columns:repeat(auto-fit, minmax(200px, 1fr));gap:16px;align-items:end;height:auto}
.filter-item{display:grid;gap:8px}
.table-card{background:linear-gradient(180deg,var(--card-grad-1),var(--card-grad-2));border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);flex:1;display:flex;flex-direction:column}
[data-theme="light"] .table-card{background:linear-gradient(180deg,var(--card-grad-1),var(--card-grad-2));box-shadow:0 4px 20px rgba(0,0,0,0.05)}
.table-head{background:rgba(255,255,255,0.02);color:var(--muted);display:grid;grid-template-columns:50px 360px 160px repeat(6, 1fr);padding:16px 24px;font-size:13px;font-weight:600;align-items:center;border-bottom:1px solid var(--border);text-transform:uppercase;letter-spacing:0.5px;flex-shrink:0;gap:16px;border-radius:var(--radius) var(--radius) 0 0}
[data-theme="light"] .table-head{background:rgba(0,0,0,0.02)}
.table-row{display:grid;grid-template-columns:50px 360px 160px repeat(6, 1fr);padding:20px 24px;font-size:14px;color:var(--text);align-items:center;border-bottom:1px solid var(--border);transition:all 0.2s;flex-shrink:0;gap:16px}
.table-row:last-child{border-bottom:0}
.table-row:hover{background:var(--hover-bg)}
.table-check{width:20px;height:20px;border:2px solid var(--border);border-radius:6px;background:transparent;cursor:pointer;transition:all 0.2s}
.table-check:hover{border-color:var(--primary)}
.table-check.checked{background:var(--primary);border-color:var(--primary)}
[data-theme="light"] .table-check{background:rgba(255,255,255,0.5)}
.table-status{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:20px;font-size:12px;font-weight:500}
.table-status.ok{background:rgba(16,185,129,0.1);color:var(--ok);border:1px solid rgba(16,185,129,0.2)}
.table-status.fail{background:rgba(239,68,68,0.1);color:var(--danger);border:1px solid rgba(239,68,68,0.2)}
.table-status.queued{background:rgba(245,158,11,0.1);color:var(--accent);border:1px solid rgba(245,158,11,0.2)}
.table-status.processing{background:rgba(91,124,255,0.1);color:var(--primary);border:1px solid rgba(91,124,255,0.2)}
.table-status.completed{background:rgba(16,185,129,0.1);color:var(--ok);border:1px solid rgba(16,185,129,0.2)}
.table-status.failed{background:rgba(239,68,68,0.1);color:var(--danger);border:1px solid rgba(239,68,68,0.2)}
.pagination{display:flex;align-items:center;justify-content:space-between;padding:16px 24px;background:transparent;border-top:1px solid var(--border);margin-top:auto;border-radius:0 0 var(--radius) var(--radius);flex-wrap:wrap;gap:12px;flex-shrink:0}
[data-theme="light"] .pagination{background:transparent}
.page-btn{width:32px;height:32px;padding:0;display:grid;place-items:center;border:1px solid var(--border);border-radius:var(--radius-sm);background:transparent;color:var(--muted);font-size:13px;cursor:pointer;transition:all 0.2s}
.page-btn:hover{border-color:var(--primary);color:var(--primary)}
.page-btn.active{background:rgba(91,124,255,0.15);color:var(--primary);border-color:rgba(91,124,255,0.4);font-weight:600}
.page-btn-text{width:auto;padding:0 12px}
.status{display:grid;gap:8px;margin-top:auto}
.status-box{background:var(--input);border:1px solid var(--border);border-radius:12px;padding:14px 16px;font-size: 13px;}
.status-box p{font-size:14px;line-height:1.3; color:var(--muted-2)}
@media(min-width:1000px) {
  .layout {grid-template-columns: 260px 1fr}
  .sidebar {position: static;transform: none;width: auto;box-shadow: none;border-right: 1px solid var(--border);z-index: auto;background: linear-gradient(180deg, var(--sidebar-grad-1), var(--sidebar-grad-2))}
  .mobile-header {display: none}
  .overlay {display: none !important}
  .full-width-cards {grid-template-columns:1fr}
  .double-column-cards {grid-template-columns:700px 1fr}
  .header {display: flex}
}

@media(min-width:1000px) {
  .layout {height: 100vh}
  .content {height: 100vh;overflow: auto}
  .sidebar {height: 100vh;position: sticky;top: 0}
}

@media(min-width:1000px) {
  .banner {display: none}
  .header-banner {display: flex}
}

.qr-card {
  margin: 12px;
  border: 1px solid rgba(91, 124, 255, 0.4);
  background: linear-gradient(135deg, rgba(91, 124, 255, 0.15), rgba(124, 91, 255, 0.15));
  box-shadow: 0 8px 24px rgba(91, 124, 255, 0.15);
  border-radius: 16px;
  padding: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}

.qr-img {
  width: 100%;
  max-width: 140px;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: 12px;
  border: 2px solid rgba(255, 255, 255, 0.1);
  display: block;
  background: #fff;
}

.qr-desc {
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  text-align: center;
  text-shadow: 0 2px 4px rgba(0, 0, 0, 0.5);
}

/* Task Status Card */
.task-status-card {
  background: #121827; /* Darker bg for contrast */
  border-radius: 12px;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  border: 1px solid var(--border);
  box-shadow: 0 4px 20px rgba(0,0,0,0.2);
  margin-bottom: 24px;
}

.task-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.05);
}
.task-header-check {
  width: 24px;
  height: 24px;
  background: var(--ok);
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-weight: bold;
}
.task-header-text {
  font-size: 15px;
  font-weight: 600;
  color: #fff;
}

.task-info-list {
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: transparent;
}
.task-info-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 14px;
  border-bottom: 1px solid rgba(255,255,255,0.05);
  padding-bottom: 12px;
}
.task-info-row:last-child {
  border-bottom: 0;
  padding-bottom: 0;
}
.task-label {
  color: var(--muted);
}
.task-value {
  color: var(--text);
  font-family: monospace;
}
.task-tag {
  padding: 4px 12px;
  border-radius: 20px;
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
}
.task-tag.queued { background: rgba(245,158,11,0.2); color: var(--accent); }
.task-tag.processing { background: rgba(91,124,255,0.2); color: var(--primary); }
.task-tag.completed { background: rgba(16,185,129,0.2); color: var(--ok); }
.task-tag.failed { background: rgba(239,68,68,0.2); color: var(--danger); }

.progress-section {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.progress-header {
  display: flex;
  justify-content: space-between;
  font-size: 13px;
  color: var(--muted);
}
.progress-bar {
  height: 16px;
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}
.progress-fill {
  height: 100%;
  background: linear-gradient(90deg, #7c5bff, #5b7cff);
  width: 0%;
  transition: width 0.5s ease;
  box-shadow: 0 0 10px rgba(124,91,255,0.5);
}

.time-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.time-box {
  background: rgba(255,255,255,0.03);
  padding: 16px;
  border-radius: 8px;
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.time-label {
  font-size: 12px;
  color: var(--muted);
}
.time-val {
  font-size: 14px;
  font-weight: 600;
  color: var(--text);
}

.video-result {
  margin-top: 16px;
  border-radius: 12px;
  overflow: hidden;
  border: 1px solid var(--border);
  background: #000;
  position: relative;
}
.video-result video {
  width: 100%;
  display: block;
}

.download-btn {
  margin-top: 16px;
  width: 100%;
  padding: 14px;
  background: linear-gradient(135deg, #7c5bff, #5b7cff);
  color: #fff;
  border: none;
  border-radius: 12px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 15px;
  text-decoration: none;
  transition: filter 0.2s;
}
.download-btn:hover {
  filter: brightness(1.1);
}

.hidden { display: none !important; }

/* User dropdown */
.user-chip{position:relative}
.user-chip .user-name{font-size:12px;font-weight:600}
.user-chip .icon{color:var(--muted);font-size:10px}
.user-dropdown{position:absolute;top:calc(100% + 8px);right:0;border:1px solid var(--border);border-radius:12px;background:var(--select-list-bg);display:none;flex-direction:column;min-width:160px;z-index:50;box-shadow:var(--shadow)}
.user-dropdown.show{display:flex}
.user-menu-item{padding:12px 14px;color:var(--text);cursor:pointer;font-size:13px}
.user-menu-item:hover{background:var(--input-hover)}

/* Modal Dialog */
.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,0.6);backdrop-filter:blur(4px);opacity:0;pointer-events:none;transition:opacity .2s;z-index:999}
.modal-overlay.show{opacity:1;pointer-events:auto}
.modal{position:fixed;inset:0;display:grid;place-items:center;z-index:1000;pointer-events:none}
.modal.show{pointer-events:auto}
.modal-card{width:90%;max-width:520px;border-radius:16px;border:1px solid var(--border);background:var(--brand-bg-3);box-shadow:var(--shadow);transform:translateY(10px);opacity:0;transition:all .2s}
.modal.show .modal-card{transform:translateY(0);opacity:1}
.modal-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border)}
.modal-title{font-size:16px;font-weight:700}
.modal-close{width:28px;height:28px;border-radius:8px;border:1px solid var(--border);background:var(--input);display:grid;place-items:center;color:var(--muted);cursor:pointer}
.modal-body{padding:18px 20px;color:var(--text);font-size:14px;line-height:1.8}
.modal-actions{display:flex;align-items:center;gap:10px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border)}
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 14px;border-radius:12px;border:1px solid transparent;cursor:pointer;font-weight:600}
.btn-primary{background:linear-gradient(135deg,var(--primary),var(--primary-2));color:#fff}
.btn-ghost{border-color:var(--border);background:var(--input);color:var(--text)}
.modal-icon{width:28px;height:28px;border-radius:8px;background:linear-gradient(135deg,#7c5bff,#5b7cff);display:grid;place-items:center;color:#fff;margin-right:8px}
.modal-header-left{display:flex;align-items:center}
.modal-type-success .modal-icon{background:linear-gradient(135deg,#10b981,#059669)}
.modal-type-error .modal-icon{background:linear-gradient(135deg,#ef4444,#b91c1c)}
.modal-type-warning .modal-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}
.toast-container{position:fixed;top:20px;right:20px;z-index:1100;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.toast{min-width:260px;max-width:420px;padding:12px 14px;border-radius:12px;border:1px solid var(--border);background:linear-gradient(180deg, rgba(255,255,255,0.18), rgba(255,255,255,0.14));color:var(--text);box-shadow:var(--shadow);display:flex;align-items:center;gap:10px;opacity:0;transform:translateY(-10px);transition:all .2s}
.toast.show{opacity:1;transform:translateY(0)}
.toast-icon{width:22px;height:22px;border-radius:8px;background:linear-gradient(135deg,#7c5bff,#5b7cff);display:grid;place-items:center;color:#fff;font-size:12px}
.toast.success .toast-icon{background:linear-gradient(135deg,#10b981,#059669)}
.toast.error .toast-icon{background:linear-gradient(135deg,#ef4444,#b91c1c)}
.toast.warning .toast-icon{background:linear-gradient(135deg,#f59e0b,#d97706)}
.toast-text{flex:1;font-size:13px;line-height:1.6}
.toast-close{width:24px;height:24px;border-radius:8px;border:1px solid var(--border);background:var(--input);display:grid;place-items:center;color:var(--muted);cursor:pointer;pointer-events:auto}
.guide-btn{width:auto!important;text-decoration:none!important;font-size:13px!important;padding:8px 10px!important;border-radius:20px!important;height: auto!important;}
.header-tools .guide-btn{margin-right:8px}
