/* ============================================================================
   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:      #8b7bff;
  --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, #4571ff 0%, #7a5cff 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:      #6d57f5;
  --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%, #6b53ff 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(60% 50% at 50% 0%, rgba(69,113,255,.14), transparent 60%),
    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,.08), transparent 62%),
    var(--bg-base) !important;
}
.login-container, .register-container { max-width: 460px; }

/* [DEV ONLY — TEMPORARY] Turnstile captcha disabled on development.bayar.gg for QA login.
   Hides the (currently unreachable) Cloudflare widget so it doesn't show a connection error.
   Remove together with the server-side bypass in config.php to restore the captcha. */
.turnstile-wrap, .cf-turnstile { display: none !important; }

/* ---------------------------------------------------------------------------
   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; }
}
