/* ═══════════════════════════════════════════════════════════
   GymAdmin Design System
   ═══════════════════════════════════════════════════════════ */

:root {
  --green-50:#f0fdf4; --green-100:#dcfce7; --green-200:#bbf7d0;
  --green-600:#16a34a; --green-700:#15803d; --green-800:#166534; --green-900:#14532d;
  --blue-50:#eff6ff; --blue-100:#dbeafe; --blue-200:#bfdbfe;
  --blue-600:#2563eb; --blue-700:#1d4ed8;
  --indigo-50:#eef2ff; --indigo-100:#e0e7ff; --indigo-200:#c7d2fe;
  --indigo-600:#4f46e5; --indigo-700:#4338ca; --indigo-800:#3730a3;
  --emerald-50:#ecfdf5; --emerald-100:#d1fae5; --emerald-600:#059669;
  --teal-50:#f0fdfa; --teal-100:#ccfbf1; --teal-600:#0d9488;
  --red-50:#fef2f2; --red-100:#fee2e2; --red-200:#fecaca;
  --red-600:#dc2626; --red-700:#b91c1c; --red-800:#991b1b;
  --orange-50:#fff7ed; --orange-100:#ffedd5; --orange-200:#fed7aa;
  --orange-600:#ea580c; --orange-800:#9a3412;
  --purple-50:#faf5ff; --purple-100:#ede9fe; --purple-200:#ddd6fe;
  --purple-600:#9333ea; --purple-700:#7c3aed;
  --slate-50:#f8fafc; --slate-100:#f1f5f9; --slate-200:#e2e8f0;
  --slate-300:#cbd5e1; --slate-400:#94a3b8; --slate-500:#64748b;
  --slate-600:#475569; --slate-700:#334155; --slate-800:#1e293b; --slate-900:#0f172a;
  --white:#ffffff;
  --body-bg:#f1f5f9;
  --border:#e2e8f0;
  --border-light:#f1f5f9;
  --shadow-sm:0 1px 2px rgba(0,0,0,.05);
  --shadow:0 1px 3px rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);
  --shadow-md:0 4px 6px -1px rgba(0,0,0,.1),0 2px 4px -2px rgba(0,0,0,.1);
  --shadow-lg:0 10px 15px -3px rgba(0,0,0,.1),0 4px 6px -4px rgba(0,0,0,.1);
  --r-sm:6px; --r:10px; --r-md:12px; --r-lg:16px; --r-full:9999px;
  --font:'Segoe UI',system-ui,-apple-system,'Helvetica Neue',sans-serif;
}

/* ── Reset ─────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
a{text-decoration:none;color:inherit}
button{font-family:inherit;cursor:pointer}
input,select,textarea{font-family:inherit}

body{
  font-family:var(--font);
  background:var(--body-bg);
  color:var(--slate-800);
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
}

/* ── Layout ────────────────────────────────────────────── */
.admin-layout{display:flex;min-height:100vh}

/* ── Sidebar ────────────────────────────────────────────── */
.sidebar{
  width:256px;
  background:var(--white);
  border-right:1px solid var(--border);
  display:flex;
  flex-direction:column;
  flex-shrink:0;
  position:sticky;
  top:0;
  height:100vh;
  overflow-y:auto;
  scrollbar-width:thin;
  scrollbar-color:var(--slate-200) transparent;
}

.brand{padding:22px 18px 18px;border-bottom:1px solid var(--border-light)}

.brand-logo{
  width:40px;height:40px;
  background:linear-gradient(135deg,var(--green-600),var(--green-700));
  border-radius:10px;
  display:flex;align-items:center;justify-content:center;
  margin-bottom:12px;
  box-shadow:0 4px 12px rgba(22,163,74,.2);
}
.brand-logo svg{width:22px;height:22px;fill:white}

.brand-name{font-size:15px;font-weight:700;color:var(--slate-900);letter-spacing:-.01em}
.brand-sub{font-size:11px;color:var(--slate-400);margin-top:1px}

.menu-section{padding:14px 12px 4px}
.menu-label{
  font-size:10px;font-weight:700;color:var(--slate-300);
  text-transform:uppercase;letter-spacing:.1em;
  padding:0 8px;margin-bottom:4px;
}

.menu-link{
  display:flex;align-items:center;gap:10px;
  padding:9px 10px;border-radius:var(--r-sm);
  color:var(--slate-500);font-size:13.5px;font-weight:500;
  margin-bottom:2px;
  transition:all .15s;
  border:1px solid transparent;
  position:relative;
}
.menu-link:hover{background:var(--slate-50);color:var(--slate-700)}
.menu-link.active{
  background:var(--green-50);color:var(--green-800);
  font-weight:600;border-color:var(--green-100);
}
.menu-link.active::before{
  content:'';position:absolute;left:-12px;top:50%;
  transform:translateY(-50%);
  width:3px;height:20px;
  background:var(--green-600);border-radius:0 3px 3px 0;
}
.menu-icon{width:16px;height:16px;flex-shrink:0;fill:var(--slate-400);transition:fill .15s}
.menu-link:hover .menu-icon{fill:var(--slate-600)}
.menu-link.active .menu-icon{fill:var(--green-600)}

.sidebar-footer{margin-top:auto;padding:12px 12px 20px;border-top:1px solid var(--border-light)}

.user-info{display:flex;align-items:center;gap:10px;padding:10px 8px 12px}
.user-avatar{
  width:34px;height:34px;border-radius:50%;
  background:linear-gradient(135deg,var(--indigo-100),var(--indigo-50));
  color:var(--indigo-700);font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;text-transform:uppercase;
  border:1px solid var(--indigo-200);
}
.user-detail-name{font-size:13px;font-weight:600;color:var(--slate-800);line-height:1.3}
.user-detail-role{font-size:11px;color:var(--slate-400);text-transform:capitalize}

.logout-btn{
  width:100%;display:flex;align-items:center;justify-content:center;gap:6px;
  background:var(--red-50);border:1px solid var(--red-200);
  color:var(--red-800);padding:8px 14px;border-radius:var(--r-sm);
  font-size:12.5px;font-weight:600;cursor:pointer;transition:background .15s;
}
.logout-btn:hover{background:var(--red-100)}

/* ── Main area ──────────────────────────────────────────── */
.main-area{flex:1;display:flex;flex-direction:column;min-width:0}

.topbar{
  background:var(--white);border-bottom:1px solid var(--border);
  padding:14px 28px;
  display:flex;align-items:center;justify-content:space-between;
  gap:16px;flex-wrap:wrap;
  position:sticky;top:0;z-index:50;
  box-shadow:var(--shadow-sm);
}
.topbar-left{display:flex;align-items:center;gap:12px}
.topbar-left h2{font-size:16px;font-weight:700;color:var(--slate-900);letter-spacing:-.01em}
.topbar-left p{font-size:12px;color:var(--slate-400);margin-top:1px}
.topbar-right{display:flex;align-items:center;gap:10px}

.topbar-badge{
  background:var(--slate-50);border:1px solid var(--border);
  border-radius:var(--r-full);padding:5px 13px;
  font-size:12px;font-weight:500;color:var(--slate-600);
  display:flex;align-items:center;gap:6px;
}
.topbar-dot{
  width:6px;height:6px;border-radius:50%;background:var(--green-600);
  animation:pulse-dot 2.5s infinite;
}
@keyframes pulse-dot{0%,100%{opacity:1}50%{opacity:.4}}

.mobile-menu-toggle{
  display:none;background:var(--slate-50);border:1px solid var(--border);
  border-radius:var(--r-sm);padding:7px;cursor:pointer;
  align-items:center;justify-content:center;
}
.mobile-menu-toggle svg{width:18px;height:18px;fill:var(--slate-600)}

.content-area{padding:28px;flex:1}

/* ── Flash messages ─────────────────────────────────────── */
.flash-message{
  border-radius:var(--r);padding:13px 18px;margin-bottom:20px;
  font-size:13.5px;font-weight:500;
  display:flex;align-items:center;gap:10px;
  animation:slide-in .25s ease;
}
@keyframes slide-in{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.flash-success{background:var(--green-50);border:1px solid var(--green-200);color:var(--green-800)}
.flash-error  {background:var(--red-50);  border:1px solid var(--red-200);  color:var(--red-800)}
.flash-info   {background:var(--blue-50); border:1px solid var(--blue-200); color:var(--blue-700)}

.error-box{
  background:var(--red-50);border:1px solid var(--red-200);
  border-radius:var(--r);padding:14px 18px;margin-bottom:20px;
  font-size:13px;color:var(--red-800);
}
.error-box ul{padding-left:18px}
.error-box li{margin-bottom:4px}

/* ── Badges ─────────────────────────────────────────────── */
.badge{
  display:inline-flex;align-items:center;gap:4px;
  padding:3px 10px;border-radius:var(--r-full);
  font-size:11px;font-weight:600;white-space:nowrap;
}
.badge-green {background:var(--green-50); color:var(--green-800);  border:1px solid var(--green-200)}
.badge-red   {background:var(--red-50);   color:var(--red-800);    border:1px solid var(--red-200)}
.badge-gray  {background:var(--slate-50); color:var(--slate-600);  border:1px solid var(--border)}
.badge-blue  {background:var(--blue-50);  color:var(--blue-700);   border:1px solid var(--blue-200)}
.badge-orange{background:var(--orange-50);color:var(--orange-800); border:1px solid var(--orange-200)}
.badge-purple{background:var(--purple-50);color:var(--purple-700); border:1px solid var(--purple-200)}
.badge-indigo{background:var(--indigo-50);color:var(--indigo-700); border:1px solid var(--indigo-200)}

.dot{width:6px;height:6px;border-radius:50%;display:inline-block;flex-shrink:0}
.dot-green {background:var(--green-600);animation:pulse 2s infinite}
.dot-orange{background:var(--orange-600)}
.dot-red   {background:var(--red-600)}
.dot-gray  {background:var(--slate-400)}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

/* ── Buttons ────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 16px;border-radius:var(--r-sm);border:1px solid var(--border);
  background:var(--white);color:var(--slate-700);
  font-size:13px;font-weight:600;cursor:pointer;
  text-decoration:none;transition:all .15s;white-space:nowrap;line-height:1;
}
.btn:hover{background:var(--slate-50)}
.btn-primary{background:var(--green-600);border-color:var(--green-700);color:white}
.btn-primary:hover{background:var(--green-700)}
.btn-green{background:var(--green-50);border-color:var(--green-200);color:var(--green-800)}
.btn-green:hover{background:var(--green-100)}
.btn-gray{background:var(--slate-50);border-color:var(--border);color:var(--slate-700)}
.btn-gray:hover{background:var(--slate-100)}
.btn-blue{background:var(--blue-50);border-color:var(--blue-200);color:var(--blue-700)}
.btn-blue:hover{background:var(--blue-100)}
.btn-red{background:var(--red-50);border-color:var(--red-200);color:var(--red-800)}
.btn-red:hover{background:var(--red-100)}
.btn-sm{padding:5px 11px;font-size:12px}
.btn-lg{padding:11px 22px;font-size:14px}

/* ── Form elements ──────────────────────────────────────── */
.form-group{display:flex;flex-direction:column;gap:6px}
.form-group.full{grid-column:1/-1}

.form-label{
  font-size:12px;font-weight:600;color:var(--slate-600);
  text-transform:uppercase;letter-spacing:.05em;
}
.form-label .opt{color:var(--slate-400);font-weight:400;text-transform:none;letter-spacing:0}

.form-input,.form-select,.form-textarea{
  width:100%;border:1px solid var(--slate-300);border-radius:var(--r-sm);
  padding:9px 12px;font-size:13.5px;
  background:var(--white);color:var(--slate-800);
  font-family:inherit;transition:border-color .15s,box-shadow .15s;line-height:1.5;
}
.form-input:focus,.form-select:focus,.form-textarea:focus{
  outline:none;border-color:var(--green-600);
  box-shadow:0 0 0 3px rgba(22,163,74,.12);
}
.form-input.error,.form-select.error{border-color:var(--red-600);background:var(--red-50)}
.form-textarea{min-height:80px;resize:vertical}
.form-error{font-size:12px;color:var(--red-600);margin-top:2px}

/* ── Cards ──────────────────────────────────────────────── */
.card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);
}
.card-header{padding:18px 22px;border-bottom:1px solid var(--border-light)}
.card-header h3{font-size:14px;font-weight:700;color:var(--slate-900);margin-bottom:2px}
.card-header p{font-size:12.5px;color:var(--slate-400)}
.card-body{padding:22px}

/* ── KPI Cards ──────────────────────────────────────────── */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:14px}

.kpi-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);padding:20px;
  box-shadow:var(--shadow-sm);
  transition:box-shadow .2s,transform .2s;
  position:relative;overflow:hidden;
}
.kpi-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.kpi-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:3px;
  background:var(--kpi-color,var(--slate-300));
}
.kpi-card-green  {--kpi-color:var(--green-600)}
.kpi-card-blue   {--kpi-color:var(--blue-600)}
.kpi-card-indigo {--kpi-color:var(--indigo-600)}
.kpi-card-emerald{--kpi-color:var(--emerald-600)}
.kpi-card-teal   {--kpi-color:var(--teal-600)}
.kpi-card-purple {--kpi-color:var(--purple-600)}
.kpi-card-orange {--kpi-color:var(--orange-600)}
.kpi-card-red    {--kpi-color:var(--red-600)}

.kpi-icon{
  width:36px;height:36px;border-radius:var(--r-sm);
  display:flex;align-items:center;justify-content:center;
  margin-bottom:14px;
}
.kpi-icon svg{width:18px;height:18px;fill:var(--kpi-color,var(--slate-500))}
.kpi-card-green  .kpi-icon{background:var(--green-50)}
.kpi-card-blue   .kpi-icon{background:var(--blue-50)}
.kpi-card-indigo .kpi-icon{background:var(--indigo-50)}
.kpi-card-emerald .kpi-icon{background:var(--emerald-50)}
.kpi-card-teal   .kpi-icon{background:var(--teal-50)}
.kpi-card-purple .kpi-icon{background:var(--purple-50)}
.kpi-card-orange .kpi-icon{background:var(--orange-50)}

.kpi-label{
  font-size:11px;font-weight:600;color:var(--slate-500);
  text-transform:uppercase;letter-spacing:.06em;margin-bottom:6px;
}
.kpi-value{
  font-size:28px;font-weight:700;color:var(--slate-900);
  line-height:1;letter-spacing:-.02em;margin-bottom:4px;
}
.kpi-value.colored{color:var(--kpi-color,var(--slate-900))}
.kpi-sub{font-size:11.5px;color:var(--slate-400)}

/* ── Stats row ──────────────────────────────────────────── */
.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}
.stat-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);padding:18px 20px;box-shadow:var(--shadow-sm);
}
.stat-label{
  font-size:11px;font-weight:600;color:var(--slate-500);
  text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;
}
.stat-value{font-size:26px;font-weight:700;color:var(--slate-900);line-height:1}
.stat-value.green {color:var(--green-600)}
.stat-value.red   {color:var(--red-600)}
.stat-value.blue  {color:var(--blue-600)}
.stat-value.gray  {color:var(--slate-400)}

/* ── Table card ─────────────────────────────────────────── */
.table-card{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm);
}
.table-card-header{
  padding:18px 22px;border-bottom:1px solid var(--border-light);
  display:flex;align-items:center;justify-content:space-between;
  flex-wrap:wrap;gap:8px;
}
.table-card-header h3{font-size:14px;font-weight:700;color:var(--slate-900)}
.table-card-header p{font-size:12.5px;color:var(--slate-400);margin-top:2px}

.table-wrap{overflow-x:auto}

.data-table{width:100%;border-collapse:collapse;min-width:640px}
.data-table th{
  background:var(--slate-50);color:var(--slate-500);
  font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;
  padding:11px 18px;border-bottom:1px solid var(--border);
  text-align:left;white-space:nowrap;
}
.data-table td{
  padding:14px 18px;border-bottom:1px solid var(--border-light);
  font-size:13.5px;color:var(--slate-700);vertical-align:middle;
}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover{background:#fafbfc}

/* ── Member cell ────────────────────────────────────────── */
.member-cell{display:flex;align-items:center;gap:10px}
.member-avatar{
  width:36px;height:36px;border-radius:50%;
  background:linear-gradient(135deg,var(--indigo-100),var(--indigo-50));
  color:var(--indigo-700);font-size:12px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;text-transform:uppercase;border:1px solid var(--indigo-100);
}
.member-avatar.sm{width:30px;height:30px;font-size:11px}
.member-name{font-weight:600;color:var(--slate-900);font-size:13.5px}
.member-id  {font-size:11px;color:var(--slate-400);margin-top:1px}

/* ── Page header ────────────────────────────────────────── */
.page-header{
  display:flex;justify-content:space-between;align-items:flex-start;
  flex-wrap:wrap;gap:12px;
}
.page-header h1{
  font-size:22px;font-weight:700;color:var(--slate-900);
  letter-spacing:-.02em;margin-bottom:3px;
}
.page-header p{font-size:13.5px;color:var(--slate-500)}
.page-date{font-size:12px;color:var(--slate-400);white-space:nowrap;padding-top:4px}

/* ── Toolbar ────────────────────────────────────────────── */
.toolbar{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.toolbar-title{font-size:15px;font-weight:700;color:var(--slate-800)}
.toolbar-sub  {font-size:12.5px;color:var(--slate-500);margin-top:2px}

/* ── Search block ───────────────────────────────────────── */
.search-block{
  background:var(--white);border:1px solid var(--border);
  border-radius:var(--r-md);padding:18px;box-shadow:var(--shadow-sm);
}
.search-form{display:flex;gap:10px;flex-wrap:wrap;align-items:flex-end}

/* ── Empty state ────────────────────────────────────────── */
.empty-state{padding:56px 24px;text-align:center}
.empty-icon {font-size:40px;margin-bottom:14px;opacity:.35}
.empty-title{font-size:16px;font-weight:600;color:var(--slate-700);margin-bottom:6px}
.empty-sub  {font-size:13px;color:var(--slate-400);line-height:1.6}

/* ── Actions ────────────────────────────────────────────── */
.actions{display:flex;flex-wrap:wrap;gap:6px}
.row-num{font-size:12px;color:var(--slate-300);font-weight:600}
.pagination-wrap{padding:14px 18px;border-top:1px solid var(--border-light);display:flex;justify-content:flex-end}

/* ── Form layout ────────────────────────────────────────── */
.form-section{margin-bottom:28px;padding-bottom:28px;border-bottom:1px solid var(--border-light)}
.form-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}
.form-section-title{
  font-size:11px;font-weight:700;color:var(--slate-600);
  text-transform:uppercase;letter-spacing:.08em;
  margin-bottom:18px;display:flex;align-items:center;gap:10px;
}
.form-section-title::after{content:'';flex:1;height:1px;background:var(--border-light)}
.form-grid  {display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form-grid-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:18px}
.form-actions{
  display:flex;justify-content:flex-end;gap:10px;
  margin-top:24px;padding-top:22px;border-top:1px solid var(--border-light);
}

/* ── Dashboard specifics ────────────────────────────────── */
.dash-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.dash-card{background:var(--white);border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;box-shadow:var(--shadow-sm)}
.dash-card.full{grid-column:1/-1}
.dash-card-header{
  padding:16px 20px;border-bottom:1px solid var(--border-light);
  display:flex;align-items:center;justify-content:space-between;
}
.dash-card-header h3{font-size:14px;font-weight:700;color:var(--slate-900);margin:0}
.dash-card-body{padding:18px 20px}

.bar-row{display:flex;align-items:center;gap:10px;margin-bottom:10px}
.bar-label{font-size:12px;color:var(--slate-500);width:32px;text-align:right;flex-shrink:0}
.bar-track{flex:1;height:10px;background:var(--slate-100);border-radius:var(--r-full);overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--green-600),var(--emerald-600));border-radius:var(--r-full);transition:width .6s ease}
.bar-val{font-size:12px;font-weight:600;color:var(--slate-700);width:90px;text-align:right;white-space:nowrap}

.inside-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border-light)}
.inside-row:last-child{border-bottom:none}
.inside-name{font-size:13px;font-weight:600;color:var(--slate-900)}
.inside-sub {font-size:11px;color:var(--slate-400);margin-top:1px}
.inside-time{margin-left:auto;font-size:12px;color:var(--slate-500);white-space:nowrap;flex-shrink:0}

.expire-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light)}
.expire-row:last-child{border-bottom:none}
.expire-name{font-size:13px;font-weight:600;color:var(--slate-900)}
.expire-plan{font-size:11px;color:var(--slate-400);margin-top:1px}
.expire-days{font-size:12px;font-weight:700;padding:3px 9px;border-radius:var(--r-sm);flex-shrink:0}
.days-red   {background:var(--red-50);   color:var(--red-600)}
.days-orange{background:var(--orange-50);color:var(--orange-600)}
.days-green {background:var(--green-50); color:var(--green-600)}

.quick-actions{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.qa-btn{
  display:flex;align-items:center;gap:12px;
  padding:13px 15px;
  background:var(--slate-50);border:1px solid var(--border);
  border-radius:var(--r);
  color:var(--slate-800);font-size:13px;font-weight:600;
  text-decoration:none;transition:all .15s;
}
.qa-btn:hover{background:var(--green-50);border-color:var(--green-200);color:var(--green-800)}
.qa-icon{
  width:36px;height:36px;border-radius:var(--r-sm);
  background:var(--white);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;font-size:18px;
}
.qa-btn:hover .qa-icon{background:var(--green-50);border-color:var(--green-100)}
.qa-sub{font-size:11px;color:var(--slate-400);font-weight:400;margin-top:1px}

.view-all{font-size:12px;color:var(--slate-400);text-decoration:none;transition:color .15s}
.view-all:hover{color:var(--slate-700)}
.empty-note{font-size:13px;color:var(--slate-400);text-align:center;padding:20px 0}

.count-badge{
  background:var(--green-50);color:var(--green-700);
  font-size:11px;font-weight:700;padding:2px 9px;
  border-radius:var(--r-full);border:1px solid var(--green-100);
  margin-left:8px;vertical-align:middle;
}

/* ── Attendance specifics ───────────────────────────────── */
.at-member-box{
  background:var(--slate-50);border:1px solid var(--border);
  border-radius:var(--r-md);overflow:hidden;margin-top:18px;
}
.at-member-top{
  display:flex;align-items:center;gap:14px;
  padding:18px 20px;border-bottom:1px solid var(--border);flex-wrap:wrap;
}
.at-avatar{
  width:52px;height:52px;border-radius:50%;
  background:linear-gradient(135deg,var(--indigo-100),var(--indigo-50));
  color:var(--indigo-700);font-size:17px;font-weight:700;
  display:flex;align-items:center;justify-content:center;
  flex-shrink:0;text-transform:uppercase;
  border:2px solid var(--indigo-200);
}
.at-member-name{font-size:17px;font-weight:700;color:var(--slate-900);margin-bottom:2px}
.at-member-sub {font-size:13px;color:var(--slate-500)}
.at-member-org {font-size:12px;color:var(--purple-700);margin-top:2px;font-weight:500}
.at-status-badge{margin-left:auto;flex-shrink:0}

.at-member-grid{display:grid;grid-template-columns:repeat(2,1fr)}
.at-field{padding:13px 20px;border-bottom:1px solid var(--border)}
.at-field:nth-child(odd){border-right:1px solid var(--border)}
.at-field:nth-last-child(-n+2){border-bottom:none}
.at-field-label{font-size:11px;font-weight:600;color:var(--slate-400);text-transform:uppercase;letter-spacing:.05em;margin-bottom:4px}
.at-field-value{font-size:14px;font-weight:500;color:var(--slate-800)}

.at-product-row{padding:16px 20px;border-top:1px solid var(--border);background:var(--white)}
.at-product-label{font-size:11px;font-weight:600;color:var(--slate-600);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px}
.at-product-grid{display:flex;gap:8px;flex-wrap:wrap}
.at-product-btn{
  padding:8px 14px;border-radius:var(--r-sm);border:1px solid var(--border);
  background:var(--white);color:var(--slate-700);font-size:13px;font-weight:500;
  cursor:pointer;transition:all .15s;font-family:inherit;
}
.at-product-btn:hover{background:var(--slate-50)}
.at-product-btn.selected{background:var(--slate-800);border-color:var(--slate-800);color:white}
.at-product-price{font-size:11px;opacity:.7;margin-left:4px}

.at-action-bar{
  display:flex;align-items:center;gap:12px;
  padding:14px 20px;border-top:1px solid var(--border);
  background:var(--white);flex-wrap:wrap;
}
.at-eligibility{font-size:13px;color:var(--slate-600);flex:1;min-width:200px}

.btn-checkin{background:var(--green-50);border-color:var(--green-200);color:var(--green-800);font-size:14px;padding:11px 24px}
.btn-checkin:hover{background:var(--green-100)}
.btn-checkout{background:var(--orange-50);border-color:var(--orange-200);color:var(--orange-800);font-size:14px;padding:11px 24px}
.btn-checkout:hover{background:var(--orange-100)}
.btn-search{background:var(--slate-800);border-color:var(--slate-800);color:white}
.btn-search:hover{background:var(--slate-700)}

.at-total-row{
  display:flex;align-items:center;gap:10px;
  margin-top:12px;padding:10px 14px;
  background:var(--green-50);border:1px solid var(--green-200);
  border-radius:var(--r-sm);
}
.at-total-label{font-size:12px;font-weight:600;color:var(--green-800);text-transform:uppercase;letter-spacing:.05em}
.at-total-amount{font-size:16px;font-weight:700;color:var(--green-700)}

/* ── Sidebar overlay ────────────────────────────────────── */
.sidebar-overlay{
  display:none;position:fixed;inset:0;
  background:rgba(15,23,42,.3);z-index:999;
  backdrop-filter:blur(2px);
}
.sidebar-overlay.show{display:block}

/* ── Page wrapper ───────────────────────────────────────── */
.page-ui{display:flex;flex-direction:column;gap:22px}
.text-muted{color:var(--slate-400);font-size:13px}

/* ── Responsive ─────────────────────────────────────────── */
@media(max-width:1024px){
  .sidebar{
    position:fixed;top:0;left:-270px;height:100%;z-index:1000;
    transition:left .22s cubic-bezier(.4,0,.2,1);
  }
  .sidebar.open{left:0;box-shadow:var(--shadow-lg)}
  .mobile-menu-toggle{display:inline-flex}
  .topbar{padding:12px 18px}
  .content-area{padding:18px}
}
@media(max-width:768px){
  .kpi-grid{grid-template-columns:repeat(2,1fr)}
  .stats-row{grid-template-columns:repeat(2,1fr)}
  .dash-grid{grid-template-columns:1fr}
  .dash-card.full{grid-column:1}
  .form-grid{grid-template-columns:1fr}
  .form-grid-3{grid-template-columns:1fr 1fr}
  .toolbar{flex-direction:column;align-items:stretch}
  .toolbar .btn{width:100%;justify-content:center}
  .form-actions{flex-direction:column-reverse}
  .form-actions .btn{width:100%;justify-content:center}
  .search-form{flex-direction:column}
  .quick-actions{grid-template-columns:1fr}
  .at-member-grid{grid-template-columns:1fr}
  .at-field:nth-child(odd){border-right:none}
  .at-field:nth-last-child(-n+2){border-bottom:1px solid var(--border)}
  .at-field:last-child{border-bottom:none}
  .page-header{flex-direction:column;gap:10px}
  .page-header h1{font-size:18px}
  .page-date{padding-top:0}
  .topbar-right{display:none}
  .kpi-value{font-size:22px}
  .kpi-card{padding:16px}
  #gchat-panel{width:calc(100vw - 32px);max-width:340px}
  .table-card-header{flex-direction:column;align-items:flex-start}
}
@media(max-width:480px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .form-grid-3{grid-template-columns:1fr}
  .content-area{padding:12px}
  .topbar{padding:10px 12px;gap:8px}
  .topbar-left h2{font-size:13px}
  .topbar-left p{display:none}
  .mobile-menu-toggle{padding:5px}
  .kpi-value{font-size:18px}
  .kpi-card{padding:12px}
  .kpi-icon{width:28px;height:28px;margin-bottom:10px}
  .stat-value{font-size:20px}
  .page-header h1{font-size:16px}
  .page-header p{font-size:12px}
  .card-body{padding:14px}
  .card-header{padding:12px 14px}
  .table-card-header{padding:12px 14px}
  .data-table th,.data-table td{padding:10px 12px}
  .stats-row{grid-template-columns:1fr 1fr}
  .dash-card-header{padding:12px 14px}
  .dash-card-body{padding:12px 14px}
  .btn{padding:7px 12px;font-size:12px}
  .btn-lg{padding:10px 18px;font-size:13px}
  #gchat-wrap{bottom:14px;right:14px}
  #gchat-panel{width:calc(100vw - 28px)}
  #gchat-toggle{width:46px;height:46px;font-size:18px}
  .at-member-top{padding:14px}
  .at-avatar{width:42px;height:42px;font-size:14px}
  .at-member-name{font-size:15px}
  .at-action-bar{flex-direction:column;align-items:stretch}
  .at-action-bar .btn{width:100%;justify-content:center}
  .at-eligibility{min-width:0}
  .sidebar-footer{padding:10px 10px 16px}
  .user-info{padding:8px 6px 10px}
}
