:root {
  --bg:#f5f7fb; --card:rgba(255,255,255,.90); --text:#111827; --muted:#6b7280;
  --line:rgba(17,24,39,.10); --soft:rgba(255,255,255,.68); --shadow:0 20px 60px rgba(17,24,39,.10);
  --radius:24px; --primary:#111827; --onPrimary:#ffffff;
}
body.dark {
  --bg:#0b0f17; --card:rgba(22,27,38,.90); --text:#f9fafb; --muted:#a5adbb;
  --line:rgba(255,255,255,.13); --soft:rgba(255,255,255,.06); --shadow:0 20px 60px rgba(0,0,0,.40);
  --primary:#f9fafb; --onPrimary:#0b0f17;
}
*{box-sizing:border-box}
body{
  margin:0;font-family:"Segoe UI","Apple SD Gothic Neo","Noto Sans KR",system-ui,sans-serif;color:var(--text);min-height:100vh;
  background:radial-gradient(circle at top left,rgba(255,230,190,.65),transparent 34%),
  radial-gradient(circle at top right,rgba(190,220,255,.7),transparent 30%),var(--bg);
}
body.dark{background:radial-gradient(circle at top left,rgba(84,47,20,.38),transparent 34%),radial-gradient(circle at top right,rgba(24,55,110,.42),transparent 30%),var(--bg)}
button,input,textarea,select{font:inherit}
button{border:0;cursor:pointer;color:inherit}
input,textarea,select{
  width:100%;border:1px solid var(--line);background:var(--soft);color:var(--text);
  border-radius:16px;padding:12px 14px;outline:none;text-align:center
}
textarea{min-height:120px;resize:vertical}
h1,h2,h3,p{margin-top:0}.center{text-align:center}.hidden{display:none!important}

.toast{
  position:fixed;left:50%;top:14px;transform:translate(-50%,-120%);
  z-index:999;background:rgba(30,41,59,.78);color:white;backdrop-filter:blur(18px);
  border:1px solid rgba(255,255,255,.20);border-radius:18px;padding:13px 18px;min-width:min(88vw,360px);
  text-align:center;font-weight:900;box-shadow:0 16px 48px rgba(0,0,0,.22);animation:toastDown 5s ease both
}
body.dark .toast{background:rgba(255,255,255,.13);color:var(--text)}
@keyframes toastDown{0%{transform:translate(-50%,-130%);opacity:0}10%,86%{transform:translate(-50%,0);opacity:1}100%{transform:translate(-50%,-130%);opacity:0}}

.mobile-shell{width:min(100%,480px);margin:0 auto;padding:18px 14px 40px}
.topbar{display:grid;grid-template-columns:48px 1fr 92px;align-items:center;gap:8px;margin-bottom:14px}
.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}
.eyebrow{margin:0 0 4px;font-size:12px;color:var(--muted);letter-spacing:.04em}
.topbar h1{margin:0;font-size:23px;letter-spacing:-.04em}
.theme-switch{width:42px;height:24px;border-radius:99px;background:var(--soft);border:1px solid var(--line);position:relative;padding:2px;box-shadow:0 8px 24px rgba(17,24,39,.08)}
.theme-switch span{width:18px;height:18px;border-radius:50%;background:var(--text);display:block;transition:.2s;position:relative}
.theme-switch span::before{content:"☀";position:absolute;inset:0;display:grid;place-items:center;font-size:10px;color:var(--bg)}
body.dark .theme-switch span{transform:translateX(18px);background:var(--text)}
body.dark .theme-switch span::before{content:"☾";color:var(--bg)}
.admin-icon,.nav-btn{width:42px;height:42px;border-radius:16px;background:var(--card);border:1px solid var(--line);box-shadow:0 8px 24px rgba(17,24,39,.08);display:inline-grid;place-items:center}

.notice-card,.calendar-card,.schedule-card,.modal-box,.admin-panel,.admin-sidebar,.admin-day-editor{
  background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:var(--radius);backdrop-filter:blur(18px)
}
.notice-card,.calendar-card,.schedule-card{padding:16px;margin-bottom:14px}
.label{display:inline-flex;justify-content:center;padding:5px 12px;border-radius:999px;background:var(--primary);color:var(--onPrimary);font-size:12px;margin-bottom:10px;font-weight:900}
.notice-slider{min-height:45px;font-size:15px;line-height:1.45;font-weight:700;white-space:pre-wrap}
.calendar-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.calendar-head strong{font-size:18px}
.weekdays,.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:7px}
.weekdays{margin-bottom:8px;color:var(--muted);font-size:12px;font-weight:800}
.weekdays span:first-child,.holiday-day,.sunday{color:#ef4444}.saturday{color:#3b82f6}
.day{
  aspect-ratio:1;border-radius:16px;background:var(--soft);border:1px solid var(--line);
  display:grid;place-items:center;position:relative;font-weight:850;overflow:hidden
}
.day.today{outline:2px solid color-mix(in srgb,var(--primary) 25%,transparent)}
.day.selected{background:var(--primary);color:var(--onPrimary);box-shadow:0 12px 28px rgba(17,24,39,.25)}
.day::after{content:"";position:absolute;top:0;left:10px;right:10px;height:4px;border-radius:0 0 999px 999px;background:#9ca3af;opacity:.75}
.day.has-schedule::after{background:#22c55e;opacity:1}
.day.blank::after{display:none}
.day.important{animation:pulseImportant 1.4s infinite;border-color:#ef4444}
.day.important::before{content:"!";position:absolute;top:7px;left:7px;color:#ef4444;font-size:11px;font-weight:1000;z-index:2}
.day.blank{background:transparent;border:0;box-shadow:none}
.day small{position:absolute;bottom:2px;left:2px;right:2px;font-size:8px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.day.selected small{color:var(--onPrimary);opacity:.75}
@keyframes pulseImportant{50%{box-shadow:0 0 0 5px rgba(239,68,68,.16)}}
.schedule-card h2{margin:0 0 2px;font-size:20px}.holiday-text{color:#ef4444;font-size:13px;font-weight:800;min-height:18px;margin-bottom:8px}
.status-badge-row{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin:4px auto 12px}
.status-badge{display:inline-flex;padding:6px 10px;border-radius:999px;background:rgba(245,158,11,.14);color:#b45309;font-weight:900;border:1px solid rgba(245,158,11,.28);font-size:12px}
.status-badge.important{background:rgba(239,68,68,.16);color:#ef4444;border-color:rgba(239,68,68,.35);animation:pulseBadge 1.2s infinite}
@keyframes pulseBadge{50%{transform:scale(1.035)}}
.schedule-board{display:grid;grid-template-columns:1fr 1fr;gap:12px;text-align:center;margin-top:8px}
.off-row{grid-column:1/-1;display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:4px}
.schedule-column{display:grid;align-content:start;gap:7px;min-height:20px}
.schedule-name{
  display:grid;grid-template-columns:14px auto auto;align-items:baseline;justify-content:center;column-gap:6px;
  font-weight:900;font-size:16px;min-height:23px
}
.schedule-time-small{font-size:10px;color:var(--muted);font-weight:800}
.schedule-time-break{height:10px}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;justify-self:center;align-self:center}
.empty{color:var(--muted);text-align:center;padding:16px 0;grid-column:1/-1}

.modal{position:fixed;inset:0;display:grid;place-items:center;background:rgba(15,23,42,.28);padding:18px;z-index:100}
.modal-box{width:min(100%,380px);padding:24px;position:relative}.modal-box p{color:var(--muted)}
.modal-x{position:absolute;right:14px;top:12px;width:28px;height:28px;border-radius:50%;background:transparent;color:var(--muted);font-size:22px;line-height:1}
.password-line{display:grid;grid-template-columns:1fr 1px 40px;align-items:center;border:1px solid var(--line);background:var(--soft);border-radius:18px;overflow:hidden}
.password-line input{border:0;background:transparent;border-radius:0}
.password-line .divider{height:22px;background:var(--line)}
.password-line button{height:44px;background:transparent;color:var(--muted);display:grid;place-items:center}
.login-btn{width:100%;margin-top:10px}
.primary-btn,.ghost-btn{border-radius:16px;padding:11px 15px;font-weight:900}
.primary-btn{background:var(--primary);color:var(--onPrimary)}.ghost-btn{background:var(--soft);border:1px solid var(--line);color:var(--text)}
.error-text{color:#ef4444;font-size:13px;min-height:20px;margin-top:8px}.warn-text{color:#f59e0b;font-size:13px;font-weight:800;margin-top:8px}

.admin-body{background:#eef2f7}.admin-shell{display:grid;grid-template-columns:260px 1fr;min-height:100vh;gap:18px;padding:18px}
.admin-sidebar{padding:20px;height:calc(100vh - 36px);position:sticky;top:18px;display:flex;flex-direction:column;gap:10px}
.admin-sidebar p{color:var(--muted);margin-bottom:16px}
.tab{padding:13px 14px;border-radius:16px;background:transparent;font-weight:900;color:var(--text);text-align:center}
.tab.active{background:var(--primary);color:var(--onPrimary)}.full{width:100%;margin-top:auto}
.admin-panel{display:none;padding:24px;min-height:calc(100vh - 36px)}.admin-panel.active{display:block}
.panel-head h2{margin-bottom:4px;font-size:28px;letter-spacing:-.04em}.panel-head p{color:var(--muted)}
.narrow{max-width:760px;margin:0 auto 18px}.form-grid{display:grid;gap:10px}
.admin-list{display:grid;gap:10px;max-width:920px;margin:0 auto}
.admin-row{display:flex;justify-content:center;align-items:center;gap:12px;padding:14px;border-radius:18px;border:1px solid var(--line);background:var(--soft)}
.admin-row-content{flex:1;text-align:center}.admin-row strong{display:block;margin-bottom:3px}.admin-row small{color:var(--muted);white-space:pre-wrap}
.danger{background:#fee2e2;color:#991b1b;border-radius:14px;padding:9px 12px;font-weight:900}
.admin-calendar-wrap{display:grid;grid-template-columns:minmax(420px,620px) 1fr;gap:18px;align-items:start}.admin-day-editor{padding:18px}
.inline-form{display:grid;grid-template-columns:1fr 110px;gap:10px;margin:0 auto 18px;max-width:520px}
.status-buttons{display:flex;justify-content:center;gap:6px;flex-wrap:wrap;margin:10px 0}
.status-btn{border-radius:999px;padding:7px 10px;background:var(--soft);border:1px solid var(--line);font-weight:900;font-size:12px}
.status-btn.active{background:var(--primary);color:var(--onPrimary)}.important-btn.active{background:#ef4444;color:#fff}
.mini-tools{display:flex;justify-content:center;gap:6px;margin:8px 0 12px}
.mini-btn{border-radius:999px;padding:6px 10px;background:var(--soft);border:1px solid var(--line);font-weight:900;font-size:11px;color:var(--muted)}
.worker-check-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;margin-top:16px}
.worker-check-card{border:1px solid var(--line);background:var(--soft);border-radius:18px;padding:12px;display:grid;gap:8px}
.pretty-check{display:flex;justify-content:center;align-items:center;gap:8px;font-weight:900}
.pretty-check input{position:absolute;opacity:0;pointer-events:none}
.check-box{width:22px;height:22px;border-radius:8px;border:2px solid var(--line);display:inline-grid;place-items:center;transition:.15s;background:var(--card)}
.pretty-check input:checked + .check-box{background:var(--primary);border-color:var(--primary)}
.pretty-check input:checked + .check-box::after{content:"✓";color:var(--onPrimary);font-weight:1000;font-size:14px}
.time-select-wrap{position:relative}
.time-select{
  appearance:none;-webkit-appearance:none;border-radius:15px;padding:10px 34px 10px 12px;font-weight:900;font-size:13px;background:var(--card)
}
.time-select-wrap::after{content:"⌄";position:absolute;right:12px;top:50%;transform:translateY(-56%);color:var(--muted);font-weight:1000;pointer-events:none}
.worker-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;max-width:920px;margin:0 auto}
.worker-row{display:grid;grid-template-columns:42px 1fr 58px;align-items:center;gap:8px;padding:10px;border-radius:18px;border:1px solid var(--line);background:var(--soft)}
.drag-handle{height:38px;border-radius:14px;background:rgba(0,0,0,.06);display:grid;place-items:center;cursor:grab;touch-action:none;font-weight:1000;color:var(--muted)}
body.dark .drag-handle{background:rgba(255,255,255,.08)}
.worker-name{font-weight:900;text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.worker-row.dragging{opacity:.45;transform:scale(.98)}
.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(220px,1fr));gap:12px}.settings-grid label{display:grid;gap:7px;color:var(--muted);font-weight:800}.settings-grid .wide{grid-column:1/-1}
.color-settings{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px;max-width:900px;margin:12px auto 20px}
.color-card{border:1px solid var(--line);background:var(--soft);border-radius:18px;padding:12px;display:grid;gap:8px;font-weight:900}.color-card input{padding:4px;height:44px}
@media(max-width:840px){.admin-shell{grid-template-columns:1fr}.admin-sidebar{height:auto;position:static}.admin-calendar-wrap{grid-template-columns:1fr}}
@media(max-width:520px){.topbar{grid-template-columns:30px 1fr 92px}.worker-check-list{grid-template-columns:1fr}.worker-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.worker-row{grid-template-columns:34px 1fr 48px;padding:8px}.danger{padding:8px 9px;font-size:12px}}

.login-stack{display:grid;gap:10px}
.header-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}
.sub-full{margin-top:auto}.admin-sidebar .sub-full + .full{margin-top:0}
.check-line{display:flex!important;align-items:center;justify-content:center;gap:8px}.check-line input{width:auto}
.account-list{margin-top:18px}
.floating-menu{position:fixed;z-index:1000;background:var(--card);border:1px solid var(--line);box-shadow:var(--shadow);border-radius:18px;padding:8px;display:grid;grid-template-columns:repeat(3,1fr);gap:6px;min-width:230px}
.floating-menu button{border-radius:14px;background:var(--soft);border:1px solid var(--line);padding:9px;font-weight:900;font-size:12px}
.floating-menu button:hover{background:var(--primary);color:var(--onPrimary)}
.worker-check-card{position:relative}
.worker-check-card.has-end::after{content:"퇴근";position:absolute;right:10px;top:8px;font-size:10px;color:var(--muted);font-weight:900}
.schedule-name{grid-template-columns:14px auto auto!important}
.schedule-end-small{font-size:10px;color:var(--muted);font-weight:900}
.schedule-arrow{font-size:10px;color:var(--muted);font-weight:900;margin:0 -2px}
.admin-sidebar .account-only.locked{opacity:.55}

.end-time-label{font-size:11px;color:var(--muted);font-weight:900}
.mini-check{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:900;color:var(--muted)}
.mini-check input{width:auto}

/* v4.1 fixes */
.schedule-name{
  grid-template-columns:14px auto auto auto auto!important;
  white-space:nowrap;
}
.schedule-time-small,.schedule-arrow,.schedule-end-small{
  align-self:center;
  line-height:1;
}
.schedule-end-small{
  font-size:10px;
  color:var(--muted);
  font-weight:900;
}
.toast strong{
  font-size:18px;
  letter-spacing:-0.03em;
}
.account-add-area{
  max-width:760px;
  margin:0 auto 18px;
}
.account-add-toggle{
  margin-bottom:12px;
}
.account-create-box{
  display:grid;
  gap:10px;
  padding:16px;
  border-radius:22px;
  border:1px solid var(--line);
  background:var(--soft);
  margin-bottom:18px;
}
.account-permission-row{
  display:flex!important;
  justify-content:center;
  align-items:center;
  gap:8px;
  font-weight:900;
  color:var(--muted);
}
.account-permission-row input{
  width:auto;
}

.account-row{
  display:grid;
  grid-template-columns:42px 54px 1fr;
  align-items:center;
  gap:10px;
  cursor:pointer;
}
.account-rank{
  width:38px;height:38px;border-radius:14px;background:var(--primary);color:var(--onPrimary);
  display:grid;place-items:center;font-weight:1000;
}
.account-meta strong{display:block;font-size:17px}
.account-meta small{color:var(--muted);font-weight:800}
.account-row.locked-row{opacity:.68}
.detail-danger{width:100%;margin-top:8px}

/* v4.3 account move button update */
.account-row{
  grid-template-columns:58px 1fr!important;
  cursor:pointer;
  transition:transform .18s ease, box-shadow .18s ease, background .18s ease;
}
.account-rank{
  display:none!important;
}
.account-move-buttons{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:4px;
}
.move-btn{
  width:25px;
  height:30px;
  border-radius:11px;
  background:var(--soft);
  border:1px solid var(--line);
  color:var(--muted);
  font-weight:1000;
  line-height:1;
  transition:transform .12s ease, background .12s ease;
}
.move-btn:active{
  transform:scale(.92);
}
.move-btn:disabled{
  opacity:.28;
  cursor:not-allowed;
}
.account-row.moving{
  transform:scale(1.025);
  box-shadow:0 18px 45px rgba(34,197,94,.22);
  background:rgba(34,197,94,.12);
}
.account-row.move-target{
  box-shadow:0 0 0 2px rgba(59,130,246,.18) inset;
}
.account-meta{
  text-align:center;
}

.permission-check-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:8px;
  margin:4px 0 10px;
}
.permission-check-grid label{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  padding:10px;
  border-radius:15px;
  border:1px solid var(--line);
  background:var(--card);
  font-size:12px;
  font-weight:900;
  color:var(--text);
}
.permission-check-grid input{
  width:auto;
}
.detail-perms{
  margin-top:12px;
}
.account-perm-mini{
  margin-top:4px;
  color:var(--muted);
  font-size:12px;
  font-weight:800;
}
@media(max-width:520px){
  .permission-check-grid{grid-template-columns:1fr}
}

/* v5 PWA / approval / push */
.app-tools{
  display:flex;
  justify-content:center;
  gap:8px;
  margin:-2px 0 14px;
}
.access-gate{
  position:fixed;
  inset:0;
  z-index:2000;
  display:grid;
  place-items:center;
  padding:18px;
  background:var(--bg);
}
.access-box{
  width:min(100%,390px);
  padding:24px;
  border-radius:28px;
  border:1px solid var(--line);
  background:var(--card);
  box-shadow:var(--shadow);
  text-align:center;
}
.access-box h2{margin-bottom:6px}
.access-box p{color:var(--muted);line-height:1.5}
.access-box input{margin:12px 0}
.access-state-icon{
  width:58px;height:58px;border-radius:20px;margin:0 auto 14px;
  display:grid;place-items:center;background:var(--primary);color:var(--onPrimary);
  font-size:28px;font-weight:1000;
}
.access-actions{display:grid;gap:8px;margin-top:12px}
.approval-tabs{
  display:flex;justify-content:center;gap:8px;flex-wrap:wrap;margin-bottom:18px;
}
.approval-tabs .active{background:var(--primary);color:var(--onPrimary)}
.approval-card{
  display:grid;grid-template-columns:1fr auto;gap:12px;align-items:center;
}
.approval-actions{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}
.approval-meta strong{font-size:18px}.approval-meta small{display:block;color:var(--muted);margin-top:4px}
.block-btn{background:#fee2e2;color:#991b1b}
.unblock-btn{background:#dcfce7;color:#166534}
.deny-btn{background:#fef3c7;color:#92400e}
.push-date-list{
  display:flex;flex-wrap:wrap;gap:6px;justify-content:center;margin:10px 0;
}
.push-date-chip{
  border:1px solid var(--line);background:var(--soft);border-radius:999px;padding:7px 10px;font-size:12px;font-weight:900;
}
.day.notified::after{background:#ef4444!important;opacity:1}
.tab.locked{opacity:.45}
.permission-check-grid label{min-height:42px}
@media(max-width:620px){
  .approval-card{grid-template-columns:1fr}
}

/* v5.1 UI polish */
.header-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
}
.circle-icon{
  width:42px;
  height:42px;
  border-radius:16px;
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:0 8px 24px rgba(17,24,39,.08);
  display:inline-grid;
  place-items:center;
  position:relative;
  font-weight:1000;
  color:var(--text);
}
.circle-icon.has-dot::after{
  content:"";
  width:9px;
  height:9px;
  border-radius:999px;
  background:#ef4444;
  position:absolute;
  right:7px;
  top:7px;
  box-shadow:0 0 0 2px var(--card);
}
.topbar{
  grid-template-columns:20px 1fr 226px!important;
}
.notification-list{
  display:grid;
  gap:8px;
  margin-top:12px;
  max-height:360px;
  overflow:auto;
}
.notification-item{
  border:1px solid var(--line);
  background:var(--soft);
  border-radius:18px;
  padding:12px;
  text-align:center;
}
.notification-item strong{display:block;margin-bottom:4px}
.notification-item small{color:var(--muted)}
.site-footer{
  text-align:center;
  color:var(--muted);
  font-size:11px;
  line-height:1.55;
  margin:24px 0 8px;
}
.admin-footer{
  margin:0 18px 18px 278px;
}
.access-logo{
  width:72px;
  height:72px;
  border-radius:24px;
  margin:0 auto 14px;
  display:block;
  box-shadow:0 14px 34px rgba(17,24,39,.18);
}
.access-state-icon.reset-icon{
  background:var(--soft);
  color:var(--text);
}
.admin-topbar{
  top:0!important;
  height:100vh!important;
  border-radius:0 24px 24px 0!important;
}
.admin-body .admin-shell{
  padding-top:0!important;
}
.employee-admin-btn{
  background:#dbeafe;
  color:#1d4ed8;
}
@media(max-width:520px){
  .topbar{grid-template-columns:8px 1fr 186px!important}
  .circle-icon,.admin-icon{width:36px;height:36px;border-radius:14px;font-size:12px}
  .theme-switch{width:38px}
}
@media(max-width:840px){
  .admin-footer{margin:18px}
  .admin-topbar{height:auto!important;border-radius:24px!important}
}

/* v5.2 header cleanup */
.topbar{
  grid-template-columns:20px 1fr 188px!important;
}
.header-actions{
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap:6px;
}
.push-switch span::before{
  content:"🔕";
  color:var(--bg);
  font-size:9px;
}
.push-switch.enabled span::before{
  content:"🔔";
}
.push-switch.enabled span{
  transform:translateX(18px);
}
.notification-icon{
  position:relative;
}
.notification-icon.has-dot::after{
  content:"";
  width:9px;
  height:9px;
  border-radius:999px;
  background:#ef4444;
  position:absolute;
  right:7px;
  top:7px;
  box-shadow:0 0 0 2px var(--card);
}
.bell-symbol{
  font-size:15px;
  line-height:1;
}
.download-card{
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  border-radius:var(--radius);
  backdrop-filter:blur(18px);
  padding:14px 16px;
  margin-bottom:14px;
}
.download-card p{
  color:var(--muted);
  font-size:13px;
  margin:0 0 10px;
  line-height:1.45;
}
.download-card .primary-btn{
  width:100%;
  max-width:220px;
}
.circle-icon{
  display:none!important;
}
@media(max-width:520px){
  .topbar{grid-template-columns:8px 1fr 166px!important}
  .theme-switch{width:38px;height:24px}
  .admin-icon{width:36px;height:36px;border-radius:14px}
}

/* v5.3 header / push fix */
.topbar{
  grid-template-columns:20px 1fr 184px!important;
}
.header-actions{
  display:flex!important;
  align-items:center!important;
  justify-content:flex-end!important;
  gap:6px!important;
}
.stack-actions{
  display:grid;
  grid-template-rows:1fr 1fr;
  gap:4px;
  width:42px;
}
.mini-toggle{
  width:42px;
  height:19px;
  border-radius:999px;
  border:1px solid var(--line);
  background:var(--card);
  color:var(--text);
  display:grid;
  place-items:center;
  font-size:11px;
  box-shadow:0 8px 24px rgba(17,24,39,.06);
}
.push-toggle.enabled{
  background:rgba(34,197,94,.18);
  border-color:rgba(34,197,94,.45);
}
.theme-toggle-btn.dark-on{
  background:rgba(99,102,241,.18);
  border-color:rgba(99,102,241,.45);
}
.theme-switch{
  display:none!important;
}
.push-switch{
  display:none!important;
}
.circle-icon{
  display:none!important;
}
.install-icon{
  font-size:16px;
}
.notification-icon{
  position:relative;
}
.notification-icon.has-dot::after{
  content:"";
  width:9px;
  height:9px;
  border-radius:999px;
  background:#ef4444;
  position:absolute;
  right:7px;
  top:7px;
  box-shadow:0 0 0 2px var(--card);
}
.bell-symbol{
  font-size:15px;
  line-height:1;
}
.download-card{
  display:none!important;
}
@media(max-width:520px){
  .topbar{grid-template-columns:8px 1fr 166px!important}
  .stack-actions{width:36px}
  .mini-toggle{width:36px;height:18px;font-size:10px}
  .admin-icon{width:36px;height:36px;border-radius:14px}
}

/* v5.4 admin top header + worker approval merge */
.admin-shell{
  display:block!important;
  padding:0!important;
}
.admin-header{
  position:sticky;
  top:0;
  z-index:50;
  min-height:auto!important;
  height:auto!important;
  border-radius:0 0 24px 24px!important;
  padding:12px 16px!important;
  display:flex!important;
  align-items:center!important;
  justify-content:center!important;
  gap:8px!important;
  flex-wrap:wrap!important;
  background:var(--card);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
}
.admin-header h1{
  width:100%;
  margin:0;
  font-size:22px;
}
.admin-header p{
  width:100%;
  margin:0 0 4px;
  color:var(--muted);
  font-size:12px;
}
.admin-header .tab,
.admin-header .ghost-btn{
  width:auto!important;
  margin:0!important;
  padding:10px 12px!important;
  font-size:13px;
}
.admin-main{
  padding:18px;
}
.admin-panel{
  min-height:auto!important;
}
.admin-footer{
  margin:0 18px 18px!important;
}
.inner-tabs{
  display:flex;
  justify-content:center;
  gap:8px;
  flex-wrap:wrap;
  margin:0 0 16px;
}
.pending-tab{
  position:relative;
}
.pending-tab.has-dot::after,
.tab.has-dot::after{
  content:"";
  width:8px;
  height:8px;
  border-radius:999px;
  background:#ef4444;
  position:absolute;
  right:5px;
  top:5px;
}
