/* ═══════════════════════════════════════════════════════════════════
   PREMIUM DESIGN OVERHAUL
   Modern, elegant enterprise styling with glass morphism,
   refined shadows, smoother animations, and premium feel.
═══════════════════════════════════════════════════════════════════ */

/* ── Fix: .modal-overlay (used by enterprise modals) ── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 25, 35, 0.5);
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
  z-index: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: fadeIn 0.2s ease;
}
.modal-overlay .modal {
  animation: modalSlideIn 0.25s cubic-bezier(0.34, 1.56, 0.64, 1);
}

@keyframes fadeIn {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes modalSlideIn {
  from { opacity: 0; transform: scale(0.92) translateY(12px); }
  to { opacity: 1; transform: scale(1) translateY(0); }
}

/* ── Enhanced Overlay/Modal animations ── */
.overlay {
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  background: rgba(15, 25, 35, 0.5);
  transition: opacity 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.overlay.show .modal {
  animation: modalSlideIn 0.3s cubic-bezier(0.34, 1.56, 0.64, 1);
}

/* ── Premium Sidebar ── */
.sidebar {
  background: linear-gradient(180deg, #0A1F14 0%, #112B1C 40%, #0E2316 100%);
  border-left: 1px solid rgba(52, 212, 138, 0.06);
}
.sb-brand {
  padding: 20px 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
}
.sb-brand-logo {
  background: linear-gradient(135deg, rgba(52, 212, 138, 0.15), rgba(34, 160, 90, 0.08));
  border: 1px solid rgba(52, 212, 138, 0.12);
  box-shadow: 0 2px 12px rgba(52, 212, 138, 0.08);
}
.sb-brand-name {
  font-size: 13.5px;
  font-weight: 800;
  letter-spacing: 0.2px;
}
.sb-item {
  border-radius: 10px;
  margin: 1px 8px;
  padding: 10px 14px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}
.sb-item:hover {
  background: rgba(255, 255, 255, 0.06);
  transform: translateX(-2px);
}
.sb-item.active {
  background: rgba(52, 212, 138, 0.12);
  border-right: 3px solid var(--g300);
  box-shadow: inset 0 0 16px rgba(52, 212, 138, 0.04);
}
.sb-item .si {
  font-size: 16px;
  width: 28px;
  text-align: center;
}
.sb-user-card {
  border: 1px solid rgba(255, 255, 255, 0.06);
  background: rgba(255, 255, 255, 0.03);
  border-radius: 12px;
  transition: background 0.2s;
}
.sb-user-card:hover {
  background: rgba(255, 255, 255, 0.05);
}
.sb-logout-btn {
  border-radius: 10px;
  transition: all 0.2s;
}
.sb-logout-btn:hover {
  background: rgba(220, 38, 38, 0.12) !important;
  color: #FCA5A5 !important;
}

/* ── Premium Topbar ── */
.topbar {
  background: var(--white);
  border-bottom: 1px solid var(--n150);
  box-shadow: 0 1px 8px rgba(15, 25, 35, 0.04);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* ── Glass Morphism Cards ── */
.card {
  background: var(--white);
  border: 1px solid var(--n150);
  border-radius: 16px;
  box-shadow: 0 1px 3px rgba(15, 25, 35, 0.04), 0 4px 16px rgba(15, 25, 35, 0.02);
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  overflow: hidden;
}
.card:hover {
  box-shadow: 0 2px 8px rgba(15, 25, 35, 0.06), 0 8px 24px rgba(15, 25, 35, 0.04);
}
.card-header {
  padding: 16px 20px;
  border-bottom: 1px solid var(--n100);
  background: linear-gradient(180deg, var(--n50), transparent);
}
.card-title {
  font-size: 14px;
  font-weight: 700;
  letter-spacing: 0.1px;
}
.card-title-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--g500);
  box-shadow: 0 0 8px rgba(34, 160, 90, 0.4);
}

/* ── Premium Stat Cards ── */
.stat-card {
  border-radius: 16px;
  border: 1px solid var(--n150);
  padding: 20px;
  position: relative;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
.stat-card::before {
  height: 4px;
  border-radius: 0 0 4px 4px;
}
.stat-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 8px 32px rgba(15, 25, 35, 0.12);
}
.stat-icon-wrap {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  font-size: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
}
.stat-num {
  font-family: 'Tajawal', sans-serif;
  font-size: 28px;
  font-weight: 900;
  color: var(--n900);
  line-height: 1.1;
  letter-spacing: -0.5px;
}
.stat-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--n500);
  margin-top: 4px;
  letter-spacing: 0.2px;
}
.stat-sub {
  font-size: 11px;
  margin-top: 8px;
  padding: 3px 8px;
  border-radius: 6px;
  display: inline-block;
  font-weight: 600;
}
.stat-sub.up {
  background: rgba(34, 160, 90, 0.1);
  color: var(--g600);
}
.stat-sub.down {
  background: rgba(224, 32, 32, 0.08);
  color: var(--red600);
}
.stat-sub.neutral {
  background: var(--n100);
  color: var(--n500);
}

/* ── Premium Buttons ── */
.btn {
  border-radius: 10px;
  font-weight: 600;
  letter-spacing: 0.15px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
  overflow: hidden;
}
.btn::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(180deg, rgba(255,255,255,0.12) 0%, transparent 100%);
  pointer-events: none;
}
.btn-primary {
  background: linear-gradient(135deg, var(--g600), var(--g500));
  box-shadow: 0 2px 8px rgba(30, 122, 68, 0.25);
}
.btn-primary:hover {
  background: linear-gradient(135deg, var(--g700), var(--g600));
  box-shadow: 0 4px 16px rgba(30, 122, 68, 0.35);
  transform: translateY(-1px);
}
.btn-secondary {
  border-color: var(--n200);
  box-shadow: 0 1px 2px rgba(15, 25, 35, 0.04);
}
.btn-secondary:hover {
  border-color: var(--n300);
  background: var(--n50);
  box-shadow: 0 2px 6px rgba(15, 25, 35, 0.06);
}
.btn-danger {
  background: linear-gradient(135deg, var(--red600), var(--red500));
  box-shadow: 0 2px 8px rgba(200, 30, 30, 0.2);
}
.btn-danger:hover {
  box-shadow: 0 4px 14px rgba(200, 30, 30, 0.3);
  transform: translateY(-1px);
}
.btn-warning {
  background: linear-gradient(135deg, var(--amber500), #E5A00D);
  color: white;
  border: none;
  box-shadow: 0 2px 8px rgba(217, 119, 6, 0.2);
}
.btn-warning:hover {
  box-shadow: 0 4px 14px rgba(217, 119, 6, 0.3);
  transform: translateY(-1px);
}

/* ── Premium Data Tables ── */
.data-table {
  border-collapse: separate;
  border-spacing: 0;
}
.data-table thead th {
  background: linear-gradient(180deg, var(--n50), var(--n100));
  font-size: 11.5px;
  font-weight: 700;
  color: var(--n600);
  letter-spacing: 0.3px;
  text-transform: none;
  padding: 12px 16px;
  border-bottom: 2px solid var(--n200);
  white-space: nowrap;
}
.data-table tbody td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--n100);
  font-size: 13px;
  transition: background 0.15s;
}
.data-table tbody tr:hover td {
  background: rgba(34, 160, 90, 0.03);
}

/* ── Premium Tags ── */
.tag {
  padding: 3px 10px;
  border-radius: 8px;
  font-size: 11.5px;
  font-weight: 700;
  letter-spacing: 0.1px;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: all 0.15s;
}
.tag-green {
  background: rgba(34, 160, 90, 0.1);
  color: var(--g700);
  border: 1px solid rgba(34, 160, 90, 0.15);
}
.tag-gold {
  background: rgba(240, 180, 41, 0.1);
  color: var(--au700);
  border: 1px solid rgba(240, 180, 41, 0.15);
}
.tag-red {
  background: rgba(224, 32, 32, 0.08);
  color: var(--red600);
  border: 1px solid rgba(224, 32, 32, 0.12);
}
.tag-blue {
  background: rgba(34, 112, 224, 0.08);
  color: var(--blue600);
  border: 1px solid rgba(34, 112, 224, 0.12);
}
.tag-purple {
  background: rgba(124, 58, 237, 0.08);
  color: var(--purple500);
  border: 1px solid rgba(124, 58, 237, 0.12);
}
.tag-gray {
  background: var(--n100);
  color: var(--n600);
  border: 1px solid var(--n200);
}

/* ── Premium Alerts ── */
.alert {
  border-radius: 12px;
  padding: 14px 18px;
  font-size: 13px;
  line-height: 1.7;
  border-width: 1px;
  border-style: solid;
}
.alert-green {
  background: linear-gradient(135deg, rgba(240, 253, 246, 0.8), rgba(214, 247, 232, 0.5));
  border-color: var(--g200);
}
.alert-gold {
  background: linear-gradient(135deg, rgba(254, 243, 199, 0.8), rgba(254, 243, 199, 0.4));
  border-color: #F5D79E;
}
.alert-red {
  background: linear-gradient(135deg, rgba(254, 232, 232, 0.8), rgba(254, 232, 232, 0.4));
  border-color: #FBD0D0;
}
.alert-blue {
  background: linear-gradient(135deg, rgba(232, 242, 254, 0.8), rgba(232, 242, 254, 0.4));
  border-color: #B6D4FE;
  color: var(--blue600);
}

/* ── Premium Form Inputs ── */
.fi {
  border-radius: 10px;
  border: 1.5px solid var(--n200);
  padding: 10px 14px;
  font-size: 13px;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  background: var(--white);
}
.fi:focus {
  border-color: var(--g400);
  box-shadow: 0 0 0 3px rgba(34, 160, 90, 0.12);
  outline: none;
}
.fs {
  border-radius: 10px;
  border: 1.5px solid var(--n200);
  padding: 10px 14px;
  transition: all 0.2s;
}
.fs:focus {
  border-color: var(--g400);
  box-shadow: 0 0 0 3px rgba(34, 160, 90, 0.12);
  outline: none;
}
.fl {
  font-size: 12px;
  font-weight: 700;
  color: var(--n600);
  margin-bottom: 6px;
  letter-spacing: 0.15px;
}

/* ── Premium Modal Refinement ── */
.modal {
  border-radius: 20px;
  box-shadow: 0 24px 80px rgba(15, 25, 35, 0.2), 0 8px 24px rgba(15, 25, 35, 0.1);
  border: 1px solid var(--n150);
}
.modal-header {
  padding: 20px 24px 16px;
  background: linear-gradient(180deg, var(--white), var(--n50));
  border-radius: 20px 20px 0 0;
}
.modal-title {
  font-size: 18px;
  font-weight: 800;
}
.modal-footer {
  background: linear-gradient(180deg, transparent, var(--n50));
  border-radius: 0 0 20px 20px;
  padding: 16px 24px;
}

/* ── Premium Progress Bars ── */
.prog-bar {
  height: 6px;
  background: var(--n100);
  border-radius: 100px;
  overflow: hidden;
}
.prog-fill {
  height: 100%;
  border-radius: 100px;
  transition: width 0.6s cubic-bezier(0.4, 0, 0.2, 1);
  position: relative;
}
.prog-fill::after {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.3), transparent);
  animation: shimmer 2s infinite;
}
@keyframes shimmer {
  0% { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* ── Premium Avatar ── */
.avatar {
  border-radius: 12px;
  font-weight: 800;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0,0,0,0.06);
  transition: transform 0.2s;
}

/* ── Page Header Enhancement ── */
.page-header {
  margin-bottom: 24px;
}
.page-header h1 {
  font-family: 'Tajawal', sans-serif;
  font-size: 24px;
  font-weight: 900;
  color: var(--n900);
  letter-spacing: -0.3px;
  line-height: 1.3;
}
.page-header p {
  font-size: 13px;
  color: var(--n500);
  margin-top: 4px;
  font-weight: 500;
}

/* ── Empty State Enhancement ── */
.empty-state {
  padding: 48px 24px;
  text-align: center;
}
.es-icon {
  font-size: 48px;
  margin-bottom: 12px;
  filter: grayscale(0.3);
}
.es-title {
  font-family: 'Tajawal', sans-serif;
  font-size: 16px;
  font-weight: 700;
  color: var(--n700);
  margin-bottom: 4px;
}
.es-sub {
  font-size: 13px;
  color: var(--n400);
}

/* ── Salary Card Enhancement ── */
.sal-card {
  border-radius: 16px;
  border: 1px solid var(--n150);
  overflow: hidden;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
}
.sal-card:hover {
  box-shadow: 0 8px 32px rgba(15, 25, 35, 0.1);
  transform: translateY(-2px);
}
.sal-card-head {
  padding: 16px 18px;
  background: linear-gradient(135deg, var(--n50), var(--white));
  border-bottom: 1px solid var(--n100);
}
.sal-total {
  background: linear-gradient(135deg, #0E4D2F, #1E7A44);
  border-radius: 12px;
  padding: 14px 16px;
  margin-top: 12px;
  color: white;
}
.sal-total .sl {
  color: rgba(255, 255, 255, 0.8);
}
.sal-total .sv {
  font-size: 18px;
  font-weight: 900;
  color: white;
}

/* ── Premium Notification Items ── */
.notif-page-item {
  border-radius: 14px;
  border: 1px solid var(--n150);
  padding: 16px 18px;
  margin-bottom: 10px;
  transition: all 0.2s;
  background: var(--white);
}
.notif-page-item:hover {
  box-shadow: 0 4px 16px rgba(15, 25, 35, 0.06);
}
.notif-page-item.urgent {
  border-right: 4px solid var(--red500);
}
.notif-page-item.warning {
  border-right: 4px solid var(--amber500);
}
.notif-page-item.info {
  border-right: 4px solid var(--blue500);
}

/* ── Premium Login Screen — dark glassmorphism (overrides base) ── */
#login-screen .login-card,
#setup-screen .login-card,
#redeem-screen .login-card {
  background: rgba(10, 15, 12, 0.92) !important;
  border: 1px solid rgba(30, 148, 104, 0.1) !important;
  border-radius: 24px;
  box-shadow: 0 25px 60px rgba(0, 0, 0, 0.5);
  backdrop-filter: blur(40px);
  -webkit-backdrop-filter: blur(40px);
}
#login-screen .login-card-header h2,
#setup-screen .login-card-header h2 {
  font-size: 22px;
  font-weight: 900;
  background: linear-gradient(135deg, #1e9468, #9ee8cb, #1e9468);
  -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.lf-btn {
  border-radius: 12px;
  font-size: 15px;
  font-weight: 700;
  padding: 14px;
  background: linear-gradient(135deg, var(--g600), var(--g500));
  box-shadow: 0 4px 16px rgba(30, 122, 68, 0.3);
  transition: all 0.25s;
}
.lf-btn:hover {
  box-shadow: 0 6px 24px rgba(30, 122, 68, 0.4);
  transform: translateY(-2px);
}
.lf-input {
  border-radius: 12px;
  border: 1.5px solid var(--n200);
  transition: all 0.2s;
}
.lf-input:focus {
  border-color: var(--g400);
  box-shadow: 0 0 0 3px rgba(34, 160, 90, 0.12);
}
.demo-btn {
  border-radius: 12px;
  border: 1.5px solid var(--n200);
  transition: all 0.2s;
}
.demo-btn:hover {
  border-color: var(--g300);
  background: var(--g50);
  transform: translateY(-2px);
  box-shadow: 0 4px 12px rgba(34, 160, 90, 0.1);
}

/* ── Premium Tooltips ── */
[title] {
  position: relative;
}

/* ── Smooth page transitions ── */
.page {
  animation: pageIn 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}
@keyframes pageIn {
  from { opacity: 0; transform: translateY(8px); }
  to { opacity: 1; transform: translateY(0); }
}

/* ── Pill badge enhancement ── */
.sb-pill {
  font-size: 10px;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 100px;
  min-width: 20px;
  text-align: center;
}

/* ── Permission Denied Enhancement ── */
.perm-denied {
  text-align: center;
  padding: 60px 24px;
}
.pd-icon {
  font-size: 56px;
  margin-bottom: 16px;
  opacity: 0.6;
}
.pd-title {
  font-family: 'Tajawal', sans-serif;
  font-size: 18px;
  font-weight: 800;
  color: var(--n700);
  margin-bottom: 6px;
}
.pd-sub {
  font-size: 13px;
  color: var(--n400);
}

/* ── Timesheet Enhancement ── */
.ts-month-nav {
  gap: 12px;
}
.ts-month-name {
  font-family: 'Tajawal', sans-serif;
  font-weight: 800;
  font-size: 16px;
}
.ts-arrow {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  transition: all 0.2s;
}
.ts-arrow:hover {
  background: var(--g50);
  color: var(--g600);
}
.day-cell {
  border-radius: 8px;
  font-weight: 700;
  transition: all 0.15s;
}

/* ── Session Warning Enhancement ── */
.session-warn {
  border-radius: 14px;
  box-shadow: 0 8px 32px rgba(15, 25, 35, 0.15);
  border: 1px solid rgba(217, 119, 6, 0.2);
}

/* ── Enhanced Spotlight ── */
.spotlight-box {
  border-radius: 20px;
  box-shadow: 0 24px 80px rgba(15, 25, 35, 0.3);
  border: 1px solid var(--n200);
}
.spotlight-input {
  font-size: 16px;
}

/* ── Section Dividers ── */
.section-divider {
  margin: 24px 0;
}
.section-divider-label {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.3px;
}

/* ── Chart Cards Enhancement ── */
.chart-card {
  border-radius: 16px;
  border: 1px solid var(--n150);
  overflow: hidden;
}
.chart-card-head {
  padding: 16px 18px;
  background: linear-gradient(180deg, var(--n50), transparent);
}
.chart-card-title {
  font-size: 14px;
  font-weight: 700;
}
.chart-card-sub {
  font-size: 11px;
  color: var(--n400);
  margin-top: 2px;
}

/* ── Notification Dropdown Enhancement ── */
.notif-dropdown {
  border-radius: 16px;
  box-shadow: 0 16px 48px rgba(15, 25, 35, 0.15);
  border: 1px solid var(--n150);
}
.notif-dd-head {
  border-radius: 16px 16px 0 0;
}

/* ── Sync Badge Enhancement ── */
.sync-badge {
  border-radius: 100px;
  font-size: 11px;
  font-weight: 600;
  padding: 4px 12px;
  transition: all 0.2s;
}

/* ── KPI Animation Refinement ── */
.analytics-kpi-grid .stat-card {
  border-radius: 16px;
}

/* ═══════ DARK MODE PREMIUM OVERRIDES ═══════ */
/* ── Premium Dark Mode — uses --dk-* vars from styles.css ── */
[data-theme="dark"] .card { background: var(--dk-card, #151f2e); border-color: var(--dk-border, rgba(30,148,104,0.1)); }
[data-theme="dark"] .card-header { background: var(--dk-surface, #111827); border-color: var(--dk-border); }
[data-theme="dark"] .stat-card { background: var(--dk-card); border-color: var(--dk-border); }
[data-theme="dark"] .stat-num { color: var(--dk-text, #f0f0f0); }
[data-theme="dark"] .data-table thead th { background: var(--dk-surface); color: var(--dk-text2, #b0b8c4); border-color: var(--dk-border); }
[data-theme="dark"] .data-table tbody td { border-color: var(--dk-border); color: var(--dk-text2); }
[data-theme="dark"] .data-table tbody tr:hover td { background: var(--dk-hover, rgba(30,148,104,0.08)); }
[data-theme="dark"] .fi, [data-theme="dark"] .fs { background: var(--dk-card); border-color: var(--dk-border); color: var(--dk-text); }
[data-theme="dark"] .fi:focus, [data-theme="dark"] .fs:focus { border-color: rgba(30,148,104,0.25); box-shadow: 0 0 0 3px rgba(30,148,104,0.12); }
[data-theme="dark"] .modal { background: var(--dk-surface); border: 1px solid var(--dk-border); }
[data-theme="dark"] .modal-header { background: var(--dk-surface); border-color: var(--dk-border); }
[data-theme="dark"] .modal-footer { background: var(--dk-card); border-color: var(--dk-border); }
[data-theme="dark"] .topbar { background: var(--dk-surface); border-color: var(--dk-border); }
[data-theme="dark"] .login-card { background: rgba(10,15,12,0.92); border-color: rgba(30,148,104,0.1); }
[data-theme="dark"] .sal-card { background: var(--dk-card); border-color: var(--dk-border); }
[data-theme="dark"] .sal-card-head { background: var(--dk-surface); border-color: var(--dk-border); }
[data-theme="dark"] .notif-page-item { background: var(--dk-card); border-color: var(--dk-border); }
[data-theme="dark"] .notif-dropdown { background: var(--dk-surface); border-color: var(--dk-border); }
[data-theme="dark"] .spotlight-box { background: var(--dk-surface); border-color: var(--dk-border); }
[data-theme="dark"] .chart-card { background: var(--dk-card); border-color: var(--dk-border); }
[data-theme="dark"] .chart-card-head { background: var(--dk-surface); border-color: var(--dk-border); }
[data-theme="dark"] .prog-bar { background: rgba(30,148,104,0.1); }
/* Tags already defined in styles.css dark mode */
/* Alerts already defined in styles.css dark mode */

/* ── Scrollbar Premium ── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--n300); border-radius: 100px; }
::-webkit-scrollbar-thumb:hover { background: var(--n400); }
[data-theme="dark"] ::-webkit-scrollbar-thumb { background: rgba(30,148,104,0.3); }
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover { background: rgba(30,148,104,0.5); }

/* ── Global Smooth Transitions ── */
html {
  scroll-behavior: smooth;
}

/* ═══════ SUBSCRIPTION & PLAN CARDS ═══════ */
.plan-card { background: var(--white, #fff); border: 1px solid var(--n200, #e5e7eb); border-radius: 16px; overflow: hidden; transition: all 0.25s ease; }
.plan-card:hover { transform: translateY(-4px); box-shadow: 0 8px 32px rgba(0,0,0,0.1); }
.plan-card.plan-current { border-color: var(--g500, #22c55e); box-shadow: 0 0 0 2px var(--g200, #bbf7d0); }
.plan-card-header { padding: 24px 20px; text-align: center; border-bottom: 3px solid var(--n100, #f3f4f6); }
.plan-name { font-family: 'Tajawal', sans-serif; font-size: 20px; font-weight: 800; margin-top: 8px; }
.plan-name-en { font-size: 12px; color: var(--n400, #9ca3af); margin-top: 2px; }
.plan-price { margin-top: 12px; }
.price-num { font-size: 28px; font-weight: 900; color: var(--g700, #15803d); }
.price-unit { font-size: 12px; color: var(--n500, #6b7280); }
.plan-card-body { padding: 16px 20px; }
.plan-feat-item { font-size: 13px; padding: 6px 0; border-bottom: 1px solid var(--n50, #f9fafb); }
.plan-feat-item:last-child { border-bottom: none; }
.plan-card-footer { padding: 12px 20px; text-align: center; background: var(--g50, #f0fdf4); }

/* Subscription badges */
.sub-badge { display: inline-flex; align-items: center; gap: 6px; padding: 4px 12px; border-radius: 20px; font-size: 11px; font-weight: 600; }
.sub-active { background: var(--g50, #f0fdf4); color: var(--g700, #15803d); border: 1px solid var(--g200, #bbf7d0); }
.sub-trial { background: #eff6ff; color: #1d4ed8; border: 1px solid #bfdbfe; }
.sub-expiring { background: #fef2f2; color: #b91c1c; border: 1px solid #fecaca; animation: pulse 2s infinite; }
.sub-none { background: var(--n100, #f3f4f6); color: var(--n600, #4b5563); border: 1px solid var(--n200, #e5e7eb); }

/* Plan locked sidebar items */
.sb-item.plan-locked { opacity: 0.5; }
.sb-item.plan-locked:hover { opacity: 0.7; }

/* Dark mode overrides */
[data-theme="dark"] .plan-card { background: var(--dk-card, #151f2e); border-color: var(--dk-border, rgba(30,148,104,0.1)); }
[data-theme="dark"] .plan-card-header { border-color: var(--dk-border); }
[data-theme="dark"] .plan-feat-item { border-color: rgba(255,255,255,0.04); }
[data-theme="dark"] .plan-card-footer { background: rgba(30,148,104,0.08); }
