:root {
  --bg: #F4F7FB; 
  --card: #FFFFFF; 
  --border: #E2E8F0;
  --text: #1E293B; 
  --muted: #64748B;
  --accent: #0145F2; 
  --accent-dim: rgba(1,69,242,.08); 
  --accent-hover: #0038CC;
  --red: #xE11D48; 
  --red-dim: rgba(225,29,72,.1);
  --green: #10B981;
}

*{margin:0;padding:0;box-sizing:border-box}

body {
  background:var(--bg);
  min-height:100vh;
  color:var(--text);
  font-family:'Outfit',sans-serif;
  overflow-x:hidden;
  scrollbar-width:none;
  -ms-overflow-style:none;
}
html{
  scrollbar-width:none;
  -ms-overflow-style:none;
}
html::-webkit-scrollbar,
body::-webkit-scrollbar{
  width:0;
  height:0;
}
body[data-theme="dark"]{
  --bg:#08111f;
  --card:#111a2d;
  --border:#26344d;
  --text:#edf2ff;
  --muted:#9aa9c2;
  --accent:#6c8dff;
  --accent-dim:rgba(108,141,255,.14);
  --accent-hover:#4f71ff;
  --red:#ff6b7a;
  --red-dim:rgba(255,107,122,.14);
  --green:#2dd4a3;
  color-scheme:dark;
}
body[data-theme="dark"]{
  background:linear-gradient(180deg, #08111f 0%, #0d1728 100%);
}
body[data-theme="dark"] .admin-login-page,
body[data-theme="dark"] .admin-body{
  background:transparent;
}
body[data-theme="dark"] .admin-header,
body[data-theme="dark"] .admin-login-card,
body[data-theme="dark"] .admin-toolbar,
body[data-theme="dark"] .admin-settings-card,
body[data-theme="dark"] .admin-rating-panel,
body[data-theme="dark"] .admin-card,
body[data-theme="dark"] .admin-section-tabs,
body[data-theme="dark"] .admin-staff-count,
body[data-theme="dark"] .admin-section-block{
  background:rgba(17,26,45,.92);
  border-color:var(--border);
  box-shadow:0 18px 42px rgba(0,0,0,.26);
}
body[data-theme="dark"] .admin-input,
body[data-theme="dark"] .admin-card-select,
body[data-theme="dark"] .admin-toolbar-select{
  background:#0f1829;
  border-color:var(--border);
  color:var(--text);
}
body[data-theme="dark"] .admin-section-tab,
body[data-theme="dark"] .admin-back{
  background:#0f1829;
  border-color:var(--border);
  color:var(--text);
}
body[data-theme="dark"] .admin-section-tab.active,
body[data-theme="dark"] .admin-save-btn{
  color:#fff;
}
body[data-theme="dark"] .admin-section-title,
body[data-theme="dark"] .admin-logo-text,
body[data-theme="dark"] .admin-logo-sub,
body[data-theme="dark"] .admin-login-error,
body[data-theme="dark"] .admin-staff-count{
  color:var(--text);
}
body[data-theme="dark"] .admin-section-block{background:transparent}
body[data-theme="dark"] .theme-toggle-btn{
  background:rgba(255,255,255,.08);
  color:var(--text);
  border:1px solid var(--border);
  box-shadow:0 8px 24px rgba(0,0,0,.22);
}

#page-admin{background:var(--bg);min-height:100vh}
.admin-hidden{display:none}
.admin-auth-pending #page-admin,
.admin-auth-pending #admin-login-page{display:none !important}
.admin-login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: 
    radial-gradient(circle at 0% 0%, rgba(1, 69, 242, 0.1) 0%, transparent 40%),
    radial-gradient(circle at 100% 100%, rgba(1, 69, 242, 0.08) 0%, transparent 40%),
    var(--bg);
  position: relative;
}
.admin-login-page::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0; bottom: 0;
  background-image: 
    radial-gradient(var(--border) 0.5px, transparent 0.5px);
  background-size: 24px 24px;
  opacity: 0.3;
  pointer-events: none;
}
.admin-login-card {
  width: min(100%, 440px);
  background: rgba(255, 255, 255, 0.85);
  backdrop-filter: blur(20px) saturate(180%);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  border: 1px solid rgba(255, 255, 255, 0.4);
  border-radius: 36px;
  padding: 40px;
  box-shadow: 
    0 4px 12px rgba(0, 0, 0, 0.02),
    0 24px 64px rgba(15, 23, 42, 0.12);
  display: flex;
  flex-direction: column;
  gap: 28px;
  position: relative;
  z-index: 1;
}
.admin-login-brand {
  justify-content: center;
  padding-bottom: 4px;
}
.admin-login-error {
  min-height: 20px;
  font-size: 13px;
  font-weight: 600;
  color: #E11D48;
  padding-top: 4px;
  text-align: center;
}
.admin-login-error.success {
  color: #10B981;
}
.admin-login-back {
  text-align: center;
  justify-content: center;
  margin-top: 8px;
  background: transparent;
  border-color: transparent;
  color: var(--muted);
  font-weight: 700;
}
.admin-login-back:hover {
  background: var(--accent-dim);
  color: var(--accent);
  transform: translateY(-1px);
}

.admin-header{background:var(--card);border-bottom:1px solid var(--border);padding:16px 32px;display:flex;align-items:center;justify-content:space-between;box-shadow:0 2px 10px rgba(0,0,0,.02)}
.admin-logo{display:flex;align-items:center;gap:12px}
.admin-logo-icon{width:40px;height:40px;background:var(--accent);border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:20px;box-shadow:0 4px 12px rgba(1,69,242,.25)}
.admin-logo-icon img{width:100%;height:100%;object-fit:cover;border-radius:10px;display:block}
.admin-logo-text{font-weight:700;font-size:18px;letter-spacing:.5px;color:var(--text)}
.admin-logo-sub{font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:1px}
.admin-header-actions{display:flex;align-items:center;gap:10px}
.admin-back{padding:8px 18px;background:var(--bg);border:1px solid var(--border);border-radius:20px;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.admin-back:hover{background:var(--border);transform:translateY(-1px)}
.admin-logout-btn{font-family:'Outfit',sans-serif}

.admin-body{padding:32px 28px 44px;max-width:1280px;margin:0 auto}
.admin-section-tabs{
  display:flex;
  align-items:center;
  padding:12px;
  margin-bottom:18px;
  background:rgba(255,255,255,.82);
  border:1px solid var(--border);
  border-radius:22px;
  box-shadow:0 10px 30px rgba(15,23,42,.04);
  position:sticky;
  top:12px;
  z-index:40;
  backdrop-filter:blur(10px);
}
.admin-section-tabs-rail{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  min-width:0;
  width:100%;
}
.admin-section-tab{
  border:1px solid var(--border);
  background:#F8FAFC;
  color:var(--text);
  border-radius:16px;
  min-height:44px;
  padding:12px 16px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-family:'Outfit',sans-serif;
  font-size:13px;
  font-weight:600;
  cursor:pointer;
  transition:all .2s;
}
.admin-section-tab:hover{border-color:var(--accent);color:var(--accent);transform:translateY(-1px)}
.admin-section-tab.active{
  background:linear-gradient(135deg, var(--accent) 0%, #0038CC 100%);
  color:#fff;
  border-color:transparent;
  box-shadow:0 8px 22px rgba(1,69,242,.22);
  font-weight:600;
}
.admin-section-block{
  display:none;
  background:transparent;
}
.admin-section-block.is-active{
  display:block;
}
.admin-section-block > .admin-section-title:first-child{
  margin-top:0;
}
.admin-section-block > .admin-toolbar,
.admin-section-block > .admin-rating-panel,
.admin-section-block > .admin-settings-card,
.admin-section-block > .admin-grid,
.admin-section-block > .admin-staff-search,
.admin-section-block > .admin-staff-filters,
.admin-section-block > .admin-staff-count{
  margin-bottom:18px;
}
.admin-toolbar{display:flex;align-items:end;justify-content:space-between;gap:18px;background:var(--card);border:1px solid var(--border);border-radius:24px;padding:22px 24px;margin-bottom:32px;box-shadow:0 10px 30px rgba(15,23,42,.04)}
.admin-toolbar-search{flex:1;display:flex;flex-direction:column;gap:10px}
.admin-toolbar-search label,.admin-toolbar-filters label{display:block;font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.5px;min-height:16px}
.admin-toolbar-filters{display:grid;grid-template-columns:repeat(2,minmax(170px,1fr));gap:14px;min-width:min(100%,380px)}
.admin-toolbar .setting-field{gap:6px}
.admin-search-input{height:48px;min-height:48px;text-align:left;padding:12px 16px}
.admin-toolbar-select{width:100%;height:48px;min-height:48px;background:#F8FAFC;border:1.5px solid var(--border);border-radius:12px;padding:12px 14px;color:var(--text);font-family:'Outfit',sans-serif;font-size:14px;font-weight:600;line-height:1.2;outline:none;transition:all .2s;appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--accent) 50%),linear-gradient(135deg, var(--accent) 50%, transparent 50%);background-position:calc(100% - 18px) calc(50% - 3px),calc(100% - 12px) calc(50% - 3px);background-size:6px 6px,6px 6px;background-repeat:no-repeat}
.admin-toolbar-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim);background-color:#fff}
@media(max-width:860px){.admin-toolbar{flex-direction:column;align-items:stretch}.admin-toolbar-filters{grid-template-columns:1fr 1fr;min-width:0}}
@media(max-width:580px){.admin-toolbar-filters{grid-template-columns:1fr}}

.admin-staff-filters{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:16px;margin:0 0 24px}
@media(max-width:700px){.admin-staff-filters{grid-template-columns:1fr}}
.admin-staff-search{margin:0 0 18px}
.admin-staff-count{display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--card);border:1px solid var(--border);border-radius:16px;padding:14px 18px;margin:0 0 18px;color:var(--muted);font-size:13px;font-weight:700;box-shadow:0 4px 16px rgba(15,23,42,.03)}
.admin-section-actions{display:flex;justify-content:flex-end;margin:18px 0 36px}
.admin-section-save-btn{
  margin-left:auto;
  background:#16A34A;
  color:#fff;
  border-color:#16A34A;
}
.admin-section-save-btn:hover{
  border-color:#15803D;
  color:#fff;
  background:#15803D;
  box-shadow:none;
  transform:translateY(-1px);
}
.theme-toggle-btn{
  position:fixed;
  right:16px;
  top:16px;
  z-index:200;
  border:1px solid var(--border);
  background:rgba(255,255,255,.88);
  color:var(--text);
  border-radius:999px;
  padding:10px 14px;
  font-family:'Outfit',sans-serif;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  box-shadow:0 8px 24px rgba(15,23,42,.08);
  backdrop-filter:blur(10px);
}

body .theme-toggle-btn{
  display:none !important;
}

.admin-section-title{font-weight:700;font-size:20px;color:var(--text);margin-bottom:24px;display:flex;align-items:center;gap:12px}
.admin-section-title::after{content:'';flex:1;height:2px;background:var(--border);border-radius:2px}

.admin-rating-panel{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:24px;margin-bottom:40px;box-shadow:0 10px 30px rgba(15,23,42,.04);display:flex;flex-direction:column;gap:20px}
.admin-rating-summary{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
.admin-rating-stat{background:#F8FAFC;border:1px solid var(--border);border-radius:18px;padding:18px 20px;display:flex;flex-direction:column;gap:8px}
.admin-rating-stat-label{font-size:12px;color:var(--muted);font-weight:700;text-transform:uppercase;letter-spacing:.6px}
.admin-rating-stat-value{font-size:28px;line-height:1;font-weight:800;color:var(--text)}
.admin-rating-stat-note{font-size:13px;color:var(--muted);font-weight:600}
.admin-rating-list{display:flex;flex-direction:column;gap:12px}
.admin-rating-row{display:grid;grid-template-columns:72px minmax(0,1fr) auto;align-items:center;gap:16px;background:#F8FAFC;border:1px solid var(--border);border-radius:20px;padding:16px 18px;transition:all .2s}
.admin-rating-row:hover{border-color:#BFD2FF;box-shadow:0 8px 20px rgba(1,69,242,.08);transform:translateY(-1px)}
.admin-rating-place{display:flex;align-items:center;justify-content:center;width:54px;height:54px;border-radius:16px;background:linear-gradient(135deg, rgba(1,69,242,.12) 0%, rgba(1,69,242,.04) 100%);color:var(--accent);font-size:22px;font-weight:800}
.admin-rating-place.top-1{background:linear-gradient(135deg, rgba(245,158,11,.22) 0%, rgba(245,158,11,.08) 100%);color:#D97706}
.admin-rating-place.top-2{background:linear-gradient(135deg, rgba(148,163,184,.24) 0%, rgba(148,163,184,.08) 100%);color:#475569}
.admin-rating-place.top-3{background:linear-gradient(135deg, rgba(251,146,60,.24) 0%, rgba(251,146,60,.08) 100%);color:#C2410C}
.admin-rating-person{display:flex;align-items:center;gap:14px;min-width:0}
.admin-rating-avatar{width:58px;height:58px;border-radius:18px;overflow:hidden;border:2px solid rgba(1,69,242,.14);background:radial-gradient(circle at center, rgba(255,255,255,.96) 0%, rgba(239,244,255,.96) 100%);display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:800;color:var(--accent);flex-shrink:0}
.admin-rating-avatar img{width:100%;height:100%;object-fit:cover;display:block}
.admin-rating-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.admin-rating-name{font-size:18px;font-weight:800;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-rating-desc{font-size:13px;color:var(--muted);font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.admin-rating-score{display:flex;flex-direction:column;align-items:flex-end;gap:6px}
.admin-rating-score-main{font-size:24px;font-weight:800;color:#F59E0B;line-height:1}
.admin-rating-score-note{font-size:13px;color:var(--muted);font-weight:700}
.admin-rating-empty{background:rgba(1,69,242,.04);border:1px dashed rgba(1,69,242,.18);border-radius:18px;padding:22px;color:var(--muted);text-align:center;font-size:14px;font-weight:600}
@media(max-width:860px){
  .admin-rating-summary{grid-template-columns:1fr}
  .admin-rating-row{grid-template-columns:60px 1fr;align-items:start}
  .admin-rating-score{grid-column:2;align-items:flex-start;padding-left:72px}
}
@media(max-width:560px){
  .admin-rating-row{padding:14px}
  .admin-rating-person{gap:10px}
  .admin-rating-avatar{width:48px;height:48px;border-radius:14px}
  .admin-rating-name{font-size:16px}
  .admin-rating-score{padding-left:58px}
}

/* Site Settings Section */
.admin-settings-card{background:var(--card);border:1px solid var(--border);border-radius:24px;padding:30px 32px;display:grid;grid-template-columns:minmax(180px,260px) minmax(320px,1fr);gap:36px;align-items:center;margin-bottom:48px;box-shadow:0 10px 32px rgba(15,23,42,.05)}
@media(max-width:760px){.admin-settings-card{grid-template-columns:1fr;gap:24px;padding:24px}}
.setting-field{display:flex;flex-direction:column;justify-content:center}
.setting-field label {
  display: block;
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  opacity: 0.8;
}
.logo-preview-wrap{width:86px;height:86px;background:var(--accent-dim);border:2px dashed #94A3B8;border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:32px;cursor:pointer;overflow:hidden;transition:all .2s;}
.logo-preview-wrap:hover{border-color:var(--accent);background:rgba(1,69,242,.15)}
.admin-settings-card .admin-input{min-height:56px;font-size:18px;font-weight:700;border-radius:14px;padding:14px 18px;box-shadow:0 2px 12px rgba(15,23,42,.03)}

/* Admin Grid for Cats, Branches, Staff */
.admin-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));gap:20px;margin-bottom:48px}
.admin-card{background:linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(248,250,252,.96) 100%);border:1px solid var(--border);border-radius:24px;padding:24px 22px 22px;position:relative;z-index:0;transition:all .2s;display:flex;flex-direction:column;gap:16px;box-shadow:0 10px 28px rgba(15,23,42,.04);overflow:visible}
.admin-card.custom-select-open{z-index:50}
.admin-card:hover{border-color:rgba(1,69,242,.22);box-shadow:0 14px 34px rgba(1,69,242,.10);transform:translateY(-2px)}

.staff-card-head{display:grid;grid-template-columns:auto minmax(0,1fr);gap:18px;align-items:center;padding-bottom:6px;margin-bottom:4px;min-height:84px}
.staff-card-summary{min-width:0;display:flex;flex-direction:column;justify-content:center;gap:6px;min-height:84px}
.staff-card-name{font-size:21px;line-height:1.12;font-weight:800;color:var(--text);letter-spacing:-.024em;overflow:hidden;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:46px}
.staff-card-role{font-size:14px;font-weight:700;color:var(--accent);line-height:1.3;overflow:hidden;overflow-wrap:anywhere;word-break:break-word;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;min-height:19px}
.staff-card-branch{font-size:13px;color:var(--muted);font-weight:600;line-height:1.35;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-height:17px}
.admin-group-card{gap:14px}
.admin-group-card-top{display:flex;align-items:center;gap:12px}
.admin-group-badge{min-width:74px;height:40px;border-radius:14px;background:linear-gradient(135deg, rgba(1,69,242,.14) 0%, rgba(1,69,242,.06) 100%);color:var(--accent);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}
.admin-group-meta{display:flex;flex-direction:column;gap:4px;min-width:0}
.admin-group-caption{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.08em}
.admin-group-count{font-size:14px;font-weight:700;color:var(--text)}
.admin-group-code-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:14px;background:#F8FAFC;border:1px solid var(--border)}
.admin-group-code-label{font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.admin-group-code-value{font-size:14px;font-weight:800;color:var(--text);letter-spacing:.08em}
.admin-group-members{display:flex;flex-direction:column;gap:10px}
.admin-group-members-title{font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.admin-group-search-input{min-height:44px;padding:10px 14px;text-align:left;font-size:14px}
.admin-group-member-list{display:flex;flex-wrap:wrap;gap:8px}
.admin-group-member{display:inline-flex;align-items:center;gap:8px;padding:10px 12px;border-radius:14px;border:1px solid var(--border);background:#F8FAFC;cursor:pointer;transition:all .2s ease}
.admin-group-member:hover{border-color:rgba(1,69,242,.24);transform:translateY(-1px)}
.admin-group-member.selected{background:rgba(1,69,242,.08);border-color:rgba(1,69,242,.3);box-shadow:0 8px 20px rgba(1,69,242,.08)}
.admin-group-member input{margin:0;accent-color:var(--accent)}
.admin-group-member-code{font-size:10px;font-weight:800;letter-spacing:.08em;text-transform:uppercase;color:var(--accent)}
.admin-group-member-name{font-size:13px;font-weight:700;color:var(--text)}
.staff-contact-grid,.staff-select-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.staff-contact-grid{margin-top:8px}
.staff-select-grid{margin-top:8px}
.staff-field{display:flex;flex-direction:column;gap:9px;min-width:0}
.staff-field>span{font-size:11px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding-left:2px}
.staff-field-wide{grid-column:1/-1}
.staff-management-grid{
  display:grid;
  grid-template-columns:1fr;
  gap:10px;
  align-items:stretch;
  margin-top:8px;
}
.staff-code-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 15px;border-radius:14px;background:#F8FAFC;border:1px solid var(--border)}
.staff-code-meta{display:flex;flex-direction:column;gap:5px;min-width:0}
.staff-code-label{font-size:11px;font-weight:800;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.staff-code-value{font-size:13px;font-weight:800;color:var(--text);letter-spacing:.12em;text-transform:uppercase;line-height:1.2}
.staff-code-copy-btn{width:34px;height:34px;flex:0 0 auto;border:1px solid rgba(1,69,242,.12);border-radius:12px;background:#fff;display:grid;place-items:center;color:var(--accent);cursor:pointer;box-shadow:none;transition:border-color .2s ease, background .2s ease, color .2s ease}
.staff-code-copy-btn:hover{transform:none;border-color:rgba(1,69,242,.22);background:#F8FAFC;box-shadow:none}
.staff-code-copy-btn svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.staff-action-row{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
}
.staff-footer{
  display:grid;
  grid-template-columns:1fr;
  align-items:center;
  gap:12px;
  margin-top:8px;
  padding-top:10px;
  border-top:1px solid rgba(148,163,184,.14);
}
.staff-card-actions{
  margin-top:6px;
}
.staff-card-actions .copy-link-btn{width:100%}
.staff-management-grid .admin-card-actions{margin-top:0}
.admin-avatar-wrap{position:relative;width:76px;height:76px;cursor:pointer;flex-shrink:0}
.admin-avatar{width:76px;height:76px;border-radius:22px;overflow:hidden;background:radial-gradient(circle at center, rgba(255,255,255,.96) 0%, rgba(239,244,255,.96) 100%);border:2px solid rgba(1,69,242,.16);display:flex;align-items:center;justify-content:center;font-size:26px;font-weight:800;color:var(--accent);transition:all .2s;box-shadow:0 10px 24px rgba(1,69,242,.08)}
.admin-avatar img{width:100%;height:100%;object-fit:contain;display:block;background:transparent}
.admin-avatar-wrap:hover .admin-avatar{box-shadow:0 16px 32px rgba(1,69,242,.18);transform:translateY(-1px)}
.avatar-upload-hint{position:absolute;bottom:-4px;right:-4px;width:28px;height:28px;background:var(--accent);border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;cursor:pointer;box-shadow:0 4px 10px rgba(1,69,242,.4);border:2px solid #fff;line-height:0;font-size:0}
.avatar-upload-hint svg{display:block;width:14px;height:14px;fill:currentColor}
.avatar-file-input{display:none}

.admin-input {
  width: 100%;
  background: #F8FAFC;
  border: 1.5px solid var(--border);
  border-radius: 14px;
  padding: 14px 18px;
  color: var(--text);
  font-family: 'Outfit', sans-serif;
  font-size: 15px;
  font-weight: 600;
  outline: none;
  text-align: center;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: inset 0 2px 4px rgba(0, 0, 0, 0.01);
}
.admin-input:focus {
  border-color: var(--accent);
  box-shadow: 
    0 0 0 4px var(--accent-dim),
    0 4px 12px rgba(1, 69, 242, 0.08);
  background: #fff;
  transform: translateY(-1px);
}
.admin-input::placeholder {
  color: #94A3B8;
  font-weight: 500;
  opacity: 0.7;
}
.phone-input-shell{
  display:flex;
  align-items:center;
  gap:10px;
  width:100%;
  background:rgba(248,250,252,.92);
  border:1.5px solid var(--border);
  border-radius:14px;
  padding:0 14px;
  transition:all .3s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow:inset 0 2px 4px rgba(0, 0, 0, 0.01);
}
.phone-input-shell:focus-within{
  border-color:var(--accent);
  background:#fff;
  box-shadow:0 0 0 3px var(--accent-dim);
}
.phone-input-prefix{
  flex:0 0 auto;
  color:var(--accent);
  font-size:14px;
  font-weight:800;
  letter-spacing:.02em;
}
.admin-phone-input{
  border:0;
  background:transparent;
  box-shadow:none;
  padding-left:0;
  padding-right:0;
}
.admin-phone-input:focus{
  border:0;
  background:transparent;
  box-shadow:none;
  transform:none;
}
.admin-card .admin-input,
.admin-card .admin-card-select{
  min-height:48px;
  border-radius:14px;
  padding:12px 14px;
  text-align:left;
  box-shadow:none;
}
.admin-card .admin-input{
  background:rgba(248,250,252,.92);
  font-size:13px;
}
.admin-card .admin-input:focus{
  background:#fff;
  box-shadow:0 0 0 3px var(--accent-dim);
}
.admin-card .phone-input-shell{
  min-height:48px;
  border-radius:14px;
}
.admin-card .admin-phone-input{
  width:100%;
  min-height:44px;
  border:0;
  border-radius:0;
  background:transparent;
  box-shadow:none;
  padding-top:12px;
  padding-bottom:12px;
  padding-left:0;
  padding-right:0;
}
.admin-card .admin-phone-input:focus{
  background:transparent;
  box-shadow:none;
}
.admin-card .admin-card-select-trigger{
  min-height:48px;
  border-radius:14px;
  padding:9px 12px;
}
.admin-card .admin-card-select-trigger .custom-select-text{
  font-size:13px;
  font-weight:700;
}
.admin-card .custom-select-menu{
  border-radius:18px;
}

.native-select-wrap{width:100%}
.custom-select-shell{position:relative;width:100%}
.admin-select-native{display:block;width:100%}
.admin-card-select{
  min-height:48px;
  font-size:14px;
  font-weight:700;
  text-align:center;
  padding:10px 40px 10px 14px;
  border:1.5px solid var(--border);
  border-radius:14px;
  background:
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  color:var(--text);
  outline:none;
  box-shadow:0 2px 12px rgba(15,23,42,.03);
  appearance:none;
  -webkit-appearance:none;
  -moz-appearance:none;
  background-image:
    linear-gradient(45deg, transparent 50%, var(--accent) 50%),
    linear-gradient(135deg, var(--accent) 50%, transparent 50%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
  background-position:
    calc(100% - 18px) 50%,
    calc(100% - 12px) 50%,
    0 0;
  background-size:6px 6px,6px 6px,100% 100%;
  background-repeat:no-repeat;
  transition:all .2s;
}
.admin-card-select-trigger{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:10px;
  width:100%;
  cursor:pointer;
  position:relative;
  background-image:none;
  text-align:left;
  padding-right:18px;
}
.admin-card-select-trigger::after{
  content:'';
  width:8px;
  height:8px;
  border-right:2px solid var(--accent);
  border-bottom:2px solid var(--accent);
  transform:rotate(45deg) translateY(-1px);
  transition:transform .22s ease;
  flex-shrink:0;
}
.custom-select-shell.open .admin-card-select-trigger::after{
  transform:rotate(225deg) translateY(1px);
}
.custom-select-text{
  flex:1;
  min-width:0;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:normal;
  line-height:1.25;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
}
.custom-select-menu{
  position:absolute;
  top:calc(100% + 8px);
  left:0;
  right:auto;
  z-index:30;
  background:rgba(255,255,255,.98);
  border:1px solid rgba(148,163,184,.35);
  border-radius:16px;
  box-shadow:0 18px 40px rgba(15,23,42,.12);
  padding:6px;
  display:flex;
  flex-direction:column;
  gap:4px;
  min-width:100%;
  width:max-content;
  max-width:min(340px, calc(100vw - 32px));
  max-height:360px;
  overflow:auto;
  opacity:0;
  visibility:hidden;
  transform:translateY(-8px) scale(.98);
  transform-origin:top center;
  pointer-events:none;
  transition:opacity .18s ease, transform .22s ease, visibility .18s ease;
}
.custom-select-shell.open .custom-select-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0) scale(1);
  pointer-events:auto;
}
.custom-select-option{
  width:100%;
  border:0;
  background:transparent;
  color:var(--text);
  text-align:left;
  padding:10px 12px;
  border-radius:12px;
  font:inherit;
  font-size:13px;
  font-weight:600;
  line-height:1.3;
  cursor:pointer;
  transition:background .18s ease, color .18s ease, transform .18s ease;
}
.custom-select-option:hover{
  background:rgba(1,69,242,.08);
  color:var(--accent);
  transform:translateX(2px);
}
.custom-select-option.active{
  background:linear-gradient(135deg, rgba(1,69,242,.12), rgba(1,69,242,.05));
  color:var(--accent);
  box-shadow:inset 0 0 0 1px rgba(1,69,242,.14);
}
.admin-select-native{
  position:absolute;
  opacity:0;
  pointer-events:none;
  width:1px;
  height:1px;
  left:0;
  top:0;
}
.custom-select-shell.open .admin-card-select-trigger{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-dim),0 10px 24px rgba(1,69,242,.08);
}
.admin-card-select:hover{border-color:rgba(1,69,242,.28);box-shadow:0 8px 18px rgba(1,69,242,.06)}
.admin-card-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim),0 8px 18px rgba(1,69,242,.08);background-color:#fff}
.admin-card-select option{font-weight:600;color:var(--text)}

.admin-staff-rating{display:flex;align-items:center;justify-content:flex-start;gap:7px;font-size:13px;margin:0;font-weight:700;padding:10px 12px;border-radius:14px;background:rgba(1,69,242,.05);color:var(--text)}
.staff-rating-star{width:16px;height:16px;display:inline-flex;align-items:center;justify-content:center;color:#F59E0B;filter:drop-shadow(0 1px 2px rgba(245,158,11,.28));flex:0 0 auto}
.staff-rating-star svg{width:16px;height:16px;display:block;fill:currentColor}
.stars-display{color:#F59E0B;font-size:16px;font-weight:800;letter-spacing:0}
.reviews-count{color:var(--muted);font-size:12px;font-weight:600}

.toggle-active{
  display:flex;
  align-items:center;
  justify-content:space-between;
  font-size:12px;
  color:var(--muted);
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.5px;
  margin:0;
  gap:12px;
  min-width:0;
  padding:10px 12px;
  border-radius:14px;
  background:rgba(1,69,242,.04);
  width:100%;
}
.toggle-switch{position:relative;width:40px;height:22px;cursor:pointer}
.toggle-switch input{display:none}
.toggle-track{width:40px;height:22px;background:#CBD5E1;border-radius:12px;position:relative;transition:background .2s}
.toggle-track::after{content:'';position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;transition:all .2s;box-shadow:0 1px 3px rgba(0,0,0,.2)}
.toggle-switch input:checked + .toggle-track{background:var(--green)}
.toggle-switch input:checked + .toggle-track::after{left:21px}

.delete-btn{position:absolute;top:-10px;right:-10px;width:30px;height:30px;background:var(--red-dim);border:1px solid rgba(225,29,72,.12);border-radius:999px;color:#E11D48;font-size:15px;font-weight:800;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:.92;transition:all .2s;z-index:6;box-shadow:0 10px 24px rgba(15,23,42,.10)}
.delete-btn:hover{opacity:1;background:#E11D48;color:#fff}

.copy-link-btn{background:var(--accent-dim);border:none;border-radius:12px;color:var(--accent);font-family:'Outfit',sans-serif;font-size:12px;font-weight:700;padding:11px 12px;cursor:pointer;transition:all .2s;margin-top:auto}
.copy-link-btn:hover{background:var(--accent);color:#fff}
.copy-link-btn .copy-link-btn-icon{display:inline-flex;align-items:center;justify-content:center;flex:0 0 auto}
.copy-link-btn .copy-link-btn-icon svg{width:15px;height:15px;display:block;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}
.admin-card-actions{
  display:grid;
  gap:8px;
  margin-top:8px;
}
.admin-card-actions .copy-link-btn{
  width:100%;
  margin-top:0;
  justify-content:center;
}
.staff-action-row .copy-link-btn,
.staff-card-actions .copy-link-btn{
  min-height:48px;
  display:flex;
  gap:8px;
  align-items:center;
  justify-content:center;
  line-height:1.15;
  text-align:center;
}
.staff-status-field{
  gap:6px;
  margin-top:2px;
}
.staff-status-field .admin-card-select-trigger{
  min-height:46px;
  padding:10px 14px;
  align-items:center;
}
.staff-status-field .custom-select-text{
  line-height:1.15;
  -webkit-line-clamp:1;
}
.staff-select-grid{margin-top:2px}
.admin-secondary-btn{
  background:#fff;
  border:1px solid var(--border);
  color:var(--text);
}
.admin-secondary-btn:hover{
  background:#F8FAFC;
  color:var(--accent);
}
.role-card{min-height:unset}
.role-fields{display:flex;flex-direction:column;gap:10px}

.add-card-btn{background:transparent;border:2px dashed #CBD5E1;border-radius:20px;padding:20px;color:var(--muted);font-family:'Outfit',sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;width:100%;display:flex;align-items:center;justify-content:center;gap:8px;height:100%;min-height:160px;box-shadow:none}
.add-card-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}

.admin-save-btn{width:100%;padding:18px;background:linear-gradient(135deg, var(--accent) 0%, #0038CC 100%);color:#fff;border:none;border-radius:16px;font-family:'Outfit',sans-serif;font-weight:700;font-size:18px;letter-spacing:1px;cursor:pointer;box-shadow:0 8px 30px rgba(1,69,242,.3);transition:all .2s;margin-top:20px}
.admin-save-btn:hover{transform:translateY(-1px);box-shadow:0 10px 28px rgba(1,69,242,.32)}

.save-toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(100px);background:var(--green);color:#fff;padding:14px 18px;border-radius:16px;font-size:15px;font-weight:600;transition:transform .4s cubic-bezier(0.175, 0.885, 0.32, 1.275);z-index:100;box-shadow:0 8px 24px rgba(16,185,129,.3);display:flex;align-items:center;gap:12px;max-width:min(92vw, 720px)}
.save-toast.show{transform:translateX(-50%) translateY(0)}
.save-toast-message{display:inline-block;line-height:1.35}
.save-toast-action{border:0;background:rgba(255,255,255,.16);color:#fff;padding:10px 14px;border-radius:12px;font:inherit;font-weight:700;cursor:pointer;transition:background .2s ease, transform .2s ease, opacity .2s ease;white-space:nowrap}
.save-toast-action:hover{background:rgba(255,255,255,.24);transform:translateY(-1px)}
.admin-empty-state{grid-column:1/-1;background:rgba(1,69,242,.04);border:1px dashed rgba(1,69,242,.18);border-radius:18px;padding:22px;color:var(--muted);text-align:center;font-size:14px;font-weight:600}

@media (max-width: 900px){
  .admin-body{padding:24px 18px 36px}
  .admin-section-tabs{
    position:static;
    overflow-x:auto;
    flex-wrap:nowrap;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
  }
  .admin-section-tabs::-webkit-scrollbar{display:none}
  .admin-section-tab{white-space:nowrap; flex:0 0 auto}
  .admin-toolbar{
    flex-direction:column;
    align-items:stretch;
    padding:18px;
  }
  .admin-toolbar-filters{
    min-width:0;
    grid-template-columns:1fr 1fr;
  }
  .admin-rating-summary,
  .admin-settings-card{
    grid-template-columns:1fr;
  }
  .admin-settings-card{gap:22px}
  .admin-grid{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}
}

@media (max-width: 700px){
  .admin-header{
    padding:14px 16px;
    flex-direction:column;
    align-items:flex-start;
    gap:12px;
  }
  .admin-logo-text{font-size:16px}
  .admin-body{padding:18px 12px 28px}
  .admin-section-tabs{padding:10px}
  .admin-section-tabs{align-items:stretch}
  .admin-section-tabs-rail{width:100%}
  .admin-section-tabs-actions{width:100%}
  .admin-section-tab{padding:11px 14px;font-size:12px}
  .admin-section-title{font-size:18px}
  .admin-toolbar-filters,
  .admin-staff-filters,
  .admin-rating-summary{
    grid-template-columns:1fr;
  }
  .admin-card{padding:22px}
  .admin-grid{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:14px}
  .admin-avatar-wrap,
  .admin-avatar{width:72px;height:72px}
  .admin-card-select,.admin-input{font-size:13px}
  .admin-section-save-btn,
  .admin-save-btn{width:100%;min-width:0}
  .admin-card-actions{gap:6px}
  .staff-management-grid{grid-template-columns:1fr}
  .staff-select-grid{grid-template-columns:1fr}
  .staff-action-row{grid-template-columns:1fr 1fr}
}

@media (max-width: 480px){
  .admin-login-card{padding:24px}
  .admin-header-actions{width:100%;flex-wrap:wrap}
  .admin-back,.admin-logout-btn{flex:1 1 140px;text-align:center}
  .admin-grid{grid-template-columns:1fr}
  .admin-card{padding:20px}
  .staff-contact-grid,
  .staff-select-grid,
  .staff-management-grid{grid-template-columns:1fr}
  .admin-avatar-wrap,
  .admin-avatar{width:68px;height:68px}
  .admin-card-select{
    min-height:58px;
    font-size:13px;
    padding:12px 40px 12px 14px;
    border-radius:12px;
    background-position:calc(100% - 17px) 50%,calc(100% - 11px) 50%,0 0;
  }
  .custom-select-menu{
    max-width:calc(100vw - 24px);
  }
  .admin-section-save-btn,
  .admin-save-btn{font-size:16px;padding:16px}
  .staff-footer{grid-template-columns:1fr}
  .toggle-active{width:100%}
  .staff-action-row{grid-template-columns:1fr}
  .admin-card-actions .copy-link-btn{min-height:46px}
  .save-toast{
    left:12px;
    right:12px;
    transform:translateY(100px);
    max-width:none;
    padding:12px 14px;
  }
  .save-toast.show{transform:translateY(0)}
}

body[data-theme="dark"] .custom-select-menu{
  background:rgba(15,24,41,.98);
  border-color:rgba(108,141,255,.2);
  box-shadow:0 24px 50px rgba(0,0,0,.28);
}
body[data-theme="dark"] .custom-select-option{
  color:var(--text);
}
body[data-theme="dark"] .custom-select-option:hover{
  background:rgba(108,141,255,.12);
  color:#fff;
}
body[data-theme="dark"] .custom-select-option.active{
  background:linear-gradient(135deg, rgba(108,141,255,.22), rgba(108,141,255,.12));
  color:#fff;
  box-shadow:inset 0 0 0 1px rgba(108,141,255,.18);
}
body[data-theme="dark"] .admin-secondary-btn,
body[data-theme="dark"] .add-card-btn{
  background:#0f1829;
  border-color:var(--border);
  color:var(--text);
}
body[data-theme="dark"] .copy-link-btn{
  background:rgba(108,141,255,.14);
  color:#dbe5ff;
}
body[data-theme="dark"] .staff-card-role{
  color:#8fb0ff;
}
body[data-theme="dark"] .staff-card-branch,
body[data-theme="dark"] .staff-field span,
body[data-theme="dark"] .staff-code-label,
body[data-theme="dark"] .reviews-count,
body[data-theme="dark"] .toggle-active{
  color:#b7c6e3;
}
body[data-theme="dark"] .admin-card .admin-input,
body[data-theme="dark"] .admin-card .admin-card-select,
body[data-theme="dark"] .admin-card .admin-card-select-trigger,
body[data-theme="dark"] .admin-card .phone-input-shell,
body[data-theme="dark"] .staff-code-row,
body[data-theme="dark"] .toggle-active,
body[data-theme="dark"] .admin-staff-rating{
  background:#16233a;
  border-color:#314566;
  color:var(--text);
  box-shadow:none;
}
body[data-theme="dark"] .admin-card .admin-input::placeholder,
body[data-theme="dark"] .admin-card .admin-phone-input::placeholder,
body[data-theme="dark"] .custom-select-text{
  color:#d7e3ff;
}
body[data-theme="dark"] .admin-card .admin-input::placeholder,
body[data-theme="dark"] .admin-card .admin-phone-input::placeholder{
  opacity:.62;
}
body[data-theme="dark"] .phone-input-prefix{
  color:#8fb0ff;
}
body[data-theme="dark"] .staff-code-value,
body[data-theme="dark"] .admin-staff-rating .stars-display{
  color:#f4f7ff;
}
body[data-theme="dark"] .staff-code-copy-btn{
  background:#1b2a45;
  border-color:#314566;
  color:#8fb0ff;
}
body[data-theme="dark"] .staff-code-copy-btn:hover{
  background:#223556;
  border-color:#4c67a0;
  color:#dbe5ff;
}
body[data-theme="dark"] .admin-secondary-btn{
  background:#243252;
  border-color:#33476d;
  color:#f4f7ff;
}
body[data-theme="dark"] .admin-secondary-btn:hover{
  background:#31456d;
  border-color:#4c67a0;
  color:#fff;
}
body[data-theme="dark"] .staff-card-actions .copy-link-btn,
body[data-theme="dark"] .admin-card-actions .copy-link-btn:not(.admin-secondary-btn){
  background:linear-gradient(135deg, #3558a8 0%, #4b74d9 100%);
  color:#fff;
}
body[data-theme="dark"] .staff-card-actions .copy-link-btn:hover,
body[data-theme="dark"] .admin-card-actions .copy-link-btn:not(.admin-secondary-btn):hover{
  background:linear-gradient(135deg, #4267bf 0%, #5b82e8 100%);
  color:#fff;
}
body[data-theme="dark"] .toggle-track{
  background:#425572;
}
body[data-theme="dark"] .admin-card .admin-input:focus,
body[data-theme="dark"] .admin-card .phone-input-shell:focus-within,
body[data-theme="dark"] .custom-select-shell.open .admin-card-select-trigger{
  border-color:#6c8dff;
  box-shadow:0 0 0 3px rgba(108,141,255,.18);
}
body[data-theme="dark"] .delete-btn{
  background:rgba(255,107,122,.14);
  color:#ff9bab;
}
body[data-theme="dark"] .delete-btn:hover{
  background:#ff6b7a;
  color:#fff;
}
body[data-theme="dark"] .admin-rating-stat,
body[data-theme="dark"] .admin-rating-row,
body[data-theme="dark"] .admin-rating-empty{
  background:#0f1829;
  border-color:var(--border);
}
body[data-theme="dark"] .admin-rating-stat-label,
body[data-theme="dark"] .admin-rating-desc,
body[data-theme="dark"] .admin-rating-score-note,
body[data-theme="dark"] .admin-rating-empty{
  color:var(--muted);
}
body[data-theme="dark"] .admin-rating-stat-value,
body[data-theme="dark"] .admin-rating-name{
  color:var(--text);
}
body[data-theme="dark"] .admin-rating-row:hover{
  border-color:rgba(108,141,255,.35);
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
body[data-theme="dark"] .admin-rating-avatar{
  background:radial-gradient(circle at center, rgba(15,24,41,.95) 0%, rgba(9,15,28,.95) 100%);
  border-color:rgba(108,141,255,.24);
}
body[data-theme="dark"] .admin-rating-place{
  color:#dbe5ff;
}
body[data-theme="dark"] .admin-rating-place.top-1{
  color:#ffbf63;
}
body[data-theme="dark"] .admin-rating-place.top-2{
  color:#b7c2d6;
}
body[data-theme="dark"] .admin-rating-place.top-3{
  color:#ffb08a;
}
body[data-theme="dark"] .toggle-track{
  background:#334155;
}
