/* ── Reset ────────────────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{height:100%;scroll-behavior:smooth;}

/* ── Tokens ───────────────────────────────────────────────────────────────── */
:root{
  /* Backgrounds — matches app DarkBg / DarkSurface */
  --bg:          #191A1F;
  --bg2:         #1C1E24;
  --surface:     #1F222B;
  --surface2:    #252830;
  --surface3:    #2D3040;

  /* Primary — yellow #FFCC00 → green #9DE23A (app gradient) */
  --primary:       #FFCC00;
  --primary-end:   #9DE23A;
  --primary-dim:   rgba(255,204,0,.10);
  --primary-glow:  rgba(255,204,0,.22);
  --primary-bdr:   rgba(255,204,0,.28);
  --primary-grad:  linear-gradient(135deg,#FFCC00,#9DE23A);

  /* Accent gold / legacy */
  --gold:        #FFCC44;
  --gold-dim:    rgba(255,204,68,.12);

  /* Glass */
  --glass:       rgba(31,34,43,.88);
  --glass-nav:   rgba(25,26,31,.97);
  --border:      rgba(255,255,255,.07);
  --border2:     rgba(255,255,255,.13);

  /* Text — matches app TextPrimary / TextSecondary / TextMuted */
  --text:        #F2F2F2;
  --text2:       #A9A9A9;
  --text3:       #636363;

  /* Semantic */
  --danger:      #FF4F6B;
  --danger-dim:  rgba(255,79,107,.12);
  --success:     #4ADE80;
  --success-dim: rgba(74,222,128,.12);
  --warning:     #F59E0B;
  --warning-dim: rgba(245,158,11,.12);

  /* Shape */
  --radius:      14px;
  --radius-sm:   9px;
  --radius-xs:   6px;
  --sidebar-w:   250px;
  --nav-h:       60px;
  --blur:        blur(22px);
  --trans:       0.17s ease;
}

/* ── Base ─────────────────────────────────────────────────────────────────── */
body{
  font-family:'Plus Jakarta Sans',system-ui,-apple-system,sans-serif;
  background:var(--bg);
  color:var(--text);
  min-height:100vh;
  font-size:14px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}

::selection{background:var(--primary-dim);color:var(--primary);}
a{color:var(--primary);text-decoration:none;}
a:hover{opacity:.8;}
img{max-width:100%;display:block;}

::-webkit-scrollbar{width:5px;height:5px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:var(--surface3);border-radius:3px;}
::-webkit-scrollbar-thumb:hover{background:var(--text3);}

/* ── Layout ───────────────────────────────────────────────────────────────── */
.layout{display:flex;min-height:100vh;}

/* ── Sidebar ──────────────────────────────────────────────────────────────── */
.sidebar{
  width:var(--sidebar-w);
  background:var(--glass-nav);
  backdrop-filter:var(--blur);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:fixed;top:0;left:0;bottom:0;
  z-index:100;
  transition:transform .25s cubic-bezier(.4,0,.2,1);
}

.sidebar-logo{
  height:var(--nav-h);
  display:flex;align-items:center;gap:10px;
  padding:0 18px;
  border-bottom:1px solid var(--border);
  flex-shrink:0;
}

.sidebar-logo-img{
  width:34px;height:34px;border-radius:10px;
  background:var(--primary-grad);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;overflow:hidden;
}
.sidebar-logo-img img{width:100%;height:100%;object-fit:cover;}
.sidebar-logo-img svg{width:18px;height:18px;color:#111;}

.sidebar-logo-text{
  font-size:15px;font-weight:800;
  background:linear-gradient(120deg,#fff 20%,var(--primary) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
  letter-spacing:-.3px;
}

.sidebar-section{
  padding:16px 10px 4px;
  font-size:10px;font-weight:700;letter-spacing:1.4px;
  color:var(--text3);text-transform:uppercase;
}

.sidebar-nav{flex:1;padding:8px;display:flex;flex-direction:column;overflow-y:auto;}

.nav-item{
  display:flex;align-items:center;gap:10px;
  padding:9px 12px;border-radius:var(--radius-sm);
  color:var(--text2);font-weight:500;font-size:13.5px;
  transition:all var(--trans);cursor:pointer;
  border:1px solid transparent;
}
.nav-item svg{width:17px;height:17px;flex-shrink:0;opacity:.75;transition:opacity var(--trans);}
.nav-item:hover{background:var(--surface2);color:var(--text);border-color:var(--border);}
.nav-item:hover svg{opacity:1;}
.nav-item.active{
  background:var(--primary-dim);
  color:var(--primary);
  border-color:var(--primary-bdr);
  box-shadow:inset 3px 0 0 var(--primary);
  font-weight:700;
}
.nav-item.active svg{opacity:1;}
.nav-item.danger{color:var(--danger);}
.nav-item.danger:hover{background:var(--danger-dim);border-color:rgba(255,79,107,.3);}

.sidebar-footer{padding:10px 8px;border-top:1px solid var(--border);}

/* ── Top Nav ──────────────────────────────────────────────────────────────── */
.main{margin-left:var(--sidebar-w);flex:1;display:flex;flex-direction:column;min-height:100vh;}

.topnav{
  height:var(--nav-h);
  background:var(--glass-nav);
  backdrop-filter:var(--blur);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 22px;
  position:sticky;top:0;z-index:90;
}

.topnav-left{display:flex;align-items:center;gap:10px;}

.hamburger{
  display:none;background:none;border:none;cursor:pointer;
  color:var(--text2);padding:6px;border-radius:var(--radius-xs);
  transition:all var(--trans);
}
.hamburger:hover{background:var(--surface2);color:var(--text);}
.hamburger svg{width:20px;height:20px;}

.breadcrumb{display:flex;align-items:center;gap:6px;font-size:13px;}
.breadcrumb-item{color:var(--text3);}
.breadcrumb-sep{color:var(--text3);}
.breadcrumb-current{color:var(--text);font-weight:600;}

.topnav-right{display:flex;align-items:center;gap:10px;}

.admin-pill{
  display:flex;align-items:center;gap:8px;
  background:var(--surface2);border:1px solid var(--border2);
  border-radius:24px;padding:5px 12px 5px 5px;
  font-size:12px;color:var(--text2);
  transition:all var(--trans);cursor:default;
}
.admin-pill:hover{border-color:var(--primary-bdr);}
.admin-avatar{
  width:26px;height:26px;border-radius:50%;
  background:var(--primary-grad);
  display:flex;align-items:center;justify-content:center;
  font-size:11px;font-weight:800;color:#111;flex-shrink:0;
}

/* ── Page ─────────────────────────────────────────────────────────────────── */
.page{padding:22px 24px;flex:1;}

.page-header{
  display:flex;align-items:flex-start;justify-content:space-between;
  margin-bottom:22px;gap:12px;flex-wrap:wrap;
}
.page-title{
  font-size:21px;font-weight:800;letter-spacing:-.4px;
  background:linear-gradient(120deg,var(--text) 40%,var(--primary) 100%);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;
}
.page-sub{font-size:12.5px;color:var(--text2);margin-top:3px;-webkit-text-fill-color:var(--text2);}

/* ── Cards ────────────────────────────────────────────────────────────────── */
.card{
  background:var(--glass);
  backdrop-filter:var(--blur);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:20px;
  transition:border-color var(--trans),box-shadow var(--trans);
}
.card:hover{border-color:var(--border2);}
.card-title{
  font-size:13px;font-weight:700;margin-bottom:16px;
  color:var(--text2);text-transform:uppercase;letter-spacing:.6px;
}

/* ── Stats ────────────────────────────────────────────────────────────────── */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:14px;margin-bottom:22px;}

.stat-card{
  background:var(--glass);border:1px solid var(--border);
  border-radius:var(--radius);padding:18px;
  display:flex;flex-direction:column;gap:10px;
  transition:all var(--trans);cursor:default;
  position:relative;overflow:hidden;
}
.stat-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:var(--primary-grad);opacity:0;transition:opacity var(--trans);
}
.stat-card:hover{border-color:var(--border2);transform:translateY(-2px);box-shadow:0 8px 32px rgba(0,0,0,.35);}
.stat-card:hover::before{opacity:1;}

.stat-icon{
  width:40px;height:40px;border-radius:11px;
  display:flex;align-items:center;justify-content:center;
}
.stat-icon svg{width:18px;height:18px;}
.stat-icon.primary{background:var(--primary-dim);color:var(--primary);}
.stat-icon.gold{background:var(--gold-dim);color:var(--gold);}
.stat-icon.green{background:var(--success-dim);color:var(--success);}
.stat-icon.red{background:var(--danger-dim);color:var(--danger);}

.stat-value{font-size:28px;font-weight:900;letter-spacing:-.6px;color:var(--text);}
.stat-label{font-size:11.5px;color:var(--text2);font-weight:500;}

/* ── Table ────────────────────────────────────────────────────────────────── */
.table-wrap{overflow-x:auto;border-radius:var(--radius);border:1px solid var(--border);}

table{width:100%;border-collapse:collapse;}

thead th{
  text-align:left;padding:11px 16px;
  font-size:10.5px;font-weight:700;letter-spacing:.9px;text-transform:uppercase;
  color:var(--text3);background:var(--surface);
  border-bottom:1px solid var(--border);white-space:nowrap;
}

tbody tr{border-bottom:1px solid var(--border);transition:background var(--trans);}
tbody tr:hover{background:var(--surface2);}
tbody tr:last-child{border-bottom:none;}
tbody td{padding:11px 16px;vertical-align:middle;}

.preview-pair{display:flex;gap:5px;}
.preview-img{
  width:46px;height:46px;border-radius:var(--radius-xs);
  object-fit:cover;border:1px solid var(--border2);
  background:var(--surface3);
}
.preview-placeholder{
  width:46px;height:46px;border-radius:var(--radius-xs);
  background:var(--surface3);border:1px dashed var(--border2);
  display:flex;align-items:center;justify-content:center;
  color:var(--text3);
}
.preview-placeholder svg{width:18px;height:18px;}

/* ── Badges ───────────────────────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 8px;border-radius:20px;
  font-size:10.5px;font-weight:700;white-space:nowrap;
}
.badge-primary{background:var(--primary-dim);color:var(--primary);border:1px solid var(--primary-bdr);}
.badge-purple{background:var(--primary-dim);color:var(--primary);border:1px solid var(--primary-bdr);}
.badge-gold{background:var(--gold-dim);color:var(--gold);border:1px solid rgba(255,204,68,.3);}
.badge-green{background:var(--success-dim);color:var(--success);border:1px solid rgba(74,222,128,.3);}
.badge-red{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(255,79,107,.3);}
.badge-gray{background:var(--surface3);color:var(--text2);border:1px solid var(--border);}

.tags{display:flex;flex-wrap:wrap;gap:4px;}

/* ── Buttons ──────────────────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:9px 16px;border-radius:var(--radius-sm);
  font-size:13px;font-weight:700;cursor:pointer;
  border:none;transition:all var(--trans);
  white-space:nowrap;text-decoration:none;
  font-family:'Plus Jakarta Sans',sans-serif;
  line-height:1;
}
.btn svg{width:15px;height:15px;flex-shrink:0;}

.btn-primary{
  background:var(--primary-grad);
  color:#111;
  box-shadow:0 2px 12px rgba(255,204,0,.2);
}
.btn-primary:hover{
  box-shadow:0 4px 24px rgba(255,204,0,.35);
  transform:translateY(-1px);opacity:.95;
}

.btn-ghost{
  background:var(--surface2);color:var(--text2);
  border:1px solid var(--border);
}
.btn-ghost:hover{color:var(--text);border-color:var(--border2);background:var(--surface3);}

.btn-danger{
  background:var(--danger-dim);color:var(--danger);
  border:1px solid rgba(255,79,107,.25);
}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger);}

.btn-sm{padding:6px 12px;font-size:12px;}
.btn-icon{width:32px;height:32px;padding:0;justify-content:center;border-radius:var(--radius-xs);}

/* ── Forms ────────────────────────────────────────────────────────────────── */
.form-group{margin-bottom:16px;}

.form-label{
  display:block;font-size:11px;font-weight:700;
  color:var(--text3);margin-bottom:6px;
  text-transform:uppercase;letter-spacing:.7px;
}

.form-control{
  width:100%;background:var(--surface2);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  padding:9px 13px;color:var(--text);font-size:14px;
  font-family:'Plus Jakarta Sans',sans-serif;outline:none;
  transition:border-color var(--trans),box-shadow var(--trans);
  appearance:none;
}
.form-control:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px var(--primary-dim);
}
.form-control::placeholder{color:var(--text3);}
select.form-control{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23A9A9A9' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;}
textarea.form-control{resize:vertical;min-height:80px;line-height:1.6;}
.form-hint{font-size:11px;color:var(--text3);margin-top:5px;line-height:1.5;}

/* Checkbox */
.checkbox-group{display:flex;flex-wrap:wrap;gap:8px;}
.checkbox-item{display:flex;align-items:center;gap:7px;cursor:pointer;padding:7px 12px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);transition:all var(--trans);}
.checkbox-item:hover{border-color:var(--primary-bdr);}
.checkbox-item input[type="checkbox"]{accent-color:var(--primary);width:15px;height:15px;cursor:pointer;flex-shrink:0;}
.checkbox-item span{font-size:13px;color:var(--text2);}
.checkbox-item:has(input:checked){background:var(--primary-dim);border-color:var(--primary-bdr);}
.checkbox-item:has(input:checked) span{color:var(--primary);}

/* ── File Upload ──────────────────────────────────────────────────────────── */
.file-drop{
  border:1.5px dashed var(--border2);border-radius:var(--radius);
  transition:all var(--trans);position:relative;overflow:hidden;
  cursor:pointer;
}
.file-drop:hover,.file-drop.drag{border-color:var(--primary);background:var(--primary-dim);}
.file-drop input[type="file"]{position:absolute;inset:0;opacity:0;cursor:pointer;width:100%;height:100%;z-index:2;}
.file-drop-body{padding:28px 20px;text-align:center;pointer-events:none;}
.file-drop-svg{margin-bottom:10px;}
.file-drop-svg svg{width:48px;height:48px;margin:0 auto;}
.file-drop-text{font-size:13px;color:var(--text2);margin-bottom:4px;}
.file-drop-link{color:var(--primary);font-weight:700;}
.file-drop-sub{font-size:11px;color:var(--text3);}
.file-preview{display:none;padding:8px;}
.file-preview img{width:100%;max-height:300px;object-fit:contain;border-radius:var(--radius-sm);border:1px solid var(--border);display:block;background:var(--surface3);}
.img-replace-bar{
  display:flex;align-items:center;gap:6px;
  margin-top:8px;padding:7px 10px;
  background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-xs);
  font-size:11px;color:var(--text3);
}
.img-replace-bar svg{width:13px;height:13px;flex-shrink:0;opacity:.6;}

/* ── Grid ─────────────────────────────────────────────────────────────────── */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:20px;}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;}

/* ── Alert ────────────────────────────────────────────────────────────────── */
.alert{
  padding:11px 14px;border-radius:var(--radius-sm);
  font-size:13px;margin-bottom:16px;
  display:flex;align-items:center;gap:9px;
  animation:slideDown .2s ease;font-weight:500;
}
.alert svg{width:16px;height:16px;flex-shrink:0;}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px);}to{opacity:1;transform:translateY(0);}}
.alert-danger{background:var(--danger-dim);color:var(--danger);border:1px solid rgba(255,79,107,.25);}
.alert-success{background:var(--success-dim);color:var(--success);border:1px solid rgba(74,222,128,.25);}

/* ── Divider ──────────────────────────────────────────────────────────────── */
.divider{height:1px;background:linear-gradient(to right,transparent,var(--border2),transparent);margin:18px 0;}

/* ── Empty ────────────────────────────────────────────────────────────────── */
.empty{text-align:center;padding:56px 20px;color:var(--text3);}
.empty-icon{width:56px;height:56px;border-radius:16px;background:var(--surface2);display:flex;align-items:center;justify-content:center;margin:0 auto 14px;}
.empty-icon svg{width:26px;height:26px;color:var(--text3);}
.empty-text{font-size:15px;font-weight:700;color:var(--text2);margin-bottom:4px;}
.empty-sub{font-size:12.5px;margin-bottom:16px;}

/* ── Login ────────────────────────────────────────────────────────────────── */
.login-page{
  min-height:100vh;display:flex;align-items:center;justify-content:center;
  background:radial-gradient(ellipse 80% 50% at 50% -10%,rgba(255,204,0,.14) 0%,transparent 65%),var(--bg);
  padding:20px;
}
.login-box{
  width:100%;max-width:400px;
  background:var(--glass);backdrop-filter:var(--blur);
  border:1px solid var(--border2);border-radius:20px;padding:36px;
}
.login-logo{text-align:center;margin-bottom:28px;}
.login-icon{
  width:58px;height:58px;border-radius:16px;
  background:var(--primary-grad);
  display:flex;align-items:center;justify-content:center;
  margin:0 auto 14px;
  box-shadow:0 0 32px rgba(255,204,0,.3);
}
.login-icon svg{width:26px;height:26px;color:#111;}
.login-title{font-size:22px;font-weight:800;letter-spacing:-.4px;}
.login-sub{font-size:13px;color:var(--text2);margin-top:4px;}

/* ── Modal ────────────────────────────────────────────────────────────────── */
.modal-backdrop{
  position:fixed;inset:0;background:rgba(0,0,0,.65);backdrop-filter:blur(6px);
  z-index:200;display:flex;align-items:center;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .2s;
}
.modal-backdrop.show{opacity:1;pointer-events:all;}
.modal{
  background:var(--surface);border:1px solid var(--border2);
  border-radius:var(--radius);padding:28px;
  width:100%;max-width:360px;text-align:center;
  transform:scale(.94) translateY(8px);transition:transform .22s cubic-bezier(.4,0,.2,1);
}
.modal-backdrop.show .modal{transform:scale(1) translateY(0);}
.modal-icon{
  width:52px;height:52px;border-radius:14px;background:var(--danger-dim);
  display:flex;align-items:center;justify-content:center;margin:0 auto 14px;
}
.modal-icon svg{width:24px;height:24px;color:var(--danger);}
.modal-title{font-size:16px;font-weight:700;margin-bottom:6px;}
.modal-text{font-size:13px;color:var(--text2);margin-bottom:22px;line-height:1.6;}
.modal-actions{display:flex;gap:10px;justify-content:center;}

/* ── Overlay ──────────────────────────────────────────────────────────────── */
.overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:99;backdrop-filter:blur(2px);}
.overlay.show{display:block;}

/* ── HTMX nav progress bar ────────────────────────────────────────────────── */
#nav-progress{
  position:fixed;top:0;left:0;right:0;height:3px;
  background:var(--primary-grad);
  z-index:9999;
  transform:scaleX(0);transform-origin:left;
  transition:transform .15s ease,opacity .3s ease;
  opacity:0;
}
#nav-progress.active{
  opacity:1;
  animation:navprog .9s ease-in-out infinite alternate;
}
@keyframes navprog{from{transform:scaleX(.3);}to{transform:scaleX(.85);}}

/* ── Spinner ──────────────────────────────────────────────────────────────── */
.spinner{
  width:16px;height:16px;
  border:2px solid rgba(255,255,255,.2);border-top-color:var(--primary);
  border-radius:50%;animation:spin .55s linear infinite;display:inline-block;
}
@keyframes spin{to{transform:rotate(360deg);}}

/* ── Category cards ───────────────────────────────────────────────────────── */
.cat-item{
  background:var(--surface2);border:1px solid var(--border);
  border-radius:var(--radius-sm);padding:14px 16px;
  display:flex;flex-direction:column;gap:10px;
  transition:border-color var(--trans);
}
.cat-item:hover{border-color:var(--primary-bdr);}
.cat-item-header{display:flex;align-items:center;justify-content:space-between;}
.cat-name{font-weight:700;font-size:14px;}
.cat-meta{font-size:11px;color:var(--text3);}
.cat-edit-row{display:flex;gap:7px;}

/* Live-save status badge */
.cat-save-status{font-size:11px;font-weight:600;min-width:44px;text-align:right;white-space:nowrap;}
.cat-save-status.saving{color:var(--text3);}
.cat-save-status.saved {color:var(--success);}

/* ── Toast notifications (top-right, auto-dismiss) ───────────────────────── */
#toast-container{
  position:fixed;top:16px;right:16px;
  z-index:9998;
  display:flex;flex-direction:column;gap:8px;
  pointer-events:none;
}
.toast{
  display:flex;align-items:flex-start;gap:10px;
  padding:12px 14px;border-radius:var(--radius-sm);
  font-size:13px;font-weight:500;line-height:1.45;
  max-width:320px;
  pointer-events:all;
  animation:toastIn .22s cubic-bezier(.4,0,.2,1);
  transition:opacity .3s,transform .3s;
}
.toast.hide{opacity:0;transform:translateX(16px);}
@keyframes toastIn{from{opacity:0;transform:translateX(20px);}to{opacity:1;transform:translateX(0);}}
.toast svg{width:16px;height:16px;flex-shrink:0;margin-top:1px;}
.toast-body{flex:1;}
.toast-close{background:none;border:none;cursor:pointer;opacity:.5;padding:0;line-height:1;font-size:16px;color:inherit;margin-left:4px;}
.toast-close:hover{opacity:1;}
.toast-success{background:#1a2e20;border:1px solid rgba(74,222,128,.3);color:var(--success);}
.toast-error  {background:#2a1a1e;border:1px solid rgba(255,79,107,.3); color:var(--danger);}
.toast-info   {background:var(--surface2);border:1px solid var(--border2);color:var(--text);}


/* ── Dashboard recent list ────────────────────────────────────────────────── */
.recent-item{
  display:flex;align-items:center;gap:12px;
  padding:10px;background:var(--surface2);
  border-radius:var(--radius-sm);border:1px solid var(--border);
  transition:border-color var(--trans);
}
.recent-item:hover{border-color:var(--primary-bdr);}
.recent-thumb{width:42px;height:42px;border-radius:8px;object-fit:cover;border:1px solid var(--border);background:var(--surface3);flex-shrink:0;}
.recent-thumb-placeholder{width:42px;height:42px;border-radius:8px;background:var(--surface3);flex-shrink:0;display:flex;align-items:center;justify-content:center;}
.recent-thumb-placeholder svg{width:18px;height:18px;color:var(--text3);}
.recent-info{flex:1;min-width:0;}
.recent-title{font-weight:600;font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.recent-cat{font-size:11px;color:var(--text3);}

/* ── Responsive ───────────────────────────────────────────────────────────── */
@media(max-width:900px){
  .sidebar{transform:translateX(-100%);}
  .sidebar.open{transform:translateX(0);}
  .main{margin-left:0;}
  .hamburger{display:flex;}
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr;}
  .page{padding:16px;}
  .stats-grid{grid-template-columns:1fr 1fr;}
}
@media(max-width:500px){
  .stats-grid{grid-template-columns:1fr;}
  .login-box{padding:26px 18px;}
  .topnav{padding:0 14px;}
}
