/* ============================================================================
   BAYAR GG — Premium Redesign Layer  (development.bayar.gg)
   Aesthetic target: Stripe · Linear · Vercel · Ramp
   Strategy: token-driven overlay loaded AFTER includes/styles.php so the new
   look cascades across every page. Frontend-only. No markup/PHP/API/DB changes
   required for the global facelift.
   ============================================================================ */

/* ---------------------------------------------------------------------------
   1. DESIGN TOKENS — DARK (default)
   The whole app reads these variables, so redefining them re-skins everything.
   --------------------------------------------------------------------------- */
:root,
[data-theme="dark"] {
  /* Brand */
  --primary:            #4571ff;
  --primary-dark:       #2f5ae6;
  --primary-light:      #88a6ff;
  --primary-glow:       rgba(69, 113, 255, .38);
  --electric-blue:      #4571ff;

  /* Background layers — refined cool near-black (Linear/Vercel) */
  --bg-base:            #08090c;
  --bg-primary:         #0a0c11;
  --bg-secondary:       #0d0f15;
  --bg-tertiary:        #13151c;
  --bg-elevated:        #161821;
  --bg-surface:         #1b1e28;

  /* Glass / hairlines */
  --glass-bg:           rgba(255, 255, 255, .024);
  --glass-bg-hover:     rgba(255, 255, 255, .045);
  --glass-bg-active:    rgba(255, 255, 255, .065);
  --glass-border:       rgba(255, 255, 255, .08);
  --glass-border-hover: rgba(255, 255, 255, .16);

  /* Text hierarchy — soft white, never pure #fff for body */
  --text-primary:       #f3f5fb;
  --text-secondary:     rgba(243, 245, 251, .66);
  --text-tertiary:      rgba(243, 245, 251, .48);
  --text-muted:         rgba(243, 245, 251, .38);

  /* Accents */
  --accent-green:       #2dd4a7;
  --accent-red:         #fb6a72;
  --accent-yellow:      #f5b945;
  --accent-purple:      #5aa6ff;
  --accent-cyan:        #46c6f5;

  /* Status */
  --success:            #2dd4a7;
  --success-bg:         rgba(45, 212, 167, .12);
  --success-border:     rgba(45, 212, 167, .26);
  --warning:            #f5b945;
  --warning-bg:         rgba(245, 185, 69, .12);
  --warning-border:     rgba(245, 185, 69, .26);
  --danger:             #fb6a72;
  --danger-bg:          rgba(251, 106, 114, .12);
  --danger-border:      rgba(251, 106, 114, .26);
  --info:               #4571ff;
  --info-bg:            rgba(69, 113, 255, .12);
  --info-border:        rgba(69, 113, 255, .26);

  /* Premium effect tokens (namespaced --ds-) */
  --ds-hairline:        rgba(255, 255, 255, .08);
  --ds-hairline-strong: rgba(255, 255, 255, .14);
  --ds-grad-brand:      linear-gradient(135deg, #3b74ff 0%, #18a0fb 100%);
  --ds-grad-brand-soft: linear-gradient(135deg, rgba(69,113,255,.16), rgba(122,92,255,.16));
  --ds-grad-text:       linear-gradient(120deg, #ffffff 0%, #cdd8ff 55%, #88a6ff 100%);
  --ds-ring:            rgba(69, 113, 255, .55);
  --ds-surface-sheen:   inset 0 1px 0 rgba(255, 255, 255, .06);

  /* Shadows — soft, layered; dark mode leans on hairlines + glow */
  --shadow-card:        0 1px 2px rgba(0, 0, 0, .35);
  --shadow-card-hover:  0 18px 44px -22px rgba(0, 0, 0, .8);
  --shadow-sm:          0 1px 2px rgba(0, 0, 0, .4);
  --shadow-md:          0 10px 28px -14px rgba(0, 0, 0, .7);
  --shadow-lg:          0 22px 50px -22px rgba(0, 0, 0, .75);
  --shadow-xl:          0 32px 70px -28px rgba(0, 0, 0, .8);
  --ds-shadow-pop:      0 24px 64px -24px rgba(0, 0, 0, .82);
  --ds-glow:            0 0 0 1px rgba(69, 113, 255, .35), 0 16px 48px -16px rgba(69, 113, 255, .5);
  --shadow-glow:        var(--ds-glow);

  /* Motion */
  --ease-out:    cubic-bezier(.16, 1, .3, 1);
  --ease-bounce: cubic-bezier(.34, 1.4, .5, 1);
  --ease-smooth: cubic-bezier(.4, 0, .2, 1);
  --duration-fast: 150ms;
  --duration-normal: 220ms;

  /* Radii — slightly tightened for a sharper, modern feel */
  --radius-sm: 8px;
  --radius-md: 11px;
  --radius-lg: 15px;
  --radius-xl: 20px;
  --radius-2xl: 26px;
  --radius-full: 9999px;
  --card-radius: 16px;

  color-scheme: dark;
}

/* ---------------------------------------------------------------------------
   2. DESIGN TOKENS — LIGHT  (premium, low-glare; Vercel/Stripe light)
   --------------------------------------------------------------------------- */
[data-theme="light"] {
  --primary:            #2f55ff;
  --primary-dark:       #2244db;
  --primary-light:      #5b79ff;
  --primary-glow:       rgba(47, 85, 255, .16);
  --electric-blue:      #2f55ff;

  --bg-base:            #fafbfd;
  --bg-primary:         #fafbfd;
  --bg-secondary:       #ffffff;
  --bg-tertiary:        #f1f4f9;
  --bg-elevated:        #ffffff;
  --bg-surface:         #ffffff;

  --glass-bg:           #ffffff;
  --glass-bg-hover:     #f6f8fc;
  --glass-bg-active:    #eef2f9;
  --glass-border:       #e6e9f1;
  --glass-border-hover: #d2d8e6;

  --text-primary:       #0a0c14;
  --text-secondary:     #444b5b;
  --text-tertiary:      #5c6475;
  --text-muted:         #7b8294;

  --accent-green:       #0c9f74;
  --accent-red:         #e0515b;
  --accent-yellow:      #b9791a;
  --accent-purple:      #2f7fe6;
  --accent-cyan:        #0c93b8;

  --success:            #0c9f74;
  --success-bg:         #e9fbf4;
  --success-border:     #b3ecd8;
  --warning:            #b9791a;
  --warning-bg:         #fff7e8;
  --warning-border:     #f6e0ad;
  --danger:             #e0515b;
  --danger-bg:          #fdeef0;
  --danger-border:      #f7cdd2;
  --info:               #2f55ff;
  --info-bg:            #ecf1ff;
  --info-border:        #c6d4ff;

  --ds-hairline:        #e6e9f1;
  --ds-hairline-strong: #d2d8e6;
  --ds-grad-brand:      linear-gradient(135deg, #2f55ff 0%, #1f8fff 100%);
  --ds-grad-brand-soft: linear-gradient(135deg, rgba(47,85,255,.08), rgba(107,83,255,.08));
  --ds-grad-text:       linear-gradient(120deg, #0a0c14 0%, #27408b 65%, #2f55ff 100%);
  --ds-ring:            rgba(47, 85, 255, .38);
  --ds-surface-sheen:   inset 0 1px 0 rgba(255, 255, 255, .9);

  --shadow-card:        0 0 0 1px #e6e9f1;
  --shadow-card-hover:  0 0 0 1px #d2d8e6, 0 14px 30px -14px rgba(16, 24, 64, .16);
  --shadow-sm:          0 1px 2px rgba(16, 24, 64, .06);
  --shadow-md:          0 6px 16px -8px rgba(16, 24, 64, .12);
  --shadow-lg:          0 16px 36px -16px rgba(16, 24, 64, .16);
  --shadow-xl:          0 28px 60px -24px rgba(16, 24, 64, .2);
  --ds-shadow-pop:      0 24px 56px -24px rgba(16, 24, 64, .24);
  --ds-glow:            0 0 0 1px rgba(47, 85, 255, .25), 0 16px 40px -16px rgba(47, 85, 255, .3);

  color-scheme: light;
}

/* ---------------------------------------------------------------------------
   3. BASE & TYPOGRAPHY
   --------------------------------------------------------------------------- */
html { -webkit-text-size-adjust: 100%; }

body {
  background: var(--bg-base);
  color: var(--text-primary);
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  font-feature-settings: "cv11", "ss01", "cv02", "cv03", "cv04";
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  letter-spacing: -0.011em;
  text-rendering: optimizeLegibility;
}

h1, h2, h3, h4, h5, h6,
.h1, .h2, .h3, .h4, .h5, .h6 {
  color: var(--text-primary);
  font-weight: 700;
  letter-spacing: -0.025em;
  line-height: 1.15;
}
h1, .h1 { font-weight: 800; letter-spacing: -0.035em; }

p { color: var(--text-secondary); }

a {
  color: var(--primary-light);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-smooth);
}
a:hover { color: var(--primary); }

::selection { background: rgba(69, 113, 255, .32); color: #fff; }
[data-theme="light"] ::selection { background: rgba(47, 85, 255, .2); color: #0a0c14; }

hr { border-color: var(--ds-hairline); opacity: 1; }
.text-muted { color: var(--text-muted) !important; }
.text-secondary { color: var(--text-secondary) !important; }

/* Refined scrollbars */
* { scrollbar-width: thin; scrollbar-color: var(--ds-hairline-strong) transparent; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb {
  background: var(--ds-hairline-strong);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
::-webkit-scrollbar-thumb:hover { background: var(--glass-border-hover); background-clip: padding-box; }

/* ---------------------------------------------------------------------------
   4. ATMOSPHERE UTILITIES (opt-in helpers for premium sections)
   --------------------------------------------------------------------------- */
.ds-gradient-text {
  background: var(--ds-grad-text);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.ds-grid-bg {
  background-image:
    linear-gradient(var(--ds-hairline) 1px, transparent 1px),
    linear-gradient(90deg, var(--ds-hairline) 1px, transparent 1px);
  background-size: 56px 56px;
  -webkit-mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 80%);
  mask-image: radial-gradient(ellipse 80% 60% at 50% 0%, #000 30%, transparent 80%);
}
.ds-dot-bg {
  background-image: radial-gradient(var(--ds-hairline) 1px, transparent 1px);
  background-size: 28px 28px;
}
.ds-glass {
  background: var(--glass-bg);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  backdrop-filter: blur(20px) saturate(160%);
  border: 1px solid var(--glass-border);
}
.ds-glow { box-shadow: var(--ds-glow); }
.ds-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 14px; border-radius: 999px;
  background: var(--ds-grad-brand-soft);
  border: 1px solid var(--glass-border);
  color: var(--primary-light);
  font-size: .74rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
}
.ds-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--primary); box-shadow: 0 0 10px var(--primary); }

/* ---------------------------------------------------------------------------
   5. BUTTONS  (Bootstrap + landing overrides)
   --------------------------------------------------------------------------- */
.btn {
  --bs-btn-border-radius: var(--radius-md);
  border-radius: var(--radius-md);
  font-weight: 600;
  letter-spacing: -0.01em;
  padding: .62rem 1.15rem;
  transition: transform var(--duration-fast) var(--ease-out),
              box-shadow var(--duration-normal) var(--ease-smooth),
              background-color var(--duration-normal), border-color var(--duration-normal), color var(--duration-normal);
}
.btn:active { transform: translateY(1px); }
.btn-lg { padding: .85rem 1.6rem; font-size: 1rem; border-radius: var(--radius-lg); }
.btn-sm { padding: .4rem .8rem; border-radius: var(--radius-sm); }

.btn-primary,
.landing-page .btn-primary {
  background: var(--ds-grad-brand);
  border: 1px solid transparent;
  color: #fff;
  box-shadow: var(--ds-surface-sheen), 0 10px 26px -12px var(--primary-glow);
}
.btn-primary:hover, .btn-primary:focus-visible,
.landing-page .btn-primary:hover {
  background: var(--ds-grad-brand);
  color: #fff;
  transform: translateY(-2px);
  box-shadow: var(--ds-surface-sheen), 0 18px 44px -14px var(--primary-glow);
}
.btn-primary:disabled, .btn-primary.disabled { opacity: .55; box-shadow: none; }

.btn-outline-primary,
.landing-page .btn-outline-primary {
  border: 1px solid var(--glass-border-hover);
  color: var(--text-primary);
  background: var(--glass-bg);
}
.btn-outline-primary:hover,
.landing-page .btn-outline-primary:hover {
  background: var(--glass-bg-hover);
  border-color: var(--primary);
  color: var(--text-primary);
}

.btn-secondary {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
}
.btn-secondary:hover { background: var(--glass-bg-hover); border-color: var(--glass-border-hover); color: var(--text-primary); }

.btn-light {
  background: var(--text-primary);
  border: 1px solid transparent;
  color: var(--bg-base);
  font-weight: 650;
}
.btn-light:hover { background: var(--text-primary); color: var(--bg-base); transform: translateY(-2px); box-shadow: var(--shadow-md); }

.btn-success { background: var(--success); border-color: transparent; color: #03110c; font-weight: 650; }
.btn-success:hover { background: var(--success); filter: brightness(1.05); color: #03110c; }
.btn-danger { background: var(--danger); border-color: transparent; color: #fff; }
.btn-outline-light { border-color: var(--glass-border-hover); color: var(--text-primary); }
.btn-outline-light:hover { background: var(--glass-bg-hover); color: var(--text-primary); border-color: var(--glass-border-hover); }
.btn-link { color: var(--primary-light); text-decoration: none; }
.btn-link:hover { color: var(--primary); }

/* ---------------------------------------------------------------------------
   6. SURFACES — cards, list groups, alerts
   --------------------------------------------------------------------------- */
.card {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--card-radius);
  box-shadow: var(--shadow-card);
  color: var(--text-primary);
}
.card .card-header,
.card .card-footer { background: transparent; border-color: var(--ds-hairline); }

.ds-card {
  position: relative;
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
  transition: transform var(--duration-normal) var(--ease-out),
              border-color var(--duration-normal), box-shadow var(--duration-normal);
}
.ds-card:hover {
  transform: translateY(-4px);
  border-color: var(--glass-border-hover);
  box-shadow: var(--ds-surface-sheen), var(--shadow-card-hover);
}

.list-group-item {
  background: var(--bg-elevated);
  border-color: var(--ds-hairline);
  color: var(--text-primary);
}
.alert { border-radius: var(--radius-md); border: 1px solid var(--glass-border); }

.dropdown-menu {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  box-shadow: var(--ds-shadow-pop);
  padding: 6px;
}
.dropdown-item { color: var(--text-secondary); border-radius: 8px; padding: .5rem .7rem; }
.dropdown-item:hover, .dropdown-item:focus { background: var(--glass-bg-hover); color: var(--text-primary); }
.dropdown-divider { border-color: var(--ds-hairline); }

.modal-content {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  box-shadow: var(--ds-shadow-pop);
}
.modal-header, .modal-footer { border-color: var(--ds-hairline); }
.offcanvas { background: var(--bg-secondary); color: var(--text-primary); border-color: var(--ds-hairline); }

/* Tables */
.table {
  --bs-table-bg: transparent;
  --bs-table-color: var(--text-secondary);
  --bs-table-border-color: var(--ds-hairline);
  color: var(--text-secondary);
}
.table > thead th {
  color: var(--text-muted);
  font-size: .74rem; font-weight: 600; letter-spacing: .06em; text-transform: uppercase;
  border-bottom: 1px solid var(--ds-hairline);
}
.table > tbody > tr { border-color: var(--ds-hairline); }
.table-hover > tbody > tr:hover > * { background: var(--glass-bg-hover); color: var(--text-primary); }

/* Badges & pills */
.badge { font-weight: 600; letter-spacing: .01em; border-radius: 999px; padding: .4em .7em; }
.badge.bg-primary { background: var(--ds-grad-brand) !important; }
.badge.bg-success { background: var(--success-bg) !important; color: var(--success) !important; border: 1px solid var(--success-border); }
.badge.bg-danger  { background: var(--danger-bg)  !important; color: var(--danger)  !important; border: 1px solid var(--danger-border); }
.badge.bg-warning { background: var(--warning-bg) !important; color: var(--warning) !important; border: 1px solid var(--warning-border); }

/* ---------------------------------------------------------------------------
   7. FORMS
   --------------------------------------------------------------------------- */
.form-control, .form-select {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-radius: var(--radius-md);
  padding: .72rem .95rem;
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast), background var(--duration-fast);
}
.form-control:hover, .form-select:hover { border-color: var(--glass-border-hover); }
.form-control:focus, .form-select:focus {
  background: var(--glass-bg-hover);
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--ds-ring);
  color: var(--text-primary);
}
.form-control::placeholder { color: var(--text-muted); }
.form-label { color: var(--text-secondary); font-weight: 550; font-size: .86rem; margin-bottom: .4rem; }
.input-group-text { background: var(--glass-bg); border: 1px solid var(--glass-border); color: var(--text-tertiary); }
.form-check-input { background-color: var(--glass-bg); border-color: var(--glass-border-hover); }
.form-check-input:checked { background-color: var(--primary); border-color: var(--primary); }
.form-check-input:focus { box-shadow: 0 0 0 3px var(--ds-ring); border-color: var(--primary); }

/* ---------------------------------------------------------------------------
   8. LANDING PAGE — elevate existing classes to Stripe/Linear calm-premium
   --------------------------------------------------------------------------- */
.landing-navbar {
  background: color-mix(in srgb, var(--bg-base) 72%, transparent);
  -webkit-backdrop-filter: blur(22px) saturate(180%);
  backdrop-filter: blur(22px) saturate(180%);
  border-bottom: 1px solid var(--ds-hairline);
}
.landing-navbar.scrolled {
  background: color-mix(in srgb, var(--bg-base) 90%, transparent);
  box-shadow: 0 1px 0 var(--ds-hairline), 0 20px 40px -30px rgba(0,0,0,.8);
}
.landing-navbar .nav-links a:not(.btn) { color: var(--text-tertiary); font-size: .9rem; }
.landing-navbar .nav-links a:not(.btn):hover { color: var(--text-primary); }

/* Hero — replace busy animated gradient with a calm, premium atmosphere */
.hero-section {
  background:
    radial-gradient(70% 60% at 72% 12%, rgba(69,113,255,.20), transparent 60%),
    radial-gradient(50% 55% at 16% 88%, rgba(122,92,255,.12), transparent 62%),
    var(--bg-base) !important;
  background-size: auto !important;
  animation: none !important;
  border-bottom: 1px solid var(--ds-hairline);
}
.hero-section::before {
  background:
    radial-gradient(60% 50% at 70% 28%, rgba(69,113,255,.16) 0%, transparent 70%) !important;
}
.hero-section::after {
  background-image:
    linear-gradient(var(--ds-hairline) 1px, transparent 1px),
    linear-gradient(90deg, var(--ds-hairline) 1px, transparent 1px) !important;
  background-size: 54px 54px !important;
  -webkit-mask-image: radial-gradient(ellipse 75% 70% at 50% 25%, #000 25%, transparent 80%);
  mask-image: radial-gradient(ellipse 75% 70% at 50% 25%, #000 25%, transparent 80%);
  opacity: .7;
}
.hero-section h1 { letter-spacing: -.045em; }
.hero-section h1 .highlight {
  background: var(--ds-grad-text);
  background-size: auto;
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
  animation: none;
}
[data-theme="light"] .hero-section { color: var(--text-primary); }
[data-theme="light"] .hero-section p { color: var(--text-secondary); }

/* Hero CTAs */
.btn-hero-primary {
  background: var(--ds-grad-brand) !important;
  box-shadow: var(--ds-surface-sheen), 0 14px 40px -14px var(--primary-glow) !important;
}
.btn-hero-outline {
  border: 1px solid var(--glass-border-hover) !important;
  color: var(--text-primary) !important;
  background: var(--glass-bg) !important;
}
.btn-hero-outline:hover { background: var(--glass-bg-hover) !important; border-color: var(--glass-border-hover) !important; }

/* Stats / feature tiles — hairline glass */
.stat-item {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
}
.stat-item:hover { background: var(--glass-bg-hover); border-color: var(--glass-border-hover); transform: translateY(-3px); }
.stat-item .number { background: var(--ds-grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.stat-item .label { color: var(--text-muted); }

/* Generic eyebrow pills already used on landing */
.vc-section-title .vc-eyebrow {
  background: var(--ds-grad-brand-soft);
  border: 1px solid var(--glass-border);
  color: var(--primary-light);
}
.vc-section-title h2 { background: var(--ds-grad-text); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }

/* ---------------------------------------------------------------------------
   9. AUTH PAGES — premium centered card on atmospheric background
   (kicks in when body has .auth-page / .login-page; harmless otherwise)
   --------------------------------------------------------------------------- */
.auth-shell {
  min-height: 100dvh;
  display: grid; place-items: center;
  padding: 24px;
  background:
    radial-gradient(60% 50% at 50% 0%, rgba(69,113,255,.16), transparent 60%),
    var(--bg-base);
}
.auth-card {
  width: 100%; max-width: 440px;
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--ds-surface-sheen), var(--ds-shadow-pop);
  padding: 36px;
}

/* ---------------------------------------------------------------------------
   10. DASHBOARD / APP CHROME polish (sidebar, topbar, balance cards)
   --------------------------------------------------------------------------- */
.sidebar { background: var(--bg-secondary); border-right: 1px solid var(--ds-hairline); }
.sidebar-menu a { color: var(--text-tertiary); border-radius: var(--radius-sm); transition: background var(--duration-fast), color var(--duration-fast); }
.sidebar-menu a:hover { background: var(--glass-bg-hover); color: var(--text-primary); }
.sidebar-menu a.active { background: var(--ds-grad-brand-soft); color: var(--text-primary); }
.mobile-header { background: color-mix(in srgb, var(--bg-base) 82%, transparent); -webkit-backdrop-filter: blur(18px); backdrop-filter: blur(18px); border-bottom: 1px solid var(--ds-hairline); }

.balance-card, .stat-card, .admin-stat-card {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
}
.balance-card:hover, .stat-card:hover, .admin-stat-card:hover { border-color: var(--glass-border-hover); }

/* Mobile bottom nav */
.bottom-nav, .mobile-bottom-nav {
  background: color-mix(in srgb, var(--bg-base) 86%, transparent);
  -webkit-backdrop-filter: blur(20px) saturate(180%);
  backdrop-filter: blur(20px) saturate(180%);
  border-top: 1px solid var(--ds-hairline);
}

/* ---------------------------------------------------------------------------
   11. ACCESSIBILITY
   --------------------------------------------------------------------------- */
:focus-visible {
  outline: 2px solid var(--ds-ring);
  outline-offset: 2px;
  border-radius: 6px;
}
.btn:focus-visible, .form-control:focus-visible, .form-select:focus-visible,
a:focus-visible { outline: 2px solid var(--ds-ring); outline-offset: 2px; }

.skip-to-content {
  position: absolute; left: 12px; top: -60px; z-index: 2000;
  background: var(--bg-elevated); color: var(--text-primary);
  border: 1px solid var(--glass-border); border-radius: 10px;
  padding: 10px 16px; font-weight: 600;
  transition: top var(--duration-normal) var(--ease-out);
}
.skip-to-content:focus { top: 12px; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
    scroll-behavior: auto !important;
  }
}

/* ---------------------------------------------------------------------------
   12. RESPONSIVE refinements
   --------------------------------------------------------------------------- */
@media (max-width: 991.98px) {
  .auth-card { padding: 28px; }
}
@media (max-width: 575.98px) {
  .btn-lg { padding: .8rem 1.2rem; font-size: .95rem; }
  .auth-card { padding: 22px; border-radius: var(--radius-xl); }
  h1, .h1 { letter-spacing: -.03em; }
}

/* Touch targets: ensure interactive controls are comfortable on mobile */
@media (pointer: coarse) {
  .btn, .nav-link, .dropdown-item { min-height: 44px; display: inline-flex; align-items: center; }
  .dropdown-item { display: flex; }
}

/* ---------------------------------------------------------------------------
   13. AUTH PAGES (self-contained login/register/forgot) — premium component
   polish on top of the cascaded tokens.
   --------------------------------------------------------------------------- */
.login-card, .register-card {
  border-radius: var(--radius-2xl) !important;
  box-shadow: var(--ds-surface-sheen), var(--ds-shadow-pop) !important;
}
.form-group input, .form-group select, .form-group textarea {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-radius: var(--radius-md);
  transition: border-color var(--duration-fast), box-shadow var(--duration-fast), background var(--duration-fast);
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus {
  border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--ds-ring);
  background: var(--glass-bg-hover);
  outline: none;
}
.btn-login, .submit-btn,
[data-theme="light"] .btn-login, [data-theme="light"] .submit-btn {
  background: var(--ds-grad-brand) !important;
  border: 1px solid transparent !important;
  color: #fff !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--ds-surface-sheen), 0 12px 30px -12px var(--primary-glow) !important;
  transition: transform var(--duration-fast) var(--ease-out), box-shadow var(--duration-normal) !important;
}
.btn-login:hover, .submit-btn:hover { transform: translateY(-2px) !important; }

/* Auth page atmospheric background */
body:has(.login-container),
body:has(.register-container) {
  background:
    radial-gradient(55% 42% at 50% -6%, rgba(41,151,255,.05), transparent 64%),
    var(--bg-base) !important;
}
[data-theme="light"] body:has(.login-container),
[data-theme="light"] body:has(.register-container) {
  background:
    radial-gradient(60% 50% at 50% 0%, rgba(47,85,255,.05), transparent 62%),
    var(--bg-base) !important;
}
.login-container, .register-container { max-width: 460px; }

/* Cloudflare Turnstile captcha renders normally (production keeps full verification). */

/* ---------------------------------------------------------------------------
   14. LANDING PAGE — bespoke section polish (Stripe / Linear / Vercel)
   --------------------------------------------------------------------------- */
.landing-page { background: var(--bg-base); }

/* Light mode hero — add premium atmosphere (was too flat in QA) */
[data-theme="light"] .hero-section {
  background:
    radial-gradient(70% 60% at 72% 8%, rgba(47,85,255,.10), transparent 58%),
    radial-gradient(50% 50% at 12% 92%, rgba(107,83,255,.06), transparent 62%),
    var(--bg-base) !important;
  color: var(--text-primary);
}
[data-theme="light"] .hero-section::before,
[data-theme="light"] .hero-section::after { opacity: 1; }
[data-theme="light"] .hero-section h1,
[data-theme="light"] .hero-section h1 .highlight { color: var(--text-primary); }
[data-theme="light"] .hero-section p { color: var(--text-secondary); }
[data-theme="light"] .btn-hero-outline {
  border-color: var(--glass-border-hover) !important;
  color: var(--text-primary) !important;
  background: var(--bg-secondary) !important;
}

/* Section titles */
.section-title { text-align: center; margin-bottom: 56px; }
.section-title h2 {
  font-size: clamp(1.75rem, 3vw, 2.35rem);
  font-weight: 800;
  letter-spacing: -.035em;
  color: var(--text-primary);
  margin-bottom: 14px;
}
.section-title h2::after { display: none; }
.section-title p {
  color: var(--text-secondary);
  font-size: 1.02rem;
  max-width: 640px;
  margin: 0 auto;
  line-height: 1.65;
}

/* Feature grid */
.features-section {
  background: var(--bg-primary);
  padding: 96px 0;
  border-top: 1px solid var(--ds-hairline);
}
.feature-card {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 28px;
  height: 100%;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
  transition: transform var(--duration-normal) var(--ease-out),
              border-color var(--duration-normal), box-shadow var(--duration-normal);
}
.feature-card::before {
  background: var(--ds-grad-brand) !important;
  height: 2px;
}
.feature-card:hover {
  transform: translateY(-5px);
  border-color: var(--glass-border-hover);
  box-shadow: var(--ds-surface-sheen), var(--shadow-card-hover);
}
.feature-icon {
  width: 48px; height: 48px;
  border-radius: var(--radius-md);
  background: var(--ds-grad-brand-soft);
  border: 1px solid var(--glass-border);
  color: var(--primary-light);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.25rem;
  margin-bottom: 18px;
}
.feature-card h4 {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -.02em;
  color: var(--text-primary);
  margin-bottom: 10px;
}
.feature-card p { color: var(--text-secondary); font-size: .92rem; line-height: 1.6; }
.feature-card ul li { color: var(--text-tertiary); font-size: .86rem; }
.feature-card ul li i { color: var(--success); }

/* Pricing grid on landing */
.pricing-section {
  background: var(--bg-secondary);
  padding: 96px 0;
  border-top: 1px solid var(--ds-hairline);
}
.pricing-card {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 28px 22px;
  height: 100%;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
  transition: transform var(--duration-normal) var(--ease-out), border-color var(--duration-normal), box-shadow var(--duration-normal);
}
.pricing-card:hover {
  transform: translateY(-4px);
  border-color: var(--glass-border-hover);
  box-shadow: var(--ds-surface-sheen), var(--shadow-card-hover);
}
.pricing-card.featured {
  border-color: rgba(69, 113, 255, .45);
  box-shadow: var(--ds-surface-sheen), var(--ds-glow);
}
.pricing-badge {
  background: var(--ds-grad-brand-soft);
  color: var(--primary-light);
  border: 1px solid var(--glass-border);
  border-radius: 999px;
  font-size: .68rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.pricing-card h3 { color: var(--text-primary); font-weight: 700; letter-spacing: -.02em; }
.pricing-card .price {
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -.03em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
}
.pricing-card .price span { color: var(--text-muted); font-size: .85rem; font-weight: 500; }
.pricing-card ul li { color: var(--text-secondary); font-size: .86rem; }

/* How-it-works */
.hiw-section {
  background: var(--bg-primary);
  padding: 96px 0;
  border-top: 1px solid var(--ds-hairline);
}
.hiw-step {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 28px 22px;
  text-align: center;
  height: 100%;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
}
.hiw-step-num {
  display: inline-flex;
  padding: 5px 12px;
  border-radius: 999px;
  background: var(--ds-grad-brand-soft);
  border: 1px solid var(--glass-border);
  color: var(--primary-light);
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .05em;
  text-transform: uppercase;
  margin-bottom: 14px;
}
.hiw-step h4, .hiw-step .step-title {
  color: var(--text-primary);
  font-weight: 700;
  letter-spacing: -.02em;
}
.hiw-step p { color: var(--text-secondary); font-size: .9rem; }

/* WA Store section */
.wa-store-section {
  background: var(--bg-secondary) !important;
  border-top: 1px solid var(--ds-hairline);
}
.wa-store-section::before { opacity: .5 !important; }

/* Hero dashboard mockup */
.hero-dash {
  background: var(--bg-elevated) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-xl) !important;
  box-shadow: var(--ds-surface-sheen), var(--ds-shadow-pop) !important;
  overflow: hidden;
}
.hero-dash-bar { background: var(--bg-surface) !important; border-bottom: 1px solid var(--ds-hairline) !important; }
.hero-stat-card {
  background: var(--glass-bg) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-md) !important;
}
.hero-trx { border-color: var(--ds-hairline) !important; }
.hero-trx-name { color: var(--text-primary) !important; }
.hero-trx-time { color: var(--text-muted) !important; }

/* CTA band */
.cta-section {
  background:
    radial-gradient(60% 80% at 50% 100%, rgba(69,113,255,.18), transparent 65%),
    var(--bg-base) !important;
  border-top: 1px solid var(--ds-hairline);
  padding: 96px 0 !important;
}
.cta-section::before { opacity: .4 !important; }
.cta-section h2 {
  font-size: clamp(1.75rem, 3vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -.035em;
  color: var(--text-primary);
}
.cta-section p { color: var(--text-secondary); max-width: 560px; margin-left: auto; margin-right: auto; }

/* Landing footer */
.landing-footer {
  background: var(--bg-secondary) !important;
  border-top: 1px solid var(--ds-hairline);
  padding: 64px 0 32px !important;
}
.landing-footer h5 {
  color: var(--text-primary);
  font-weight: 700;
  letter-spacing: -.01em;
  font-size: .92rem;
}
.landing-footer a { color: var(--text-tertiary); transition: color var(--duration-fast); }
.landing-footer a:hover { color: var(--primary-light); }
.landing-footer p { color: var(--text-muted) !important; }

/* FAQ accordion — premium */
.landing-page .accordion-item {
  background: var(--bg-elevated) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-md) !important;
  margin-bottom: 10px !important;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.landing-page .accordion-button {
  background: transparent !important;
  color: var(--text-primary) !important;
  font-weight: 600 !important;
  font-size: .95rem !important;
  padding: 18px 20px !important;
  box-shadow: none !important;
}
.landing-page .accordion-button:not(.collapsed) {
  background: var(--glass-bg-hover) !important;
  color: var(--text-primary) !important;
}
.landing-page .accordion-button::after { filter: opacity(.55); }
[data-theme="dark"] .landing-page .accordion-button::after { filter: invert(1) opacity(.45); }
.landing-page .accordion-body {
  color: var(--text-secondary) !important;
  font-size: .92rem !important;
  line-height: 1.65 !important;
  padding: 0 20px 18px !important;
}

/* ---------------------------------------------------------------------------
   15. APP PAGES — dashboard, pricing (service-subscription), card system
   --------------------------------------------------------------------------- */
.top-bar {
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 22px 26px;
  margin-bottom: 24px;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
}
.top-bar h4 {
  font-weight: 800;
  letter-spacing: -.025em;
  color: var(--text-primary);
  margin-bottom: 4px;
}
.top-bar p { color: var(--text-secondary); margin: 0; font-size: .92rem; }

.card-custom,
.card-3d-glass,
.card-glass {
  background: var(--bg-elevated) !important;
  border: 1px solid var(--glass-border) !important;
  border-radius: var(--radius-lg) !important;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card) !important;
  transition: border-color var(--duration-normal), box-shadow var(--duration-normal), transform var(--duration-normal);
}
.card-custom:hover,
.card-3d-glass:hover,
.card-glass:hover {
  border-color: var(--glass-border-hover) !important;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card-hover) !important;
}

.card-icon {
  border-radius: var(--radius-md);
  border: 1px solid var(--glass-border);
}
.icon-primary { background: var(--ds-grad-brand-soft) !important; color: var(--primary-light) !important; }
.icon-success { background: var(--success-bg) !important; color: var(--success) !important; border-color: var(--success-border) !important; }
.icon-warning { background: var(--warning-bg) !important; color: var(--warning) !important; border-color: var(--warning-border) !important; }
.icon-danger  { background: var(--danger-bg)  !important; color: var(--danger)  !important; border-color: var(--danger-border)  !important; }

.text-title { color: var(--text-primary); font-weight: 700; letter-spacing: -.015em; }
.text-subtitle { color: var(--text-secondary); font-size: .9rem; line-height: 1.55; }

/* Premium pricing page plan cards */
.plan-price-value {
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -.03em;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  margin: 8px 0 16px;
}
.plan-price-value small { color: var(--text-muted); font-weight: 500; }
.plan-features li {
  color: var(--text-secondary);
  border-color: var(--ds-hairline) !important;
  padding: 10px 0 !important;
}
.duration-btn {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  color: var(--text-primary);
  border-radius: var(--radius-sm);
  min-width: 44px; min-height: 44px;
}
.duration-btn:hover { background: var(--glass-bg-hover); border-color: var(--primary); }
.duration-display {
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
}
.total-price {
  font-weight: 700;
  color: var(--primary-light);
  margin: 12px 0 16px;
  font-variant-numeric: tabular-nums;
}

/* Floating widget stack — cleaner premium FAB */
.floating-widget-stack .fab-btn,
.floating-widget-stack button[class*="fab"] {
  background: var(--bg-elevated) !important;
  border: 1px solid var(--glass-border) !important;
  box-shadow: var(--shadow-md) !important;
  color: var(--primary-light) !important;
  transition: transform var(--duration-fast), box-shadow var(--duration-normal), border-color var(--duration-fast);
}
.floating-widget-stack .fab-btn:hover,
.floating-widget-stack button[class*="fab"]:hover {
  transform: translateY(-2px);
  border-color: var(--glass-border-hover) !important;
  box-shadow: var(--shadow-lg) !important;
}

/* Main footer on app pages */
.main-footer {
  background: var(--bg-secondary);
  border-top: 1px solid var(--ds-hairline);
}
.main-footer a { color: var(--text-tertiary); }
.main-footer a:hover { color: var(--primary-light); }

/* Skip link injection target — ensure main content landmark spacing */
.main-content { padding-bottom: calc(var(--bottom-nav-height, 72px) + 16px); }

@media (max-width: 767.98px) {
  .features-section, .pricing-section, .hiw-section, .cta-section { padding: 64px 0; }
  .section-title { margin-bottom: 36px; }
  .feature-card, .pricing-card { padding: 22px; }
  .top-bar { padding: 18px; }
}

/* ===========================================================================
   16. BESPOKE DASHBOARD — premium hero balance card + refined stat grid
   =========================================================================== */
.dashboard-balance-card {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(255,255,255,.16), transparent 45%),
    linear-gradient(135deg, #2f6bff 0%, #3b8eff 50%, #1fb6e6 100%) !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  box-shadow: var(--ds-surface-sheen), 0 24px 60px -26px rgba(69,113,255,.75) !important;
  color: #fff !important;
}
.dashboard-balance-card::before {
  content: "";
  position: absolute; inset: 0;
  background-image: radial-gradient(rgba(255,255,255,.12) 1px, transparent 1px);
  background-size: 22px 22px;
  -webkit-mask-image: radial-gradient(ellipse 70% 80% at 90% 10%, #000, transparent 70%);
  mask-image: radial-gradient(ellipse 70% 80% at 90% 10%, #000, transparent 70%);
  opacity: .6; pointer-events: none;
}
.dashboard-balance-card::after {
  content: "";
  position: absolute; right: -40px; top: -40px;
  width: 180px; height: 180px; border-radius: 50%;
  background: radial-gradient(circle, rgba(255,255,255,.18), transparent 70%);
  pointer-events: none;
}
.dashboard-balance-card .label { color: rgba(255,255,255,.82) !important; }
.dashboard-balance-card .amount {
  color: #fff !important;
  font-size: clamp(1.9rem, 3vw, 2.4rem) !important;
  font-weight: 800 !important;
  letter-spacing: -.03em;
  font-variant-numeric: tabular-nums;
  text-shadow: 0 2px 18px rgba(0,0,0,.18);
}
.dashboard-balance-card .btn-light {
  background: #fff !important; color: #1b2240 !important; font-weight: 650 !important;
  border: 1px solid transparent !important;
}
.dashboard-balance-card .btn-light:hover { transform: translateY(-2px); box-shadow: 0 10px 24px -10px rgba(0,0,0,.5); }
.dashboard-balance-card .btn-outline-light {
  border: 1px solid rgba(255,255,255,.5) !important;
  color: #fff !important; background: rgba(255,255,255,.08) !important;
}
.dashboard-balance-card .btn-outline-light:hover { background: rgba(255,255,255,.18) !important; }

/* Stat cards: refined accent + tabular numbers + smooth icon pop */
.stat-card { transition: transform var(--duration-normal) var(--ease-out), border-color var(--duration-normal), box-shadow var(--duration-normal); }
.stat-card .text-value, .stat-card h3 { font-variant-numeric: tabular-nums; letter-spacing: -.02em; }
.stat-card .card-icon { transition: transform var(--duration-normal) var(--ease-out); }
.stat-card:hover .card-icon { transform: scale(1.08) rotate(-3deg); }

/* Create-payment button on dashboard top-bar */
.btn-create {
  background: var(--ds-grad-brand) !important;
  border: 1px solid transparent !important;
  color: #fff !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--ds-surface-sheen), 0 12px 30px -12px var(--primary-glow) !important;
}
.btn-create:hover { transform: translateY(-2px); box-shadow: var(--ds-surface-sheen), 0 18px 42px -14px var(--primary-glow) !important; }

/* API key card */
.dashboard-api-card .api-key-box {
  font-family: "JetBrains Mono", ui-monospace, SFMono-Regular, Menlo, monospace;
  font-size: .82rem;
  letter-spacing: .01em;
}

/* ===========================================================================
   17. BESPOKE PRICING (service-subscription) — plan cards
   =========================================================================== */
.plan-card-wrap .card-custom { position: relative; transition: transform var(--duration-normal) var(--ease-out), border-color var(--duration-normal), box-shadow var(--duration-normal); }
.plan-card-wrap .card-custom:hover { transform: translateY(-6px); }

/* Plan icon → gradient chip */
.plan-card-wrap .card-icon.icon-primary {
  width: 52px !important; height: 52px !important;
  border-radius: var(--radius-lg) !important;
  background: var(--ds-grad-brand) !important;
  color: #fff !important; border: 1px solid transparent !important;
  font-size: 1.4rem !important;
  box-shadow: 0 12px 28px -12px var(--primary-glow);
}

/* Featured (recommended) plan — highlighted */
.plan-featured {
  border-color: rgba(69,113,255,.5) !important;
  box-shadow: var(--ds-surface-sheen), var(--ds-glow) !important;
  background:
    radial-gradient(120% 90% at 50% 0%, rgba(69,113,255,.12), transparent 60%),
    var(--bg-elevated) !important;
}
.plan-ribbon {
  position: absolute; top: 14px; right: 14px;
  display: inline-flex; align-items: center; gap: 6px;
  padding: 5px 12px; border-radius: 999px;
  background: var(--ds-grad-brand); color: #fff;
  font-size: .68rem; font-weight: 700; letter-spacing: .06em; text-transform: uppercase;
  box-shadow: 0 8px 20px -8px var(--primary-glow);
}
.plan-price-value {
  font-size: clamp(1.9rem, 3vw, 2.3rem) !important;
  font-weight: 800 !important;
  letter-spacing: -.03em !important;
  background: var(--ds-grad-text);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.plan-price-value small { -webkit-text-fill-color: var(--text-muted); color: var(--text-muted); }
.plan-features li i { color: var(--success) !important; }
.duration-selector {
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: 6px;
  display: inline-flex; align-items: center; gap: 10px;
}
.total-price {
  background: var(--ds-grad-brand-soft);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-md);
  padding: 10px 14px;
  color: var(--text-primary) !important;
}

/* ===========================================================================
   18. LANDING HERO — Linear-style BENTO grid
   =========================================================================== */
.hero-bento-section { padding: 84px 0 92px !important; }
.hero-head { text-align: center; max-width: 840px; margin: 0 auto; position: relative; z-index: 2; }
.hero-head .ds-eyebrow { margin-bottom: 22px; }
.hero-head h1 {
  font-size: clamp(2.3rem, 5vw, 3.6rem) !important;
  line-height: 1.05 !important;
  letter-spacing: -.045em !important;
  margin-bottom: 20px !important;
  animation: none !important;
}
.hero-head h1 .highlight {
  background: var(--ds-grad-text);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  animation: none !important;
}
.hero-head p {
  margin: 0 auto 30px !important;
  max-width: 600px !important;
  font-size: 1.05rem !important;
  color: var(--text-secondary) !important;
  animation: none !important;
}
.hero-cta { display: flex; gap: 14px; justify-content: center; flex-wrap: wrap; }

.bento-grid {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  grid-auto-rows: minmax(150px, auto);
  gap: 16px;
  margin-top: 56px;
  position: relative;
  z-index: 2;
}
.bento-card {
  position: relative;
  display: flex;
  flex-direction: column;
  background: var(--bg-elevated);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-xl);
  padding: 22px;
  overflow: hidden;
  box-shadow: var(--ds-surface-sheen), var(--shadow-card);
  transition: transform .3s var(--ease-out), border-color .3s var(--ease-smooth), box-shadow .3s var(--ease-smooth);
}
.bento-card:hover {
  transform: translateY(-4px);
  border-color: var(--glass-border-hover);
  box-shadow: var(--ds-surface-sheen), var(--shadow-card-hover);
}
.bento-card .bento-body { margin-top: auto; }
.bento-card h3 {
  font-size: 1.06rem; font-weight: 700; letter-spacing: -.02em;
  color: var(--text-primary); margin: 14px 0 6px;
}
.bento-card p { color: var(--text-secondary); font-size: .9rem; line-height: 1.55; margin: 0; }

/* Placement */
.bento-a { grid-column: 1 / 9;  grid-row: 1 / 3; }
.bento-b { grid-column: 9 / 13; grid-row: 1 / 2; }
.bento-c { grid-column: 9 / 13; grid-row: 2 / 3; }
.bento-d { grid-column: 1 / 5;  grid-row: 3 / 4; }
.bento-e { grid-column: 5 / 9;  grid-row: 3 / 4; }
.bento-f { grid-column: 9 / 13; grid-row: 3 / 4; }

/* A — dashboard preview */
.bento-a { padding: 18px; }
.bento-tag {
  display: inline-flex; align-items: center; gap: 7px; align-self: flex-start;
  padding: 5px 11px; border-radius: 999px; margin-bottom: 14px;
  background: var(--success-bg); border: 1px solid var(--success-border);
  color: var(--success); font-size: .72rem; font-weight: 700; letter-spacing: .04em;
}
.bento-tag i { font-size: .7rem; }
.bento-a .hero-dash {
  margin: 0; width: 100%; flex: 1;
  box-shadow: none;
}
/* Keep the dashboard preview always dark (like a real product screenshot),
   so it stays high-contrast & premium in BOTH light and dark page themes.
   The [data-theme="light"] .bento-a prefix outranks the page's inline
   [data-theme="light"] .hero-dash rule. */
.bento-a .hero-dash,
[data-theme="light"] .bento-a .hero-dash {
  background: #0e1017 !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  box-shadow: none !important;
}
.bento-a .hero-dash-bar,
[data-theme="light"] .bento-a .hero-dash-bar { background: #15171f !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; }
.bento-a .hero-dash-tab { color: rgba(255,255,255,.7) !important; }
.bento-a .hero-stat-card { background: rgba(255,255,255,.045) !important; border: 1px solid rgba(255,255,255,.08) !important; }
.bento-a .hs-val { color: #fff !important; }
.bento-a .hs-lbl { color: rgba(255,255,255,.5) !important; }
.bento-a .hero-trx { border-color: rgba(255,255,255,.06) !important; }
.bento-a .hero-trx-name { color: #fff !important; }
.bento-a .hero-trx-time { color: rgba(255,255,255,.5) !important; }
.bento-a .hero-chart-bar .bar { opacity: .9; }

/* B — virtual card visual */
.bento-vcard {
  position: relative;
  border-radius: 16px;
  padding: 18px;
  aspect-ratio: 1.6 / 1;
  background: linear-gradient(135deg, #0f1b3d 0%, #15366e 55%, #2f6bff 130%);
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: 0 16px 36px -18px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.12);
  color: #fff; overflow: hidden;
}
.bento-vcard::after {
  content: ""; position: absolute; right: -30px; top: -30px; width: 120px; height: 120px;
  border-radius: 50%; background: radial-gradient(circle, rgba(255,255,255,.18), transparent 70%);
}
.bento-vcard-chip { width: 36px; height: 26px; border-radius: 6px; background: linear-gradient(135deg,#f5d479,#caa53d); box-shadow: inset 0 0 0 1px rgba(0,0,0,.15); }
.bento-vcard-brand { position: absolute; top: 16px; right: 16px; font-size: 1.4rem; }
.bento-vcard-num { font-family: "JetBrains Mono", ui-monospace, monospace; font-size: .92rem; letter-spacing: .06em; margin-top: 18px; }
.bento-vcard-row { display: flex; justify-content: space-between; font-size: .68rem; opacity: .82; margin-top: 8px; letter-spacing: .05em; }

/* C — payment chips */
.bento-chips { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 14px; }
.bento-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 11px; border-radius: 999px;
  background: var(--glass-bg); border: 1px solid var(--glass-border);
  color: var(--text-secondary); font-size: .76rem; font-weight: 600;
}
.bento-chip i { color: var(--primary-light); font-size: .8rem; }

/* D/F — icon tiles */
.bento-icon {
  width: 46px; height: 46px; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center; font-size: 1.3rem; color: #fff;
  background: linear-gradient(135deg, var(--c1, #3b74ff), var(--c2, #18a0fb));
  box-shadow: 0 10px 24px -12px color-mix(in srgb, var(--c1, #4571ff) 80%, transparent);
  align-self: flex-start;
}

/* E — live stats */
.bento-e { flex-direction: row; align-items: center; gap: 18px; justify-content: space-around; }
.bento-stat { text-align: center; }
.bento-stat-num {
  font-size: clamp(1.5rem, 2.4vw, 2rem); font-weight: 800; letter-spacing: -.03em;
  font-variant-numeric: tabular-nums;
  background: var(--ds-grad-text);
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
}
.bento-stat-lbl { color: var(--text-muted); font-size: .76rem; font-weight: 600; margin-top: 4px; }
.bento-stat-divider { width: 1px; align-self: stretch; background: var(--ds-hairline); margin: 8px 0; }

/* Responsive bento */
@media (max-width: 991.98px) {
  .bento-grid { grid-template-columns: repeat(6, 1fr); grid-auto-rows: minmax(140px, auto); }
  .bento-a { grid-column: 1 / 7; grid-row: auto; }
  .bento-b { grid-column: 1 / 4; grid-row: auto; }
  .bento-c { grid-column: 4 / 7; grid-row: auto; }
  .bento-d { grid-column: 1 / 3; grid-row: auto; }
  .bento-e { grid-column: 3 / 5; grid-row: auto; }
  .bento-f { grid-column: 5 / 7; grid-row: auto; }
}
@media (max-width: 767.98px) {
  .hero-bento-section { padding: 56px 0 60px !important; }
  .bento-grid { grid-template-columns: 1fr; grid-auto-rows: auto; margin-top: 32px; }
  .bento-a, .bento-b, .bento-c, .bento-d, .bento-e, .bento-f { grid-column: auto; grid-row: auto; }
  .bento-e { flex-direction: row; }
  /* Tidy eyebrow + CTAs on mobile */
  .hero-head .ds-eyebrow { font-size: .6rem; padding: 6px 12px; letter-spacing: .035em; line-height: 1.35; gap: 6px; }
  .hero-cta { width: 100%; }
  .hero-cta .btn-hero { width: 100%; justify-content: center; }
}
@media (max-width: 400px) {
  .hero-head h1 { font-size: clamp(1.7rem, 8.5vw, 2.1rem) !important; }
  .hero-head .ds-eyebrow { font-size: .56rem; }
}

/* ===========================================================================
   20. LANDING ANIMATIONS — subtle, premium ambient motion (Apple-restrained).
   transform/opacity only; auto-disabled under prefers-reduced-motion (see §11).
   =========================================================================== */
/* Ambient drifting glow orbs behind the hero */
.hero-fx { position: absolute; inset: 0; overflow: hidden; pointer-events: none; z-index: 0; }
.hero-orb { position: absolute; border-radius: 50%; filter: blur(70px); will-change: transform; }
.hero-orb.orb-1 { width: 360px; height: 360px; top: -90px; left: -70px;
  background: radial-gradient(circle, rgba(41,151,255,.28), transparent 70%); animation: orbDrift1 19s ease-in-out infinite; }
.hero-orb.orb-2 { width: 280px; height: 280px; top: 120px; right: -50px;
  background: radial-gradient(circle, rgba(10,132,255,.20), transparent 70%); animation: orbDrift2 23s ease-in-out infinite; }
.hero-orb.orb-3 { width: 220px; height: 220px; bottom: -60px; left: 38%;
  background: radial-gradient(circle, rgba(70,198,245,.16), transparent 70%); animation: orbDrift3 27s ease-in-out infinite; }
[data-theme="light"] .hero-orb { opacity: .5; }
@keyframes orbDrift1 { 0%,100%{ transform: translate3d(0,0,0) } 50%{ transform: translate3d(46px,32px,0) } }
@keyframes orbDrift2 { 0%,100%{ transform: translate3d(0,0,0) } 50%{ transform: translate3d(-34px,44px,0) } }
@keyframes orbDrift3 { 0%,100%{ transform: translate3d(0,0,0) scale(1) } 50%{ transform: translate3d(22px,-26px,0) scale(1.12) } }

/* Hero entrance — CRITICAL: title/subtitle are ALWAYS visible (opacity:1).
   Only a subtle slide animates (transform only, never opacity), so the text can
   NEVER be hidden by a paused/disabled animation (iOS Low Power Mode, reduced
   motion, cached/legacy CSS, or Safari quirks). */
.hero-head > * { opacity: 1 !important; }
@media (prefers-reduced-motion: no-preference) {
  .hero-bento-section .hero-head .ds-eyebrow { animation: heroSlide .6s var(--ease-out) .05s both; }
  .hero-bento-section .hero-head h1          { animation: heroSlide .6s var(--ease-out) .14s both; }
  .hero-bento-section .hero-head p           { animation: heroSlide .6s var(--ease-out) .26s both; }
  .hero-bento-section .hero-head .hero-cta   { animation: heroSlide .6s var(--ease-out) .36s both; }
}
@keyframes heroSlide { from { transform: translateY(14px); } to { transform: translateY(0); } }

/* Bento cards — visible by default; only a subtle slide animates (transform only). */
.bento-card { opacity: 1; }
@media (prefers-reduced-motion: no-preference) {
  .bento-card { animation: bentoSlide .7s var(--ease-out) both; }
  .bento-a { animation-delay: .10s; } .bento-b { animation-delay: .16s; } .bento-c { animation-delay: .22s; }
  .bento-d { animation-delay: .28s; } .bento-e { animation-delay: .34s; } .bento-f { animation-delay: .40s; }
}
@keyframes bentoSlide { from { transform: translateY(20px); } to { transform: translateY(0); } }

/* "Live" indicator pulse */
.bento-tag i { animation: livePulse 1.6s ease-in-out infinite; }
@keyframes livePulse { 0%,100% { opacity: 1; } 50% { opacity: .3; } }

/* Holographic light sweep across the virtual card */
.bento-vcard { position: relative; overflow: hidden; }
.bento-vcard-chip, .bento-vcard-brand, .bento-vcard-num, .bento-vcard-row { position: relative; z-index: 2; }
.bento-vcard::before {
  content: ""; position: absolute; top: 0; left: -70%; width: 55%; height: 100%; z-index: 1;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.20), transparent);
  transform: skewX(-18deg);
  animation: cardSweep 6s ease-in-out infinite;
}
@keyframes cardSweep { 0% { left: -70%; } 40% { left: 140%; } 100% { left: 140%; } }

/* Eyebrow live dot ping */
.ds-eyebrow .dot { position: relative; }
.ds-eyebrow .dot::after {
  content: ""; position: absolute; inset: -3px; border-radius: 50%;
  border: 1px solid var(--primary); opacity: .6;
  animation: dotPing 2s ease-out infinite;
}
@keyframes dotPing { 0% { transform: scale(.8); opacity: .7; } 80%,100% { transform: scale(2.2); opacity: 0; } }

/* Feature/step icons gently lift on hover (already have card hover) */
.feature-card .feature-icon, .bento-icon { transition: transform .3s var(--ease-out); }
.feature-card:hover .feature-icon { transform: translateY(-3px); }

/* Safety: if animations are reduced, force final visible state */
@media (prefers-reduced-motion: reduce) {
  .hero-head > *, .bento-card { opacity: 1 !important; transform: none !important; }
  .hero-orb { animation: none !important; }
  .bento-vcard::before, .bento-shot-card::before { display: none !important; }
}

/* ===========================================================================
   21. REAL PRODUCT IMAGERY in bento (Apple photo-bento)
   =========================================================================== */
.bento-a { padding: 16px; }
.bento-a .bento-shot {
  flex: 1; min-height: 210px;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--glass-border);
  background: #000;
}
.bento-a .bento-shot img { width: 100%; height: 100%; object-fit: cover; object-position: center; display: block; }

.bento-shot-card {
  position: relative;
  border-radius: 16px;
  overflow: hidden;
  border: 1px solid var(--glass-border);
  background: #000;
  aspect-ratio: 16 / 10;
  margin-bottom: 12px;
}
.bento-shot-card img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .5s var(--ease-out); }
.bento-card:hover .bento-shot-card img { transform: scale(1.05); }
/* light sweep across image cards */
.bento-shot-card::before {
  content: ""; position: absolute; top: 0; left: -70%; width: 55%; height: 100%; z-index: 2;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.16), transparent);
  transform: skewX(-18deg); animation: cardSweep 6.5s ease-in-out infinite;
}
/* Image cards: text sits directly under the image (not pushed to bottom) */
.bento-shot-card + .bento-body { margin-top: 0 !important; }
/* keep the live-stats tile vertically centred so the bottom row stays balanced */
.bento-e { justify-content: center; }

@media (max-width: 991.98px) {
  .bento-a .bento-shot { min-height: 230px; }
}

/* ===========================================================================
   19. APPLE-STYLE DARK THEME  (apple.com black aesthetic)
   Pure-black canvas, #1d1d1f surfaces, off-white text, Apple blue, pill buttons,
   minimal borders & shadows. Scoped to [data-theme="dark"] (light unaffected).
   =========================================================================== */
[data-theme="dark"] {
  --bg-base:      #000000;
  --bg-primary:   #060607;
  --bg-secondary: #0a0a0c;
  --bg-tertiary:  #161618;
  --bg-elevated:  #1d1d1f;   /* Apple surface gray */
  --bg-surface:   #262628;

  --glass-bg:           rgba(255,255,255,.045);
  --glass-bg-hover:     rgba(255,255,255,.08);
  --glass-bg-active:    rgba(255,255,255,.10);
  --glass-border:       rgba(255,255,255,.10);
  --glass-border-hover: rgba(255,255,255,.24);
  --ds-hairline:        rgba(255,255,255,.10);
  --ds-hairline-strong: rgba(255,255,255,.18);

  --text-primary:   #f5f5f7;  /* Apple off-white */
  --text-secondary: #a1a1a6;  /* Apple gray */
  --text-tertiary:  #86868b;
  --text-muted:     #6e6e73;

  --primary:       #2997ff;   /* Apple blue (links/accents on dark) */
  --primary-light: #5aacff;
  --primary-dark:  #0071e3;   /* Apple button blue */
  --primary-glow:  rgba(41,151,255,.30);
  --electric-blue: #2997ff;
  --info:          #2997ff;
  --info-bg:       rgba(41,151,255,.12);
  --info-border:   rgba(41,151,255,.28);

  --ds-grad-brand:      linear-gradient(180deg, #2b9bff 0%, #0071e3 100%);
  --ds-grad-brand-soft: linear-gradient(135deg, rgba(41,151,255,.16), rgba(10,132,255,.10));
  --ds-grad-text:       linear-gradient(180deg, #fbfbfd 0%, #c7c7cc 100%);
  --ds-ring:            rgba(41,151,255,.6);

  --shadow-card:        0 0 0 1px rgba(255,255,255,.06);
  --shadow-card-hover:  0 0 0 1px rgba(255,255,255,.12), 0 22px 44px -30px rgba(0,0,0,.9);
  --shadow-sm:          0 1px 2px rgba(0,0,0,.6);
  --shadow-md:          0 12px 30px -18px rgba(0,0,0,.85);
  --shadow-lg:          0 24px 50px -24px rgba(0,0,0,.9);
  --shadow-xl:          0 32px 64px -28px rgba(0,0,0,.92);
  --ds-shadow-pop:      0 30px 60px -28px rgba(0,0,0,.92);
  --ds-glow:            0 0 0 1px rgba(41,151,255,.30);
  --shadow-glow:        var(--ds-glow);
}

/* Pill buttons (Apple) — !important to beat per-page inline button radii */
.btn, .btn-lg, .btn-sm, .btn-hero,
.btn-create, .btn-login, .submit-btn { border-radius: 980px !important; }

/* Solid Apple-blue primary CTAs in dark (flat, no glow) */
[data-theme="dark"] .btn-primary,
[data-theme="dark"] .landing-page .btn-primary,
[data-theme="dark"] .btn-hero-primary,
[data-theme="dark"] .btn-create,
[data-theme="dark"] .btn-login,
[data-theme="dark"] .submit-btn {
  background: #0071e3 !important;
  border: 1px solid transparent !important;
  color: #fff !important;
  box-shadow: none !important;
}
[data-theme="dark"] .btn-primary:hover,
[data-theme="dark"] .btn-hero-primary:hover,
[data-theme="dark"] .btn-create:hover,
[data-theme="dark"] .btn-login:hover,
[data-theme="dark"] .submit-btn:hover {
  background: #0077ed !important;
  transform: translateY(-1px);
  box-shadow: none !important;
}

/* Secondary / outline buttons → Apple subtle */
[data-theme="dark"] .btn-hero-outline,
[data-theme="dark"] .btn-outline-primary,
[data-theme="dark"] .btn-outline-light,
[data-theme="dark"] .btn-outline-secondary,
[data-theme="dark"] .btn-secondary {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  color: var(--text-primary) !important;
}
[data-theme="dark"] .btn-hero-outline:hover,
[data-theme="dark"] .btn-outline-primary:hover,
[data-theme="dark"] .btn-outline-secondary:hover,
[data-theme="dark"] .btn-secondary:hover { background: rgba(255,255,255,.12) !important; }

/* Hero: near-pure black + a whisper of blue at the very top (Apple) */
[data-theme="dark"] .hero-section,
[data-theme="dark"] .hero-bento-section {
  background:
    radial-gradient(55% 38% at 50% -14%, rgba(41,151,255,.05), transparent 64%),
    #000 !important;
}
[data-theme="dark"] .hero-section::before { background: none !important; }
[data-theme="dark"] .hero-section::after { opacity: .28; }
[data-theme="dark"] .hero-head h1 .highlight,
[data-theme="dark"] .hero-section h1 .highlight {
  background: linear-gradient(180deg, #2b9bff, #0a84ff) !important;
  -webkit-background-clip: text !important; background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}

/* Section tiers: subtle near-black separation */
[data-theme="dark"] .features-section,
[data-theme="dark"] .hiw-section { background: #060607 !important; }
[data-theme="dark"] .pricing-section,
[data-theme="dark"] .wa-store-section,
[data-theme="dark"] .stats-section,
[data-theme="dark"] .landing-footer,
[data-theme="dark"] .main-footer { background: #0a0a0c !important; }
[data-theme="dark"] .cta-section {
  background:
    radial-gradient(55% 80% at 50% 100%, rgba(41,151,255,.08), transparent 68%),
    #000 !important;
}

/* Surfaces: Apple #1d1d1f, hairline border, minimal shadow */
[data-theme="dark"] .bento-card,
[data-theme="dark"] .feature-card,
[data-theme="dark"] .pricing-card,
[data-theme="dark"] .hiw-step,
[data-theme="dark"] .card,
[data-theme="dark"] .card-custom,
[data-theme="dark"] .card-3d-glass,
[data-theme="dark"] .card-glass,
[data-theme="dark"] .stat-card,
[data-theme="dark"] .stat-item,
[data-theme="dark"] .balance-card,
[data-theme="dark"] .top-bar,
[data-theme="dark"] .dropdown-menu,
[data-theme="dark"] .modal-content {
  background: #1d1d1f !important;
  border: 1px solid rgba(255,255,255,.08) !important;
  box-shadow: none !important;
}
[data-theme="dark"] .bento-card:hover,
[data-theme="dark"] .feature-card:hover,
[data-theme="dark"] .pricing-card:hover,
[data-theme="dark"] .card-custom:hover,
[data-theme="dark"] .stat-card:hover,
[data-theme="dark"] .stat-item:hover {
  border-color: rgba(255,255,255,.18) !important;
  box-shadow: 0 18px 40px -26px rgba(0,0,0,.9) !important;
}

/* Refined dark balance card — deep Apple blue, no heavy glow */
[data-theme="dark"] .dashboard-balance-card {
  background:
    radial-gradient(120% 120% at 0% 0%, rgba(41,151,255,.22), transparent 52%),
    linear-gradient(135deg, #0a84ff 0%, #0058c7 58%, #0a2c5e 100%) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow: none !important;
}

/* Pricing featured ring → Apple blue */
[data-theme="dark"] .plan-featured {
  border-color: rgba(41,151,255,.45) !important;
  box-shadow: 0 0 0 1px rgba(41,151,255,.3) !important;
  background: #1d1d1f !important;
}

/* Navbar & app chrome — translucent black (Apple) */
[data-theme="dark"] .landing-navbar { background: rgba(0,0,0,.7) !important; }
[data-theme="dark"] .landing-navbar.scrolled { background: rgba(0,0,0,.86) !important; }
[data-theme="dark"] .sidebar { background: #060607 !important; border-right: 1px solid rgba(255,255,255,.08) !important; }
[data-theme="dark"] .mobile-header,
[data-theme="dark"] .bottom-nav,
[data-theme="dark"] .mobile-bottom-nav { background: rgba(0,0,0,.8) !important; }

/* Inputs — Apple dark fields */
[data-theme="dark"] .form-control,
[data-theme="dark"] .form-select {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}
[data-theme="dark"] .form-control:focus,
[data-theme="dark"] .form-select:focus {
  border-color: #2997ff !important;
  box-shadow: 0 0 0 3px rgba(41,151,255,.4) !important;
}

/* Eyebrow pill & chips — subtle on black */
[data-theme="dark"] .ds-eyebrow,
[data-theme="dark"] .bento-chip {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
}

/* Headline tracking refinement */
[data-theme="dark"] h1, [data-theme="dark"] .h1 { letter-spacing: -.03em; }

/* Virtual-cards section: replace legacy red/orange glow with on-theme Apple blue */
[data-theme="dark"] .virtual-cards-section { background: #060607 !important; }
[data-theme="dark"] .virtual-cards-section::before {
  background:
    radial-gradient(circle at 18% 28%, rgba(41,151,255,.10), transparent 55%),
    radial-gradient(circle at 82% 72%, rgba(41,151,255,.06), transparent 55%) !important;
}
[data-theme="dark"] .vc-section-title h2 {
  background: var(--ds-grad-text) !important;
  -webkit-background-clip: text !important; background-clip: text !important;
  -webkit-text-fill-color: transparent !important;
}
[data-theme="light"] .virtual-cards-section::before {
  background:
    radial-gradient(circle at 18% 28%, rgba(47,85,255,.06), transparent 55%),
    radial-gradient(circle at 82% 72%, rgba(47,85,255,.04), transparent 55%) !important;
}
/* Premium black Mastercard (was red/maroon) — keeps logo, stays on-theme */
[data-theme="dark"] .vc-card.vc-mastercard {
  background: linear-gradient(135deg, #2a2a2e 0%, #1a1a1c 55%, #0c0c0e 100%) !important;
}
[data-theme="dark"] .vc-card.vc-mastercard:hover {
  box-shadow: 0 40px 100px -10px rgba(0,0,0,.6), 0 0 0 1px rgba(255,255,255,.16) !important;
}

/* Anchor offset so the sticky navbar never covers section titles when jumping to #fitur/#harga/#faq etc. */
section[id] { scroll-margin-top: 84px; }

/* Admin-specific surfaces */
[data-theme="dark"] .admin-stat-card,
[data-theme="dark"] .sidebar.admin-sidebar {
  background: #1d1d1f !important;
  border-color: rgba(255,255,255,.08) !important;
  box-shadow: none !important;
}
[data-theme="dark"] .sidebar.admin-sidebar { background: #060607 !important; }
[data-theme="dark"] .admin-stat-card:hover {
  border-color: rgba(255,255,255,.18) !important;
  box-shadow: 0 18px 40px -26px rgba(0,0,0,.9) !important;
}

/* ---------------------------------------------------------------------------
   19b. APPLE DARK — AUTH PAGES (login / register / forgot)
   Solid #1d1d1f card, hairline border, no blue glow; Apple dark fields.
   --------------------------------------------------------------------------- */
[data-theme="dark"] .login-card,
[data-theme="dark"] .register-card {
  background: #1d1d1f !important;
  border: 1px solid rgba(255,255,255,.09) !important;
  box-shadow: 0 30px 70px -30px rgba(0,0,0,.9) !important;  /* clean shadow, no blue */
}
[data-theme="dark"] .browser-chrome { background: #161618 !important; border-bottom-color: rgba(255,255,255,.08) !important; }
[data-theme="dark"] .browser-tab { background: rgba(255,255,255,.06) !important; }
[data-theme="dark"] .form-group input,
[data-theme="dark"] .form-group select,
[data-theme="dark"] .form-group textarea {
  background: rgba(255,255,255,.06) !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  color: #f5f5f7 !important;
}
[data-theme="dark"] .form-group input:focus,
[data-theme="dark"] .form-group select:focus,
[data-theme="dark"] .form-group textarea:focus {
  border-color: #2997ff !important;
  box-shadow: 0 0 0 3px rgba(41,151,255,.4) !important;
}
/* Social login buttons (Passkey/Facebook/Google/WhatsApp) → Apple subtle, pill */
[data-theme="dark"] .login-card .btn,
[data-theme="dark"] .register-card .btn { border-radius: 980px !important; }
