/* ============================================================
   FemooleSMS OTP – assets/css/style.css
   Purple + White | Dark/Light Mode | Glassy | CSS Variables
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Outfit:wght@400;500;600;700;800;900&display=swap');

/* ── CSS Variables (overridden by admin theme picker) ── */
:root {
  --primary:       #7C3AED;
  --primary-dark:  #5B21B6;
  --primary-light: #EDE9FE;
  --accent:        #A78BFA;
  --bg-dark:       #0F0A1E;

  /* Light mode defaults */
  --bg:            #F5F3FF;
  --bg2:           #FFFFFF;
  --bg3:           #EDE9FE;
  --text:          #1A0A3B;
  --text2:         #6B5B8E;
  --text3:         #9B8ABE;
  --border:        rgba(124,58,237,.15);
  --card-bg:       rgba(255,255,255,0.75);
  --card-border:   rgba(124,58,237,.12);
  --glass-blur:    blur(18px);
  --nav-bg:        rgba(255,255,255,0.85);
  --shadow:        0 4px 24px rgba(124,58,237,.10);
  --shadow-md:     0 8px 32px rgba(124,58,237,.18);
  --shadow-lg:     0 16px 48px rgba(124,58,237,.22);
  --input-bg:      rgba(255,255,255,0.9);
  --input-border:  rgba(124,58,237,.2);

  --radius:    16px;
  --radius-sm: 10px;
  --radius-xs: 6px;
  --nav-h:     60px;
  --bot-h:     68px;

  --success:  #059669;
  --danger:   #DC2626;
  --warning:  #D97706;
  --info:     var(--primary);
}

/* ── Dark Mode ── */
[data-theme="dark"] {
  --bg:          #0F0A1E;
  --bg2:         #1A1035;
  --bg3:         #231848;
  --text:        #F0EAFF;
  --text2:       #C4B5FD;
  --text3:       #7C5EAE;
  --border:      rgba(167,139,250,.15);
  --card-bg:     rgba(26,16,53,0.80);
  --card-border: rgba(167,139,250,.12);
  --nav-bg:      rgba(15,10,30,0.90);
  --shadow:      0 4px 24px rgba(0,0,0,.40);
  --shadow-md:   0 8px 32px rgba(0,0,0,.50);
  --shadow-lg:   0 16px 48px rgba(0,0,0,.60);
  --input-bg:    rgba(26,16,53,0.80);
  --input-border:rgba(167,139,250,.25);
}

/* ── Reset ── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{
  font-family:'Outfit',sans-serif;
  background:var(--bg);
  color:var(--text);
  font-size:15px;
  line-height:1.6;
  padding-bottom:var(--bot-h);
  transition:background .3s,color .3s;
  min-height:100vh;
}
[data-theme="dark"] body{
  background:
    radial-gradient(ellipse 80% 50% at 20% 10%, rgba(124,58,237,.15) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 80%, rgba(124,58,237,.10) 0%, transparent 60%),
    var(--bg);
}
a{color:var(--primary);text-decoration:none;transition:opacity .2s;}
a:hover{opacity:.8;}
img{max-width:100%;}

/* ── Glass card ── */
.glass{
  background:var(--card-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--card-border);
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}
.glass-solid{
  background:var(--primary);
  border-radius:var(--radius);
  box-shadow:var(--shadow-md);
}

/* ── Top Nav ── */
.top-nav{
  position:fixed;top:0;left:0;right:0;z-index:900;
  height:var(--nav-h);
  background:var(--nav-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border-bottom:1.5px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  padding:0 16px;
  box-shadow:0 2px 16px rgba(124,58,237,.08);
  transition:background .3s;
}
.logo-wrap{display:flex;align-items:center;gap:8px;}
.logo-text{font-size:19px;font-weight:900;color:var(--primary);}
.site-logo{height:36px;width:auto;object-fit:contain;}
.nav-actions{display:flex;align-items:center;gap:10px;}

/* Theme toggle button */
.theme-toggle{
  width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--card-bg);backdrop-filter:var(--glass-blur);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text2);font-size:16px;transition:all .2s;
}
.theme-toggle:hover{border-color:var(--primary);color:var(--primary);}

.notif-wrap{position:relative;}
.notif-btn{
  width:36px;height:36px;border-radius:50%;border:1.5px solid var(--border);
  background:var(--card-bg);backdrop-filter:var(--glass-blur);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text2);font-size:16px;text-decoration:none;transition:all .2s;
}
.notif-btn:hover{border-color:var(--primary);color:var(--primary);}
.notif-badge{
  position:absolute;top:-3px;right:-3px;
  background:var(--danger);color:#fff;
  border-radius:50%;width:16px;height:16px;
  font-size:9px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  border:2px solid var(--bg);
}
.avatar-btn{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;font-weight:800;font-size:13px;
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;border:2px solid rgba(255,255,255,.2);
}

/* ── Page wrapper ── */
.page-wrap{
  max-width:600px;margin:0 auto;
  padding:calc(var(--nav-h) + 12px) 14px 20px;
}

/* ── Balance card ── */
.balance-card{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
  border-radius:var(--radius);
  padding:20px;color:#fff;
  position:relative;overflow:hidden;
  box-shadow:var(--shadow-md);
  margin-bottom:14px;
}
.balance-card::before{
  content:'';position:absolute;right:-30px;top:-30px;
  width:120px;height:120px;border-radius:50%;
  background:rgba(255,255,255,.08);
}
.balance-card::after{
  content:'';position:absolute;right:40px;bottom:-50px;
  width:90px;height:90px;border-radius:50%;
  background:rgba(255,255,255,.05);
}
.bal-label{font-size:12px;opacity:.75;font-weight:500;margin-bottom:3px;}
.bal-amount{font-size:30px;font-weight:900;letter-spacing:-.5px;}
.bal-va{margin-top:14px;padding-top:14px;border-top:1px solid rgba(255,255,255,.15);}
.bal-va-num{font-size:18px;font-weight:800;letter-spacing:1px;}
.bal-va-sub{font-size:12px;opacity:.7;margin-top:2px;}

/* ── Quick actions ── */
.quick-grid{
  display:grid;grid-template-columns:repeat(3,1fr);
  gap:10px;margin-bottom:14px;
}
.quick-btn{
  background:var(--card-bg);
  backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--card-border);
  border-radius:var(--radius-sm);
  padding:16px 8px;text-align:center;
  cursor:pointer;transition:all .18s;
  display:flex;flex-direction:column;align-items:center;gap:7px;
  text-decoration:none;box-shadow:var(--shadow);
}
.quick-btn:hover{
  transform:translateY(-2px);
  box-shadow:var(--shadow-md);
  border-color:var(--primary);
}
.quick-btn .fi{font-size:24px;color:var(--primary);}
.quick-btn span{font-size:11px;font-weight:600;color:var(--text2);}

/* ── Section header ── */
.sec-hdr{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px;}
.sec-hdr h3{font-size:15px;font-weight:800;color:var(--text);}
.sec-hdr a{font-size:13px;color:var(--primary);font-weight:600;}

/* ── Service item (numbers list) ── */
.svc-item{
  background:var(--card-bg);
  backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--card-border);
  border-radius:var(--radius-sm);
  padding:12px 14px;
  display:flex;align-items:center;gap:12px;
  box-shadow:var(--shadow);
  transition:all .18s;
  margin-bottom:8px;
}
.svc-item:hover{border-color:var(--primary);transform:translateX(2px);}
.svc-icon{
  width:42px;height:42px;border-radius:10px;
  background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;
}
[data-theme="dark"] .svc-icon{background:rgba(124,58,237,.25);}
.svc-icon .fi{font-size:20px;color:var(--primary);}
.svc-info{flex:1;min-width:0;}
.svc-name{font-size:14px;font-weight:700;color:var(--text);}
.svc-meta{font-size:11px;color:var(--text3);margin-top:2px;}
.svc-price{font-size:14px;font-weight:800;color:var(--primary);margin-right:8px;}

/* ── Order item ── */
.order-item{
  background:var(--card-bg);
  backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--card-border);
  border-radius:var(--radius-sm);
  padding:14px;margin-bottom:10px;
  box-shadow:var(--shadow);
}
.order-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;}
.order-title{font-size:14px;font-weight:700;color:var(--text);}
.order-meta{font-size:12px;color:var(--text3);}
.order-amount{font-size:14px;font-weight:800;color:var(--primary);}

/* ── Status pills ── */
.pill{
  display:inline-flex;align-items:center;gap:4px;
  font-size:11px;padding:3px 10px;border-radius:20px;font-weight:600;
}
.pill-success{background:#d1fae5;color:#065f46;}
.pill-pending{background:#fef3c7;color:#92400e;}
.pill-danger {background:#fee2e2;color:#991b1b;}
.pill-info   {background:var(--primary-light);color:var(--primary-dark);}
.pill-gray   {background:var(--bg3);color:var(--text2);}
[data-theme="dark"] .pill-success{background:rgba(5,150,105,.2);color:#34d399;}
[data-theme="dark"] .pill-pending{background:rgba(217,119,6,.2);color:#fbbf24;}
[data-theme="dark"] .pill-danger {background:rgba(220,38,38,.2);color:#f87171;}
[data-theme="dark"] .pill-info   {background:rgba(124,58,237,.2);color:var(--accent);}
[data-theme="dark"] .pill-gray   {background:rgba(255,255,255,.1);color:var(--text3);}

/* ── OTP display box ── */
.otp-box{
  background:linear-gradient(135deg,var(--primary-light),#ddd6fe);
  border:2px solid rgba(124,58,237,.2);
  border-radius:var(--radius);
  padding:24px;text-align:center;margin:14px 0;
}
[data-theme="dark"] .otp-box{
  background:linear-gradient(135deg,rgba(124,58,237,.25),rgba(91,33,182,.2));
  border-color:rgba(167,139,250,.25);
}
.otp-number{font-size:22px;font-weight:900;letter-spacing:2px;color:var(--primary);}
.otp-code{
  font-size:34px;font-weight:900;letter-spacing:5px;
  color:var(--success);margin:10px 0;
}
.otp-timer{font-size:28px;font-weight:900;color:var(--primary);}

/* ── Bottom Navigation ── */
.bottom-nav{
  position:fixed;bottom:0;left:0;right:0;z-index:900;
  height:var(--bot-h);
  background:var(--nav-bg);
  backdrop-filter:var(--glass-blur);
  -webkit-backdrop-filter:var(--glass-blur);
  border-top:1.5px solid var(--border);
  display:flex;align-items:center;
  box-shadow:0 -4px 20px rgba(124,58,237,.08);
}
.bottom-nav a{
  flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:3px;color:var(--text3);font-size:10.5px;font-weight:600;
  text-decoration:none;padding:8px 0;transition:all .18s;position:relative;
}
.bottom-nav a .fi{font-size:22px;transition:transform .2s;}
.bottom-nav a.active{color:var(--primary);}
.bottom-nav a.active .fi{transform:scale(1.1);}
.bottom-nav a.active::after{
  content:'';position:absolute;bottom:0;left:20%;right:20%;
  height:3px;background:var(--primary);
  border-radius:3px 3px 0 0;
}
.notif-dot{
  position:absolute;top:6px;right:calc(50% - 14px);
  width:7px;height:7px;border-radius:50%;
  background:var(--danger);border:1.5px solid var(--bg);
}

/* ── Floating support button ── */
.fab{
  position:fixed;
  bottom:calc(var(--bot-h) + 14px);
  right:16px;z-index:800;
  width:50px;height:50px;border-radius:50%;
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:20px;text-decoration:none;
  box-shadow:0 4px 20px rgba(124,58,237,.45);
  transition:all .2s;border:2px solid rgba(255,255,255,.2);
}
.fab:hover{transform:scale(1.1) translateY(-2px);color:#fff;}

/* ── Forms ── */
.form-group{margin-bottom:16px;}
.form-label{
  font-size:13px;font-weight:600;color:var(--text2);
  margin-bottom:6px;display:block;
}
.form-control{
  width:100%;padding:13px 14px;
  border:1.5px solid var(--input-border);
  border-radius:var(--radius-sm);
  font-size:15px;font-family:inherit;
  background:var(--input-bg);
  backdrop-filter:blur(8px);
  color:var(--text);
  transition:all .2s;outline:none;
}
.form-control:focus{
  border-color:var(--primary);
  box-shadow:0 0 0 3px rgba(124,58,237,.12);
}
.form-control::placeholder{color:var(--text3);}
.input-wrap{position:relative;}
.input-wrap .form-control{padding-left:42px;}
.input-wrap .fi{
  position:absolute;left:14px;top:50%;transform:translateY(-50%);
  color:var(--text3);font-size:17px;
}
select.form-control{cursor:pointer;}

/* ── Buttons ── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:13px 22px;border-radius:var(--radius-sm);
  font-size:15px;font-weight:700;cursor:pointer;
  border:none;transition:all .18s;font-family:inherit;text-decoration:none;
}
.btn-primary{
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;box-shadow:0 4px 16px rgba(124,58,237,.3);
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 24px rgba(124,58,237,.4);color:#fff;}
.btn-outline{
  background:none;border:1.5px solid var(--primary);color:var(--primary);
}
.btn-outline:hover{background:var(--primary);color:#fff;}
.btn-ghost{
  background:var(--card-bg);backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--border);color:var(--text);
}
.btn-ghost:hover{border-color:var(--primary);color:var(--primary);}
.btn-danger{background:var(--danger);color:#fff;}
.btn-success{background:var(--success);color:#fff;}
.btn-block{width:100%;}
.btn-sm{padding:8px 16px;font-size:13px;border-radius:var(--radius-xs);}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none!important;}

/* ── Alerts ── */
.alert{
  padding:12px 16px;border-radius:var(--radius-sm);
  font-size:13px;margin-bottom:14px;
  display:flex;align-items:flex-start;gap:10px;
}
.alert .fi{font-size:16px;flex-shrink:0;margin-top:1px;}
.alert-success{background:rgba(5,150,105,.1);color:#065f46;border:1px solid rgba(5,150,105,.2);}
.alert-danger {background:rgba(220,38,38,.1);color:#991b1b;border:1px solid rgba(220,38,38,.2);}
.alert-info   {background:rgba(124,58,237,.08);color:var(--primary-dark);border:1px solid rgba(124,58,237,.2);}
.alert-warning{background:rgba(217,119,6,.1);color:#92400e;border:1px solid rgba(217,119,6,.2);}
[data-theme="dark"] .alert-success{color:#34d399;}
[data-theme="dark"] .alert-danger {color:#f87171;}
[data-theme="dark"] .alert-info   {color:var(--accent);}
[data-theme="dark"] .alert-warning{color:#fbbf24;}

/* ── Modal ── */
.modal-overlay{
  position:fixed;inset:0;z-index:1000;
  background:rgba(15,10,30,.6);
  backdrop-filter:blur(10px);
  -webkit-backdrop-filter:blur(10px);
  display:flex;align-items:flex-end;justify-content:center;
  opacity:0;pointer-events:none;transition:opacity .3s;
}
.modal-overlay.open{opacity:1;pointer-events:all;}
.modal-sheet{
  background:var(--bg2);
  border:1.5px solid var(--border);
  border-radius:20px 20px 0 0;
  padding:24px 20px 36px;
  width:100%;max-width:600px;
  transform:translateY(100%);
  transition:transform .3s cubic-bezier(.34,1.26,.64,1);
  max-height:88vh;overflow-y:auto;
}
.modal-overlay.open .modal-sheet{transform:translateY(0);}
.modal-handle{
  width:36px;height:4px;background:var(--border);
  border-radius:2px;margin:0 auto 20px;
}
.modal-title{font-size:18px;font-weight:800;margin-bottom:16px;color:var(--text);}

/* ── Auth pages ── */
.auth-page{
  min-height:100vh;display:flex;align-items:center;
  justify-content:center;padding:20px;
  padding-bottom:0;
}
.auth-card{width:100%;max-width:420px;}
.auth-logo{text-align:center;margin-bottom:24px;}
.auth-logo .logo-text{font-size:26px;}
.auth-logo p{color:var(--text2);font-size:14px;margin-top:4px;}
.auth-box{
  background:var(--card-bg);
  backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--card-border);
  border-radius:var(--radius);
  padding:28px;box-shadow:var(--shadow-lg);
}
.auth-footer{
  text-align:center;margin-top:16px;
  font-size:14px;color:var(--text2);
}

/* ── Profile ── */
.profile-hdr{
  background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
  border-radius:var(--radius);padding:24px;color:#fff;
  text-align:center;margin-bottom:14px;
  box-shadow:var(--shadow-md);position:relative;overflow:hidden;
}
.profile-hdr::before{
  content:'';position:absolute;right:-30px;top:-30px;
  width:120px;height:120px;border-radius:50%;
  background:rgba(255,255,255,.07);
}
.profile-avatar{
  width:70px;height:70px;border-radius:50%;
  background:rgba(255,255,255,.2);
  display:flex;align-items:center;justify-content:center;
  font-size:26px;font-weight:900;margin:0 auto 12px;
  border:2px solid rgba(255,255,255,.3);
}

/* ── Chat bubbles ── */
.chat-wrap{display:flex;flex-direction:column;gap:10px;padding:8px 0;}
.msg{
  max-width:80%;padding:11px 15px;border-radius:16px;
  font-size:14px;line-height:1.5;
}
.msg-user{
  background:linear-gradient(135deg,var(--primary),var(--primary-dark));
  color:#fff;align-self:flex-end;border-bottom-right-radius:4px;
}
.msg-admin{
  background:var(--card-bg);color:var(--text);
  align-self:flex-start;box-shadow:var(--shadow);
  border:1.5px solid var(--card-border);border-bottom-left-radius:4px;
}
.msg small{display:block;font-size:10px;opacity:.65;margin-top:4px;}

/* ── Ticket item ── */
.ticket-item{
  background:var(--card-bg);backdrop-filter:var(--glass-blur);
  border:1.5px solid var(--card-border);border-radius:var(--radius-sm);
  padding:14px;box-shadow:var(--shadow);margin-bottom:10px;
}

/* ── Settings list ── */
.settings-list .s-row{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 0;border-bottom:1px solid var(--border);
  text-decoration:none;color:var(--text);
}
.settings-list .s-row:last-child{border-bottom:none;}
.s-row .s-icon{
  width:36px;height:36px;border-radius:9px;
  background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
  margin-right:12px;flex-shrink:0;
}
[data-theme="dark"] .s-row .s-icon{background:rgba(124,58,237,.25);}
.s-icon .fi{color:var(--primary);font-size:16px;}
.s-row .s-label{font-size:14px;font-weight:600;flex:1;}
.s-row .s-right{color:var(--text3);font-size:13px;}

/* ── Tabs ── */
.tabs-wrap{
  display:flex;background:var(--bg3);
  border-radius:var(--radius-sm);padding:4px;
  margin-bottom:16px;
}
[data-theme="dark"] .tabs-wrap{background:rgba(255,255,255,.07);}
.tab-btn{
  flex:1;padding:9px;text-align:center;
  font-size:13px;font-weight:600;color:var(--text2);
  border-radius:6px;cursor:pointer;border:none;
  background:none;transition:all .2s;font-family:inherit;
}
.tab-btn.active{
  background:var(--bg2);color:var(--primary);
  box-shadow:var(--shadow);
}

/* ── Empty state ── */
.empty{text-align:center;padding:48px 20px;}
.empty .fi{font-size:52px;color:var(--text3);margin-bottom:14px;display:block;opacity:.4;}
.empty p{color:var(--text3);font-size:14px;}

/* ── Landing ── */
.hero{
  background:linear-gradient(160deg,var(--primary) 0%,var(--primary-dark) 100%);
  padding:80px 20px 70px;text-align:center;color:#fff;
  position:relative;overflow:hidden;padding-top:100px;
}
.hero::after{
  content:'';position:absolute;bottom:-1px;left:0;right:0;
  height:50px;background:var(--bg);
  clip-path:ellipse(60% 100% at 50% 100%);
}

/* ── Admin layout ── */
.admin-body{background:#f8f5ff;color:#1a0a3b;min-height:100vh;}
[data-theme="dark"] .admin-body{background:#0F0A1E;color:#f0eaff;}
.admin-wrap{display:flex;min-height:100vh;}
.admin-sidebar{
  width:240px;
  background:linear-gradient(180deg,#1A0A3B 0%,#2D1B69 100%);
  position:fixed;top:0;left:0;bottom:0;z-index:200;
  overflow-y:auto;display:flex;flex-direction:column;
  border-right:1px solid rgba(167,139,250,.1);
}
.admin-sidebar .logo-area{
  padding:20px;
  border-bottom:1px solid rgba(255,255,255,.08);
  display:flex;align-items:center;gap:8px;
}
.admin-sidebar .logo-area .logo-text{font-size:17px;font-weight:900;color:var(--accent);}
.admin-sidebar .logo-area .site-logo{height:32px;}
.admin-sidebar .nav-section{
  padding:14px 20px 6px;
  font-size:10px;font-weight:700;
  color:rgba(167,139,250,.4);
  letter-spacing:1.5px;text-transform:uppercase;
}
.admin-sidebar a{
  display:flex;align-items:center;gap:10px;
  padding:11px 20px;color:rgba(255,255,255,.5);
  font-size:13.5px;font-weight:500;text-decoration:none;
  transition:all .18s;border-left:3px solid transparent;
}
.admin-sidebar a .fi{font-size:16px;width:18px;text-align:center;}
.admin-sidebar a:hover{background:rgba(124,58,237,.15);color:rgba(255,255,255,.85);}
.admin-sidebar a.active{
  background:rgba(124,58,237,.2);color:#fff;
  border-left-color:var(--accent);
}
.admin-sidebar .logout-link{
  margin-top:auto;
  border-top:1px solid rgba(255,255,255,.08);
  color:rgba(255,255,255,.35)!important;
}
.admin-content{
  margin-left:240px;flex:1;padding:24px;
  background:#f8f5ff;min-height:100vh;
}
[data-theme="dark"] .admin-content{background:#0F0A1E;}
.admin-topbar{
  background:#fff;border-radius:var(--radius);
  padding:16px 20px;margin-bottom:20px;
  box-shadow:0 2px 12px rgba(124,58,237,.08);
  display:flex;align-items:center;justify-content:space-between;
}
[data-theme="dark"] .admin-topbar{background:#1A1035;box-shadow:0 2px 12px rgba(0,0,0,.3);}
.admin-topbar h2{font-size:18px;font-weight:800;color:var(--text);}
.admin-stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:20px;}
.admin-stat{
  background:#fff;border-radius:var(--radius);padding:18px;
  box-shadow:0 2px 12px rgba(124,58,237,.08);
}
[data-theme="dark"] .admin-stat{background:#1A1035;box-shadow:0 2px 12px rgba(0,0,0,.3);}
.admin-stat .s-num{font-size:22px;font-weight:900;color:var(--primary);}
.admin-stat .s-lbl{font-size:12px;color:var(--text2);font-weight:500;}
.admin-stat .s-ico{
  width:40px;height:40px;border-radius:10px;
  background:var(--primary-light);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:10px;
}
.admin-stat .s-ico .fi{color:var(--primary);font-size:18px;}
.table-wrap{
  background:#fff;border-radius:var(--radius);
  box-shadow:0 2px 12px rgba(124,58,237,.08);overflow-x:auto;
}
[data-theme="dark"] .table-wrap{background:#1A1035;box-shadow:0 2px 12px rgba(0,0,0,.3);}
.admin-table{width:100%;border-collapse:collapse;}
.admin-table th{
  background:#f8f5ff;padding:11px 14px;
  text-align:left;font-size:11.5px;font-weight:700;
  color:var(--text2);border-bottom:1px solid var(--border);
}
[data-theme="dark"] .admin-table th{background:rgba(124,58,237,.1);}
.admin-table td{
  padding:11px 14px;font-size:13.5px;
  border-bottom:1px solid var(--border);color:var(--text);
}
.admin-table tr:last-child td{border-bottom:none;}
.admin-table tr:hover td{background:rgba(124,58,237,.04);}
[data-theme="dark"] .admin-table tr:hover td{background:rgba(124,58,237,.08);}

/* ── Copy button ── */
.copy-btn{
  background:none;border:none;cursor:pointer;
  color:rgba(255,255,255,.7);padding:0 4px;
  font-size:14px;transition:color .2s;
}
.copy-btn:hover{color:#fff;}

/* ── Color input ── */
input[type="color"]{
  width:40px;height:40px;border-radius:8px;
  border:1.5px solid var(--input-border);
  padding:2px;cursor:pointer;background:transparent;
}

/* ── Utilities ── */
.d-flex{display:flex;}
.align-center{align-items:center;}
.justify-between{justify-content:space-between;}
.gap-1{gap:6px;}.gap-2{gap:10px;}.gap-3{gap:16px;}
.fw-700{font-weight:700;}.fw-800{font-weight:800;}.fw-900{font-weight:900;}
.text-primary{color:var(--primary);}
.text-muted{color:var(--text2);}
.text-sm{font-size:13px;}.text-xs{font-size:11px;}
.text-center{text-align:center;}
.mt-1{margin-top:8px;}.mt-2{margin-top:16px;}.mt-3{margin-top:24px;}
.mb-1{margin-bottom:8px;}.mb-2{margin-bottom:16px;}
.divider{border:none;border-top:1px solid var(--border);margin:14px 0;}
.w-100{width:100%;}

/* ── Responsive ── */
@media(min-width:768px){
  .bottom-nav,.fab{display:none;}
  body{padding-bottom:0;}
  .page-wrap{padding-top:calc(var(--nav-h) + 20px);}
}
@media(max-width:900px){
  .admin-sidebar{display:none!important;}
  .admin-content{margin-left:0!important;}
  .admin-stat-grid{grid-template-columns:repeat(2,1fr);}
}

/* ── Smooth transitions ── */
.page-wrap,nav,aside,.glass,.order-item,.svc-item,.ticket-item{
  transition:background .3s,border-color .3s,color .3s;
}
