/* === admin.css — fully rewritten design system === */
/* Use independent variables so the admin can look distinct from the public site */
#admin-panel.v2{
  --a-bg: #FAF7F1;
  --a-surface: #FFFFFF;
  --a-surface-2: #F4F0E8;
  --a-surface-3: #EBE5D9;
  --a-border: rgba(60,40,20,.07);
  --a-border-strong: rgba(60,40,20,.14);
  --a-ink: #15110D;
  --a-ink-2: #3D342B;
  --a-ink-3: #847A6E;
  --a-ink-4: #B6ADA2;
  --a-gold: #B8924A;
  --a-gold-2: #9A7A3A;
  --a-gold-soft: rgba(184,146,74,.10);
  --a-gold-soft-strong: rgba(184,146,74,.20);
  --a-danger: #C8403E;
  --a-danger-soft: rgba(200,64,62,.10);
  --a-success: #2E8B57;
  --a-success-soft: rgba(46,139,87,.12);
  --a-info: #4670A4;
  --a-info-soft: rgba(70,112,164,.10);
  --a-rail: 260px;
  --a-rail-expanded: 260px;
  --a-topbar: 56px;
  --a-radius: 12px;
  --a-radius-lg: 16px;
  --a-shadow-xs: 0 1px 2px rgba(20,15,10,.04);
  --a-shadow-sm: 0 2px 8px rgba(20,15,10,.06);
  --a-shadow-md: 0 8px 24px rgba(20,15,10,.10);
  --a-shadow-lg: 0 20px 48px rgba(20,15,10,.16);
  background:var(--a-bg);color:var(--a-ink);
  font-family:'DM Sans',sans-serif;
}
body.dark #admin-panel.v2{
  --a-bg:#0B0907;
  --a-surface:#12100D;
  --a-surface-2:#1A1611;
  --a-surface-3:#251F18;
  --a-border:rgba(255,235,200,.06);
  --a-border-strong:rgba(255,235,200,.14);
  --a-ink:#F4ECDF;
  --a-ink-2:#D0C5B0;
  --a-ink-3:#8A8077;
  --a-ink-4:#5C5448;
  --a-gold-soft:rgba(184,146,74,.18);
  --a-gold-soft-strong:rgba(184,146,74,.30);
  --a-shadow-xs:0 1px 2px rgba(0,0,0,.5);
  --a-shadow-sm:0 2px 8px rgba(0,0,0,.5);
  --a-shadow-md:0 8px 24px rgba(0,0,0,.6);
  --a-shadow-lg:0 20px 48px rgba(0,0,0,.7);
}

/* ═══ admin-panel root ═══ */
#admin-panel{position:fixed;inset:0;z-index:200;background:var(--a-bg);overflow:hidden;animation:adminFadeIn .25s ease;}
#admin-panel.hidden{display:none;}
@keyframes adminFadeIn{from{opacity:0;}to{opacity:1;}}

/* ═══ ADMIN SHELL — icon rail | main | (inspector) ═══ */
.adm-shell{display:flex;height:100vh;width:100%;overflow:hidden;}

/* ─── LEFT SIDEBAR — full width, always visible (no icon-rail) ─── */
.adm-side{
  width:var(--a-rail);min-width:var(--a-rail);
  flex-shrink:0;flex-grow:0;
  background:var(--a-surface);
  border-right:1px solid var(--a-border);
  display:flex;flex-direction:column;
  overflow:hidden;position:relative;z-index:30;
}
.adm-side-hdr{
  display:flex;align-items:center;justify-content:space-between;
  padding:18px 18px 14px;
  border-bottom:1px solid var(--a-border);
}
.adm-side-hdr .lg{
  font-family:'Playfair Display',serif;font-size:22px;color:var(--a-gold);
  line-height:1;letter-spacing:-.2px;font-weight:500;
}
.adm-side-hdr .lg small{
  display:block;font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:2.5px;
  color:var(--a-ink-3);text-transform:uppercase;margin-top:4px;font-weight:600;
}
.adm-side-close{
  width:28px;height:28px;border-radius:8px;
  background:transparent;border:1px solid transparent;
  color:var(--a-ink-3);display:flex;align-items:center;justify-content:center;
  cursor:pointer;font-size:13px;transition:all .15s;margin-left:auto;
}
.adm-side-close:hover{background:var(--a-surface-2);color:var(--a-ink);border-color:var(--a-border);}

/* Search input in sidebar */
.adm-search{position:relative;padding:12px;}
.adm-search input{
  width:100%;box-sizing:border-box;
  padding:9px 12px 9px 34px;border-radius:9px;
  background:var(--a-surface-2);border:1px solid transparent;
  font-size:13px;color:var(--a-ink);outline:none;font-family:inherit;
  transition:all .15s;
}
.adm-search input::placeholder{color:var(--a-ink-3);}
.adm-search input:focus{background:var(--a-surface);border-color:var(--a-gold);box-shadow:0 0 0 3px var(--a-gold-soft);}
.adm-search svg{position:absolute;left:22px;top:21px;color:var(--a-ink-3);width:14px;height:14px;}

/* Groups + items */
.adm-side-nav{
  flex:1;overflow-y:auto;padding:4px 12px 12px;
  display:block !important;
}
.adm-side-nav::-webkit-scrollbar{width:6px;}
.adm-side-nav::-webkit-scrollbar-thumb{background:var(--a-border-strong);border-radius:3px;}
.adm-side-group{display:block !important;width:100% !important;margin-bottom:18px;}
.adm-side-item{width:100% !important;}
.adm-side-grp-lbl{
  font-size:9.5px;letter-spacing:2px;text-transform:uppercase;
  color:var(--a-ink-3);font-weight:700;
  padding:6px 12px;margin-bottom:4px;
  cursor:pointer;user-select:none;
  display:flex;align-items:center;
  border-radius:6px;transition:color .12s;
}
.adm-side-grp-lbl:hover{color:var(--a-ink-2);}
.adm-side-grp-lbl::after{
  content:'';margin-left:auto;
  width:0;height:0;border-left:3.5px solid transparent;border-right:3.5px solid transparent;
  border-top:4px solid var(--a-ink-4);
  transition:transform .15s;
}
.adm-side-group.collapsed .adm-side-grp-lbl::after{transform:rotate(-90deg);}
.adm-side-group.collapsed .adm-side-item{display:none;}
.adm-side-group.collapsed.search-open .adm-side-item{display:flex;}
.adm-side-group.collapsed.search-open .adm-side-grp-lbl::after{transform:rotate(0);}

.adm-side-item{
  display:flex;align-items:center;gap:11px;
  padding:8px 10px;border-radius:8px;
  cursor:pointer;color:var(--a-ink-2);
  transition:all .12s;border:none;background:none;
  width:100%;text-align:left;font-family:inherit;
  position:relative;font-weight:500;font-size:13.5px;
  white-space:nowrap;
}
.adm-side-item:hover{background:var(--a-surface-2);color:var(--a-ink);}
.adm-side-item.active{background:var(--a-gold-soft);color:var(--a-ink);}
.adm-side-item.active::before{
  content:'';position:absolute;left:-12px;top:8px;bottom:8px;
  width:3px;border-radius:0 2px 2px 0;background:var(--a-gold);
}
.adm-side-item .ic{
  width:26px;height:26px;border-radius:7px;
  background:var(--a-surface-2);
  display:flex;align-items:center;justify-content:center;
  font-size:13px;flex-shrink:0;color:var(--a-ink-2);
  transition:all .15s;
}
.adm-side-item:hover .ic{background:var(--a-surface);box-shadow:var(--a-shadow-xs);}
.adm-side-item.active .ic{background:var(--a-gold);color:white;box-shadow:0 2px 8px var(--a-gold-soft-strong);}
.adm-side-item.hidden-by-search{display:none;}

/* Pin button */
.adm-side-item .pin-btn{
  position:absolute;right:8px;top:50%;transform:translateY(-50%);
  width:20px;height:20px;border-radius:5px;
  background:transparent;border:none;color:var(--a-ink-4);
  display:none;align-items:center;justify-content:center;
  cursor:pointer;font-size:11px;transition:all .12s;
}
.adm-side-item:hover .pin-btn{display:flex;}
.adm-side-item.pinned .pin-btn{display:flex;color:var(--a-gold);}
.adm-side-item .pin-btn:hover{background:var(--a-surface-2);color:var(--a-gold);}

/* Bottom: pin sidebar-open + profile chip */
.adm-side-foot{padding:12px;border-top:1px solid var(--a-border);}
.adm-side-foot-btn{
  display:flex;align-items:center;gap:10px;
  width:100%;padding:8px 10px;border-radius:8px;
  background:transparent;border:none;cursor:pointer;
  color:var(--a-ink-2);font-family:inherit;font-size:13px;
  transition:background .12s;
}
.adm-side-foot-btn:hover{background:var(--a-surface-2);color:var(--a-ink);}
.adm-side-foot-btn .ic{width:26px;height:26px;border-radius:7px;background:var(--a-surface-2);display:flex;align-items:center;justify-content:center;flex-shrink:0;}

/* ═══ MAIN ═══ */
.adm-main{
  flex:1;min-width:0;
  display:flex;flex-direction:column;
  overflow-y:auto;background:var(--a-bg);
  scroll-behavior:smooth;
}
.adm-main::-webkit-scrollbar{width:10px;}
.adm-main::-webkit-scrollbar-thumb{background:var(--a-border-strong);border-radius:5px;}

/* ─── Top bar ─── */
.adm-topbar{
  position:sticky;top:0;z-index:20;
  display:flex;align-items:center;gap:14px;
  height:var(--a-topbar);padding:0 28px;
  background:rgba(250,247,241,.85);
  backdrop-filter:blur(18px) saturate(140%);-webkit-backdrop-filter:blur(18px) saturate(140%);
  border-bottom:1px solid var(--a-border);
}
body.dark .adm-topbar{background:rgba(11,9,7,.85);}
.adm-crumb{display:flex;align-items:center;gap:8px;font-size:13px;}
.adm-crumb-grp{color:var(--a-ink-3);}
.adm-crumb-sep{color:var(--a-ink-4);}
.adm-crumb-pane{color:var(--a-ink);font-weight:600;font-size:14px;}
.adm-topbar-spacer{flex:1;}
.adm-topbar-cmdk{
  display:flex;align-items:center;gap:8px;
  padding:7px 14px;border-radius:100px;
  background:var(--a-surface);border:1px solid var(--a-border-strong);
  color:var(--a-ink-3);font-size:13px;cursor:pointer;
  font-family:inherit;transition:all .12s;min-width:240px;
}
.adm-topbar-cmdk:hover{background:var(--a-surface-2);color:var(--a-ink);border-color:var(--a-ink-4);}
.adm-topbar-cmdk svg{color:var(--a-ink-3);}
.adm-topbar-cmdk kbd{
  margin-left:auto;font-family:'SF Mono',monospace;font-size:10.5px;
  background:var(--a-surface-2);border:1px solid var(--a-border);
  border-radius:4px;padding:1.5px 6px;color:var(--a-ink-3);
}
.adm-iconbtn{
  width:34px;height:34px;border-radius:9px;
  background:transparent;border:1px solid transparent;
  color:var(--a-ink-3);cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  transition:all .12s;
}
.adm-iconbtn:hover{background:var(--a-surface-2);color:var(--a-ink);border-color:var(--a-border);}

/* ─── Pane body ─── */
.adm-pane-wrap{
  flex:1;max-width:1080px;width:100%;margin:0 auto;
  padding:36px 36px 80px;box-sizing:border-box;
}
/* Each pane is a direct child of <main> — give them the padded layout */
.adm-main > [id^="adm-"]:not(#adm-fab):not(#adm-save-indicator):not(#adm-palette):not(#adm-topbar){
  max-width:1080px;width:100%;margin:0 auto;
  padding:36px 36px 80px;box-sizing:border-box;
}
.adm-section-title{
  font-family:'Playfair Display',serif;
  font-size:36px;color:var(--a-ink);
  margin:0 0 6px;letter-spacing:-.7px;
  font-weight:500;line-height:1.1;
}
.adm-section-sub{
  font-size:14px;color:var(--a-ink-3);
  margin:0 0 28px;line-height:1.5;
  max-width:680px;
}

/* ─── Cards ─── */
.adm-card{
  background:var(--a-surface);
  border:1px solid var(--a-border);
  border-radius:var(--a-radius-lg);
  margin-bottom:18px;overflow:hidden;
  box-shadow:var(--a-shadow-xs);
  transition:border-color .15s, box-shadow .15s;
}
.adm-card:hover{border-color:var(--a-border-strong);box-shadow:var(--a-shadow-sm);}
.adm-card-hdr{padding:18px 22px 6px;display:flex;align-items:center;gap:12px;}
.adm-card-hdr-ttl{
  font-size:11px;letter-spacing:1.8px;text-transform:uppercase;
  color:var(--a-ink-3);font-weight:700;
}
.adm-card-hdr-actions{margin-left:auto;display:flex;gap:6px;}

/* Settings rows (cs-row + adm-row reused) */
.cs-toggles,.adm-row{} /* keep existing */
.cs-row,.adm-row{
  display:flex;align-items:center;justify-content:space-between;
  gap:20px;padding:14px 22px;
  border-top:1px solid var(--a-border);
  min-height:56px;transition:background .12s;
}
.cs-row:first-child,.adm-row:first-of-type{border-top:none;}
.cs-row:hover,.adm-row:hover{background:var(--a-surface-2);}
.cs-info,.adm-row-text{flex:1;min-width:0;}
.cs-name,.adm-row-title{font-size:14px;font-weight:500;color:var(--a-ink);letter-spacing:-.1px;}
.cs-desc,.adm-row-sub{font-size:12.5px;color:var(--a-ink-3);margin-top:3px;line-height:1.45;}
.cs-sel{width:200px;flex-shrink:0;margin:0;font-size:13px;padding:8px 12px;}
.cs-num{width:100px;flex-shrink:0;margin:0;text-align:right;font-variant-numeric:tabular-nums;font-size:13px;padding:8px 12px;}
.adm-row-ctrl{flex-shrink:0;display:flex;align-items:center;gap:8px;}

/* Inputs */
.adm-input,.adinput,.cs-sel,.cs-num{
  padding:8px 12px;border-radius:9px;
  background:var(--a-surface-2);
  border:1px solid var(--a-border);
  font-size:13px;color:var(--a-ink);
  outline:none;font-family:inherit;
  transition:all .15s;
}
.adm-input{min-width:200px;}
.adm-input:focus,.adinput:focus,.cs-sel:focus,.cs-num:focus{
  background:var(--a-surface);
  border-color:var(--a-gold);
  box-shadow:0 0 0 3px var(--a-gold-soft);
}

/* Buttons */
.adm-btn,.adbtn{
  padding:9px 16px;border-radius:9px;
  background:var(--a-ink);color:var(--a-surface);
  font-size:12.5px;border:1px solid var(--a-ink);
  cursor:pointer;font-family:inherit;
  transition:all .12s;font-weight:500;
  letter-spacing:.1px;
}
.adm-btn:hover,.adbtn:hover{background:#2a221c;border-color:#2a221c;transform:translateY(-1px);box-shadow:var(--a-shadow-xs);}
.adm-btn:active,.adbtn:active{transform:translateY(0);}
.adm-btn.subtle{background:transparent;color:var(--a-ink-2);border:1px solid var(--a-border-strong);}
.adm-btn.subtle:hover{background:var(--a-surface-2);color:var(--a-ink);border-color:var(--a-ink-3);}
.adm-btn.danger,.adm-btn.red,.adbtn.red{background:transparent;color:var(--a-danger);border:1px solid rgba(200,64,62,.30);}
.adm-btn.danger:hover,.adm-btn.red:hover,.adbtn.red:hover{background:var(--a-danger);color:white;border-color:var(--a-danger);}
.adm-btn.gold,.adbtn.gold{background:var(--a-gold);color:white;border-color:var(--a-gold);}
.adm-btn.gold:hover,.adbtn.gold:hover{background:var(--a-gold-2);border-color:var(--a-gold-2);}

/* Text rows */
.adm-text-row{display:flex;flex-direction:column;gap:8px;padding:14px 22px;border-top:1px solid var(--a-border);}
.adm-text-row:first-of-type{border-top:none;}
.adm-text-row label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--a-ink-3);font-weight:600;}
.adm-text-row input,.adm-text-row textarea{
  padding:10px 12px;border-radius:9px;background:var(--a-surface-2);
  border:1px solid var(--a-border);font-size:14px;color:var(--a-ink);outline:none;
  font-family:inherit;width:100%;box-sizing:border-box;transition:all .15s;
}
.adm-text-row input:focus,.adm-text-row textarea:focus{background:var(--a-surface);border-color:var(--a-gold);box-shadow:0 0 0 3px var(--a-gold-soft);}
.adm-text-row textarea{min-height:72px;resize:vertical;line-height:1.5;}

/* iOS-style toggle — refined */
.adtoggle{position:relative;width:44px;height:26px;flex-shrink:0;cursor:pointer;display:inline-block;}
.adtoggle input{opacity:0;width:0;height:0;}
.adtogslider{
  position:absolute;inset:0;background:var(--a-border-strong);
  border-radius:26px;transition:.22s cubic-bezier(.16,1,.3,1);
}
.adtogslider::before{
  position:absolute;content:'';left:2px;bottom:2px;
  width:22px;height:22px;background:white;
  border-radius:50%;transition:.22s cubic-bezier(.16,1,.3,1);
  box-shadow:0 1px 3px rgba(0,0,0,.18);
}
.adtoggle input:checked + .adtogslider{background:var(--a-gold);}
.adtoggle input:checked + .adtogslider::before{transform:translateX(18px);}

/* ─── DASHBOARD widgets ─── */
.dash-hero{
  background:linear-gradient(135deg,var(--a-gold) 0%, var(--a-gold-2) 100%);
  color:white;border-radius:var(--a-radius-lg);
  padding:28px 30px;margin-bottom:22px;
  box-shadow:var(--a-shadow-md);
  position:relative;overflow:hidden;
}
.dash-hero::before{content:'';position:absolute;top:-50%;right:-30%;width:60%;height:200%;background:radial-gradient(ellipse,rgba(255,255,255,.15),transparent 60%);pointer-events:none;}
.dash-hero-greet{font-size:12.5px;opacity:.85;letter-spacing:.3px;margin-bottom:4px;}
.dash-hero-name{font-family:'Playfair Display',serif;font-size:32px;letter-spacing:-.6px;margin-bottom:14px;font-weight:500;}
.dash-hero-stats{display:flex;gap:32px;flex-wrap:wrap;}
.dash-hero-stat{}
.dash-hero-stat .n{font-family:'Playfair Display',serif;font-size:30px;font-weight:500;line-height:1;}
.dash-hero-stat .l{font-size:10.5px;letter-spacing:1.5px;text-transform:uppercase;opacity:.85;margin-top:6px;}

.dash-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px;margin-bottom:22px;}
.dash-tile{
  background:var(--a-surface);border:1px solid var(--a-border);
  border-radius:var(--a-radius);padding:18px;
  cursor:pointer;transition:all .15s;
  display:flex;flex-direction:column;gap:8px;
  position:relative;overflow:hidden;
  text-decoration:none;color:inherit;
}
.dash-tile:hover{transform:translateY(-2px);box-shadow:var(--a-shadow-md);border-color:var(--a-border-strong);}
.dash-tile .lbl{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--a-ink-3);font-weight:700;}
.dash-tile .val{font-family:'Playfair Display',serif;font-size:32px;font-weight:500;line-height:1;color:var(--a-ink);letter-spacing:-.5px;}
.dash-tile .delta{font-size:11.5px;color:var(--a-ink-3);}
.dash-tile .delta.up{color:var(--a-success);}
.dash-tile .delta.down{color:var(--a-danger);}
.dash-tile::after{content:'›';position:absolute;top:16px;right:18px;font-size:20px;color:var(--a-ink-4);transition:transform .15s;}
.dash-tile:hover::after{transform:translateX(4px);color:var(--a-ink-2);}

/* Recent activity panel */
.dash-recent{
  background:var(--a-surface);border:1px solid var(--a-border);
  border-radius:var(--a-radius);margin-bottom:18px;
}
.dash-recent-hdr{padding:16px 20px 8px;display:flex;align-items:center;justify-content:space-between;}
.dash-recent-hdr .ttl{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--a-ink-3);font-weight:700;}
.dash-recent-hdr a{font-size:12px;color:var(--a-gold);text-decoration:none;}
.dash-recent-row{
  display:flex;align-items:center;gap:11px;
  padding:12px 20px;font-size:13px;color:var(--a-ink-2);
  border-top:1px solid var(--a-border);
  cursor:pointer;transition:background .12s;
}
.dash-recent-row:hover{background:var(--a-surface-2);}
.dash-recent-row .av{
  width:28px;height:28px;border-radius:7px;
  background:linear-gradient(135deg,var(--a-gold),var(--a-gold-2));
  color:white;font-size:11px;font-weight:600;
  display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.dash-recent-row .what{flex:1;line-height:1.4;}
.dash-recent-row .when{font-size:11px;color:var(--a-ink-3);font-variant-numeric:tabular-nums;}

/* Empty state */
.adm-empty{
  text-align:center;padding:60px 20px;color:var(--a-ink-3);
}
.adm-empty .emoji{font-size:42px;margin-bottom:14px;opacity:.5;}
.adm-empty .ttl{font-size:15px;font-weight:500;color:var(--a-ink-2);margin-bottom:4px;}
.adm-empty .sub{font-size:13px;}

/* ═══ COMMAND PALETTE (extends earlier) ═══ */
.adm-palette{
  position:fixed;inset:0;z-index:400;display:none;
  background:rgba(0,0,0,.55);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
  align-items:flex-start;justify-content:center;padding-top:14vh;
  animation:palFadeIn .15s ease;
}
.adm-palette.show{display:flex;}
@keyframes palFadeIn{from{opacity:0;}to{opacity:1;}}
.adm-palette-box{
  width:min(640px,92vw);max-height:70vh;
  background:var(--a-surface);
  border:1px solid var(--a-border-strong);
  border-radius:var(--a-radius-lg);
  box-shadow:var(--a-shadow-lg);
  display:flex;flex-direction:column;
  animation:palSlideIn .22s cubic-bezier(.2,.9,.3,1.05);overflow:hidden;
}
@keyframes palSlideIn{from{transform:translateY(-14px) scale(.97);opacity:0;}to{transform:translateY(0) scale(1);opacity:1;}}
.adm-palette-input-wrap{display:flex;align-items:center;gap:11px;padding:14px 16px;border-bottom:1px solid var(--a-border);}
.adm-palette-input-wrap svg{color:var(--a-ink-3);flex-shrink:0;}
.adm-palette-input-wrap input{flex:1;border:none;background:transparent;outline:none;font-size:15px;color:var(--a-ink);font-family:inherit;}
.adm-palette-input-wrap input::placeholder{color:var(--a-ink-3);}
.adm-palette-input-wrap kbd{font-family:'SF Mono',monospace;font-size:10px;background:var(--a-surface-2);border:1px solid var(--a-border);border-radius:4px;padding:2px 6px;color:var(--a-ink-3);}
.adm-palette-results{flex:1;overflow-y:auto;padding:8px;min-height:120px;}
.adm-palette-empty{padding:32px;text-align:center;color:var(--a-ink-3);font-size:13px;}
.adm-palette-section{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--a-ink-4);font-weight:700;padding:10px 12px 4px;}
.adm-palette-item{display:flex;align-items:center;gap:11px;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13.5px;color:var(--a-ink);transition:background .08s;}
.adm-palette-item.active{background:var(--a-gold-soft);}
.adm-palette-item .ic{width:26px;height:26px;border-radius:7px;background:var(--a-surface-2);display:flex;align-items:center;justify-content:center;font-size:13px;flex-shrink:0;}
.adm-palette-item.active .ic{background:var(--a-gold);color:white;}
.adm-palette-item .label{flex:1;min-width:0;}
.adm-palette-item .label small{display:block;font-size:11px;color:var(--a-ink-3);margin-top:1px;}
.adm-palette-item .meta{font-size:10.5px;color:var(--a-ink-3);background:var(--a-surface-2);padding:2px 7px;border-radius:5px;flex-shrink:0;}
.adm-palette-footer{display:flex;gap:14px;padding:10px 16px;background:var(--a-surface-2);border-top:1px solid var(--a-border);font-size:11px;color:var(--a-ink-3);}
.adm-palette-footer kbd{font-family:'SF Mono',monospace;font-size:10px;background:var(--a-surface);border:1px solid var(--a-border);border-radius:3px;padding:1px 5px;margin-right:4px;}

/* ═══ Save indicator ═══ */
.adm-save-indicator{
  position:fixed;bottom:24px;right:24px;z-index:350;
  display:flex;align-items:center;gap:9px;
  padding:9px 16px;border-radius:100px;
  background:var(--a-surface);border:1px solid var(--a-border-strong);
  font-size:12.5px;color:var(--a-ink);
  box-shadow:var(--a-shadow-md);
  transform:translateY(80px);opacity:0;
  transition:transform .25s cubic-bezier(.2,.9,.3,1.1), opacity .2s;
  pointer-events:none;font-weight:500;
}
.adm-save-indicator.show{transform:translateY(0);opacity:1;}
.adm-save-indicator .dot{width:9px;height:9px;border-radius:50%;background:var(--a-success);box-shadow:0 0 0 0 var(--a-success-soft);animation:savePulse 1s ease-out;}
@keyframes savePulse{0%{box-shadow:0 0 0 0 rgba(46,139,87,.5);}100%{box-shadow:0 0 0 10px rgba(46,139,87,0);}}
.adm-save-indicator.saving .dot{background:var(--a-gold);animation:none;}
.adm-save-indicator.error .dot{background:var(--a-danger);animation:none;}

/* ═══ Click-to-edit ═══ */
.edt{cursor:pointer;border-radius:5px;padding:1px 4px;margin:-1px -4px;transition:background .12s;}
.edt:hover{background:var(--a-gold-soft);}
.edt.editing{background:var(--a-surface);box-shadow:0 0 0 2px var(--a-gold);}

/* ═══ Tooltip for icon-only buttons ═══ */
[data-tip]{position:relative;}
[data-tip]:hover::after{
  content:attr(data-tip);
  position:absolute;left:100%;top:50%;transform:translateY(-50%);
  margin-left:10px;
  background:var(--a-ink);color:var(--a-surface);
  font-size:11.5px;font-weight:500;letter-spacing:.2px;
  padding:5px 9px;border-radius:6px;white-space:nowrap;pointer-events:none;
  z-index:100;box-shadow:var(--a-shadow-sm);
  animation:tipIn .12s ease-out;
}
[data-tip]:hover::before{
  content:'';position:absolute;left:100%;top:50%;transform:translateY(-50%);
  border:5px solid transparent;border-right-color:var(--a-ink);margin-left:0;
  pointer-events:none;z-index:100;
}
@keyframes tipIn{from{opacity:0;transform:translate(4px,-50%);}to{opacity:1;transform:translate(0,-50%);}}

/* Responsive */
@media(max-width:900px){
  .adm-shell{flex-direction:column;}
  .adm-side{width:100%;min-width:0;max-height:60px;border-right:none;border-bottom:1px solid var(--a-border);position:relative;}
  .adm-side:hover{width:100%;max-height:80vh;}
  .adm-main{height:auto;}
  .adm-pane-wrap{padding:24px 20px 80px;}
  .adm-section-title{font-size:28px;}
  .adm-topbar{padding:0 18px;}
  .adm-topbar-cmdk{min-width:0;flex:1;}
  .cs-row,.adm-row,.adm-text-row{padding:13px 18px;}
}

/* ═══ Legacy classes — keep working for old panes ═══ */
.adnav{position:sticky;top:0;z-index:10;background:var(--a-surface);border-bottom:2px solid var(--a-border);padding:0 1.75rem;height:58px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 14px rgba(26,20,16,.05);}
.adlogo{font-family:'Playfair Display',serif;font-size:19px;color:var(--a-gold);}
.adlogo small{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:2px;color:var(--a-ink-3);display:block;margin-top:-4px;}
.adclosebtn{padding:6px 16px;border-radius:100px;border:1px solid var(--a-border);background:none;color:var(--a-ink-2);font-size:11px;letter-spacing:1px;transition:all .2s;cursor:pointer;}
.adclosebtn:hover{background:var(--a-ink);color:var(--a-surface);border-color:var(--a-ink);}
.adtabsbar{display:flex;padding:0 1.75rem;border-bottom:1px solid var(--a-border);background:var(--a-surface);overflow-x:auto;}
.adtab{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--a-ink-3);background:none;border:none;border-bottom:2px solid transparent;padding:.75rem .875rem;white-space:nowrap;margin-bottom:-1px;transition:all .2s;cursor:pointer;}
.adtab.active{color:var(--a-ink);border-bottom-color:var(--a-gold);}
.adbody{max-width:880px;margin:0 auto;padding:1.75rem 1.375rem;}
.adstitle{font-family:'Playfair Display',serif;font-size:19px;color:var(--a-ink);margin-bottom:1.375rem;}
.adsgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(125px,1fr));gap:.875rem;margin-bottom:1.75rem;}
.adscard{background:var(--a-surface-2);border-radius:10px;padding:1.1rem;text-align:center;}
.adsnum{font-family:'Playfair Display',serif;font-size:28px;color:var(--a-gold);}
.adslbl{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--a-ink-3);margin-top:3px;}
.adta{width:100%;padding:11px 13px;border-radius:7px;resize:none;height:85px;background:var(--a-surface-2);border:1px solid var(--a-border);font-size:14px;color:var(--a-ink);outline:none;margin-bottom:.875rem;transition:border-color .2s;}
.adta:focus{border-color:var(--a-gold);}
.adinput{width:100%;padding:9px 13px;border-radius:9px;background:var(--a-surface-2);border:1px solid var(--a-border);font-size:13px;color:var(--a-ink);outline:none;margin-bottom:.625rem;transition:border-color .2s;box-sizing:border-box;}
.adinput:focus{border-color:var(--a-gold);}
.aduser{display:flex;align-items:center;gap:9px;padding:.75rem 0;border-bottom:1px solid var(--a-border);flex-wrap:wrap;}
.aduav{width:34px;height:34px;border-radius:50%;background:var(--a-surface-2);border:1.5px solid var(--a-gold);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;color:var(--a-gold);overflow:hidden;flex-shrink:0;}
.aduav img{width:100%;height:100%;object-fit:cover;}
.adunm{flex:1;font-size:13px;color:var(--a-ink);min-width:90px;}
.adust{font-size:11px;}
.adust.active{color:var(--a-gold);}
.adust.pending{color:#B03030;}
.adua{display:flex;gap:4px;flex-wrap:wrap;}
.aduact{font-size:10px;padding:3px 8px;border-radius:100px;border:1px solid var(--a-border);background:none;color:var(--a-ink-3);transition:all .2s;cursor:pointer;}
.aduact:hover{border-color:var(--a-ink-2);color:var(--a-ink);}
.aduact.m{border-color:#B03030;color:#B03030;}
.actitem{display:flex;gap:9px;align-items:flex-start;padding:.625rem 0;border-bottom:1px solid var(--a-border);}
.actdot{width:6px;height:6px;border-radius:50%;background:var(--a-gold);flex-shrink:0;margin-top:5px;}
.acttx{font-size:13px;color:var(--a-ink-2);flex:1;line-height:1.5;}
.acttm{font-size:11px;color:var(--a-ink-3);}
.adanitem{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid var(--a-border);gap:.875rem;}
.adantx{font-size:13px;color:var(--a-ink-2);flex:1;}
.topup{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--a-border);}
.fl{display:block;font-size:11px;color:var(--a-ink-3);font-weight:600;letter-spacing:1.5px;text-transform:uppercase;margin-bottom:6px;}
.hidden{display:none !important;}
/* ADMIN */
#admin-panel{position:fixed;inset:0;z-index:200;background:var(--c);overflow-y:auto;animation:adminIn .25s ease;}
@keyframes adminIn{from{opacity:0;}to{opacity:1;}}
.adnav{position:sticky;top:0;z-index:10;background:var(--c);border-bottom:2px solid var(--b);padding:0 1.75rem;height:58px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 14px rgba(26,20,16,.05);}
.adlogo{font-family:'Playfair Display',serif;font-size:19px;color:var(--gold);}
.adlogo small{font-family:'DM Sans',sans-serif;font-size:9px;letter-spacing:2px;color:var(--ink3);display:block;margin-top:-4px;}
.adclosebtn{padding:6px 16px;border-radius:100px;border:1px solid var(--b);background:none;color:var(--ink2);font-size:11px;letter-spacing:1px;transition:all .2s;cursor:pointer;}
.adclosebtn:hover{background:var(--ink);color:var(--c);border-color:var(--ink);}
.adtabsbar{display:flex;padding:0 1.75rem;border-bottom:1px solid var(--b);background:var(--c);overflow-x:auto;}
.adtab{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink3);background:none;border:none;border-bottom:2px solid transparent;padding:.75rem .875rem;white-space:nowrap;margin-bottom:-1px;transition:all .2s;cursor:pointer;}
.adtab.active{color:var(--ink);border-bottom-color:var(--gold);}
.adbody{max-width:880px;margin:0 auto;padding:1.75rem 1.375rem;}
.adstitle{font-family:'Playfair Display',serif;font-size:19px;color:var(--ink);margin-bottom:1.375rem;}
.adsgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(125px,1fr));gap:.875rem;margin-bottom:1.75rem;}
.adscard{background:var(--c2);border-radius:10px;padding:1.1rem;text-align:center;}
.adsnum{font-family:'Playfair Display',serif;font-size:28px;color:var(--gold);}
.adslbl{font-size:10px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink3);margin-top:3px;}
.adta{width:100%;padding:11px 13px;border-radius:7px;resize:none;height:85px;background:var(--c2);border:1px solid var(--b);font-size:14px;color:var(--ink);outline:none;margin-bottom:.875rem;transition:border-color .2s;}
.adta:focus{border-color:var(--gold);}
.adbtn{padding:8px 20px;border-radius:100px;background:var(--ink);color:var(--c);font-size:11px;letter-spacing:1.5px;text-transform:uppercase;border:none;transition:background .2s;cursor:pointer;}
.adbtn:hover{background:#2C241C;}
.adbtn.red{background:none;border:1px solid rgba(176,48,48,.3);color:#B03030;}
.adbtn.red:hover{background:#B03030;color:white;border-color:#B03030;}
.adinput{width:100%;padding:9px 13px;border-radius:7px;background:var(--c2);border:1px solid var(--b);font-size:13px;color:var(--ink);outline:none;margin-bottom:.625rem;transition:border-color .2s;}
.adinput:focus{border-color:var(--gold);}
.aduser{display:flex;align-items:center;gap:9px;padding:.75rem 0;border-bottom:1px solid var(--b);flex-wrap:wrap;}
.aduav{width:34px;height:34px;border-radius:50%;background:var(--c2);border:1.5px solid var(--gold);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:500;color:var(--gold);overflow:hidden;flex-shrink:0;}
.aduav img{width:100%;height:100%;object-fit:cover;}
.adunm{flex:1;font-size:13px;color:var(--ink);min-width:90px;}
.adust{font-size:11px;}
.adust.active{color:var(--gold);}
.adust.pending{color:#B03030;}
.adua{display:flex;gap:4px;flex-wrap:wrap;}
.aduact{font-size:10px;padding:3px 8px;border-radius:100px;border:1px solid var(--b);background:none;color:var(--ink3);transition:all .2s;cursor:pointer;}
.aduact:hover{border-color:var(--ink2);color:var(--ink);}
.aduact.m{border-color:#B03030;color:#B03030;}
.actitem{display:flex;gap:9px;align-items:flex-start;padding:.625rem 0;border-bottom:1px solid var(--b);}
.actdot{width:6px;height:6px;border-radius:50%;background:var(--gold);flex-shrink:0;margin-top:5px;}
.acttx{font-size:13px;color:var(--ink2);flex:1;line-height:1.5;}
.acttm{font-size:11px;color:var(--ink3);}
.adanitem{display:flex;justify-content:space-between;align-items:flex-start;padding:.75rem 0;border-bottom:1px solid var(--b);gap:.875rem;}
.adantx{font-size:13px;color:var(--ink2);flex:1;}
.topup{display:flex;justify-content:space-between;align-items:center;padding:.5rem 0;border-bottom:1px solid var(--b);}

/* User-list filter pills */
.adu-filters{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;}
.adu-fp{
  display:inline-flex;align-items:center;gap:6px;
  padding:6px 12px;border-radius:100px;
  background:var(--a-surface);border:1px solid var(--a-border);
  color:var(--a-ink-2);font-size:12.5px;font-family:inherit;font-weight:500;
  cursor:pointer;transition:all .12s;
}
.adu-fp:hover{background:var(--a-surface-2);color:var(--a-ink);border-color:var(--a-border-strong);}
.adu-fp.active{background:var(--a-ink);color:var(--a-surface);border-color:var(--a-ink);}
.adu-fp .ct{
  display:inline-flex;align-items:center;justify-content:center;
  min-width:18px;height:18px;padding:0 5px;border-radius:9px;
  background:var(--a-surface-2);color:var(--a-ink-3);font-size:10.5px;font-weight:600;
  font-variant-numeric:tabular-nums;
}
.adu-fp.active .ct{background:rgba(255,255,255,.18);color:rgba(255,255,255,.95);}

/* USERS — list + detail */
.adu-search{position:relative;margin-bottom:14px;}
.adu-search input{width:100%;padding:10px 13px 10px 36px;border-radius:9px;background:var(--c2);border:1px solid var(--b);font-size:14px;color:var(--ink);outline:none;font-family:inherit;box-sizing:border-box;}
.adu-search input:focus{border-color:var(--gold);}
.adu-search svg{position:absolute;left:12px;top:11px;color:var(--ink3);pointer-events:none;}
.adu-list{display:flex;flex-direction:column;gap:0;}
.adu-row{display:flex;align-items:center;gap:14px;padding:12px 16px;background:var(--c);border:1px solid var(--b);border-radius:0;cursor:pointer;transition:background .12s;}
.adu-row:first-child{border-top-left-radius:12px;border-top-right-radius:12px;}
.adu-row:last-child{border-bottom-left-radius:12px;border-bottom-right-radius:12px;}
.adu-row+.adu-row{border-top:none;}
.adu-row:hover{background:var(--c2);}
.adu-row.hidden-by-search{display:none;}
.adu-row-av{width:42px;height:42px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;color:white;font-size:13px;font-weight:600;flex-shrink:0;overflow:hidden;border:2px solid var(--c);box-shadow:0 1px 3px rgba(0,0,0,.1);}
.adu-row-av img{width:100%;height:100%;object-fit:cover;}
.adu-row-main{flex:1;min-width:0;}
.adu-row-name{font-size:14px;color:var(--ink);font-weight:500;line-height:1.3;display:flex;align-items:center;gap:6px;}
.adu-row-meta{font-size:11px;color:var(--ink3);margin-top:2px;display:flex;gap:10px;flex-wrap:wrap;}
.adu-row-meta .dot{width:6px;height:6px;border-radius:50%;background:var(--ink3);display:inline-block;}
.adu-row-meta .dot.on{background:#4CAF50;box-shadow:0 0 5px #4CAF50;}
.adu-row-meta .dot.mut{background:#B85050;}
.adu-row-stats{display:flex;gap:14px;font-size:11px;color:var(--ink3);flex-shrink:0;}
.adu-row-stats .v{font-size:14px;color:var(--ink);font-weight:600;display:block;}
.adu-row-chev{color:var(--ink3);font-size:18px;flex-shrink:0;}
.adu-pill{display:inline-block;font-size:9px;letter-spacing:1px;text-transform:uppercase;padding:2px 7px;border-radius:100px;background:var(--gold);color:white;font-weight:600;}
.adu-pill.muted{background:#B85050;}
.adu-pill.blocked{background:#7a1f1f;}
.adu-pill.pending{background:rgba(176,48,48,.12);color:#B03030;}

/* Bulk action bar */
#adu-bulk-bar{position:sticky;top:0;z-index:5;background:var(--gold);color:white;padding:10px 14px;border-radius:10px;margin-bottom:10px;display:none;align-items:center;gap:10px;}
#adu-bulk-bar.show{display:flex;}
#adu-bulk-bar .ct{font-size:13px;font-weight:600;flex:1;}
#adu-bulk-bar button{background:rgba(255,255,255,.18);color:white;border:none;padding:6px 12px;border-radius:100px;font-size:12px;cursor:pointer;font-family:inherit;}
#adu-bulk-bar button:hover{background:rgba(255,255,255,.28);}
.adu-row .bulk-cb{width:18px;height:18px;flex-shrink:0;cursor:pointer;accent-color:var(--gold);display:none;}
.adu-list.bulk-mode .bulk-cb{display:block;}
.adu-list.bulk-mode .adu-row{cursor:default;}
.adu-row .inline-name-edit{background:var(--c2);border:1px solid var(--gold);padding:4px 8px;border-radius:6px;font-size:14px;color:var(--ink);outline:none;width:100%;font-family:inherit;}

/* User detail drawer */
#adu-detail{position:fixed;inset:0;z-index:300;background:rgba(0,0,0,.4);display:none;animation:fadeIn .15s;}
#adu-detail.show{display:block;}
@keyframes fadeIn{from{opacity:0;}to{opacity:1;}}
.adu-drawer{position:absolute;top:0;right:0;height:100%;width:min(520px,100vw);background:var(--c);box-shadow:-8px 0 40px rgba(0,0,0,.18);display:flex;flex-direction:column;animation:slideIn .22s cubic-bezier(.16,1,.3,1);}
@keyframes slideIn{from{transform:translateX(100%);}to{transform:translateX(0);}}
.adu-dr-hdr{padding:18px 22px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--b);}
.adu-dr-close{width:32px;height:32px;border-radius:50%;background:var(--c2);border:none;color:var(--ink2);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;}
.adu-dr-close:hover{background:var(--ink);color:var(--c);}
.adu-dr-body{flex:1;overflow-y:auto;padding:0 22px 30px;}
.adu-hero{display:flex;flex-direction:column;align-items:center;gap:12px;padding:24px 0 18px;border-bottom:1px solid var(--b);text-align:center;}
.adu-hero-av{width:84px;height:84px;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));display:flex;align-items:center;justify-content:center;color:white;font-size:24px;font-weight:600;overflow:hidden;border:3px solid var(--c);box-shadow:0 4px 16px rgba(184,146,74,.3);}
.adu-hero-av img{width:100%;height:100%;object-fit:cover;}
.adu-hero-name{font-family:'Playfair Display',serif;font-size:22px;color:var(--ink);}
.adu-hero-meta{font-size:11px;color:var(--ink3);letter-spacing:.5px;display:flex;gap:10px;justify-content:center;flex-wrap:wrap;}
.adu-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--b);border-radius:10px;overflow:hidden;margin:18px 0;}
.adu-stat{background:var(--c);padding:14px 8px;text-align:center;}
.adu-stat .n{font-family:'Playfair Display',serif;font-size:20px;color:var(--gold);line-height:1;}
.adu-stat .l{font-size:9px;letter-spacing:1px;text-transform:uppercase;color:var(--ink3);margin-top:4px;}
.adu-field{margin-bottom:14px;}
.adu-field label{display:block;font-size:11px;letter-spacing:1px;text-transform:uppercase;color:var(--ink3);font-weight:600;margin-bottom:5px;}
.adu-field input{width:100%;padding:9px 12px;border-radius:8px;background:var(--c2);border:1px solid var(--b);font-size:14px;color:var(--ink);outline:none;box-sizing:border-box;font-family:inherit;}
.adu-field input:focus{border-color:var(--gold);}
.adu-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-top:18px;}
.adu-act{padding:10px 12px;border-radius:9px;background:var(--c2);border:1px solid var(--b);color:var(--ink);font-size:12px;cursor:pointer;display:flex;align-items:center;gap:8px;justify-content:center;font-family:inherit;transition:all .12s;}
.adu-act:hover{background:var(--ink);color:var(--c);border-color:var(--ink);}
.adu-act.danger{color:#B03030;border-color:rgba(176,48,48,.3);}
.adu-act.danger:hover{background:#B03030;color:white;border-color:#B03030;}
.adu-act.gold{background:var(--gold);color:white;border-color:var(--gold);}
.adu-act.gold:hover{background:#a07d3a;border-color:#a07d3a;}
.adu-photos-strip{display:flex;gap:6px;overflow-x:auto;padding-bottom:6px;margin-top:8px;}
.adu-photos-strip::-webkit-scrollbar{height:6px;}
.adu-photos-strip img{width:80px;height:80px;border-radius:8px;object-fit:cover;flex-shrink:0;cursor:pointer;}

/* LIVE CURSORS — redesign */
.alc-grid{display:grid;grid-template-columns:1fr;gap:14px;}
@media(min-width:1100px){.alc-grid.with-list{grid-template-columns:minmax(0,2.5fr) minmax(280px,1fr);}}
.alc-grid.no-list .alc-list-wrap{display:none;}
.alc-map-wrap{background:var(--c);border:1px solid var(--b);border-radius:14px;overflow:hidden;position:relative;}
.alc-grid.sz-md .alc-map{padding-top:62%;}
.alc-grid.sz-lg .alc-map{padding-top:75%;}
.alc-grid.sz-xl .alc-map{padding-top:90%;}
/* Full-screen mode for the map */
.alc-grid.sz-full{position:fixed;inset:20px;z-index:400;background:var(--c);padding:18px;border-radius:14px;box-shadow:0 12px 40px rgba(0,0,0,.3);overflow:auto;grid-template-columns:minmax(0,1fr);}
.alc-grid.sz-full.with-list{grid-template-columns:minmax(0,3fr) minmax(280px,1fr);}
.alc-grid.sz-full .alc-map{padding-top:0;height:calc(100vh - 140px);}
.alc-grid.sz-full .alc-list-wrap{max-height:calc(100vh - 140px);}
.alc-map-hdr{padding:12px 16px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;}
.alc-map-hdr .ttl{font-size:13px;font-weight:600;color:var(--ink);}
.alc-map-hdr .pulse{display:inline-flex;align-items:center;gap:6px;font-size:11px;color:var(--ink3);}
.alc-map-hdr .pulse-dot{width:7px;height:7px;border-radius:50%;background:#4CAF50;animation:lcPulse 1.5s infinite;}
@keyframes lcPulse{0%,100%{opacity:.5;}50%{opacity:1;box-shadow:0 0 6px #4CAF50;}}
.alc-map{position:relative;padding-top:75%;background:#F8F4EE;}
.alc-map iframe{pointer-events:none;}
body.dark .alc-map{background:#1a1411;}
/* Realistic site preview inside the map */
.alc-site{position:absolute;inset:0;font-family:'DM Sans',sans-serif;overflow:hidden;}
.alc-site-nav{position:absolute;top:0;left:0;right:0;height:8%;background:rgba(255,255,255,.95);border-bottom:1px solid #E8E0D2;display:flex;align-items:center;padding:0 2.5%;gap:1.5%;box-shadow:0 1px 8px rgba(0,0,0,.04);}
body.dark .alc-site-nav{background:rgba(20,16,10,.96);border-bottom-color:rgba(255,255,255,.06);}
.alc-site-logo{font-family:'Playfair Display',serif;color:var(--gold);font-size:1.4cqw;letter-spacing:1px;font-weight:500;}
.alc-site-tabs{display:flex;gap:1.5%;margin:0 auto;align-items:center;}
.alc-site-tab{font-size:.85cqw;color:rgba(0,0,0,.45);letter-spacing:.8px;text-transform:uppercase;padding:.3% .8%;border-radius:3px;}
.alc-site-tab.active{color:var(--gold);background:rgba(184,146,74,.1);}
body.dark .alc-site-tab{color:rgba(255,255,255,.4);}
.alc-site-actions{display:flex;align-items:center;gap:1%;}
.alc-site-pill{width:8%;height:34%;border-radius:100px;background:rgba(0,0,0,.06);}
.alc-site-bell{width:1.3cqw;height:1.3cqw;border-radius:50%;background:rgba(0,0,0,.06);}
.alc-site-avatar{width:1.6cqw;height:1.6cqw;border-radius:50%;background:linear-gradient(135deg,var(--gold),var(--gold2));border:1px solid white;}
.alc-site-body{position:absolute;top:10%;left:0;right:0;bottom:0;padding:1.5% 2.5%;display:grid;grid-template-columns:repeat(4,1fr);gap:1%;align-content:start;container-type:inline-size;}
.alc-site-card{aspect-ratio:1;border-radius:6px;background:linear-gradient(135deg,#E8DDC8,#D8C8A8);position:relative;overflow:hidden;box-shadow:0 1px 3px rgba(0,0,0,.06);}
.alc-site-card::after{content:'';position:absolute;inset:0;background:radial-gradient(circle at 30% 25%,rgba(255,255,255,.25),transparent 40%);}
.alc-site-card:nth-child(2){background:linear-gradient(135deg,#C8B8A0,#A89880);aspect-ratio:.78;}
.alc-site-card:nth-child(3){background:linear-gradient(135deg,#F0E5D0,#D8C8B0);aspect-ratio:1.15;}
.alc-site-card:nth-child(4){background:linear-gradient(135deg,#B89870,#A88860);aspect-ratio:.92;}
.alc-site-card:nth-child(5){background:linear-gradient(135deg,#D8C8B0,#B89870);aspect-ratio:1.05;}
.alc-site-card:nth-child(6){background:linear-gradient(135deg,#E0D0B5,#B8A080);aspect-ratio:.85;}
.alc-site-card:nth-child(7){background:linear-gradient(135deg,#F0E0CA,#C8B090);aspect-ratio:1.2;}
.alc-site-card:nth-child(8){background:linear-gradient(135deg,#B89870,#806040);aspect-ratio:.95;}
.alc-site-card:nth-child(9){background:linear-gradient(135deg,#E8D8B8,#A89060);aspect-ratio:1;}
.alc-site-card:nth-child(10){background:linear-gradient(135deg,#D0B890,#988060);aspect-ratio:1.1;}
.alc-site-card:nth-child(11){background:linear-gradient(135deg,#E8D8C0,#B0A080);aspect-ratio:.85;}
.alc-site-card:nth-child(12){background:linear-gradient(135deg,#C8A878,#886030);aspect-ratio:1;}
body.dark .alc-site-card{filter:brightness(.6) saturate(.7);}
.alc-list-wrap{background:var(--c);border:1px solid var(--b);border-radius:14px;overflow:hidden;}
.alc-list-hdr{padding:12px 16px;border-bottom:1px solid var(--b);display:flex;align-items:center;justify-content:space-between;}
.alc-list-hdr .ttl{font-size:13px;font-weight:600;color:var(--ink);}
.alc-list-hdr .count{font-size:11px;color:var(--ink3);background:var(--c2);padding:2px 8px;border-radius:100px;}
.alc-list{max-height:340px;overflow-y:auto;}
.alc-user{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--b);cursor:pointer;transition:background .12s;}
.alc-user:last-child{border-bottom:none;}
.alc-user:hover,.alc-user.hl{background:var(--c2);}
.alc-user-av{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:white;font-size:11px;font-weight:600;flex-shrink:0;overflow:hidden;border:2px solid var(--c);box-shadow:0 1px 3px rgba(0,0,0,.15);}
.alc-user-av img{width:100%;height:100%;object-fit:cover;}
.alc-user-main{flex:1;min-width:0;}
.alc-user-name{font-size:13px;color:var(--ink);font-weight:500;}
.alc-user-tab{font-size:11px;color:var(--ink3);margin-top:1px;}
.alc-user-time{font-size:10px;color:var(--ink3);background:var(--c2);padding:3px 8px;border-radius:100px;flex-shrink:0;}
.alc-cursor{position:absolute;z-index:5;transition:left .35s cubic-bezier(.16,1,.3,1),top .35s cubic-bezier(.16,1,.3,1);pointer-events:none;will-change:transform;}
.alc-cursor svg{filter:drop-shadow(0 2px 6px rgba(0,0,0,.45));}
.alc-cursor .lbl{display:inline-flex;align-items:center;gap:5px;font-size:9px;font-weight:600;padding:3px 8px 3px 5px;border-radius:100px;margin-top:3px;color:white;box-shadow:0 2px 8px rgba(0,0,0,.35);white-space:nowrap;}
.alc-cursor .lbl .lbl-av{width:14px;height:14px;border-radius:50%;background:rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:8px;overflow:hidden;}
.alc-cursor .lbl .lbl-av img{width:100%;height:100%;object-fit:cover;}
.alc-empty{padding:40px 20px;text-align:center;color:var(--ink3);font-size:13px;}

/* MOBILE NAV */
#mobnav{display:none;position:fixed;bottom:0;left:0;right:0;z-index:100;background:rgba(248,244,238,.92);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-top:1px solid rgba(255,255,255,.5);box-shadow:0 -4px 20px rgba(0,0,0,.07);padding:.4rem 0;}
body.dark #mobnav{background:rgba(28,24,16,.92);}
.mninner{display:flex;justify-content:space-around;align-items:center;}
.mntab{display:flex;flex-direction:column;align-items:center;gap:2px;padding:5px 10px;border-radius:10px;border:none;background:none;color:var(--ink3);font-size:9px;letter-spacing:1px;text-transform:uppercase;transition:all .2s;min-width:52px;cursor:pointer;}
.mntab.active{color:var(--gold);}
.mntab svg{width:21px;height:21px;stroke:currentColor;fill:none;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;}
.mntab.active svg{stroke:var(--gold);}

/* TOAST */
.toast{position:fixed;bottom:2rem;left:50%;transform:translateX(-50%) translateY(60px);background:var(--ink);color:var(--c);padding:9px 22px;font-size:12px;letter-spacing:1px;border-radius:100px;z-index:500;transition:transform .4s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;pointer-events:none;box-shadow:0 4px 18px rgba(0,0,0,.12);}
.toast.show{transform:translateX(-50%) translateY(0);}

.ss-opt{padding:8px 22px;border-radius:100px;border:1px solid rgba(255,255,255,.25);background:rgba(255,255,255,.1);color:rgba(255,255,255,.8);font-size:12px;letter-spacing:1px;cursor:pointer;transition:all .2s;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);}
.ss-opt.active{background:rgba(255,255,255,.9);color:#1A1410;border-color:transparent;}
.ss-opt:hover:not(.active){background:rgba(255,255,255,.2);color:white;}
@media(max-width:768px){
  nav{height:56px;padding:0 1rem;}
  .ntabs{display:none;}
  #mobnav{display:block;}
  #feed-tab,#class-tab,#albums-tab{padding:1rem 1rem 4.5rem;}
  .cgrid{grid-template-columns:repeat(2,1fr);}
  .albgrid{grid-template-columns:repeat(2,1fr);}
  .sdrawer{width:100%;}
  .lbphoto{padding:1rem 3rem;}
  #app .mc{padding-bottom:56px;}

  /* ── LIGHTBOX MOBILE ── */
  #lb-inner{flex-direction:column;}

  /* Comments panel becomes bottom sheet */
  #lb-comments-panel{
    width:100%;
    border-left:none;
    border-top:1px solid rgba(255,255,255,.1);
    height:0;
    overflow:hidden;
    transition:height .3s cubic-bezier(.4,0,.2,1);
    flex-shrink:0;
  }
  #lb-comments-panel.open{height:52vh;}

  /* Photo area takes remaining space */
  #lb-photo-area{flex:1;min-height:0;}

  /* Always show nav arrows on mobile */
  #lb-ui{opacity:1 !important;}
  .lb-arr{width:38px;height:38px;font-size:18px;}
  #lb-prev{left:8px;}
  #lb-next{right:8px;}

  /* Action bar scrollable on small screens */
  #lb-actions{overflow-x:auto;gap:6px;padding:10px 14px;}
  #lb-actions::-webkit-scrollbar{display:none;}

  /* Comments toggle button on mobile */
  #lb-cmts-toggle-btn{display:flex !important;}
}

/* ════════════════════════════════════════════════════════════════ */
/*  INLINE EDIT MODE v2 — floating toolbar + visual states           */
/* ════════════════════════════════════════════════════════════════ */
#st-edit-toolbar{
  position:fixed;right:22px;bottom:22px;z-index:9999;
  width:240px;
  background:#1A1410;color:#F8F4EE;
  border-radius:14px;
  padding:14px 16px;
  box-shadow:0 12px 38px rgba(0,0,0,.35),0 2px 6px rgba(0,0,0,.18);
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text','DM Sans',sans-serif;
  display:none;
  animation:stTbIn .25s cubic-bezier(.16,1,.3,1);
}
#st-edit-toolbar.show{display:block;}
@keyframes stTbIn{from{opacity:0;transform:translateY(8px) scale(.97);}to{opacity:1;transform:none;}}

.st-tb-hdr{display:flex;align-items:center;gap:8px;margin-bottom:12px;}
.st-tb-dot{width:7px;height:7px;border-radius:50%;background:#B8924A;box-shadow:0 0 8px rgba(184,146,74,.6);animation:lcPulse 1.4s infinite;}
.st-tb-ttl{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:#B8924A;font-weight:600;}

.st-tb-modes{
  display:flex;background:rgba(255,255,255,.06);
  border-radius:10px;padding:3px;margin-bottom:11px;
}
.st-mode-btn{
  flex:1;display:flex;align-items:center;justify-content:center;gap:5px;
  background:transparent;border:none;color:rgba(255,255,255,.6);
  font-size:11.5px;font-weight:600;letter-spacing:.3px;
  padding:7px 0;border-radius:8px;cursor:pointer;font-family:inherit;
  transition:all .15s;
}
.st-mode-btn:hover{color:rgba(255,255,255,.9);}
.st-mode-btn.active{background:#B8924A;color:white;box-shadow:0 1px 4px rgba(184,146,74,.4);}

.st-tb-hint{
  font-size:11.5px;color:rgba(255,255,255,.55);line-height:1.5;
  padding:8px 0 12px;border-bottom:1px solid rgba(255,255,255,.08);
  margin-bottom:11px;
}

.st-tb-actions{display:flex;justify-content:space-between;align-items:center;gap:8px;}
.st-tb-link{
  background:none;border:none;color:rgba(255,255,255,.6);
  font-size:11.5px;font-family:inherit;cursor:pointer;
  padding:6px 0;transition:color .15s;
}
.st-tb-link:hover{color:#D14545;}
.st-tb-done{
  background:#B8924A;color:white;border:none;
  font-size:12px;font-weight:600;
  padding:7px 16px;border-radius:100px;cursor:pointer;
  font-family:inherit;transition:transform .15s,background .15s;
  letter-spacing:.3px;
}
.st-tb-done:hover{background:#A07F3F;transform:translateY(-1px);}

/* Save-pill that pops at the corner after each save */
#st-save-pill{
  position:fixed;top:18px;left:50%;transform:translate(-50%,-40px);
  background:#1A1410;color:#F8F4EE;
  padding:8px 18px;border-radius:100px;
  font-size:12.5px;font-weight:500;letter-spacing:.3px;
  font-family:-apple-system,BlinkMacSystemFont,'SF Pro Text',sans-serif;
  box-shadow:0 4px 18px rgba(0,0,0,.25);
  opacity:0;pointer-events:none;
  transition:opacity .22s,transform .22s;
  z-index:10000;
}
#st-save-pill.show{opacity:1;transform:translate(-50%,0);}
#st-save-pill.ok{background:#3D7A4A;color:white;}
#st-save-pill.err{background:#B03030;color:white;}

/* TEXT MODE — hover state for every editable element */
body.st-edit-mode.st-mode-text [data-st]:not(#st-edit-toolbar [data-st]){
  cursor:text !important;
  outline:1.5px dashed transparent;outline-offset:3px;border-radius:4px;
  transition:outline-color .12s,background .12s;
}
body.st-edit-mode.st-mode-text [data-st]:hover{
  outline-color:#B8924A;
  background:rgba(184,146,74,.10);
}
body.st-edit-mode [data-st][contenteditable="true"]{
  outline:2px solid #B8924A !important;
  background:rgba(184,146,74,.16) !important;
  box-shadow:0 0 0 4px rgba(184,146,74,.18);
  cursor:text !important;
}

/* MOVE MODE — sortable affordances */
body.st-edit-mode.st-mode-move .st-draggable{
  cursor:grab;
  outline:1.5px dashed rgba(184,146,74,.5);outline-offset:3px;
  border-radius:6px;
  transition:transform .12s,box-shadow .12s,outline-color .12s;
  position:relative;
}
body.st-edit-mode.st-mode-move .st-draggable::after{
  content:'⋮⋮';position:absolute;top:50%;right:6px;
  transform:translateY(-50%);
  font-size:11px;color:#B8924A;opacity:.4;
  pointer-events:none;
}
body.st-edit-mode.st-mode-move .st-draggable:hover{
  outline-color:#B8924A;
  background:rgba(184,146,74,.10);
}
body.st-edit-mode.st-mode-move .st-draggable.st-being-dragged{
  opacity:.45;cursor:grabbing;
}
body.st-edit-mode.st-mode-move .st-draggable.st-drag-over{
  outline:2px solid #B8924A;
  background:rgba(184,146,74,.20);
}
body.st-edit-mode.st-mode-move .st-sortable{
  background:rgba(184,146,74,.04);
  border-radius:8px;
}

/* Mobile: dock toolbar to bottom */
@media (max-width:600px){
  #st-edit-toolbar{
    right:12px;left:12px;bottom:12px;
    width:auto;
  }
}
