/* GMaaS StockControl — v1.7.23 */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
:root {
  --bg:#f7f5f0; --surface:#fff; --border:#ddd9d0; --border-light:#eeebe4;
  --text:#2a2a2a; --text-muted:#6a6a6a;
  --accent:#8b6914; --accent-dark:#6a4f0e; --accent-light:#f5edd8;
  --nav-bg:#1a1a1a; --nav-text:#ede9e0; --nav-hover:#8b6914;
  --green:#2d6a2d; --green-bg:#eaf4ea; --red:#c0392b; --red-bg:#fdf0ee;
  --orange:#c56a00; --orange-bg:#fff4e5; --blue:#1a5276; --blue-bg:#eaf2fb;
  --radius:6px; --shadow:0 2px 8px rgba(0,0,0,.08); --shadow-sm:0 1px 4px rgba(0,0,0,.06);
}
body { font-family:'Segoe UI',system-ui,-apple-system,sans-serif; background:var(--bg); color:var(--text); font-size:15px; line-height:1.6; min-height:100vh; display:flex; flex-direction:column; }
a { color:var(--accent); text-decoration:none; }
a:hover { color:var(--accent-dark); text-decoration:underline; }

.nav { background:var(--nav-bg); padding:0 24px; display:flex; align-items:center; position:sticky; top:0; z-index:100; box-shadow:0 2px 6px rgba(0,0,0,.3); }
.nav-brand { font-family:Georgia,serif; font-size:1.15rem; color:#e8c96a; letter-spacing:.04em; padding:16px 24px 16px 0; margin-right:8px; border-right:1px solid #3a3a3a; white-space:nowrap; text-decoration:none; }
.nav-brand:hover { color:#f0d87a; text-decoration:none; }
.nav-links { display:flex; align-items:stretch; flex:1; }
.nav-links a { color:var(--nav-text); padding:0 16px; display:flex; align-items:center; font-size:.88rem; letter-spacing:.03em; text-transform:uppercase; transition:background .15s,color .15s; text-decoration:none; height:52px; }
.nav-links a:hover, .nav-links a.active { background:var(--nav-hover); color:#fff; text-decoration:none; }
.nav-right { margin-left:auto; display:flex; align-items:center; gap:12px; }
.nav-logo { max-height:40px; width:auto; display:block; }
.nav-logout { font-size:.8rem; color:#999; border:1px solid #444; padding:5px 12px; border-radius:var(--radius); transition:background .15s,color .15s; }
.nav-logout:hover { background:var(--nav-hover); color:#fff; border-color:var(--nav-hover); }
/* Hamburger button — hidden on desktop, shown via media query below */
.nav-toggle { display:none; background:none; border:none; cursor:pointer; padding:10px; margin-left:auto; flex-direction:column; justify-content:center; gap:5px; }
.nav-toggle span { display:block; width:22px; height:2px; background:var(--nav-text); border-radius:2px; transition:transform .2s, opacity .2s; }
.nav-open .nav-toggle span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.nav-open .nav-toggle span:nth-child(2) { opacity:0; transform:scaleX(0); }
.nav-open .nav-toggle span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.page-wrapper { max-width:1200px; margin:0 auto; padding:32px 24px 60px; flex:1; width:100%; }
.page-header { display:flex; align-items:center; justify-content:space-between; margin-bottom:28px; padding-bottom:16px; border-bottom:2px solid var(--border); gap:16px; flex-wrap:wrap; }
.page-title { font-family:Georgia,serif; font-size:1.7rem; font-weight:normal; letter-spacing:.01em; }
.page-subtitle { font-size:.9rem; color:var(--text-muted); margin-top:2px; }

.btn { display:inline-flex; align-items:center; gap:6px; padding:9px 18px; border-radius:var(--radius); font-size:.88rem; font-weight:500; cursor:pointer; border:none; transition:background .15s,transform .1s; text-decoration:none; white-space:nowrap; }
.btn:hover { text-decoration:none; transform:translateY(-1px); }
.btn:active { transform:translateY(0); }
.btn-primary { background:var(--accent); color:#fff; }
.btn-primary:hover { background:var(--accent-dark); color:#fff; }
.btn-secondary { background:var(--border); color:var(--text); }
.btn-secondary:hover { background:#ccc9c0; color:var(--text); }
.btn-danger { background:var(--red-bg); border:1px solid var(--red); color:var(--red); }
.btn-danger:hover { background:var(--red); border-color:var(--red); color:#fff; }
.btn-success { background:var(--green); color:#fff; }
.btn-success:hover { background:#1d4a1d; color:#fff; }
.btn-sm { padding:5px 12px; font-size:.82rem; }
.btn-outline { background:transparent; border:1px solid var(--accent); color:var(--accent); }
.btn-outline:hover { background:var(--accent); color:#fff; }

.card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); }
.card-title { font-family:Georgia,serif; font-size:1.05rem; font-weight:normal; margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid var(--border-light); }
/* Gold header card style */
body.style-gold .card { overflow:hidden; }
body.style-gold .card-title { background:var(--accent-light); border-bottom:2px solid #d4ad50; color:var(--accent-dark); margin:-24px -24px 20px; padding:15px 24px; }
/* First detail-section h3: bleeds to card edges as a header band */
body.style-gold .detail-section:first-child h3 { background:var(--accent-light); border-bottom:2px solid #d4ad50; color:var(--accent-dark); margin:-24px -24px 12px; padding:10px 24px; }
/* Subsequent detail-section h3: side-bleed band as a section divider */
body.style-gold .detail-section + .detail-section h3 { background:var(--accent-light); border-top:1px solid #d4ad50; border-bottom:2px solid #d4ad50; color:var(--accent-dark); margin:0 -24px 12px; padding:10px 24px; }
/* Table card header (padding:0 cards with h2 title row) */
body.style-gold .card-table-header { background:var(--accent-light); border-bottom:2px solid #d4ad50; }
body.style-gold .card-table-header h2 { color:var(--accent-dark); }

.stats-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:16px; margin-bottom:32px; }
.stat-card { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:20px; text-align:center; box-shadow:var(--shadow-sm); border-top:3px solid var(--accent); }
.stat-value { font-family:Georgia,serif; font-size:2rem; color:var(--accent); font-weight:normal; line-height:1; margin-bottom:6px; }
.stat-label { font-size:.78rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.05em; }

.table-wrap { overflow-x:auto; }
table { width:100%; border-collapse:collapse; font-size:.9rem; }
thead th { text-align:left; padding:10px 14px; background:#f0ede5; border-bottom:2px solid var(--border); font-weight:600; font-size:.82rem; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); white-space:nowrap; }
tbody tr { border-bottom:1px solid var(--border-light); }
tbody tr:last-child { border-bottom:none; }
tbody tr:hover { background:#faf8f4; }
tbody td { padding:11px 14px; vertical-align:middle; }
.td-actions { display:flex; gap:6px; flex-wrap:wrap; }

.badge { display:inline-block; padding:3px 10px; border-radius:99px; font-size:.76rem; font-weight:600; letter-spacing:.03em; text-transform:capitalize; }
.badge-available { background:var(--green-bg); color:var(--green); }
.badge-sold      { background:var(--red-bg);   color:var(--red); }
.badge-reserved  { background:var(--orange-bg);color:var(--orange); }

.form-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(260px,1fr)); gap:18px 24px; }
.form-section { grid-column:1/-1; margin-top:12px; padding-top:16px; border-top:1px solid var(--border-light); font-family:Georgia,serif; font-size:.95rem; color:var(--accent); letter-spacing:.02em; }
.form-group { display:flex; flex-direction:column; gap:5px; }
.form-group.full-width { grid-column:1/-1; }
label { font-size:.83rem; font-weight:600; color:var(--text-muted); text-transform:uppercase; letter-spacing:.04em; }
label .required { color:var(--red); margin-left:2px; }
input[type="text"],input[type="email"],input[type="tel"],input[type="number"],input[type="date"],input[type="password"],input[type="url"],select,textarea {
  width:100%; padding:9px 12px; border:1px solid var(--border); border-radius:var(--radius); font-size:.92rem; font-family:inherit; background:#fff; color:var(--text); transition:border-color .15s,box-shadow .15s; appearance:none; }
input:focus,select:focus,textarea:focus { outline:none; border-color:var(--accent); box-shadow:0 0 0 3px rgba(139,105,20,.12); }
textarea { resize:vertical; min-height:90px; }
select { background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%236a6a6a' stroke-width='1.5' fill='none' stroke-linecap='round'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 10px center; padding-right:32px; }
.field-hint { font-size:.78rem; color:var(--text-muted); margin-top:2px; }
.form-actions { display:flex; gap:12px; align-items:center; margin-top:28px; padding-top:20px; border-top:1px solid var(--border-light); flex-wrap:wrap; }

.alert { padding:12px 16px; border-radius:var(--radius); margin-bottom:20px; font-size:.9rem; border-left:4px solid; }
.alert ul { margin:6px 0 0 18px; }
.alert-success { background:var(--green-bg); border-color:var(--green); color:var(--green); }
.alert-error   { background:var(--red-bg);   border-color:var(--red);   color:var(--red); }
.alert-info    { background:var(--blue-bg);  border-color:var(--blue);  color:var(--blue); }
.alert-warning { background:var(--orange-bg);border-color:var(--orange);color:var(--orange); }

.detail-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(280px,1fr)); gap:24px; }
.artwork-layout { display:grid; grid-template-columns:minmax(0,1fr) minmax(0,1.8fr); gap:24px; align-items:start; margin-bottom:24px; }
.detail-section h3 { font-family:Georgia,serif; font-size:.95rem; font-weight:normal; color:var(--accent); margin-bottom:12px; padding-bottom:6px; border-bottom:1px solid var(--border-light); letter-spacing:.03em; }
.detail-section + .detail-section { margin-top:16px; padding-top:16px; border-top:1px solid var(--border-light); }
body.style-gold .detail-section + .detail-section { border-top:none; padding-top:0; }
.card-table-header { padding:20px 24px 12px; display:flex; justify-content:space-between; align-items:center; }
.card-table-header h2 { font-family:Georgia,serif; font-size:1.1rem; font-weight:normal; }
dl { display:grid; grid-template-columns:auto 1fr; gap:6px 16px; align-items:baseline; }
dt { font-size:.8rem; font-weight:600; text-transform:uppercase; letter-spacing:.04em; color:var(--text-muted); white-space:nowrap; }
dd { font-size:.92rem; color:var(--text); }

.artwork-image { width:100%; max-width:400px; border-radius:var(--radius); border:1px solid var(--border); display:block; margin-bottom:16px; }
.image-placeholder { width:100%; max-width:400px; height:200px; background:var(--bg); border:2px dashed var(--border); border-radius:var(--radius); display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:.85rem; margin-bottom:16px; }

.login-wrap { min-height:100vh; display:flex; align-items:center; justify-content:center; background:var(--nav-bg); padding:24px; }
.login-box { background:var(--surface); border-radius:8px; padding:40px 44px; width:100%; max-width:420px; box-shadow:0 8px 32px rgba(0,0,0,.35); }
.login-logo { font-family:Georgia,serif; font-size:1.5rem; color:var(--accent); text-align:center; margin-bottom:4px; letter-spacing:.05em; }
.login-subtitle { text-align:center; font-size:.82rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.1em; margin-bottom:32px; }
.login-box .form-group { margin-bottom:16px; }
.login-box .btn { width:100%; justify-content:center; padding:11px; }

.filter-bar { display:flex; gap:10px; flex-wrap:wrap; align-items:center; margin-bottom:20px; }
.filter-bar input,.filter-bar select { width:auto; min-width:140px; height:34px; padding:0 12px; font-size:.87rem; box-sizing:border-box; }
.filter-bar .btn { height:34px; padding:0 14px; font-size:.87rem; box-sizing:border-box; }

.thumb { width:48px; height:48px; object-fit:cover; border-radius:4px; border:1px solid var(--border); }
.thumb-placeholder { width:48px; height:48px; background:var(--bg); border:1px solid var(--border); border-radius:4px; display:flex; align-items:center; justify-content:center; color:var(--text-muted); font-size:.7rem; }

.sale-summary { background:var(--accent-light); border:1px solid #d4ad50; border-radius:var(--radius); padding:18px 22px; margin-bottom:24px; display:grid; grid-template-columns:repeat(auto-fit,minmax(160px,1fr)); gap:12px 24px; }
.sale-summary-item .label { font-size:.78rem; font-weight:600; text-transform:uppercase; letter-spacing:.04em; color:var(--accent-dark); margin-bottom:2px; }
.sale-summary-item .value { font-family:Georgia,serif; font-size:1.2rem; color:var(--accent-dark); }

.docs-layout { display:grid; grid-template-columns:220px 1fr; gap:32px; align-items:start; }
.settings-users-layout { display:grid; grid-template-columns:repeat(2,1fr); gap:24px; align-items:start; }
.settings-users-layout .users-card { grid-column:1/-1; }
/* ── Dashboard layout ────────────────────────────────────────────────────────── */
.dash-layout { display:grid; grid-template-columns:200px 1fr; gap:20px; align-items:stretch; margin-bottom:24px; }
.dash-stats { display:flex; flex-direction:column; gap:8px; }
.stat-card-v { display:flex; flex-direction:column; align-items:flex-start; padding:8px 12px; border-top:none; border-left:3px solid var(--accent); position:relative; }
.stat-card-v .stat-label { font-size:.75rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:.05em; line-height:1; }
.stat-card-v .stat-value { font-family:Georgia,serif; font-size:1.15rem; color:var(--accent); font-weight:normal; line-height:1; margin-top:3px; }
.stat-card-v .stat-value-sm { font-size:1rem; }
.stat-card-v .drag-grip { position:absolute; top:6px; right:8px; }
.dash-chart-card { padding:20px; display:flex; flex-direction:column; }
.dash-chart-header { display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:10px; margin-bottom:16px; }
.dash-range-form { display:flex; align-items:center; gap:8px; flex-wrap:wrap; }
.dash-range-form select, .dash-range-form input[type=date] { font-size:.82rem; padding:5px 8px; border:1px solid var(--border); border-radius:var(--radius); background:var(--surface); color:var(--text); }
.dash-chart-checks { display:flex; flex-wrap:wrap; gap:6px 18px; margin-top:14px; padding-top:14px; border-top:1px solid var(--border-light); }
.dash-check { display:flex; align-items:center; gap:6px; font-size:.82rem; cursor:pointer; user-select:none; color:var(--text-muted); }
.dash-check input { accent-color:var(--accent); cursor:pointer; flex-shrink:0; }
.dash-check-text { display:flex; flex-direction:column; align-items:flex-start; gap:3px; line-height:1.2; }
.dash-swatch { display:block; width:100%; height:4px; border-radius:2px; background:var(--border); transition:background .2s; }
.stat-now { font-size:.65rem; font-weight:600; background:var(--border-light); color:var(--text-muted); border-radius:3px; padding:0 4px; vertical-align:middle; letter-spacing:.03em; text-transform:none; }
.drag-grip { font-size:1rem; color:var(--border); cursor:grab; padding:0 2px; user-select:none; transition:color .15s; flex-shrink:0; }
.stat-card-v:hover .drag-grip { color:var(--text-muted); }
.drag-grip:active { cursor:grabbing; }
.dash-stat-ghost { opacity:.35; border:1px dashed var(--accent) !important; background:var(--accent-light) !important; }
.dash-stat-chosen { box-shadow:0 4px 16px rgba(0,0,0,.12); }
.docs-nav { position:sticky; top:80px; background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:16px 0; box-shadow:var(--shadow-sm); }
.docs-nav a { display:block; padding:7px 20px; font-size:.87rem; color:var(--text-muted); text-decoration:none; border-left:3px solid transparent; transition:color .15s, border-color .15s, background .15s; }
.docs-nav a:hover { color:var(--accent); background:var(--accent-light); border-left-color:var(--accent); text-decoration:none; }
.docs-nav .docs-nav-heading { padding:10px 20px 4px; font-size:.72rem; font-weight:700; text-transform:uppercase; letter-spacing:.07em; color:var(--text-muted); margin-top:6px; }
.docs-section { background:var(--surface); border:1px solid var(--border); border-radius:var(--radius); padding:24px; box-shadow:var(--shadow-sm); margin-bottom:24px; scroll-margin-top:68px; }
.docs-section h2 { font-family:Georgia,serif; font-size:1.2rem; font-weight:normal; color:var(--accent-dark); margin-bottom:16px; padding-bottom:10px; border-bottom:1px solid var(--border-light); }
body.style-gold .docs-section { overflow:hidden; }
body.style-gold .docs-section h2 { margin:-24px -24px 20px; padding:15px 24px; background:var(--accent-light); border-bottom:2px solid #d4ad50; }
.docs-section h3 { font-size:.97rem; font-weight:600; color:var(--accent-dark); margin:24px 0 8px; padding-left:10px; border-left:3px solid var(--accent); }
.docs-section h4 { font-size:.9rem; font-weight:600; color:var(--text); margin:16px 0 6px; }
.docs-section p { margin-bottom:12px; line-height:1.7; }
.docs-section ul { list-style:none; margin:8px 0 14px; padding:0; }
.docs-section ul li { padding-left:18px; position:relative; margin-bottom:6px; line-height:1.7; }
.docs-section ul li::before { content:''; position:absolute; left:0; top:10px; width:6px; height:6px; background:var(--accent); border-radius:50%; }
.docs-section ol { list-style:none; counter-reset:step-counter; margin:8px 0 14px; padding:0; }
.docs-section ol li { counter-increment:step-counter; padding-left:40px; position:relative; margin-bottom:10px; line-height:1.7; }
.docs-section ol li::before { content:counter(step-counter); position:absolute; left:0; top:2px; width:24px; height:24px; background:var(--accent); color:#fff; border-radius:50%; font-size:.72rem; font-weight:700; line-height:24px; text-align:center; }
.docs-tip { background:var(--blue-bg); border-left:4px solid var(--blue); border-radius:var(--radius); padding:12px 16px; margin:16px 0; font-size:.9rem; }
.docs-tip strong { color:var(--blue); }
mark.search-hl { background:var(--accent-light); color:var(--accent-dark); border-radius:2px; padding:0 1px; }

.breadcrumb { font-size:.82rem; color:var(--text-muted); margin-bottom:20px; }
.breadcrumb a { color:var(--text-muted); }
.breadcrumb a:hover { color:var(--accent); }
.breadcrumb .sep { margin:0 6px; }

.empty-state { text-align:center; padding:48px 24px; color:var(--text-muted); }
.empty-state .empty-icon { font-size:2.5rem; margin-bottom:12px; }
.empty-state p { margin-bottom:16px; }

#toast-container { position:fixed; bottom:24px; right:24px; z-index:9999; display:flex; flex-direction:column; gap:10px; pointer-events:none; }
.toast { background:var(--surface); border:1px solid var(--border); border-left:4px solid; border-radius:var(--radius); padding:12px 16px; min-width:260px; max-width:380px; box-shadow:0 4px 20px rgba(0,0,0,.15); font-size:.88rem; pointer-events:all; display:flex; align-items:flex-start; gap:10px; animation:toast-in .25s ease; }
.toast-success { border-left-color:var(--green); color:var(--green); }
.toast-error   { border-left-color:var(--red);   color:var(--red); }
.toast-info    { border-left-color:var(--blue);   color:var(--blue); }
.toast-warning { border-left-color:var(--orange); color:var(--orange); }
.toast-msg { flex:1; color:var(--text); }
.toast-close { cursor:pointer; font-size:.8rem; line-height:1.4; color:var(--text-muted); background:none; border:none; padding:0; flex-shrink:0; }
.toast-close:hover { color:var(--text); }
@keyframes toast-in { from { opacity:0; transform:translateX(40px); } to { opacity:1; transform:translateX(0); } }

/* ── Image file picker modal ─────────────────────────────────────────────────── */
.picker-modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.5); z-index:900; align-items:center; justify-content:center; }
.picker-modal-overlay.open { display:flex; }
.picker-modal { background:#fff; border-radius:8px; width:min(92vw,800px); max-height:82vh; display:flex; flex-direction:column; overflow:hidden; box-shadow:0 8px 32px rgba(0,0,0,.18); }
.picker-modal-header { padding:14px 20px; border-bottom:1px solid var(--border-light); display:flex; align-items:center; gap:12px; }
.picker-modal-header h3 { flex:1; font-size:1rem; margin:0; }
.picker-nav { padding:8px 20px; background:var(--bg-soft); border-bottom:1px solid var(--border-light); font-size:.8rem; color:var(--text-muted); }
.picker-crumb { cursor:pointer; color:var(--accent); }
.picker-crumb:hover { text-decoration:underline; }
.picker-body { flex:1; overflow-y:auto; padding:16px 20px; }
.picker-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(110px,1fr)); gap:12px; }
.picker-item { border:2px solid var(--border-light); border-radius:6px; overflow:hidden; text-align:center; transition:border-color .15s; background:#fff; }
.picker-item:hover { border-color:var(--accent); }
.picker-item img { width:100%; height:80px; object-fit:cover; display:block; }
.picker-item span { display:block; padding:4px 6px; font-size:.7rem; color:var(--text-muted); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.picker-filename { cursor:pointer; }
.picker-item-actions { border-top:1px solid var(--border-light); padding:3px 6px; display:flex; justify-content:flex-end; }
.picker-rename-btn { background:none; border:none; cursor:pointer; font-size:.8rem; color:var(--text-muted); padding:2px 4px; border-radius:3px; line-height:1; }
.picker-rename-btn:hover { background:var(--bg-soft); color:var(--accent); }
.picker-delete-btn { background:none; border:none; cursor:pointer; font-size:.8rem; color:var(--text-muted); padding:2px 4px; border-radius:3px; line-height:1; margin-left:2px; }
.picker-delete-btn:hover { background:#fde8e8; color:var(--red,#c0392b); }
.picker-folder { display:flex; flex-direction:column; align-items:center; justify-content:center; padding:16px 8px; gap:4px; background:var(--bg-soft); cursor:pointer; }
.picker-folder .folder-icon { font-size:2rem; line-height:1; }

@media (max-width:768px) {
  /* Nav: show hamburger, hide links until toggled */
  .nav { padding:0 12px; flex-wrap:wrap; }
  .nav-toggle { display:flex; }
  .nav-links { display:none; flex:none; width:100%; }
  .nav-right { display:none; flex:none; width:100%; margin-left:0; }
  .nav-open .nav-links { display:flex; flex-direction:column; border-top:1px solid #2a2a2a; }
  .nav-open .nav-right { display:flex; flex-direction:row; flex-wrap:wrap; align-items:center; gap:8px; padding:10px 12px; border-top:1px solid #2a2a2a; }
  .nav-links a { height:auto; padding:13px 16px; border-bottom:1px solid #2a2a2a; font-size:.9rem; }
  /* Docs */
  .docs-layout { grid-template-columns:1fr; }
  .docs-nav { position:static; }
  /* Page content */
  .page-wrapper { padding:20px 14px 40px; }
  .artwork-layout { grid-template-columns:1fr; }
  .form-grid { grid-template-columns:1fr; }
  .settings-users-layout { grid-template-columns:1fr; }
  .settings-users-layout .users-card { grid-column:span 1; }
  .dash-layout { grid-template-columns:1fr; }
  .dash-stats { display:grid; grid-template-columns:repeat(2,1fr); }
  .stat-card-v { flex-direction:column; align-items:flex-start; border-left:none; border-top:3px solid var(--accent); }
  .stats-grid { grid-template-columns:repeat(2,1fr); }
  .login-box { padding:28px 22px; }
  .page-header { flex-direction:column; align-items:flex-start; }
}

/* ── Pagination ──────────────────────────────────────────────────────────────── */
.pagination-bar { display:flex; align-items:center; flex-wrap:wrap; gap:12px; margin-top:16px; scroll-margin-top:70px; }
.pagination-info { font-size:.82rem; color:var(--text-muted); flex:1; min-width:160px; }
.pagination-controls { display:flex; gap:4px; flex-wrap:wrap; }
.pagination-perpage { display:flex; align-items:center; gap:4px; margin-left:auto; }

/* ── Scroll-to-top button ────────────────────────────────────────────────────── */
#scroll-top { position:fixed; bottom:80px; right:24px; width:38px; height:38px; border-radius:50%; background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow); cursor:pointer; display:flex; align-items:center; justify-content:center; color:var(--text-muted); opacity:0; visibility:hidden; transition:opacity .2s,visibility .2s,background .15s,color .15s; z-index:500; }
#scroll-top.scroll-top-visible { opacity:1; visibility:visible; }
#scroll-top:hover { background:var(--accent-light); color:var(--accent); border-color:var(--accent); }

/* ── Email obfuscation ───────────────────────────────────────────────────────── */
my-email::before { content: attr(data-user) "\0040"; }
my-email::after  { content: attr(data-domain); }

