/* ===== VARIABLES ===== */
:root {
  --font-sans: 'Inter', system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial, 'Noto Sans', sans-serif;
  --bg: #09090D;
  --bg2: #0F1018;
  --bg3: #14161E;
  --bg4: #1A1C28;
  --border: rgba(255,255,255,0.06);
  --border2: rgba(255,255,255,0.12);
  --gold: #C9A84C;
  --gold2: #E8C96A;
  --gold-dim: rgba(201,168,76,0.12);
  --gold-glow: rgba(201,168,76,0.25);
  --text: #E4E6F0;
  --text2: #9298B0;
  --text3: #5A607A;
  --success: #2ECC87;
  --error: #FF4F6D;
  --info: #4FAAFF;
  --radius: 12px;
  --sidebar-w: 230px;
  --shadow-card: 0 12px 32px rgba(0,0,0,.5);
  --shadow-modal: 0 24px 80px rgba(0,0,0,.65);
  --text-dim: var(--text3);
  font-size: 14px;
}

html { scroll-behavior: smooth; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
  html { scroll-behavior: auto; }
}

/* ===== RESET ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
body { font-family:var(--font-sans); background:var(--bg); color:var(--text); min-height:100vh; overflow-x:hidden; -webkit-font-smoothing:auto; text-rendering:optimizeLegibility; font-feature-settings:'kern' 1; }
::selection { background:var(--gold-dim); color:var(--text); }
a { text-decoration:none; color:inherit; cursor:pointer; }
button, select { font-family:inherit; cursor:pointer; }
input, textarea { font-family:inherit; }
img { display:block; }

/* ===== SCROLLBAR ===== */
::-webkit-scrollbar { width:5px; height:5px; }
::-webkit-scrollbar-track { background:transparent; }
::-webkit-scrollbar-thumb { background:var(--bg4); border-radius:3px; }
::-webkit-scrollbar-thumb:hover { background:var(--gold-dim); }
* { scrollbar-width: thin; scrollbar-color: var(--bg4) transparent; }

/* Keyboard focus — rõ ràng, không làm xấu :focus chuột */
:focus:not(:focus-visible) { outline: none; }
:where(
  button,
  [href],
  input:not([type="hidden"]),
  select,
  textarea,
  .nav-item,
  .pill,
  .vt-btn,
  .preset-chip,
  .variant-btn,
  .fg-btn,
  .pos-btn,
  .icon-tab,
  .icon-chip,
  .drive-tab,
  .admin-tab,
  .ltab,
  .img-card,
  .logo-drop
):focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 2px;
}

/* ===== SPLASH ===== */
#splash { position:fixed; inset:0; background:var(--bg); display:flex; align-items:center; justify-content:center; z-index:9999; transition:opacity .5s, transform .5s; }
#splash.out { opacity:0; transform:scale(1.04); pointer-events:none; }
.splash-inner { text-align:center; }
.splash-logo { font-size:38px; font-weight:700; letter-spacing:3px; color:#fff; }
.splash-logo span { color:var(--gold); }
.splash-sub { font-size:12px; letter-spacing:5px; text-transform:uppercase; color:var(--text3); margin-top:8px; }
.splash-bar { width:160px; height:2px; background:var(--bg4); border-radius:2px; margin:28px auto 0; overflow:hidden; }
.splash-fill { height:100%; background:linear-gradient(90deg,var(--gold),var(--gold2)); border-radius:2px; width:0%; animation:splashLoad 1.4s cubic-bezier(.25,1,.5,1) forwards .2s; }
@keyframes splashLoad { to { width:100%; } }

/* ===== APP SHELL ===== */
.app-hidden { display:none; }
#app { display:flex; min-height:100vh; }

/* ===== SIDEBAR ===== */
.sidebar {
  width:var(--sidebar-w); flex-shrink:0;
  background:var(--bg2);
  border-right:1px solid var(--border);
  display:flex; flex-direction:column;
  position:sticky; top:0; height:100vh;
  overflow-y:auto;
  transition:transform .3s cubic-bezier(.25,1,.5,1);
}
.sidebar-logo {
  display:flex; align-items:center; gap:12px;
  padding:22px 18px 16px;
  border-bottom:1px solid var(--border);
}
.logo-mark {
  width:36px; height:36px; border-radius:8px;
  background:var(--gold-dim); border:1px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-size:13px; font-weight:700; color:var(--gold);
  flex-shrink:0; letter-spacing:1px;
}
.logo-main { font-size:14px; font-weight:700; letter-spacing:0.02em; }
.logo-sub { font-size:10px; color:var(--text3); letter-spacing:1px; margin-top:1px; }
.user-card {
  display:flex; align-items:center; gap:10px;
  padding:12px 16px; border-bottom:1px solid var(--border);
}
.user-av {
  width:32px; height:32px; border-radius:50%;
  background:var(--gold-dim); border:1.5px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; font-weight:700; color:var(--gold); flex-shrink:0;
}
.user-name { font-size:13px; font-weight:600; }
.user-role { font-size:10px; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-top:1px; }
.logout-btn { margin-left:auto; background:none; border:none; color:var(--text3); font-size:16px; padding:4px; border-radius:6px; transition:color .2s; }
.logout-btn:hover { color:var(--error); }
.nav-group { padding:10px 10px 4px; }
.nav-label { font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; color:var(--text3); padding:5px 8px 5px; }
.nav-item {
  display:flex; align-items:center; gap:9px;
  padding:8px 10px; border-radius:8px;
  font-size:13px; font-weight:500; color:var(--text2);
  margin-bottom:1px; transition:all .18s; cursor:pointer;
}
.nav-item:hover { background:var(--bg3); color:var(--text); }
.nav-item.active { background:var(--gold-dim); color:var(--gold); }
.ni { font-size:13px; width:16px; text-align:center; flex-shrink:0; opacity:.6; }
.nav-badge { margin-left:auto; font-size:10px; font-weight:700; padding:1px 6px; border-radius:8px; background:var(--bg4); color:var(--text3); }
.nav-badge.gold { background:var(--gold-dim); color:var(--gold); }
.nav-badge.dim { background:rgba(79,170,255,.1); color:var(--info); }
.admin-only { display:none; }
.sidebar-footer { margin-top:auto; padding:14px; border-top:1px solid var(--border); }
.storage-label { font-size:10px; color:var(--text3); letter-spacing:1px; text-transform:uppercase; }
.storage-bar { height:3px; background:var(--bg4); border-radius:2px; margin:7px 0 4px; overflow:hidden; }
.storage-fill { height:100%; background:linear-gradient(90deg,var(--gold),var(--gold2)); border-radius:2px; transition:width .5s; }
.storage-text { font-size:11px; color:var(--text3); }

/* ===== MAIN ===== */
#main { flex:1; display:flex; flex-direction:column; overflow:hidden; min-width:0; }

/* TOPBAR */
.topbar {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 24px; background:var(--bg2);
  border-bottom:1px solid var(--border);
  position:sticky; top:0; z-index:50; gap:12px; flex-wrap:wrap;
}
.topbar-left { display:flex; align-items:center; gap:12px; }
.menu-btn { display:none; background:none; border:none; color:var(--text2); font-size:18px; padding:4px; }
.page-title { font-size:21px; font-weight:700; letter-spacing:-0.02em; }
.page-count { font-size:12px; color:var(--text3); }
.topbar-right { display:flex; align-items:center; gap:8px; flex-wrap:wrap; margin-left:auto; }
.search-wrap { position:relative; }
.search-wrap input {
  background:var(--bg3); border:1px solid var(--border);
  border-radius:9px; padding:8px 34px 8px 12px;
  color:var(--text); font-size:13px; outline:none; width:200px;
  transition:border-color .2s;
}
.search-wrap input:focus,
.search-wrap input:focus-visible { border-color:var(--gold); }
.search-wrap input::placeholder { color:var(--text3); }
.search-icon { position:absolute; right:11px; top:50%; transform:translateY(-50%); color:var(--text3); font-size:15px; pointer-events:none; }

/* BUTTONS */
.btn {
  display:inline-flex; align-items:center; gap:6px;
  padding:8px 16px; border-radius:9px; border:none;
  font-size:13px; font-weight:600; transition:all .18s; white-space:nowrap;
}
.btn-primary { background:var(--gold); color:#0a0800; }
.btn-primary:hover { background:var(--gold2); transform:translateY(-1px); box-shadow:0 4px 16px var(--gold-glow); }
.btn-primary:active { transform:translateY(0); }
.btn-outline { background:var(--bg3); color:var(--text); border:1px solid var(--border2); }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); }
.btn-danger { background:rgba(255,79,109,.12); color:var(--error); border:1px solid rgba(255,79,109,.2); }
.btn-danger:hover { background:rgba(255,79,109,.2); }
.btn-sm { padding:5px 11px; font-size:12px; }
.btn-full, .w-full { width:100%; justify-content:center; }

/* CONTENT */
.page { display:none; padding:22px 24px; flex:1; overflow-y:auto; }
.page.active { display:block; }

/* STATS */
.stats-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:12px; margin-bottom:20px; }
.stat-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); padding:16px; cursor:pointer;
  transition:border-color .2s, transform .2s;
}
.stat-card:hover { border-color:var(--gold-glow); transform:translateY(-2px); }
.stat-icon { font-size:20px; margin-bottom:8px; opacity:.5; }
.stat-num { font-size:30px; font-weight:700; color:var(--gold); line-height:1; letter-spacing:-0.03em; font-variant-numeric:tabular-nums; }
.stat-label { font-size:11px; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-top:5px; }

/* UPLOAD ZONE */
.upload-zone {
  background:var(--bg2); border:1.5px dashed var(--border2);
  border-radius:var(--radius); padding:28px;
  text-align:center; transition:all .25s;
  margin-bottom:18px; position:relative; overflow:hidden;
}
.upload-zone::after { content:''; position:absolute; inset:0; background:radial-gradient(ellipse at 50% 50%, var(--gold-dim) 0%, transparent 65%); opacity:0; transition:opacity .3s; pointer-events:none; }
.upload-zone:hover, .upload-zone.drag { border-color:var(--gold); background:var(--bg3); }
.upload-zone:hover::after, .upload-zone.drag::after { opacity:1; }
.uz-icon { font-size:36px; margin-bottom:8px; opacity:.4; }
.uz-title { font-size:17px; font-weight:600; margin-bottom:4px; letter-spacing:-0.02em; }
.uz-sub { font-size:12px; color:var(--text3); margin-bottom:14px; }
.uz-opts { position:relative; z-index:1; }
.uz-presets { display:flex; gap:6px; flex-wrap:wrap; justify-content:center; margin-bottom:12px; }
.preset-chip { padding:4px 12px; border-radius:16px; font-size:11px; font-weight:600; border:1px solid var(--border2); background:var(--bg3); color:var(--text3); cursor:pointer; transition:all .18s; }
.preset-chip.active { background:var(--gold-dim); border-color:var(--gold); color:var(--gold); }
.vis-select { display:flex; gap:16px; justify-content:center; font-size:12px; font-weight:600; }
.vis-select label { cursor:pointer; display:flex; align-items:center; gap:5px; }

/* UPLOAD PROGRESS */
.upload-progress { margin-bottom:14px; }
.up-item {
  display:flex; align-items:center; gap:10px;
  background:var(--bg2); border:1px solid var(--border);
  border-radius:9px; padding:10px 13px; margin-bottom:6px;
  animation:fadeIn .3s;
}
.up-thumb { width:38px; height:38px; border-radius:6px; object-fit:cover; background:var(--bg3); flex-shrink:0; }
.up-info { flex:1; min-width:0; }
.up-name { font-size:12px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.up-size { font-size:11px; color:var(--text3); }
.up-bar-wrap { height:2px; background:var(--bg4); border-radius:2px; margin-top:5px; overflow:hidden; }
.up-bar { height:100%; background:linear-gradient(90deg,var(--gold),var(--gold2)); transition:width .3s; }
.up-status { font-size:11px; font-weight:700; flex-shrink:0; }
.up-status.done { color:var(--success); }
.up-status.err { color:var(--error); }

/* TOOLBAR */
.toolbar { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:14px; flex-wrap:wrap; }
.filter-pills { display:flex; background:var(--bg2); border:1px solid var(--border); border-radius:9px; padding:3px; gap:2px; }
.pill { padding:5px 12px; border-radius:7px; border:none; background:none; font-size:12px; font-weight:600; color:var(--text3); transition:all .18s; }
.pill.active { background:var(--gold); color:#0a0800; }
.pill:hover:not(.active) { background:var(--bg3); color:var(--text); }
.toolbar-right { display:flex; align-items:center; gap:8px; flex-wrap:wrap; justify-content:flex-end; }

.folder-mode-toggle {
  display:inline-flex;
  align-items:center;
  gap:8px;
  font-size:12px;
  font-weight:600;
  color:var(--text2);
  cursor:pointer;
  user-select:none;
  white-space:nowrap;
}
.folder-mode-toggle input { width:15px; height:15px; accent-color:var(--gold); cursor:pointer; }

.folder-browse-inner { margin-bottom:14px; }

.folder-breadcrumb {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:4px 6px;
  margin-bottom:10px;
  font-size:13px;
}
.fb-crumb {
  background:transparent;
  border:none;
  color:var(--gold2);
  cursor:pointer;
  padding:4px 6px;
  border-radius:6px;
  font:inherit;
}
.fb-crumb:hover { background:var(--gold-dim); color:var(--text); }
.fb-crumb-current { color:var(--text3); cursor:default; }
.fb-crumb-current:hover { background:transparent; }
.fb-sep { color:var(--text3); user-select:none; padding:0 2px; }

.folder-cards {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-bottom:4px;
}
.folder-card {
  display:inline-flex;
  align-items:center;
  gap:8px;
  padding:10px 14px;
  background:var(--bg3);
  border:1px solid var(--border);
  border-radius:var(--radius);
  color:var(--text);
  font-size:13px;
  font-weight:600;
  transition:border-color .18s, background .18s;
}
.folder-card:hover {
  border-color:var(--gold-glow);
  background:var(--bg4);
}
.folder-card-icon { font-size:18px; opacity:0.9; }
.folder-card-name {
  max-width:min(240px, 38vw);
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.folder-card-count {
  font-size:11px;
  font-weight:700;
  color:var(--text3);
  background:var(--bg);
  padding:2px 9px;
  border-radius:999px;
}
.sort-sel { background:var(--bg2); border:1px solid var(--border); color:var(--text); padding:7px 10px; border-radius:9px; font-size:12px; font-weight:600; outline:none; }
.view-toggle { display:flex; background:var(--bg2); border:1px solid var(--border); border-radius:9px; padding:3px; gap:2px; }
.vt-btn { padding:5px 8px; border-radius:6px; border:none; background:none; color:var(--text3); font-size:14px; transition:all .18s; }
.vt-btn.active { background:var(--bg4); color:var(--text); }

/* GALLERY GRID */
.gallery-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:12px; }
.gallery-grid.list { grid-template-columns:1fr; }
.img-card {
  background:var(--bg2); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  cursor:pointer; transition:all .22s; position:relative;
  animation:fadeIn .35s;
}
.img-card:hover { border-color:var(--gold-glow); transform:translateY(-3px); box-shadow:var(--shadow-card); }
.img-card.selected { border-color:var(--gold); box-shadow:0 0 0 2px var(--gold); }
.img-card.selected .img-chk { opacity:1; }
.img-card.priv { border-color:rgba(79,170,255,.2); }
.img-card.priv:hover { border-color:var(--info); }
.img-thumb-wrap { position:relative; overflow:hidden; }
.img-thumb { width:100%; aspect-ratio:4/3; object-fit:cover; transition:transform .3s; display:block; }
.img-card:hover .img-thumb { transform:scale(1.05); }
.img-chk {
  position:absolute; top:8px; left:8px; z-index:2;
  width:20px; height:20px; border-radius:5px;
  background:var(--gold); color:#0a0800;
  display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:800; opacity:0; transition:opacity .18s;
}
.img-card:hover .img-chk { opacity:.4; }
.img-priv { position:absolute; top:8px; right:8px; background:rgba(79,170,255,.85); color:#fff; font-size:9px; font-weight:700; padding:2px 6px; border-radius:4px; letter-spacing:.5px; }
.img-hover {
  position:absolute; inset:0;
  background:linear-gradient(to top, rgba(0,0,0,.85) 0%, transparent 55%);
  opacity:0; transition:opacity .22s;
  display:flex; align-items:flex-end; padding:10px; gap:5px;
}
.img-card:hover .img-hover { opacity:1; }
.img-ha { padding:4px 9px; border-radius:6px; font-size:11px; font-weight:700; border:none; cursor:pointer; transition:all .15s; }
.img-ha.view { background:var(--gold); color:#0a0800; }
.img-ha.edit { background:rgba(255,255,255,.15); color:#fff; }
.img-ha:hover { transform:scale(1.06); }
.img-info { padding:9px 11px; }
.img-iname { font-size:12px; font-weight:600; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.img-imeta { display:flex; justify-content:space-between; margin-top:3px; }
.img-isize { font-size:11px; color:var(--text3); }
.img-tags { display:flex; gap:3px; flex-wrap:wrap; margin-top:5px; }
.itag { font-size:10px; font-weight:600; padding:2px 6px; border-radius:3px; }
.itag.web { background:rgba(79,170,255,.12); color:var(--info); }
.itag.fb { background:rgba(59,89,152,.2); color:#8AB4F8; }
.itag.tiktok { background:rgba(255,0,80,.12); color:#FF6B9D; }
.itag.zalo { background:rgba(0,100,255,.12); color:var(--info); }
/* LIST VIEW */
.gallery-grid.list .img-card { display:flex; }
.gallery-grid.list .img-thumb { width:72px; height:54px; aspect-ratio:unset; flex-shrink:0; border-radius:0; }
.gallery-grid.list .img-hover { display:none; }
.gallery-grid.list .img-info { flex:1; padding:8px 12px; }
.gallery-grid.list .img-card:hover { transform:none; }
/* EMPTY */
.empty-state { text-align:center; padding:60px 20px; color:var(--text3); }
.es-icon { font-size:48px; margin-bottom:14px; opacity:.3; }
.es-title { font-size:19px; font-weight:600; color:var(--text2); margin-bottom:5px; letter-spacing:-0.02em; }
.es-sub { font-size:13px; }
@keyframes fadeIn { from { opacity:0; transform:translateY(8px); } to { opacity:1; transform:translateY(0); } }

/* BULK BAR */
.bulk-bar {
  position:fixed; bottom:22px; left:50%;
  transform:translateX(-50%) translateY(80px);
  background:var(--bg2); border:1px solid var(--gold);
  border-radius:14px; padding:10px 16px;
  display:flex; align-items:center; gap:9px;
  box-shadow:0 20px 60px rgba(0,0,0,.7), 0 0 0 1px var(--gold-glow);
  transition:transform .3s cubic-bezier(.34,1.56,.64,1);
  z-index:100; white-space:nowrap;
}
.bulk-bar.show { transform:translateX(-50%) translateY(0); }
.bulk-count { background:var(--gold); color:#0a0800; font-size:12px; font-weight:800; padding:3px 9px; border-radius:7px; }

/* ===== MODALS ===== */
.modal-bg {
  position:fixed; inset:0; background:rgba(0,0,0,.88);
  display:flex; align-items:center; justify-content:center;
  z-index:200; opacity:0; pointer-events:none;
  transition:opacity .22s;
  backdrop-filter:saturate(1.1) blur(8px);
}
@media (prefers-reduced-motion: reduce) {
  .modal-bg { backdrop-filter: none; }
}
.modal-bg.show { opacity:1; pointer-events:all; }
.modal {
  background:var(--bg2); border:1px solid var(--border2);
  border-radius:18px; width:90%; max-height:90vh;
  overflow:hidden; transform:scale(.95) translateY(12px);
  transition:transform .22s; display:flex; flex-direction:column;
}
.modal-bg.show .modal { transform:scale(1) translateY(0); box-shadow:var(--shadow-modal); }
.modal-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--border); font-size:15px; font-weight:700; }
.modal-body { padding:20px; overflow-y:auto; flex:1; }
.modal-x { width:28px; height:28px; border-radius:7px; background:var(--bg3); border:none; color:var(--text); font-size:14px; display:flex; align-items:center; justify-content:center; transition:background .2s; }
.modal-x:hover { background:var(--error); }

/* LOGIN MODAL */
.login-modal { max-width:400px; }
.lm-logo { text-align:center; padding:32px 20px 24px; border-bottom:1px solid var(--border); }
.lm-title { font-size:26px; font-weight:700; letter-spacing:2px; }
.lm-sub { font-size:11px; color:var(--text3); letter-spacing:2px; text-transform:uppercase; margin-top:5px; }
.login-tabs { display:flex; gap:4px; padding:12px 16px 0; }
.ltab { flex:1; padding:9px; background:none; border:none; font-size:13px; font-weight:600; color:var(--text3); border-bottom:2px solid transparent; transition:all .18s; }
.ltab.active { color:var(--gold); border-color:var(--gold); }
#loginForm, #registerForm { padding:16px; }
.form-row { margin-bottom:13px; }
.form-row label { display:block; font-size:11px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-bottom:5px; }
.form-input { width:100%; background:var(--bg3); border:1px solid var(--border2); border-radius:9px; color:var(--text); font-size:13px; padding:10px 13px; outline:none; transition:border-color .2s; }
.form-input:focus,
.form-input:focus-visible { border-color:var(--gold); }
.form-error { color:var(--error); font-size:12px; min-height:18px; margin-bottom:8px; }

/* ===== LOGIN PAGE (/login) ===== */
body.login-page-body {
  overflow-x:hidden;
}
.login-page-shell {
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px 16px;
  background:
    radial-gradient(ellipse 90% 70% at 50% -25%, rgba(201,168,76,0.1), transparent 52%),
    var(--bg);
}
.login-page-shell .login-page-card.modal {
  transform:none;
  box-shadow:var(--shadow-modal);
  width:100%;
}

/* DETAIL MODAL */
.detail-modal { max-width:900px; }
.dm-header { display:flex; align-items:center; justify-content:space-between; padding:16px 20px; border-bottom:1px solid var(--border); }
.dm-title { font-size:14px; font-weight:700; flex:1; min-width:0; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dm-body { display:flex; gap:20px; padding:20px; overflow-y:auto; }
.dm-preview { flex:1; }
.dm-preview img { width:100%; border-radius:10px; object-fit:cover; max-height:420px; }
.dm-img-actions { display:flex; gap:7px; margin-top:10px; flex-wrap:wrap; }
.dm-info { width:280px; flex-shrink:0; }
.di-row { margin-bottom:13px; }
.di-row.di-embed { margin-bottom:14px; }
.di-label { font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-bottom:4px; }
.di-val { font-size:13px; }
.embed-field { display:flex; gap:8px; align-items:flex-start; }
.embed-input {
  flex:1; min-width:0; font-size:11px; font-family:ui-monospace,monospace;
  background:var(--bg3); border:1px solid var(--border2); border-radius:8px; color:var(--text);
  padding:8px 10px; outline:none;
}
.embed-ta {
  flex:1; min-width:0; font-size:11px; font-family:ui-monospace,monospace; line-height:1.45;
  background:var(--bg3); border:1px solid var(--border2); border-radius:8px; color:var(--text);
  padding:8px 10px; outline:none; resize:vertical;
}
.variant-btn { display:block; width:100%; text-align:left; padding:8px 10px; background:var(--bg3); border:1px solid var(--border); border-radius:8px; font-size:12px; font-weight:600; margin-bottom:5px; transition:all .18s; }
.variant-btn:hover { border-color:var(--gold); color:var(--gold); }

/* DRIVE MODAL */
.drive-modal { max-width:560px; }
.drive-vis-row {
  display:flex; align-items:center; gap:12px 18px; margin-bottom:14px;
  padding:10px 12px; background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius);
  font-size:13px; font-weight:600; flex-wrap:wrap;
}
.drive-vis-label { color:var(--text2); font-weight:600; }
.drive-vis-opts { display:flex; gap:14px; flex-wrap:wrap; align-items:center; }
.drive-vis-opts label {
  display:inline-flex; align-items:center; gap:6px; cursor:pointer;
  font-weight:600; padding:4px 2px; border-radius:6px; transition:color .15s;
}
.drive-vis-opts label:first-of-type { color:var(--gold); }
.drive-vis-opts label:last-of-type { color:var(--info); }
.drive-vis-opts input { accent-color:var(--gold); width:15px; height:15px; }
.drive-folder-hint {
  font-size:12px; color:var(--text-dim); margin:0 0 12px; line-height:1.55;
}
.drive-folder-hint code { font-size:11px; padding:1px 5px; background:var(--bg4); border-radius:5px; }
.drive-actions { display:flex; gap:8px; margin-top:12px; align-items:stretch; }
.drive-actions .btn-primary { flex:1; }
.drive-progress-section {
  margin-top:16px; padding-top:16px;
  border-top:1px solid var(--border);
}
.drive-progress-section .ep-label { margin-bottom:8px; }
.drive-tabs {
  display:flex; gap:4px; margin-bottom:14px;
  background:var(--bg3); border:1px solid var(--border); border-radius:9px; padding:4px;
}
.drive-tab {
  flex:1; min-width:0; padding:8px 6px; border-radius:7px; border:none;
  background:transparent; font-size:11px; font-weight:600; color:var(--text3);
  transition:background .15s, color .15s, box-shadow .15s;
}
.drive-tab:hover:not(.active) {
  color:var(--text);
  background:rgba(255,255,255,.04);
}
.drive-tab.active {
  background:rgba(201,168,76,.14);
  color:var(--gold);
  box-shadow:inset 0 0 0 1px rgba(201,168,76,.32);
}
.drive-tab.drive-tab--muted:not(.active) {
  opacity:.88;
  font-weight:500;
}
.drive-panel { display:none; }
.drive-panel.active { display:block; }
.ep-label { display:block; font-size:10px; font-weight:700; color:var(--text3); text-transform:uppercase; letter-spacing:1px; margin-bottom:6px; }
.ep-textarea { width:100%; min-height:110px; background:var(--bg3); border:1px solid var(--border2); border-radius:9px; color:var(--text); font-size:13px; padding:10px 12px; outline:none; resize:vertical; transition:border-color .2s; line-height:1.6; }
.ep-textarea:focus { border-color:var(--gold); }
.ep-input { width:100%; background:var(--bg3); border:1px solid var(--border2); border-radius:8px; color:var(--text); font-size:12px; padding:8px 10px; outline:none; margin-bottom:7px; transition:border-color .2s; }
.ep-input:focus { border-color:var(--gold); }
.ep-notice { background:rgba(79,170,255,.08); border:1px solid rgba(79,170,255,.2); border-radius:8px; padding:9px 12px; font-size:12px; color:var(--info); margin-bottom:9px; }
.drive-guide-panel { padding-top:2px; }
.drive-guide-tldr {
  list-style:none; margin:0 0 14px; padding:0;
  border:1px solid var(--border); border-radius:var(--radius); background:var(--bg3);
  overflow:hidden;
}
.drive-guide-tldr li {
  position:relative;
  padding:10px 14px 10px 22px;
  font-size:12px; line-height:1.55;
  color:var(--text2);
  text-align:left;
  word-spacing:normal;
  border-bottom:1px solid var(--border);
}
.drive-guide-tldr li:last-child { border-bottom:none; }
.drive-guide-tldr li::before {
  content:''; position:absolute; left:10px; top:15px;
  width:5px; height:5px; border-radius:50%; background:var(--gold); opacity:.9;
}
.drive-guide-tldr code {
  font-size:11px; padding:1px 5px; background:var(--bg4); border-radius:5px;
  word-break:break-word;
}
.drive-guide-details {
  border:1px solid var(--border); border-radius:var(--radius);
  background:var(--bg3); overflow:hidden;
}
.drive-guide-summary {
  cursor:pointer; padding:11px 14px;
  font-size:12px; font-weight:600; color:var(--gold);
  list-style:none; user-select:none; text-align:left;
}
.drive-guide-summary::-webkit-details-marker { display:none; }
.drive-guide-summary::after {
  content:'▸'; float:right; opacity:.55;
  transition:transform .18s;
}
.drive-guide-details[open] .drive-guide-summary::after {
  transform:rotate(90deg);
}
.drive-guide-details .guide-steps {
  padding:2px 12px 14px;
}
.guide-steps { display:flex; flex-direction:column; gap:6px; }
.gs {
  display:flex; align-items:flex-start; gap:10px;
  background:var(--bg2); border-radius:8px;
  padding:8px 11px; font-size:12px; line-height:1.55;
  text-align:left; word-spacing:normal;
  border:1px solid var(--border);
}
.gs-body {
  flex:1; min-width:0;
  text-align:left; word-spacing:normal;
  overflow-wrap:anywhere;
}
.gs-body code {
  font-size:11px; padding:1px 5px; background:var(--bg4); border-radius:5px;
  word-break:break-word;
}
.gs-n {
  background:var(--gold); color:#0a0800;
  width:22px; height:22px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:10px; font-weight:800; flex-shrink:0; margin-top:1px;
}
.drive-pi {
  display:flex; align-items:flex-start; gap:12px;
  background:var(--bg3); border:1px solid var(--border); border-radius:var(--radius);
  padding:12px 14px; margin-bottom:8px;
}
.drive-pi:last-child { margin-bottom:0; }
.dpi-icon {
  font-size:20px; line-height:1; flex-shrink:0; margin-top:2px; opacity:.95;
}
.dpi-info { flex:1; min-width:0; }
.dpi-name { font-size:13px; font-weight:600; color:var(--text); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.dpi-st {
  font-size:12px; color:var(--text2); margin-top:6px; line-height:1.45;
  word-break:break-word;
}
.dpi-st.dpi-st--error {
  margin-top:10px; padding:10px 12px;
  background:rgba(255,79,109,.08); border:1px solid rgba(255,79,109,.22);
  border-radius:9px; color:#FFB4C0; font-weight:500;
}
.drive-progress-head {
  display:flex; flex-wrap:wrap; align-items:baseline; justify-content:space-between; gap:8px 14px;
  margin-bottom:10px;
}
.drive-progress-head .ep-label { margin-bottom:0; }
.drive-progress-hint {
  font-size:11px; color:var(--text3); font-weight:500; max-width:100%; line-height:1.4;
}

/* Card tiến trình import cả thư mục Drive */
.drive-job-card {
  background:var(--bg3);
  border:1px solid var(--border2);
  border-radius:var(--radius);
  padding:14px 16px;
  margin-bottom:10px;
}
.drive-job-card:last-child { margin-bottom:0; }
.drive-job-top {
  display:flex; gap:12px; align-items:flex-start;
}
.drive-job-main { flex:1; min-width:0; }
.drive-job-end {
  font-size:22px; line-height:1; flex-shrink:0; margin-top:4px;
  min-width:1.35em; text-align:center;
}

.drive-job-steps {
  display:flex; flex-wrap:wrap; gap:8px 14px;
  margin-bottom:12px;
}
.djs-step {
  display:inline-flex; align-items:center; gap:8px;
  font-size:11px; font-weight:700; text-transform:uppercase;
  letter-spacing:0.45px; color:var(--text3);
}
.djs-dot {
  width:9px; height:9px; border-radius:50%;
  background:var(--bg4); border:2px solid var(--border2);
  transition:background .2s, border-color .2s, box-shadow .2s;
}
.djs-step.is-wait .djs-dot { opacity:0.55; }
.djs-step.is-active {
  color:var(--gold);
}
.djs-step.is-active .djs-dot {
  background:var(--gold-dim); border-color:var(--gold);
  box-shadow:0 0 0 3px var(--gold-glow);
  animation:djsPulse 1.4s ease-in-out infinite;
}
.djs-step.is-done {
  color:var(--text2);
}
.djs-step.is-done .djs-dot {
  background:var(--success); border-color:rgba(46,204,135,.5);
  animation:none;
}
@keyframes djsPulse {
  0%, 100% { box-shadow:0 0 0 3px var(--gold-glow); }
  50% { box-shadow:0 0 0 6px rgba(201,168,76,.12); }
}

.drive-job-track {
  height:8px; background:var(--bg4); border-radius:6px; overflow:hidden;
  margin-bottom:10px;
}
.drive-job-fill {
  height:100%; min-width:0;
  background:linear-gradient(90deg,var(--info),var(--gold));
  border-radius:6px;
  transition:width .35s ease-out;
  width:4%;
}

.drive-job-phase {
  font-size:13px; font-weight:700; color:var(--text); margin-bottom:6px; letter-spacing:-0.02em;
}
.drive-job-detail {
  font-size:12px; color:var(--text2); line-height:1.55;
  display:-webkit-box; -webkit-line-clamp:4; -webkit-box-orient:vertical;
  overflow:hidden; word-break:break-word;
}
.drive-job-detail.dpi-st--error {
  display:block; -webkit-line-clamp:unset;
  margin-top:8px; padding:10px 12px;
  background:rgba(255,79,109,.08); border:1px solid rgba(255,79,109,.22);
  border-radius:9px; color:#FFB4C0; font-weight:500;
}
.drive-job-stats {
  margin-top:10px; font-size:11px; font-weight:600; color:var(--text3);
  display:flex; flex-wrap:wrap; gap:8px 16px;
}
.drive-job-stats span { white-space:nowrap; }
.drive-job-stats .djs-n_ok { color:var(--success); }
.drive-job-stats .djs-n_warn { color:var(--gold2); }
.drive-job-stats .djs-n_err { color:var(--error); }

.drive-job-errbox {
  margin-top:12px; border-radius:9px; border:1px solid var(--border);
  background:var(--bg2); overflow:hidden;
}
.drive-job-errsum {
  cursor:pointer; padding:10px 12px; font-size:11px; font-weight:700;
  color:var(--text2); list-style:none;
}
.drive-job-errsum::-webkit-details-marker { display:none; }
.drive-job-errbox[open] .drive-job-errsum { color:var(--gold); }
.drive-job-errlist {
  max-height:160px; overflow:auto; margin:0; padding:0 12px 12px;
  font-size:11px; color:var(--text2); line-height:1.45; list-style:none;
}
.drive-job-errlist li {
  padding:6px 0; border-top:1px solid var(--border);
}
.drive-job-errlist .ej-file { color:var(--text); font-weight:600; word-break:break-word; }

.dpi-bar-wrap { height:6px; background:var(--bg4); border-radius:4px; margin-top:8px; overflow:hidden; }
.dpi-bar { height:100%; background:linear-gradient(90deg,var(--info),var(--gold)); transition:width .4s; border-radius:4px; }
.dpi-end {
  font-size:18px; flex-shrink:0; line-height:1; margin-top:2px;
  min-width:1.25em; text-align:center;
}

/* ===== EDITOR ===== */
.editor-overlay { position:fixed; inset:0; background:rgba(5,6,12,.97); z-index:300; display:flex; flex-direction:column; opacity:0; pointer-events:none; transition:opacity .22s; }
.editor-overlay.show { opacity:1; pointer-events:all; }
.editor-topbar { display:flex; align-items:center; gap:10px; padding:11px 18px; background:var(--bg2); border-bottom:1px solid var(--border); flex-wrap:wrap; }
.editor-logo { font-size:15px; font-weight:700; color:var(--gold); flex-shrink:0; letter-spacing:-0.02em; }
.editor-fname { font-size:12px; color:var(--text3); flex:1; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.editor-tbr { display:flex; gap:7px; margin-left:auto; flex-wrap:wrap; }
.editor-body { display:flex; flex:1; overflow:hidden; min-height:0; }
.editor-canvas-area {
  flex:1; display:flex; flex-direction:column; align-items:stretch;
  background:#050608; overflow:hidden; min-width:0; min-height:0;
}
.editor-canvas-toolbar {
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  padding:8px 12px; background:var(--bg3); border-bottom:1px solid var(--border); flex-shrink:0;
}
.ect-label { font-size:10px; color:var(--text3); font-weight:700; text-transform:uppercase; letter-spacing:0.5px; }
.ect-zoom { font-size:11px; color:var(--gold); font-weight:700; min-width:40px; }
.editor-hint {
  font-size:11px; color:var(--text3); padding:6px 14px; flex-shrink:0; line-height:1.45;
  border-bottom:1px solid var(--border);
}
.editor-hint kbd { font-size:10px; padding:2px 6px; background:var(--bg4); border-radius:4px; border:1px solid var(--border); }
/* Không căn giữa bằng justify-content/align-items — làm scrollWidth/scrollHeight sai khi zoom, không kéo hết vùng ẩn */
.editor-viewport {
  flex:1; overflow:auto; display:flex;
  min-height:100px; cursor:default;
}
.editor-viewport.editor-panning { cursor:grabbing; }
.editor-viewport.editor-hand-space { cursor:grab; }
.editor-viewport.editor-hand-space #edCanvas { cursor:grab !important; }
.editor-viewport.editor-drag-over-icon {
  outline:2px dashed rgba(201,168,76,.55);
  outline-offset:-3px;
}
.icon-chip[draggable='true'] { cursor:grab; }
.icon-chip[draggable='true']:active { cursor:grabbing; }
.editor-zoom-pad {
  display:inline-block;
  line-height:0;
  vertical-align:middle;
  box-sizing:content-box;
  flex-shrink:0;
  margin:auto;
}
.editor-zoom-wrap {
  display:inline-block;
  line-height:0;
}
#edCanvas {
  display:block; box-shadow:0 0 60px rgba(0,0,0,.9); cursor:crosshair;
  vertical-align:middle;
}
.editor-panel {
  width:278px;
  background:var(--bg2);
  border-left:1px solid var(--border);
  overflow-y:auto;
  flex-shrink:0;
}
/* ——— Panel chỉnh ảnh: gọn chiều dọc ——— */
.editor-panel .ep-sec { padding:8px 10px; }
.editor-panel .ep-title { margin-bottom:6px; font-size:8px; letter-spacing:1px; }
.editor-panel .sl-row {
  display:grid;
  grid-template-columns:minmax(88px, 34%) 1fr;
  align-items:center;
  gap:2px 8px;
  margin-bottom:4px;
}
.editor-panel .sl-row > .sl-label {
  margin-bottom:0;
  font-size:10px;
  font-weight:600;
  line-height:1.2;
}
.editor-panel .sl-row > input[type='range'] { grid-column:2; min-width:0; }
.editor-panel .filter-grid { grid-template-columns:repeat(3, 1fr); gap:3px; }
.editor-panel .fg-btn {
  padding:5px 5px;
  font-size:10px;
  font-weight:600;
  border-radius:6px;
  line-height:1.25;
}
.editor-panel .icon-tab-row { gap:3px; margin-bottom:5px; }
.editor-panel .icon-tab { padding:4px 6px; font-size:9px; border-radius:5px; }
.editor-panel .icon-palette-host .icon-grid {
  max-height:min(34vh, 200px);
  gap:3px;
  padding:3px 2px;
}
.editor-panel .icon-chip { font-size:17px; padding:4px 2px; border-radius:6px; }
.editor-panel .layer-mini-list { margin-top:5px; font-size:10px; max-height:100px; }
.editor-panel .ep-input {
  padding:6px 8px;
  font-size:11px;
  margin-bottom:5px;
  border-radius:6px;
}
.editor-panel .ep-check { font-size:11px; gap:5px; }
.editor-panel .ep-check-primary {
  padding:6px 8px;
  font-size:12px;
  margin-bottom:7px;
  border-radius:6px;
}
.editor-panel .color-row { margin-bottom:5px; gap:6px; }
.editor-panel .cl { font-size:10px; }
.editor-panel .pos-grid { gap:2px; margin-bottom:5px; }
.editor-panel .pos-btn { padding:5px 4px; font-size:11px; border-radius:4px; }
.editor-panel .logo-drop { padding:7px 8px; font-size:11px; margin-bottom:5px; border-radius:6px; }
.editor-panel .ep-hint { margin-top:4px; font-size:9px; line-height:1.35; }
.editor-panel .editor-crop-select { padding:6px 8px; font-size:11px; margin-bottom:3px; border-radius:6px; }
.editor-panel .ep-sub { margin:7px 0 4px; font-size:9px; letter-spacing:0.45px; }
.editor-panel .crop-field-label {
  display:block;
  font-size:10px;
  font-weight:600;
  color:var(--text3);
  margin:0 0 4px;
}
.editor-panel .logo-drop + .ep-check-primary { margin-top:6px; }
.editor-panel .ft-row { margin-bottom:5px; }
.editor-panel .ft-inline { padding:5px 7px; font-size:10px; border-radius:5px; }
.editor-panel .editor-btn-tight { margin-top:4px; }
.editor-panel .editor-export-full { margin-top:4px; width:100%; box-sizing:border-box; }
.editor-panel .filter-grid.editor-grid-2 { grid-template-columns:1fr 1fr; }
.editor-layerfx-btns { display:flex; gap:6px; flex-wrap:wrap; margin-bottom:6px; }
.editor-layerfx-btns .btn { flex:1; min-width:0; }
.editor-panel .ep-notice { padding:6px 9px; font-size:11px; margin-bottom:6px; border-radius:6px; }

/* ===== BATCH OPTIMIZE / RESIZE ===== */
.batch-opt-overlay {
  position:fixed; inset:0; z-index:292;
  background:rgba(5,6,12,.97);
  display:flex; flex-direction:column;
  opacity:0; pointer-events:none; transition:opacity .2s;
}
.batch-opt-overlay.show { opacity:1; pointer-events:all; }
.batch-opt-header {
  display:flex; align-items:flex-start; justify-content:space-between; gap:12px;
  padding:11px 18px; background:var(--bg2); border-bottom:1px solid var(--border); flex-shrink:0;
}
.batch-opt-sub {
  display:block; font-size:11px; color:var(--text3); font-weight:400; margin-top:4px;
}
.batch-opt-main {
  flex:1; display:grid;
  grid-template-columns:minmax(220px, 1fr) minmax(272px, 340px);
  gap:0; min-height:0; overflow:hidden;
}
.batch-opt-pane {
  padding:12px 14px; overflow-y:auto;
  border-right:1px solid var(--border);
}
.batch-opt-pane:last-child { border-right:none; }
.batch-opt-step {
  font-size:9px; font-weight:800; color:var(--gold); text-transform:uppercase;
  letter-spacing:1px; margin-bottom:7px;
}
.batch-drop-zone {
  border:2px dashed var(--border2); border-radius:10px; padding:18px 12px;
  text-align:center; font-size:13px; color:var(--text3); cursor:pointer;
  transition:all .18s; margin-bottom:8px;
}
.batch-drop-zone:hover,
.batch-drop-zone-hover {
  border-color:var(--gold-dim); color:var(--text); background:rgba(201,168,76,.04);
}
.batch-drop-zone small { font-size:11px; opacity:.88; }
.batch-file-toolbar {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:7px; font-size:12px;
}
.batch-file-list {
  list-style:none; margin:0; padding:0;
  max-height:min(52vh, 420px); overflow-y:auto;
}
.batch-file-row {
  display:flex; align-items:center; gap:8px;
  padding:5px 8px; border-radius:6px; background:var(--bg3);
  border:1px solid var(--border); margin-bottom:4px; font-size:11px;
}
.batch-file-name {
  flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap;
}
.batch-file-meta { color:var(--text3); font-size:10px; flex-shrink:0; }
.batch-file-x {
  border:none; background:none; color:var(--text3); cursor:pointer;
  padding:2px 6px; border-radius:4px; font-size:12px;
}
.batch-file-x:hover { color:var(--error); background:rgba(255,80,80,.08); }
.batch-radio-stack {
  display:flex; flex-direction:column; gap:7px; margin-bottom:11px;
}
.batch-radio {
  display:flex; align-items:flex-start; gap:8px;
  font-size:12px; color:var(--text2); cursor:pointer; line-height:1.35;
}
.batch-radio input { margin-top:3px; accent-color:var(--gold); flex-shrink:0; }
.batch-field-row { margin-bottom:9px; }
.batch-label {
  display:block; font-size:10px; font-weight:700; color:var(--text3);
  text-transform:uppercase; letter-spacing:0.5px; margin-bottom:4px;
}
.batch-field-inline { display:flex; flex-wrap:wrap; gap:8px; align-items:center; }
.batch-select-compact { flex:1; min-width:120px; margin-bottom:0 !important; }
.batch-num-input { width:88px; margin-bottom:0 !important; }
.batch-slider-row input[type='range'] { width:100%; }
.batch-action-btn { width:100%; margin-bottom:7px; box-sizing:border-box; }
.batch-progress-wrap { margin-bottom:9px; }
.batch-progress-track {
  height:6px; background:var(--bg4); border-radius:4px; overflow:hidden;
}
.batch-progress-fill {
  height:100%; width:0%;
  background:linear-gradient(90deg, var(--gold-dim), var(--gold));
  transition:width .12s;
}
.batch-progress-txt { font-size:11px; color:var(--text3); margin-top:5px; min-height:1.2em; }
.batch-opt-note { font-size:10px; color:var(--text3); line-height:1.4; margin:8px 0 0; }
@media(max-width:900px) {
  .batch-opt-main { grid-template-columns:1fr; }
  .batch-opt-pane {
    border-right:none; border-bottom:1px solid var(--border);
    max-height:44vh;
  }
}

.icon-tab-row { display:flex; flex-wrap:wrap; gap:4px; margin-bottom:8px; }
.icon-tab {
  padding:5px 9px; border-radius:6px; border:1px solid var(--border); background:var(--bg3);
  font-size:10px; font-weight:700; cursor:pointer; color:var(--text3); transition:all .15s;
}
.icon-tab:hover { border-color:var(--gold-dim); color:var(--text); }
.icon-tab.active { border-color:var(--gold); color:var(--gold); background:var(--gold-dim); }
.icon-palette-host .icon-grid {
  display:grid; grid-template-columns:repeat(6,1fr); gap:4px;
  max-height:min(42vh,260px); overflow-y:auto; padding:4px 2px;
}
.icon-chip {
  font-size:19px; padding:6px 3px; border-radius:8px; border:1px solid var(--border); background:var(--bg3);
  cursor:pointer; line-height:1; transition:all .15s;
}
.icon-chip:hover { border-color:var(--gold); transform:scale(1.06); background:var(--bg4); }
.layer-mini-list { margin-top:8px; font-size:11px; max-height:130px; overflow-y:auto; }
.ft-row { display:flex; gap:6px; align-items:center; margin-bottom:6px; }
.ft-row-sel { outline:1px solid var(--gold); border-radius:8px; padding:3px 4px; background:rgba(201,168,76,.06); }
.ft-inline { flex:1; min-width:0; font-size:11px; padding:6px 8px; border-radius:6px; border:1px solid var(--border2); background:var(--bg3); color:var(--text); }
.icon-tag { font-size:18px; width:26px; text-align:center; flex-shrink:0; }
.icon-size-sl { flex:1; min-width:40px; }
.ep-hint { font-size:10px; color:var(--text3); line-height:1.4; display:block; margin-top:6px; }
.editor-crop-select {
  width:100%; box-sizing:border-box; margin-bottom:4px;
  padding:8px 10px; border-radius:8px; border:1px solid var(--border); background:var(--bg3); color:var(--text);
  font-size:12px; cursor:pointer;
}
.editor-crop-select:focus { outline:none; border-color:var(--gold-dim); }
.ep-sub { font-size:10px; color:var(--text3); margin:10px 0 6px; font-weight:700; text-transform:uppercase; letter-spacing:0.6px; }
.w-full { width:100%; box-sizing:border-box; }
.ep-sec { padding:13px 14px; border-bottom:1px solid var(--border); }
.ep-title { font-size:9px; font-weight:800; color:var(--text3); text-transform:uppercase; letter-spacing:1.5px; margin-bottom:10px; }
.sl-row { margin-bottom:8px; }
.sl-label { display:flex; justify-content:space-between; font-size:11px; font-weight:600; color:var(--text3); margin-bottom:4px; }
.sl-label span { color:var(--gold); }
input[type=range] { width:100%; accent-color:var(--gold); cursor:pointer; }
.filter-grid { display:grid; grid-template-columns:1fr 1fr; gap:4px; }
.fg-btn { padding:7px 8px; border-radius:8px; border:1px solid var(--border); background:var(--bg3); color:var(--text2); font-size:11px; font-weight:600; cursor:pointer; text-align:center; transition:all .18s; }
.fg-btn:hover,.fg-btn.active { background:var(--gold-dim); border-color:var(--gold); color:var(--gold); }
.color-row { display:flex; gap:8px; align-items:center; margin-bottom:8px; flex-wrap:wrap; }
.cl { font-size:11px; color:var(--text3); font-weight:600; }
input[type=color] { width:30px; height:26px; border:1px solid var(--border); border-radius:5px; background:none; padding:2px; cursor:pointer; }
.pos-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:3px; margin-bottom:8px; }
.pos-btn { padding:7px; border-radius:5px; border:1px solid var(--border); background:var(--bg3); color:var(--text3); font-size:12px; cursor:pointer; text-align:center; transition:all .18s; }
.pos-btn:hover,.pos-btn.active { background:var(--gold-dim); border-color:var(--gold); color:var(--gold); }
.logo-drop { border:1px dashed var(--border2); border-radius:7px; padding:10px; text-align:center; cursor:pointer; font-size:12px; color:var(--text3); transition:all .18s; margin-bottom:7px; }
.logo-drop:hover { border-color:var(--gold); color:var(--gold); background:rgba(201,168,76,.04); }
.logo-drop + .ep-check-primary { margin-top: 10px; }
.ep-check { display:flex; align-items:center; gap:6px; font-size:12px; cursor:pointer; }
.ep-check-primary { margin-bottom:12px; font-weight:600; font-size:13px; color:var(--text); padding:8px 10px; background:var(--bg3); border-radius:8px; border:1px solid var(--border2); }
.ep-check-primary input { width:16px; height:16px; accent-color:var(--gold); }
.wm-controls-wrap { transition:opacity .18s; }
.wm-controls-wrap.is-disabled { opacity:0.4; pointer-events:none; user-select:none; }
.batch-nav { display:flex; align-items:center; gap:8px; }
.batch-nav span { flex:1; text-align:center; font-size:12px; color:var(--text3); }

/* ALBUMS PAGE */
.albums-header { margin-bottom:16px; }
.albums-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(220px,1fr)); gap:12px; }
.album-card { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:18px; cursor:pointer; transition:all .22s; }
.album-card:hover { border-color:var(--gold-glow); transform:translateY(-2px); }
.album-icon { font-size:32px; margin-bottom:10px; }
.album-name { font-size:16px; font-weight:700; margin-bottom:3px; letter-spacing:-0.02em; }
.album-count { font-size:12px; color:var(--text3); }

/* ADMIN PAGE */
.page.admin-page {
  padding:12px 18px 40px;
  max-width:1240px;
  margin:0 auto;
  width:100%;
}
.main--admin .topbar { border-bottom-color:rgba(201,168,76,.12); }

.admin-tabs {
  display:flex; flex-wrap:wrap; gap:4px 8px;
  margin-bottom:18px; border-bottom:1px solid var(--border); padding-bottom:0;
}
.admin-tab {
  padding:10px 14px; background:none; border:none; border-bottom:2px solid transparent;
  font-size:13px; font-weight:600; color:var(--text3); transition:all .18s; margin-bottom:-1px;
}
.admin-tab.active { color:var(--gold); border-color:var(--gold); }
.admin-panel { display:none; }
.admin-panel.active { display:block; }

.admin-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius);
  padding:22px 24px; margin-bottom:20px;
  box-shadow:0 8px 28px rgba(0,0,0,.35);
}
.admin-card--narrow { max-width:460px; }
.admin-card--create { border-color:rgba(201,168,76,.14); }
.admin-card--table { padding-bottom:14px; }
.admin-card-head { margin-bottom:18px; }
.admin-card-head--inline {
  display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap;
}
.admin-card-title { font-size:18px; font-weight:700; letter-spacing:-0.02em; margin:0; }
.admin-card-title--sm { font-size:15px; }
.admin-card-desc { font-size:13px; color:var(--text2); margin-top:6px; line-height:1.45; }
.admin-meta { font-size:12px; font-weight:600; color:var(--text3); }

.admin-form-grid {
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:14px 20px;
}
@media(max-width:720px){ .admin-form-grid { grid-template-columns:1fr; } }
.admin-form-grid--single { grid-template-columns:1fr; max-width:540px; }
.admin-field-full { margin-top:8px; max-width:100%; }
.field-hint { font-size:11px; color:var(--text3); margin:4px 0 8px; line-height:1.35; }
.admin-mt { margin-top:14px; }
.admin-ml { margin-left:10px; }

.admin-select {
  width:100%; padding:9px 11px; border-radius:9px; background:var(--bg3);
  border:1px solid var(--border); color:var(--text); font-size:13px;
}
.admin-select--compact { min-width:112px; padding:6px 8px; font-size:12px; }
.admin-select-multi {
  min-height:140px; padding:8px; font-size:13px; line-height:1.35; border-radius:9px;
  background:var(--bg3); border:1px solid var(--border2); color:var(--text); width:100%;
}
.admin-select-multi option { padding:6px 8px; }
.admin-select-multi--row { min-height:112px; font-size:12px; }

.admin-table-scroll { overflow-x:auto; margin:0 -4px; padding:0 4px; }
.admin-table { width:100%; border-collapse:collapse; font-size:13px; min-width:520px; }
.admin-table th {
  text-align:left; padding:10px 12px; font-size:10px; font-weight:700; color:var(--text2);
  text-transform:uppercase; letter-spacing:1px; border-bottom:1px solid var(--border);
}
.admin-table td { padding:12px; border-bottom:1px solid var(--border); vertical-align:middle; }
.admin-table tr:hover td { background:var(--bg3); }
.admin-table--users td { vertical-align:top; }

.admin-td-groups { min-width:220px; max-width:300px; }
.admin-btn-groups { margin-top:8px; display:inline-flex; }
.admin-td-actions { white-space:nowrap; }
.admin-btn-del { margin-left:8px; min-width:34px; padding-left:10px; padding-right:10px; }
.admin-user-name { font-weight:600; color:var(--text); }
.admin-code {
  font-size:12px; color:var(--text2); background:var(--bg3); padding:3px 8px;
  border-radius:6px; border:1px solid var(--border);
}
.admin-code--slug { display:inline-block; margin-top:4px; font-size:11px; color:var(--text3); }
.admin-td-date { font-size:12px; color:var(--text2); white-space:nowrap; }

.admin-groups-grid { display:grid; gap:16px; }
@media(min-width:920px){ .admin-groups-grid { grid-template-columns:repeat(2,minmax(0,1fr)); } }

.admin-group-head {
  margin-bottom:14px; padding-bottom:12px; border-bottom:1px solid var(--border);
}
.admin-group-title {
  font-size:16px; font-weight:700; margin:0 0 6px; display:flex; align-items:center;
  gap:10px; flex-wrap:wrap;
}
.admin-badge-sys {
  font-size:10px; font-weight:700; text-transform:uppercase; letter-spacing:.06em;
  color:var(--gold); background:var(--gold-dim); padding:3px 8px; border-radius:6px;
}
.admin-perm-label {
  font-size:11px; font-weight:700; text-transform:uppercase; letter-spacing:1px;
  color:var(--text3); margin:14px 0 10px;
}
.admin-perm-grid {
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:8px 18px;
  padding:14px 16px; background:var(--bg3); border:1px solid var(--border2); border-radius:10px;
}
@media(max-width:640px){ .admin-perm-grid { grid-template-columns:1fr; } }
.admin-perm-item {
  display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--text2);
  line-height:1.4; cursor:pointer;
}
.admin-perm-item input { margin-top:3px; accent-color:var(--gold); flex-shrink:0; }
.admin-perm-item span { color:var(--text); }
.admin-card-actions { display:flex; align-items:center; flex-wrap:wrap; gap:10px; margin-top:16px; }

.role-badge { padding:3px 10px; border-radius:6px; font-size:11px; font-weight:700; }
.role-badge.admin { background:var(--gold-dim); color:var(--gold); }
.role-badge.ctv { background:rgba(79,170,255,.12); color:var(--info); }
.role-badge.content { background:rgba(46,204,135,.12); color:var(--success); }

.settings-section { background:var(--bg2); border:1px solid var(--border); border-radius:var(--radius); padding:20px; max-width:400px; }
.settings-section h3 { font-size:17px; font-weight:700; margin-bottom:14px; letter-spacing:-0.02em; }

/* TOAST */
.toast { position:fixed; top:16px; right:16px; z-index:500; background:var(--bg2); border:1px solid var(--border2); border-radius:10px; padding:11px 16px; font-size:13px; font-weight:600; transform:translateX(120%); transition:transform .3s cubic-bezier(.34,1.56,.64,1); box-shadow:0 8px 32px rgba(0,0,0,.5); max-width:340px; display:flex; align-items:center; gap:8px; }
.toast.show { transform:translateX(0); }
.toast.success { border-color:var(--success); }
.toast.error { border-color:var(--error); }
.toast.info { border-color:var(--gold); }

/* RESPONSIVE */
@media(max-width:860px) {
  .folder-mode-toggle span { font-size:11px; }
  .sidebar { position:fixed; left:0; top:0; z-index:150; transform:translateX(-100%); }
  .sidebar.open { transform:translateX(0); }
  .menu-btn { display:block; }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .dm-body { flex-direction:column; }
  .dm-info { width:100%; }
  .editor-panel { width:260px; }
  .topbar-right { gap:5px; }
  .search-wrap input { width:130px; }
}
