﻿/* Fonts are loaded via <link> tags in HTML for better performance */

/* External font imports were removed to keep first paint fast on mobile networks. */

/* ══════════════════════════════════════════════════════════════
   DESIGN TOKENS
   ══════════════════════════════════════════════════════════════ */
:root {
  --bg: #04080f;
  --bg2: #0a1120;
  --surface: rgba(255,255,255,0.04);
  --surface-hover: rgba(255,255,255,0.08);
  --text: #f8fafc;
  --text-secondary: #94a3b8;
  --border: rgba(255,255,255,0.08);
  --brand: #10b981;
  --brand-hover: #059669;
  --brand2: #0ea5e9;
  --shadow: 0 4px 20px rgba(0,0,0,0.3);
  --radius: 14px;
  --radius-lg: 18px;
  --radius-xl: 24px;
  --transition: 0.2s cubic-bezier(0.4, 0, 0.2, 1);
}

:root[data-theme="light"] {
  --bg: #fdfdfd;
  --bg2: #f1f5f9;
  --surface: rgba(255,255,255,0.7);
  --surface-hover: rgba(255,255,255,0.9);
  --text: #0f172a;
  --text-secondary: #64748b;
  --border: rgba(0,0,0,0.06);
  --shadow: 0 8px 30px rgba(15,23,42,0.06);
}

/* ══════════════════════════════════════════════════════════════
   RESET & BASE
   ══════════════════════════════════════════════════════════════ */
* { -webkit-tap-highlight-color: transparent; box-sizing: border-box; }
html { color-scheme: dark; }
html[data-theme="light"] { color-scheme: light; }

body {
  margin: 0;
  font-family: "Tajawal", "Inter", system-ui, -apple-system, sans-serif !important;
  background:
    radial-gradient(circle at top right, rgba(16,185,129,0.14), transparent 34rem),
    radial-gradient(circle at bottom left, rgba(14,165,233,0.10), transparent 28rem),
    var(--bg) !important;
  color: var(--text) !important;
  min-height: 100vh;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 1.6;
}

/* Remove all old body pseudo-elements */
body:before, body:after {
  display: none !important;
}

a { color: inherit; text-decoration: none; }

/* ══════════════════════════════════════════════════════════════
   LAYOUT
   ══════════════════════════════════════════════════════════════ */
.wrap {
  min-height: 100vh;
  display: flex;
}

.user-shell {
  width: min(100%, 1440px);
  margin: 0 auto;
  padding: 18px;
  gap: 18px;
}

.side {
  width: 260px;
  min-width: 260px;
  height: 100vh;
  position: sticky;
  top: 0;
  padding: 24px 16px;
  background: var(--bg) !important;
  border-left: 1px solid var(--border) !important;
  overflow-y: auto;
}

.user-side {
  height: calc(100vh - 36px);
  top: 18px;
  border: 1px solid var(--border) !important;
  border-radius: 28px;
  background: rgba(24,24,27,0.86) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,0.22);
}

html[data-theme="light"] .user-side {
  background: rgba(255,255,255,0.9) !important;
}

.brand {
  display: flex;
  align-items: center;
  margin-bottom: 32px;
  padding-bottom: 20px;
  border-bottom: 1px solid var(--border);
}

.user-brand {
  justify-content: center;
  margin: -6px -2px 22px;
  padding: 18px 12px 22px;
  border-radius: 22px;
  background: #0b0b0d;
  border: 1px solid var(--border);
}

html[data-theme="light"] .user-brand {
  background: #fff;
}

.brand img, .topbar img, .auth-logo img {
  height: 52px !important;
  width: auto !important;
  max-width: 240px;
  object-fit: contain;
  filter: none;
}

.theme-logo-light {
  display: none;
}

html[data-theme="light"] .theme-logo-dark {
  display: none;
}

html[data-theme="light"] .theme-logo-light {
  display: inline-block;
}

.logo-shell {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border-radius: var(--radius);
  padding: 0;
  border: 0;
  overflow: hidden;
}

html[data-theme="light"] .logo-shell {
  background: transparent;
  box-shadow: none;
}

.brand .logo-shell {
  width: 100%;
  padding: 0;
}

.main {
  flex: 1;
  min-width: 0;
  padding: 32px 40px;
}

.user-main {
  padding: 0;
  max-width: 1120px;
  margin: 0 auto;
}

/* ══════════════════════════════════════════════════════════════
   GRID
   ══════════════════════════════════════════════════════════════ */
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 16px;
}

/* ══════════════════════════════════════════════════════════════
   CARDS
   ══════════════════════════════════════════════════════════════ */
.card, .feature-card, .price-card, .flow-step {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  box-shadow: none !important;
  backdrop-filter: none !important;
  transition: background var(--transition);
}

.card {
  border-radius: var(--radius-xl);
  padding: 24px;
  margin-bottom: 16px;
}

.user-main .card {
  border-radius: 24px;
  background: rgba(255,255,255,0.045) !important;
  box-shadow: 0 16px 45px rgba(0,0,0,0.12) !important;
}

html[data-theme="light"] .user-main .card {
  background: rgba(255,255,255,0.86) !important;
  box-shadow: 0 16px 45px rgba(15,23,42,0.08) !important;
}

.card:hover {
  background: var(--surface-hover) !important;
}

.hero {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-top: 2px solid var(--brand) !important;
  color: var(--text) !important;
  position: relative;
  overflow: hidden;
}

.user-main .hero {
  border-top: 0 !important;
  background:
    linear-gradient(135deg, rgba(16,185,129,0.18), rgba(14,165,233,0.08)),
    rgba(255,255,255,0.05) !important;
}

.hero:after { display: none; }

.hero h1 { color: var(--text); }
.hero p { color: var(--text-secondary); }

/* ══════════════════════════════════════════════════════════════
   TYPOGRAPHY
   ══════════════════════════════════════════════════════════════ */
h1, h2, h3 {
  margin: 0 0 12px;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
}

h1 { font-size: 24px; }
h2 { font-size: 18px; }
h3 { font-size: 16px; }

.muted { color: var(--text-secondary) !important; line-height: 1.7; }
.section-sub, .footer { color: var(--text-secondary) !important; }

.stat {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 800;
  color: var(--text) !important;
  line-height: 1.1;
  letter-spacing: -0.03em;
}

.price small, .dot { color: var(--brand) !important; }

.title {
  color: var(--text);
  background: none;
  -webkit-background-clip: unset;
  background-clip: unset;
  -webkit-text-fill-color: unset;
}

/* ══════════════════════════════════════════════════════════════
   BUTTONS
   ══════════════════════════════════════════════════════════════ */
.btn, .mini-btn {
  border-radius: var(--radius);
  padding: 10px 20px;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  cursor: pointer;
  font-size: 14px;
  font-family: inherit;
  transition: all var(--transition);
}

.btn {
  border: 0;
  background: var(--brand) !important;
  color: #fff;
  box-shadow: none !important;
}

.btn:hover {
  background: var(--brand-hover) !important;
  transform: translateY(-1px);
}

.btn.dark, .mini-btn {
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none !important;
}

.btn.dark:hover, .mini-btn:hover {
  background: var(--surface-hover) !important;
}

.btn.red {
  background: #dc2626 !important;
  box-shadow: none !important;
}

.btn.red:hover {
  background: #b91c1c !important;
}

.mini-btn {
  border-radius: var(--radius);
  padding: 8px 14px;
  font-weight: 600;
  min-height: 36px;
  font-size: 13px;
}

.install-btn {
  background: var(--brand) !important;
  color: white !important;
  border: none !important;
}

/* ══════════════════════════════════════════════════════════════
   FORMS
   ══════════════════════════════════════════════════════════════ */
.input, textarea {
  width: 100%;
  background: var(--surface) !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  border-radius: var(--radius);
  padding: 10px 14px;
  margin-top: 8px;
  outline: none;
  font-family: inherit;
  font-size: 15px;
  transition: border-color var(--transition);
}

input,
textarea,
select,
button {
  font-size: max(16px, 1rem);
}

.input:focus, textarea:focus {
  border-color: var(--brand) !important;
}

label {
  display: block;
  margin-bottom: 16px;
  font-weight: 600;
  color: var(--text);
  font-size: 14px;
}

.alert {
  padding: 14px 18px;
  border-radius: var(--radius);
  margin-bottom: 16px;
  font-size: 14px;
  font-weight: 500;
}

.ok {
  background: rgba(16,185,129,0.08);
  color: #34d399;
  border: 1px solid rgba(16,185,129,0.15);
}

.err {
  background: rgba(239,68,68,0.08);
  color: #f87171;
  border: 1px solid rgba(239,68,68,0.15);
}

/* ══════════════════════════════════════════════════════════════
   NAVIGATION
   ══════════════════════════════════════════════════════════════ */
.nav a {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 10px;
  margin-bottom: 4px;
  color: var(--text-secondary) !important;
  font-weight: 600;
  font-size: 14px;
  border: 1px solid transparent;
  transition: all var(--transition);
}

.nav a:hover {
  color: var(--text) !important;
  background: var(--surface-hover) !important;
  transform: none;
}

html[dir="ltr"] .nav a:hover { transform: none; }

.nav .active {
  color: var(--text) !important;
  background: var(--surface-hover) !important;
  border-color: var(--border) !important;
}

.user-nav {
  display: grid;
  gap: 7px;
}

.user-nav a {
  min-height: 46px;
  border-radius: 16px !important;
  padding: 12px 14px !important;
  background: transparent !important;
}

.user-nav a:hover,
.user-nav .active {
  background: rgba(16,185,129,0.12) !important;
  border-color: rgba(16,185,129,0.22) !important;
  color: var(--text) !important;
}

/* ══════════════════════════════════════════════════════════════
   APP HEADER
   ══════════════════════════════════════════════════════════════ */
.app-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 24px;
  padding: 16px 20px;
  border-radius: var(--radius-lg);
  background: var(--surface);
  border: 1px solid var(--border);
  box-shadow: none;
  backdrop-filter: none;
}

.user-app-header {
  position: sticky;
  top: 18px;
  z-index: 70;
  margin-bottom: 18px;
  padding: 14px 16px;
  border-radius: 24px;
  background: rgba(24,24,27,0.88);
  box-shadow: 0 18px 50px rgba(0,0,0,0.18);
}

html[data-theme="light"] .user-app-header {
  background: rgba(255,255,255,0.92);
}

.app-header strong {
  display: block;
  font-size: 16px;
  color: var(--text);
  font-weight: 700;
}

.app-header p {
  margin: 4px 0 0;
  color: var(--text-secondary);
  font-size: 13px;
}

.header-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

.account-btn {
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}

.app-actions {
  position: fixed;
  top: 14px;
  inset-inline-end: 14px;
  z-index: 999;
  display: flex;
  gap: 8px;
}

.app-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-top: 18px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background: rgba(255,255,255,0.035);
  color: var(--text-secondary);
}

html[data-theme="light"] .app-footer {
  background: rgba(255,255,255,0.86);
}

.app-footer strong {
  display: block;
  color: var(--text);
  font-size: 14px;
}

.app-footer p {
  margin: 3px 0 0;
  font-size: 12px;
}

.app-footer-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
  font-size: 12px;
}

.version-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 30px;
  padding: 6px 12px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(16,185,129,0.18), rgba(14,165,233,0.12));
  border: 1px solid rgba(16,185,129,0.26);
  color: var(--brand);
  font-weight: 800;
  direction: ltr;
}

/* ══════════════════════════════════════════════════════════════
   DASHBOARD INSIGHTS
   ══════════════════════════════════════════════════════════════ */
.dashboard-insights {
  grid-template-columns: minmax(0, 2fr) minmax(260px, .8fr);
  align-items: stretch;
}

.dashboard-device-notice {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  border-color: rgba(245, 158, 11, .24) !important;
  background: linear-gradient(135deg, rgba(255, 251, 235, .96), rgba(236, 253, 245, .92)) !important;
}

html[data-theme="dark"] .dashboard-device-notice {
  background: linear-gradient(135deg, rgba(69, 46, 13, .38), rgba(21, 35, 30, .94)) !important;
}

.usage-chart-card {
  min-height: 320px;
}

.usage-card-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 18px;
}

.usage-legend {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
}

.usage-legend span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.usage-legend i {
  width: 10px;
  height: 10px;
  border-radius: 999px;
  display: inline-block;
}

.usage-legend .incoming,
.usage-bar.incoming {
  background: linear-gradient(180deg, #0ea5e9, #38bdf8);
}

.usage-legend .replies,
.usage-bar.replies {
  background: linear-gradient(180deg, #10b981, #34d399);
}

.usage-chart {
  height: 210px;
  display: flex;
  align-items: end;
  gap: 7px;
  padding: 18px 10px 4px;
  border-radius: 18px;
  background: rgba(255,255,255,0.025);
  border: 1px solid var(--border);
  overflow-x: auto;
}

.usage-day {
  min-width: 22px;
  height: 100%;
  display: grid;
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr auto;
  align-items: end;
  gap: 7px;
}

.usage-day:before {
  content: "";
  display: none;
}

.usage-day > .usage-bar {
  width: 9px;
  min-height: 4px;
  border-radius: 999px 999px 4px 4px;
  display: inline-block;
  align-self: end;
  box-shadow: 0 10px 22px rgba(0,0,0,0.18);
}

.usage-day > .usage-bar.incoming {
  justify-self: start;
  grid-row: 1;
}

.usage-day > .usage-bar.replies {
  justify-self: end;
  grid-row: 1;
}

.usage-day small {
  grid-column: 1 / -1;
  color: var(--text-secondary);
  font-size: 11px;
  text-align: center;
  direction: ltr;
  unicode-bidi: plaintext;
  line-height: 1;
}

.usage-metric {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}

.usage-metric span {
  color: var(--text-secondary);
  font-size: 13px;
}

.usage-metric strong {
  font-size: 18px;
  color: var(--text);
}

.usage-progress-row {
  display: grid;
  grid-template-columns: minmax(110px, 1fr) minmax(120px, 1.2fr);
  gap: 12px;
  align-items: center;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
}

.usage-progress-row strong,
.usage-progress-row small {
  display: block;
}

.usage-progress-row > span {
  height: 10px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(148,163,184,.18);
}

.usage-progress-row i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
}

/* ══════════════════════════════════════════════════════════════
   TOPBAR (LANDING)
   ══════════════════════════════════════════════════════════════ */
.topbar {
  max-width: 1100px;
  margin: 0 auto;
  padding: 20px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.topbar div {
  display: flex;
  gap: 10px;
  align-items: center;
}

/* ══════════════════════════════════════════════════════════════
   LANDING PAGE
   ══════════════════════════════════════════════════════════════ */
.landing {
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 24px 80px;
}

.landing-hero {
  min-height: calc(100vh - 100px);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 48px;
  align-items: center;
}

.marketing-landing {
  position: relative;
}

.marketing-landing:before,
.marketing-landing:after {
  display: none !important;
}

.marketing-hero {
  grid-template-columns: 1fr 1fr !important;
  gap: 48px !important;
}

/* ── HUMAN LANDING ── */
.human-landing {
  max-width: 1100px !important;
  isolation: isolate;
}

.human-landing:before,
.human-landing:after {
  display: none !important;
}

.human-hero {
  min-height: auto !important;
  grid-template-columns: minmax(0, 1fr) minmax(400px, 1fr) !important;
  align-items: center !important;
  gap: 48px !important;
  padding: 56px 48px !important;
  margin-top: 24px;
  border-radius: var(--radius-xl);
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none;
  overflow: hidden;
  position: relative;
}

.human-hero:before,
.human-hero:after {
  display: none !important;
}

.human-hero .hero-copy { order: 1; }
.human-hero .phone-showcase { order: 2; }

.hero-copy {
  position: relative;
  z-index: 2;
}

.eyebrow, .human-eyebrow {
  display: inline-flex;
  padding: 6px 14px;
  border-radius: 20px;
  background: rgba(16,185,129,0.08) !important;
  border: 1px solid rgba(16,185,129,0.15) !important;
  color: var(--brand) !important;
  font-weight: 600;
  font-size: 13px;
  margin-bottom: 20px;
  box-shadow: none;
}

.title, .human-title {
  font-size: clamp(40px, 5vw, 64px) !important;
  line-height: 1.1 !important;
  letter-spacing: -0.03em !important;
  font-weight: 800;
  max-width: 600px;
  color: var(--text) !important;
  background: none !important;
  -webkit-text-fill-color: var(--text) !important;
  -webkit-background-clip: unset !important;
  background-clip: unset !important;
  margin-bottom: 20px;
}

.human-title span { display: block; }
.human-title span:nth-child(2) {
  color: var(--brand) !important;
  -webkit-text-fill-color: var(--brand) !important;
}

.hero-sub {
  color: var(--text-secondary) !important;
  max-width: 520px;
  font-size: 17px !important;
  line-height: 1.8 !important;
}

.hero-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 28px;
}

.human-notes {
  display: grid;
  grid-template-columns: repeat(3, auto);
  gap: 8px;
  max-width: 520px;
  margin: 24px 0 16px;
}

.human-notes span,
.human-notes span:nth-child(2),
.human-notes span:nth-child(3) {
  width: auto;
  margin: 0;
  padding: 8px 14px;
  border-radius: var(--radius);
  color: var(--text-secondary);
  background: var(--surface);
  border: 1px solid var(--border);
  font-weight: 600;
  font-size: 13px;
  text-align: center;
}

.trust-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 20px 0 8px;
}

.trust-row span {
  padding: 6px 12px;
  border-radius: var(--radius);
  color: var(--text-secondary);
  background: var(--surface);
  border: 1px solid var(--border);
  font-weight: 600;
  font-size: 13px;
}

/* ══════════════════════════════════════════════════════════════
   PHONE MOCKUP
   ══════════════════════════════════════════════════════════════ */
.phone-showcase {
  display: grid;
  grid-template-columns: minmax(260px, 340px) 180px;
  align-items: center;
  justify-content: end;
  gap: 16px;
  position: relative;
  perspective: none;
}

.phone-frame {
  min-height: 520px;
  border-radius: 36px;
  padding: 16px;
  background: var(--bg2);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  position: relative;
  z-index: 2;
}

.phone-frame:before {
  content: "";
  position: absolute;
  width: 100px;
  height: 20px;
  border-radius: 0 0 14px 14px;
  background: var(--bg);
  top: 0;
  left: 50%;
  transform: translateX(-50%);
}

.human-landing .phone-frame {
  transform: none;
  width: 100%;
  min-height: 480px;
  border-radius: 36px;
  background: var(--bg2);
}

.human-landing .phone-frame:after {
  display: none;
}

.phone-top {
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  color: var(--brand);
  font-weight: 700;
  font-size: 14px;
}

.phone-top span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--brand);
}

.chat-area {
  min-height: 380px;
  border-radius: var(--radius-xl);
  padding: 20px 12px;
  background: var(--bg);
  border: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: center;
}

.chat-date {
  align-self: center;
  padding: 4px 10px;
  border-radius: 8px;
  color: var(--text-secondary);
  background: var(--surface);
  font-size: 11px;
  font-weight: 600;
}

.chat-bubble {
  max-width: 85%;
  padding: 12px 14px;
  border-radius: var(--radius-lg);
  line-height: 1.7;
  font-weight: 500;
  font-size: 13px;
}

.chat-bubble.incoming {
  align-self: flex-start;
  background: rgba(255,255,255,0.95);
  color: #18181b;
  border-bottom-left-radius: 4px;
}

.chat-bubble.bot {
  align-self: flex-end;
  background: var(--brand);
  color: #fff;
  border-bottom-right-radius: 4px;
}

.typing-pill {
  margin: 12px auto 0;
  width: fit-content;
  padding: 8px 14px;
  border-radius: 20px;
  color: var(--brand);
  background: rgba(16,185,129,0.08);
  border: 1px solid rgba(16,185,129,0.12);
  font-weight: 600;
  font-size: 12px;
}

.mini-price-card {
  border-radius: var(--radius-xl);
  padding: 20px;
  background: var(--surface);
  border: 1px solid var(--border);
  display: grid;
  gap: 8px;
}

.mini-price-card span { color: var(--text-secondary); font-weight: 600; font-size: 13px; }
.mini-price-card strong { font-size: 32px; color: var(--text); font-weight: 800; }
.mini-price-card small { color: var(--brand); font-weight: 600; font-size: 12px; margin-bottom: 6px; }

.human-price {
  transform: none;
  align-self: center;
  background: var(--surface);
}

.human-price strong { color: var(--text); }
.human-price span, .human-price small { color: var(--brand); }

.floating-note { display: none; }

.scene-art {
  position: absolute;
  z-index: 0;
  display: grid;
  place-items: center;
  border: 1px solid var(--border);
  background: var(--surface);
  color: var(--text-secondary);
  font-weight: 700;
  font-size: 12px;
  letter-spacing: 0.05em;
  transform: none;
}

.scene-whatsapp {
  width: 100px;
  height: 100px;
  border-radius: var(--radius-xl);
  top: 8px;
  inset-inline-start: 12px;
  color: var(--brand);
}

.scene-whatsapp:before {
  content: "";
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: 3px solid var(--brand);
  position: absolute;
  opacity: 0.3;
}

.scene-ai {
  width: 72px;
  height: 72px;
  border-radius: var(--radius-lg);
  right: 32px;
  bottom: 32px;
  color: var(--brand2);
  font-size: 20px;
}

.scene-bot {
  width: 90px;
  height: 56px;
  border-radius: var(--radius-lg);
  left: 8px;
  bottom: 140px;
  color: var(--text-secondary);
}

.scene-bot:before, .scene-bot:after {
  content: "";
  position: absolute;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand);
  top: 14px;
}
.scene-bot:before { right: 24px; }
.scene-bot:after { left: 24px; }

.phone-frame, .mini-price-card { z-index: 2; }

/* ══════════════════════════════════════════════════════════════
   SECTIONS
   ══════════════════════════════════════════════════════════════ */
.section {
  padding: 56px 0;
}

.section-title {
  font-size: 28px;
  font-weight: 800;
  text-align: center;
  margin-bottom: 12px;
  letter-spacing: -0.02em;
  color: var(--text);
}

.section-sub {
  max-width: 560px;
  margin: 0 auto 40px;
  text-align: center;
  line-height: 1.8;
  font-size: 15px;
}

.feature-card {
  border-radius: var(--radius-xl);
  padding: 28px;
  min-height: 160px;
}

.feature-card strong {
  display: block;
  font-size: 17px;
  margin-bottom: 10px;
  color: var(--text);
}

.feature {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  margin-top: 16px;
  color: var(--text-secondary);
}

.dot {
  width: 24px;
  height: 24px;
  border-radius: 8px;
  background: rgba(16,185,129,0.08);
  color: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  flex: 0 0 auto;
  font-size: 12px;
}

.step-no {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(16,185,129,0.08);
  color: var(--brand);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  margin-bottom: 16px;
  font-size: 14px;
}

.flow {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin: 24px 0;
}

.flow-step {
  border-radius: var(--radius);
  padding: 16px;
  font-weight: 600;
  font-size: 14px;
  text-align: center;
}

.human-landing .flow {
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
  max-width: 520px;
}

.human-landing .flow-step {
  min-width: 0;
  color: var(--text-secondary);
}

.human-landing .section {
  margin-top: 32px;
  padding: 40px;
  border-radius: var(--radius-xl);
  background: var(--surface);
  border: 1px solid var(--border);
}

.human-landing .section-title {
  color: var(--text);
}

.human-landing .feature-card {
  min-height: 150px;
}

.footer {
  border-top: 1px solid var(--border);
  margin-top: 48px;
  padding: 24px;
  text-align: center;
  color: var(--text-secondary);
  font-size: 14px;
}

.footer a {
  color: var(--brand);
  font-weight: 600;
}

/* ══════════════════════════════════════════════════════════════
   PRICE
   ══════════════════════════════════════════════════════════════ */
.price-card {
  border-radius: var(--radius-xl);
  padding: 32px;
}

.price {
  font-size: 56px;
  line-height: 1;
  font-weight: 800;
  color: var(--text);
}

.price small {
  font-size: 20px;
  font-weight: 500;
}

/* ══════════════════════════════════════════════════════════════
   BADGES & TOKENS
   ══════════════════════════════════════════════════════════════ */
.badge {
  display: inline-flex;
  padding: 4px 10px;
  border-radius: 8px;
  background: rgba(16,185,129,0.08);
  color: var(--brand);
  font-weight: 600;
  font-size: 12px;
}

.badge.warn {
  background: rgba(245,158,11,0.08);
  color: #f59e0b;
}

.badge.danger {
  background: rgba(239,68,68,0.08);
  color: #ef4444;
}

.token {
  direction: ltr;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
  font-size: 12px;
  word-break: break-all;
  color: var(--text-secondary);
  font-family: "SF Mono", "Fira Code", monospace;
}

.device-row {
  display: grid;
  grid-template-columns: 1.2fr .9fr .9fr auto;
  gap: 12px;
  align-items: center;
}

.qr-box {
  width: 200px;
  height: 200px;
  border-radius: var(--radius-xl);
  background: #fff;
  margin: auto;
  padding: 12px;
}

.qr-img {
  display: block;
  max-width: 200px;
  width: 100%;
  margin: 12px auto;
  background: #fff;
  border-radius: var(--radius-lg);
  padding: 10px;
}

.device-link-card {
  display: grid;
  gap: 14px;
}

.device-tab-radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.device-link-tabs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  padding: 5px;
  border-radius: 999px;
  background: var(--surface);
  border: 1px solid var(--border);
}

.device-link-tabs label {
  min-height: 44px;
  display: grid;
  place-items: center;
  margin: 0;
  border-radius: 999px;
  color: var(--text-secondary);
  font-weight: 900;
  cursor: pointer;
}

#deviceTabQr:checked ~ .device-link-tabs label[for="deviceTabQr"],
#deviceTabCode:checked ~ .device-link-tabs label[for="deviceTabCode"] {
  background: linear-gradient(135deg, var(--brand), #18c6b5);
  color: #fff;
}

.device-tab-panel {
  display: none;
  padding: 16px;
  border-radius: 24px;
  background: rgba(255,255,255,.035);
  border: 1px solid var(--border);
}

#deviceTabQr:checked ~ .device-tab-qr,
#deviceTabCode:checked ~ .device-tab-code {
  display: grid;
  gap: 12px;
}

.device-qr-img,
.device-qr-placeholder {
  width: min(240px, 82vw) !important;
  height: min(240px, 82vw) !important;
  border-radius: 28px !important;
  background: #fff !important;
  padding: 12px !important;
  display: block;
  margin: 10px auto 4px !important;
  box-shadow: var(--app-shadow-soft);
}

.pairing-code-box {
  direction: ltr;
  unicode-bidi: plaintext;
  text-align: center;
  letter-spacing: .14em;
  font-size: clamp(30px, 9vw, 46px);
  font-weight: 950;
  padding: 16px;
  border-radius: 22px;
  color: #d1fae5;
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.22);
}

html[data-theme="light"] .pairing-code-box {
  color: #064e3b !important;
  background: linear-gradient(135deg, #ecfdf5, #d1fae5) !important;
  border-color: rgba(15, 118, 110, .22) !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.75), 0 12px 28px rgba(15, 118, 110, .10);
}

/* ══════════════════════════════════════════════════════════════
   AUTH
   ══════════════════════════════════════════════════════════════ */
.auth-shell {
  max-width: 420px;
  margin: 60px auto;
}

.auth-logo {
  text-align: center;
  margin-bottom: 28px;
}

/* ══════════════════════════════════════════════════════════════
   TABLES
   ══════════════════════════════════════════════════════════════ */
.table-card {
  padding: 0 !important;
  overflow: hidden;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
  min-width: 700px;
}

.data-table th,
.data-table td {
  padding: 12px 16px;
  border-bottom: 1px solid var(--border);
  text-align: right;
  vertical-align: middle;
  font-size: 14px;
}

.data-table th {
  color: var(--text-secondary);
  background: var(--surface);
  font-weight: 700;
  font-size: 13px;
}

.data-table a {
  color: var(--brand);
  font-weight: 600;
}

/* ══════════════════════════════════════════════════════════════
   ADMIN
   ══════════════════════════════════════════════════════════════ */
.admin-shell { align-items: stretch; }

.admin-side {
  width: 240px;
  min-width: 240px;
  padding: 16px;
}

.admin-brand {
  justify-content: center;
  margin-bottom: 12px;
  padding-bottom: 12px;
}

.admin-brand .logo-shell { padding: 8px 12px; border-radius: 10px; }
.admin-brand img { height: 40px !important; }

.admin-menu-title {
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  margin: 8px 4px 12px;
}

.admin-nav { display: grid; gap: 4px; }

.admin-nav a {
  min-height: 40px;
  margin: 0 !important;
  padding: 10px 12px !important;
  border-radius: 10px !important;
  display: flex !important;
  align-items: center;
  gap: 10px;
  white-space: nowrap;
  font-size: 14px;
}

.nav-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--brand);
  opacity: 0.4;
  flex: 0 0 auto;
}

.nav-dot.danger {
  background: #ef4444;
  opacity: 0.5;
}

.admin-main { max-width: calc(100vw - 240px); }

.admin-charts {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}

.admin-live-device-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  margin: 14px 0;
}

.admin-live-device-grid .card {
  margin: 0;
  padding: 16px !important;
}

.admin-live-device-grid .stat {
  font-size: 24px;
}

.chart-card { display: grid; gap: 14px; }

.metric-chart {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px;
  background: var(--surface);
}

.metric-chart-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 12px;
}

.metric-chart-head strong { color: var(--text); font-size: 14px; }
.metric-chart-head span { color: var(--brand); font-weight: 700; direction: ltr; font-size: 14px; }

.bars {
  height: 120px;
  display: flex;
  align-items: end;
  gap: 4px;
  padding-top: 8px;
}

.bar-item {
  min-width: 0;
  flex: 1;
  height: 100%;
  display: flex;
  flex-direction: column;
  justify-content: end;
  align-items: center;
  gap: 4px;
}

.bar-item span {
  width: 100%;
  min-height: 4px;
  border-radius: 6px 6px 2px 2px;
  background: var(--brand);
  opacity: 0.6;
}

.bar-item small {
  color: var(--text-secondary);
  font-size: 10px;
  direction: ltr;
  unicode-bidi: plaintext;
  writing-mode: horizontal-tb;
  transform: none;
  max-height: none;
  white-space: nowrap;
  text-align: center;
}

.admin-form { display: grid; gap: 16px; }

.form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.form-field {
  display: grid;
  gap: 6px;
  margin: 0 !important;
  color: var(--text);
  font-weight: 600;
  font-size: 14px;
}

.form-field-wide { grid-column: 1 / -1; }

.form-field .input, .form-field textarea {
  margin: 0 !important;
  min-height: 44px;
}

.form-field textarea { resize: vertical; }

.form-actions {
  display: flex;
  justify-content: flex-start;
  padding-top: 4px;
}

.form-actions .btn { min-width: 160px; }

.card form + form { margin-top: 10px; }

/* ══════════════════════════════════════════════════════════════
   TRAINING
   ══════════════════════════════════════════════════════════════ */
.training-tabs {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin: 0 0 16px;
}

.training-tabs .mini-btn {
  border-color: rgba(16,185,129,.26);
}

.ready-training-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}

.training-save-bar {
  position: sticky;
  top: 12px;
  z-index: 20;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 14px 16px;
  margin-bottom: 14px;
  border: 1px solid rgba(16,185,129,.24);
  border-radius: var(--radius-xl);
  background: var(--surface);
  box-shadow: var(--shadow-lg);
}

.training-save-bar p { margin: 3px 0 0; }

.training-option-card {
  display: grid !important;
  grid-template-columns: 1fr auto;
  align-items: start;
  gap: 12px;
  padding: 14px 16px !important;
}

.training-option-card .badge { width: fit-content; }

.section-collapse-toggle {
  appearance: none;
  border: 0;
  background: transparent;
  color: var(--text);
  padding: 0;
  margin: 0;
  width: 100%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  text-align: inherit;
  font-family: inherit;
}

.section-collapse-toggle span:first-child { display: grid; gap: 4px; }
.section-collapse-toggle strong { font-size: 17px; }
.section-collapse-toggle small { font-size: 12px; font-weight: 600; color: var(--text-secondary); }

.collapse-chevron {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  background: rgba(16,185,129,0.08);
  color: var(--brand);
  transition: transform 0.2s ease;
  flex: 0 0 auto;
  font-size: 12px;
}

.collapsible-section.is-open .section-collapse-toggle {
  padding-bottom: 14px;
  margin-bottom: 14px;
  border-bottom: 1px solid var(--border);
}

.collapsible-section.is-open .collapse-chevron { transform: rotate(180deg); }
.collapsible-section.is-collapsed .collapsible-content { display: none; }
.collapsible-section.is-collapsed { padding-block: 14px !important; }

.training-option-body { display: grid; gap: 6px; min-width: 0; }

.training-option-head {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}

.incoming-line { display: block; font-size: 12px; line-height: 1.5; color: var(--text-secondary); }

.option-preview {
  display: block;
  padding: 8px 10px !important;
  margin: 0 !important;
  border-radius: var(--radius) !important;
  font-size: 12px;
  line-height: 1.5;
}

.fixed-reply-toggle {
  width: fit-content;
  margin-top: 4px;
}

.admin-training-dashboard,
.admin-training-review-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: 14px;
}

.admin-training-group {
  margin: 0 !important;
}

.admin-training-group h3 {
  margin-bottom: 6px;
}

.admin-training-options {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}

.training-admin-option {
  display: grid;
  gap: 5px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  color: var(--text);
  text-decoration: none;
}

.training-admin-option:hover,
.active-training-admin-option {
  border-color: rgba(16,185,129,.5);
  background: rgba(16,185,129,.08);
}

.training-quality-pill,
.review-status {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 12px;
  font-weight: 800;
  color: var(--brand);
  background: rgba(16,185,129,.1);
}

.admin-training-review-card {
  display: grid;
  gap: 10px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--surface);
}

.training-review-head,
.training-stats-row,
.training-meta-line,
.training-style-checks {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  justify-content: space-between;
}

.training-meta-line,
.training-style-checks {
  justify-content: flex-start;
}

.training-style-checks {
  padding: 8px;
  border-radius: var(--radius);
  background: var(--surface-hover);
}

.fixed-reply-field {
  display: none;
  gap: 6px;
  margin-top: 10px;
  padding: 10px;
  border-radius: var(--radius);
  background: var(--surface-hover);
}

.fixed-reply-field.is-open {
  display: grid;
}

.fixed-reply-field textarea {
  min-height: 68px;
}

.training-test-dialog {
  overflow: hidden;
}

.training-test-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin-bottom: 14px;
}

.whatsapp-test-box {
  display: grid;
  gap: 12px;
}

.wa-chat-preview {
  min-height: 260px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 22px;
  background:
    radial-gradient(circle at 20% 10%, rgba(16,185,129,.12), transparent 24%),
    linear-gradient(135deg, rgba(16,185,129,.08), rgba(15,23,42,.14)),
    var(--surface-hover);
}

.wa-test-live-preview {
  min-height: 340px;
  position: relative;
  background:
    linear-gradient(rgba(8, 19, 17, .88), rgba(8, 19, 17, .88)),
    repeating-linear-gradient(135deg, rgba(255,255,255,.035) 0 1px, transparent 1px 18px),
    var(--surface-hover);
}

.wa-test-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--border);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 800;
}

.wa-test-meta strong {
  color: var(--text);
}

.wa-bubble {
  width: min(78%, 520px);
  display: grid;
  gap: 6px;
  padding: 12px 14px;
  border-radius: 18px;
  box-shadow: var(--shadow);
}

.wa-bubble small {
  color: var(--text-secondary);
  font-weight: 800;
}

.wa-bubble.incoming {
  align-self: flex-start;
  border-bottom-left-radius: 6px;
  background: var(--surface);
  border: 1px solid var(--border);
}

.wa-bubble.outgoing {
  align-self: flex-end;
  border-bottom-right-radius: 6px;
  color: #d1fae5;
  background: linear-gradient(135deg, rgba(16,185,129,.28), rgba(20,184,166,.18));
  border: 1px solid rgba(16,185,129,.2);
}

.wa-bubble textarea {
  width: 100%;
  min-height: 74px;
  resize: vertical;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  line-height: 1.7;
}

.test-input-bubble textarea {
  min-height: 96px;
  font-size: 15px;
}

.test-reply-bubble {
  min-height: 92px;
}

.test-reply-bubble span {
  display: block;
  color: #ecfdf5;
  line-height: 1.9;
  font-weight: 800;
  font-size: 15px;
}

.test-reply-bubble.is-waiting {
  opacity: .78;
  background: rgba(148,163,184,.12);
  border-color: rgba(148,163,184,.18);
  color: var(--text-secondary);
}

.test-reply-bubble.is-waiting span {
  color: var(--text-secondary);
  font-weight: 700;
}

.training-test-live .wa-compose-row {
  grid-template-columns: minmax(0, 1fr) minmax(210px, auto);
  padding: 12px;
  border-radius: 22px;
  background: var(--surface);
  border: 1px solid var(--border);
}

.wa-bubble input {
  width: 100%;
  border: 0;
  outline: 0;
  color: var(--text);
  background: transparent;
  font: inherit;
  direction: ltr;
}

.wa-compose-row {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 10px;
  align-items: center;
}

.send-test-preview {
  min-height: 230px;
}

.send-number-bubble {
  width: min(58%, 360px);
}

.send-test-actions {
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--surface-hover);
}

.training-stats-row {
  justify-content: flex-start;
  margin: 14px 0;
}

.training-stats-row span {
  padding: 8px 10px;
  border-radius: var(--radius);
  background: var(--surface-hover);
  color: var(--text);
  font-weight: 800;
}

.review-status.approved {
  color: #10b981;
  background: rgba(16,185,129,.12);
}

.review-status.rejected {
  color: #ef4444;
  background: rgba(239,68,68,.12);
}

.review-status.pending {
  color: #f59e0b;
  background: rgba(245,158,11,.12);
}

.inline-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-secondary);
}

/* ══════════════════════════════════════════════════════════════
   TOGGLE SWITCH
   ══════════════════════════════════════════════════════════════ */
.switch-wrap {
  width: 48px;
  height: 28px;
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  order: 2;
}

.switch-wrap input {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}

.switch-ui {
  width: 46px;
  height: 26px;
  border-radius: 999px;
  background: var(--surface-hover);
  border: 1px solid var(--border);
  position: relative;
  transition: all 0.2s ease;
  cursor: pointer;
}

.switch-ui:before {
  content: "";
  position: absolute;
  top: 3px;
  inset-inline-start: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  transition: transform 0.2s ease;
}

.switch-wrap input:checked + .switch-ui {
  background: var(--brand);
  border-color: var(--brand);
}

html[dir="rtl"] .switch-wrap input:checked + .switch-ui:before {
  transform: translateX(-20px);
}

html[dir="ltr"] .switch-wrap input:checked + .switch-ui:before {
  transform: translateX(20px);
}

.custom-training-card {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 12px;
  padding: 14px 16px !important;
}

.settings-simple-form {
  display: grid;
  gap: 18px;
}
.settings-toggle-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: var(--radius-xl);
  background: var(--surface);
}
.settings-toggle-row strong {
  display: block;
  margin-bottom: 4px;
  color: var(--text);
}
.settings-toggle-row .muted {
  margin: 0;
  font-size: 13px;
}
.settings-toggle-row .switch-wrap {
  flex: 0 0 auto;
}

.custom-training-body { min-width: 0; display: grid; gap: 5px; }

.custom-training-body p {
  margin: 0 !important;
  font-size: 12px;
  line-height: 1.5;
  max-height: 3em;
  overflow: hidden;
  color: var(--text-secondary);
}

.danger-mini {
  color: #fecaca !important;
  background: rgba(220,38,38,0.08) !important;
  border-color: rgba(248,113,113,0.15) !important;
}

/* ══════════════════════════════════════════════════════════════
   CHAT PAGE
   ══════════════════════════════════════════════════════════════ */
.chat-page { max-width: 860px; margin: 0 auto; }

.chat-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 14px;
}

.chat-head h1 { margin: 0 0 4px; }

.chat-window {
  min-height: 420px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.chat-meta {
  display: flex;
  justify-content: center;
  margin-bottom: 6px;
}

.chat-bubble {
  max-width: 78%;
  padding: 12px 16px;
  border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}

.chat-bubble p { margin: 6px 0 0; line-height: 1.8; }

.chat-bubble.ai {
  align-self: flex-start;
  background: rgba(16,185,129,0.06);
}

.chat-bubble.user {
  align-self: flex-end;
  background: var(--surface);
}

.chat-compose form + form { margin-top: 10px; }

/* ══════════════════════════════════════════════════════════════
   PWA
   ══════════════════════════════════════════════════════════════ */
.pwa-hint {
  position: fixed;
  left: 14px;
  right: 14px;
  bottom: 14px;
  z-index: 1000;
  display: none;
  padding: 14px 16px;
  border-radius: var(--radius-lg);
  background: var(--bg2);
  color: var(--text);
  border: 1px solid var(--border);
}

.pwa-hint.show { display: block; }

/* ══════════════════════════════════════════════════════════════
   LANGUAGE OVERRIDES
   ══════════════════════════════════════════════════════════════ */
html[data-lang="en"] body { font-family: "Tajawal", "Inter", system-ui, -apple-system, sans-serif !important; }
html[data-lang="en"] [data-i18n="logout"] { font-size: 0; }
html[data-lang="en"] [data-i18n="logout"]:after { content: "Logout"; font-size: 14px; }
html[data-lang="en"] .account-btn { font-size: 0; }
html[data-lang="en"] .account-btn:after { content: "My account"; font-size: 14px; }
html[data-lang="en"] [data-nav="dashboard"] { font-size: 0; }
html[data-lang="en"] [data-nav="dashboard"]:after { content: "Home"; font-size: 14px; }
html[data-lang="en"] [data-nav="subscribe"] { font-size: 0; }
html[data-lang="en"] [data-nav="subscribe"]:after { content: "Plan"; font-size: 14px; }
html[data-lang="en"] [data-nav="device"] { font-size: 0; }
html[data-lang="en"] [data-nav="device"]:after { content: "Devices"; font-size: 14px; }
html[data-lang="en"] [data-nav="training"] { font-size: 0; }
html[data-lang="en"] [data-nav="training"]:after { content: "Training"; font-size: 14px; }
html[data-lang="en"] [data-nav="settings"] { font-size: 0; }
html[data-lang="en"] [data-nav="settings"]:after { content: "Settings"; font-size: 14px; }

/* ══════════════════════════════════════════════════════════════
   STANDALONE MODE
   ══════════════════════════════════════════════════════════════ */
@media (display-mode: standalone) {
  .install-btn { display: none !important; }
}

/* ══════════════════════════════════════════════════════════════
   MOBILE RESPONSIVE (≤900px)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  html, body {
    width: 100%;
    overflow-x: hidden;
  }

  .app-actions { display: none !important; }

  .wrap {
    display: block !important;
    min-height: 100vh;
    padding: 0 0 88px !important;
  }

  .user-shell {
    width: min(100%, 430px);
    margin: 0 auto;
    padding: 0 12px calc(104px + env(safe-area-inset-bottom, 0px)) !important;
    background:
      linear-gradient(180deg, rgba(16,185,129,0.10), transparent 180px),
      var(--bg);
  }

  .app-header {
    position: sticky;
    top: 0;
    z-index: 80;
    margin: 0 0 12px !important;
    padding: 12px 16px !important;
    border-radius: 0 !important;
    background: var(--bg) !important;
    border-bottom: 1px solid var(--border) !important;
    border-top: none !important;
    border-left: none !important;
    border-right: none !important;
    display: flex !important;
    align-items: center;
    gap: 10px;
  }

  .user-app-header {
    top: 8px;
    margin: 8px 0 12px !important;
    border-radius: 22px !important;
    padding: 12px 14px !important;
    background: rgba(24,24,27,0.94) !important;
    box-shadow: 0 14px 34px rgba(0,0,0,0.22);
    backdrop-filter: blur(14px);
    -webkit-backdrop-filter: blur(14px);
  }

  html[data-theme="light"] .user-app-header {
    background: rgba(255,255,255,0.95) !important;
  }

  .app-header strong { font-size: 14px !important; }
  .app-header p { font-size: 11px; margin: 2px 0 0 !important; }

  .header-actions {
    justify-content: flex-end;
    gap: 6px;
    flex-wrap: nowrap;
  }

  .header-actions .mini-btn {
    flex: 0 0 auto;
    min-width: 36px;
    height: 36px;
    padding: 0 10px !important;
    font-size: 11px;
  }

  .header-actions .install-btn { display: none !important; }
  .account-btn { min-width: 50px !important; }

  .side {
    position: static !important;
    width: auto !important;
    height: auto !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
  }

  .user-side {
    height: auto !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: transparent !important;
  }

  .brand {
    position: sticky;
    top: 0;
    z-index: 90;
    margin: 0 !important;
    padding: 12px 16px 8px !important;
    border: 0 !important;
    background: var(--bg);
    justify-content: center;
  }

  .user-brand {
    position: relative;
    top: auto;
    z-index: 1;
    margin: 10px 0 0 !important;
    padding: 18px 16px 20px !important;
    border-radius: 0 0 28px 28px !important;
    border-top: 0 !important;
    border-left: 0 !important;
    border-right: 0 !important;
    background: #0b0b0d !important;
  }

  html[data-theme="light"] .user-brand {
    background: #fff !important;
  }

  .brand .logo-shell {
    width: auto !important;
    max-width: 180px;
    padding: 8px 12px !important;
    border-radius: 10px !important;
  }

  .brand img { height: 36px !important; }

  .nav {
    position: fixed;
    left: max(10px, env(safe-area-inset-left, 0px));
    right: max(10px, env(safe-area-inset-right, 0px));
    bottom: max(10px, env(safe-area-inset-bottom, 0px));
    z-index: 120;
    display: grid !important;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 5px;
    padding: 7px;
    border-radius: 24px;
    background: rgba(24,24,27,0.94) !important;
    border: 1px solid var(--border);
    overflow: hidden;
    box-shadow: 0 18px 42px rgba(0,0,0,0.28);
    backdrop-filter: blur(18px);
    -webkit-backdrop-filter: blur(18px);
  }

  html[data-theme="light"] .nav {
    background: rgba(255,255,255,0.96) !important;
    box-shadow: 0 18px 42px rgba(15,23,42,0.14);
  }

  .nav a {
    margin: 0 !important;
    padding: 7px 4px !important;
    min-height: 54px;
    border-radius: 16px !important;
    justify-content: center;
    text-align: center;
    font-size: 0 !important;
    display: grid !important;
    place-items: center;
    gap: 4px;
  }

  .user-nav .active {
    background: linear-gradient(135deg, var(--brand), #14b8a6) !important;
    color: #fff !important;
    border-color: transparent !important;
  }

  .user-nav .active:before {
    background: rgba(255,255,255,0.18);
  }

  .nav a:before {
    content: attr(data-icon);
    display: block;
    font-size: 15px;
    line-height: 1;
    width: 24px;
    height: 24px;
    border-radius: 9px;
    display: inline-grid;
    place-items: center;
    background: rgba(255,255,255,0.04);
  }
  .nav a:after {
    content: attr(data-label);
    display: block;
    font-size: 10px !important;
    font-weight: 800;
    white-space: nowrap;
  }

  html[data-lang="en"] .nav a:after { content: attr(data-label-en); }

  .nav a[data-nav="send-test"] { display: none !important; }
  .nav a[data-nav="billing"] { display: none !important; }
  .nav a[data-i18n="logout"] { display: none !important; }

  .admin-nav {
    grid-template-columns: none !important;
    grid-auto-flow: column;
    grid-auto-columns: minmax(72px, 1fr);
    overflow-x: auto !important;
    overflow-y: hidden !important;
    scrollbar-width: none;
  }

  .admin-nav::-webkit-scrollbar {
    display: none;
  }

  .admin-nav a span {
    display: none !important;
  }

  .main {
    padding: 8px 0 16px !important;
    width: 100%;
  }

  .user-main {
    max-width: 100%;
  }

  .card {
    border-radius: var(--radius-lg) !important;
    padding: 16px !important;
    margin-bottom: 10px !important;
  }

  .user-main .card {
    border-radius: 22px !important;
    padding: 16px !important;
    background: rgba(255,255,255,0.04) !important;
  }

  .hero {
    min-height: auto;
    padding: 16px !important;
    border-radius: var(--radius-lg) !important;
  }

  .user-main .hero {
    border-radius: 24px !important;
    padding: 18px 16px !important;
  }

  .user-main .feature {
    margin-top: 8px !important;
    padding: 9px 10px;
    border-radius: 14px;
    background: rgba(255,255,255,0.025);
    border: 1px solid var(--border);
  }

  .user-main .feature strong {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
  }

  .hero h1 { font-size: 18px !important; margin-bottom: 6px !important; }
  .hero p { font-size: 13px; margin: 0 !important; }

  .grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .dashboard-insights {
    grid-template-columns: 1fr !important;
  }

  .usage-chart-card {
    min-height: auto;
  }

  .usage-card-head {
    display: grid;
    gap: 8px;
    margin-bottom: 12px;
  }

  .usage-chart {
    height: 170px;
    gap: 5px;
    padding-inline: 8px;
    direction: ltr;
  }

  .usage-day {
    min-width: 24px;
    gap: 4px;
  }

  .usage-day > .usage-bar {
    width: 7px;
  }

  .usage-day small,
  .bar-item small {
    font-size: 10px !important;
    letter-spacing: 0;
  }

  .usage-progress-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .app-footer {
    display: grid;
    gap: 10px;
    margin-top: 12px;
    margin-bottom: 4px;
    padding: 14px;
    border-radius: 20px;
    text-align: center;
  }

  .app-footer-meta {
    justify-content: center;
  }

  .grid > .card { min-height: auto !important; }

  .grid > .card:has(.feature),
  .grid > .card:has(form),
  .grid > .card:has(.token),
  .grid > .card:has(.device-row),
  .grid > .price-card {
    grid-column: 1 / -1;
  }

  .ready-training-grid {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }

  .training-save-bar {
    top: 8px;
    align-items: stretch;
    flex-direction: column;
    padding: 12px;
  }

  .training-save-bar .btn {
    width: 100%;
  }

  .training-test-head,
  .wa-compose-row {
    grid-template-columns: 1fr;
    display: grid;
  }

  .wa-bubble {
    width: 92%;
  }

  .wa-compose-row .btn {
    width: 100%;
  }

  .training-option-card {
    grid-template-columns: 1fr 48px;
    gap: 8px !important;
    padding: 12px !important;
    border-radius: var(--radius) !important;
  }

  .training-option-card p { margin: 0 !important; }

  .training-option-card .option-preview {
    padding: 6px 8px !important;
    font-size: 11px;
  }

  .training-option-head { gap: 4px; }
  .section-collapse-toggle strong { font-size: 15px; }
  .section-collapse-toggle small { font-size: 10px; }
  .collapse-chevron { width: 24px; height: 24px; }

  .collapsible-section.is-open .section-collapse-toggle {
    padding-bottom: 10px;
    margin-bottom: 10px;
  }

  .collapsible-section.is-collapsed { padding-block: 12px !important; }
  .training-option-head strong { font-size: 14px; }
  .incoming-line { font-size: 11px; }

  .switch-wrap { width: 44px; height: 26px; }
  .switch-ui { width: 42px; height: 24px; }
  .switch-ui:before { width: 16px; height: 16px; top: 3px; }

  html[dir="rtl"] .switch-wrap input:checked + .switch-ui:before { transform: translateX(-18px); }
  html[dir="ltr"] .switch-wrap input:checked + .switch-ui:before { transform: translateX(18px); }

  .custom-training-card {
    grid-template-columns: 40px 1fr auto;
    gap: 8px !important;
    padding: 12px !important;
    border-radius: var(--radius) !important;
  }

  .custom-training-body strong { font-size: 14px; }
  .custom-training-body p { font-size: 11px; }

  .danger-mini {
    min-width: auto !important;
    height: 32px !important;
    padding: 0 10px !important;
    font-size: 11px !important;
  }

  .chat-page { max-width: none; }
  .chat-head { margin-bottom: 10px; }
  .chat-head h1 { font-size: 18px !important; }
  .chat-window { min-height: calc(100vh - 300px); gap: 10px; }
  .chat-bubble { max-width: 90%; padding: 10px 12px; border-radius: var(--radius); }
  .chat-bubble p { font-size: 13px; }

  .title { font-size: 36px !important; }
  .stat { font-size: 24px !important; margin-bottom: 4px !important; }

  .stat + .muted, .card > .muted, .card p.muted {
    font-size: 12px !important;
    margin-bottom: 0 !important;
  }

  .card h1, .card h2, .card h3 {
    font-size: 15px !important;
    margin-bottom: 8px !important;
  }

  .btn {
    width: 100%;
    text-align: center;
    justify-content: center;
    margin-top: 4px;
    padding: 10px 16px !important;
    border-radius: 10px !important;
    font-size: 14px;
  }

  .btn + .btn { margin-inline-start: 0 !important; }

  .input, textarea { font-size: 16px; min-height: 44px; }

  .feature { gap: 10px !important; font-size: 13px; margin-top: 8px !important; }
  .dot { width: 22px !important; height: 22px !important; font-size: 10px; }
  .badge { font-size: 11px !important; padding: 4px 8px !important; }
  .token { font-size: 11px !important; }

  .landing { padding: 0 16px 80px !important; }

  .topbar { padding: 14px 16px !important; gap: 10px; }
  .topbar .logo-shell { padding: 6px 10px !important; }
  .topbar img { height: 34px !important; }
  .topbar .btn { width: auto; padding: 8px 14px !important; font-size: 13px; }

  .landing-hero { gap: 20px !important; padding: 20px 0 !important; }
  .marketing-hero { grid-template-columns: 1fr !important; }

  .phone-showcase { grid-template-columns: 1fr !important; }

  .phone-frame {
    min-height: 440px;
    max-width: 360px;
    width: 100%;
    margin: 0 auto;
    border-radius: 32px;
  }

  .human-landing .phone-frame,
  .human-price,
  .scene-art {
    transform: none;
  }

  .scene-art { display: none; }

  .floating-note {
    position: static;
    max-width: 360px;
    width: 100%;
    margin: 0 auto;
  }

  .human-landing .flow {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .chat-area { min-height: 320px; }

  .mini-price-card {
    max-width: 360px;
    width: 100%;
    margin: 0 auto;
  }

  .hero-actions .btn { width: auto; }

  .trust-row span { font-size: 11px; padding: 6px 10px; }
  .price { font-size: 48px !important; }
  .device-row { gap: 8px !important; }

  .flow {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .flow-step {
    padding: 12px !important;
    border-radius: 10px !important;
    font-size: 13px;
  }

  .feature-card {
    min-height: auto !important;
    padding: 16px !important;
  }

  .feature-card strong {
    font-size: 14px !important;
    margin-bottom: 6px !important;
  }

  .human-hero {
    grid-template-columns: 1fr !important;
    padding: 28px 20px !important;
    gap: 24px !important;
    margin-top: 16px;
  }

  .human-title {
    font-size: 36px !important;
  }

  .human-notes {
    grid-template-columns: 1fr 1fr 1fr;
    gap: 6px;
  }

  .human-notes span { font-size: 11px; padding: 6px 8px; }

  .human-landing .section {
    padding: 24px 16px;
    margin-top: 16px;
  }
}

/* ══════════════════════════════════════════════════════════════
   EXTRA SMALL (≤420px)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 420px) {
  .main { padding-inline: 8px !important; }
  .user-main { padding-inline: 0 !important; }
  .grid { gap: 8px !important; }
  .card { padding: 14px !important; border-radius: var(--radius) !important; }
  .hero { padding: 14px !important; }
  .hero h1 { font-size: 16px !important; }
  .stat { font-size: 22px !important; }

  .nav {
    left: 6px;
    right: 6px;
    bottom: 6px;
    padding: 4px;
    border-radius: var(--radius);
  }

  .user-nav {
    left: 8px;
    right: 8px;
    bottom: 8px;
    padding: 6px;
    border-radius: 22px;
  }

  .nav a {
    min-height: 44px;
    padding: 6px 4px !important;
    border-radius: 8px !important;
  }

  .user-nav a {
    min-height: 52px;
    border-radius: 15px !important;
  }

  .nav a:before { font-size: 14px; }
  .nav a:after { font-size: 9px !important; }

  .human-notes { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
   ADMIN RESPONSIVE (≤900px)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .admin-shell {
    display: block;
    padding-bottom: 16px;
  }

  .admin-side {
    width: auto !important;
    min-width: 0 !important;
    padding: 8px !important;
  }

  .admin-brand { display: none !important; }
  .admin-menu-title { display: none; }

  .admin-nav {
    position: static !important;
    grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
    gap: 4px !important;
    padding: 6px !important;
  }

  .admin-nav a {
    min-height: 44px !important;
    font-size: 11px !important;
    white-space: normal;
    line-height: 1.2;
    text-align: center;
    justify-content: center;
  }

  .admin-main { max-width: none; }
  .admin-charts { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .form-actions .btn { width: 100%; }
  .bars { height: 100px; }
}

/* Clean final homepage */
.landing-clean, .landing-topbar { max-width: 1240px !important; }
.app-actions:has(+ main .landing-topbar) {
  top: 22px;
  inset-inline-start: 18px;
  inset-inline-end: auto;
}
.landing-topbar {
  margin-top: 78px !important;
  padding: 14px 18px !important;
  border-radius: 28px;
  background: color-mix(in srgb, var(--card2) 88%, transparent);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(22px) saturate(150%);
  position: relative;
  z-index: 20;
}
.landing-topbar + .landing-clean {
  margin-top: 24px;
}
.landing-topbar .logo-shell {
  border-radius: 18px;
  padding: 8px 12px;
}
.landing-topbar img {
  width: 190px !important;
  max-height: 64px !important;
}
.landing-topbar > div {
  display: flex;
  align-items: center;
  gap: 10px;
}
.clean-hero {
  position: relative; display: grid; grid-template-columns: minmax(0, 1fr) 520px;
  gap: 34px; align-items: center; min-height: 660px; padding: 46px; margin-top: 20px;
  border-radius: 42px; overflow: hidden; border: 1px solid rgba(255,255,255,.12);
  background:
    radial-gradient(circle at 15% 18%, rgba(16,185,129,.18), transparent 30%),
    radial-gradient(circle at 82% 22%, rgba(20,184,166,.14), transparent 32%),
    linear-gradient(135deg, #f8fafc 0%, #ecfdf5 48%, #f1f5f9 100%);
  box-shadow: 0 34px 120px rgba(2,6,23,.32);
}
.clean-hero:before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,.045) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px);
  background-size: 46px 46px; mask-image: linear-gradient(90deg, black, transparent 82%);
}
.clean-copy, .clean-visual { position: relative; z-index: 1; }
.clean-copy h1 { margin: 18px 0; color: #0f172a; font-size: clamp(46px, 5.8vw, 82px); line-height: 1.04; letter-spacing: -.055em; }
.clean-copy h1 span { display: block; }
.clean-copy h1 span:nth-child(2) { color: #34d399; }
.clean-copy p { max-width: 610px; color: #475569; font-size: 20px; line-height: 2; margin: 0; }
.cta-primary {
  min-height: 52px;
  padding-inline: 28px !important;
  font-size: 16px !important;
  font-weight: 900 !important;
}
.conversion-strip {
  max-width: 640px;
  margin-top: 18px;
  padding: 14px 16px;
  border-radius: 20px;
  display: flex;
  gap: 10px;
  align-items: center;
  flex-wrap: wrap;
  color: #d1fae5;
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.20);
  font-weight: 800;
}
.conversion-strip span {
  color: #cbd5e1;
  font-weight: 700;
}
.clean-points { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 10px; max-width: 650px; margin-top: 24px; }
.clean-points span { padding: 10px 12px; border-radius: 16px; text-align: center; color: #e2e8f0; background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.13); font-weight: 900; font-size: 13px; white-space: nowrap; }
.clean-visual { min-height: 590px; display: grid; place-items: center; }
.clean-phone { width: 305px; min-height: 610px; padding: 15px; border-radius: 54px; background: linear-gradient(180deg, rgba(2,6,23,.98), rgba(8,18,33,.88)), radial-gradient(circle at 70% 0%, rgba(16,185,129,.28), transparent 44%); border: 1px solid rgba(255,255,255,.16); box-shadow: 0 34px 110px rgba(0,0,0,.34), inset 0 0 0 9px rgba(255,255,255,.055); }
.clean-phone .phone-top { height: 48px; }
.clean-phone .chat-area { min-height: 470px; border-radius: 34px; padding: 18px 12px; gap: 12px; }
.clean-phone .chat-bubble { font-size: 12px; line-height: 1.65; padding: 11px 13px; border-radius: 18px; }
.clean-price { position: absolute; inset-inline-start: 8px; bottom: 54px; width: 190px; padding: 20px; border-radius: 28px; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); box-shadow: 0 22px 70px rgba(0,0,0,.24); backdrop-filter: blur(18px); display: grid; gap: 7px; }
.clean-price small, .clean-price span { color: #bbf7d0; font-weight: 900; }
.clean-price strong { color: #fff; font-size: 34px; }
.visual-chip { position: absolute; display: grid; place-items: center; border-radius: 24px; background: rgba(255,255,255,.10); border: 1px solid rgba(255,255,255,.16); color: #e0f2fe; font-weight: 900; box-shadow: 0 20px 60px rgba(0,0,0,.20); backdrop-filter: blur(14px); }
.chip-wa { width: 126px; height: 54px; top: 54px; inset-inline-end: 34px; color: #bbf7d0; }
.chip-ai { width: 82px; height: 82px; top: 155px; inset-inline-start: 28px; color: #67e8f9; font-size: 28px; }
.chip-bot { width: 92px; height: 52px; bottom: 150px; inset-inline-end: 18px; }
.clean-section { margin-top: 28px; padding: 34px; border-radius: 34px; background: color-mix(in srgb, var(--card2) 88%, transparent); border: 1px solid var(--line); box-shadow: var(--shadow); }
.clean-section h2 { text-align: center; font-size: 34px; margin-bottom: 8px; }
.clean-section > p { text-align: center; color: var(--muted); margin: 0 auto 24px; max-width: 680px; line-height: 1.8; }
.clean-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 14px; }
.clean-card { min-height: 165px; padding: 22px; border-radius: 24px; background: var(--card); border: 1px solid var(--line); box-shadow: var(--shadow); display: grid; align-content: start; gap: 10px; }
.clean-card b { width: 40px; height: 40px; display: grid; place-items: center; border-radius: 14px; color: #fff; background: linear-gradient(135deg, #10b981, #0ea5e9); }
.clean-card strong { color: var(--text); font-size: 19px; }
.clean-card span { color: var(--muted); line-height: 1.7; }
.persuasion-section {
  border-color: rgba(16,185,129,.20) !important;
}
.persuasion-grid .clean-card {
  min-height: 150px;
  background: linear-gradient(180deg, rgba(16,185,129,.08), rgba(255,255,255,.035)) !important;
}
.final-cta-section {
  text-align: center;
  background:
    linear-gradient(135deg, rgba(16,185,129,.16), rgba(14,165,233,.08)),
    var(--app-surface) !important;
}
.final-cta-section .eyebrow {
  margin-inline: auto;
}
.final-cta-section h2 {
  max-width: 780px;
  margin-inline: auto;
  font-size: clamp(30px, 4vw, 48px);
}
.final-actions {
  justify-content: center;
}
.legal-card { line-height: 1.9; }
.legal-card h2 { margin-top: 22px; }
.terms-check {
  display: flex !important;
  align-items: flex-start;
  gap: 10px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(255,255,255,.06);
  border: 1px solid var(--line);
  line-height: 1.7;
}
.terms-check input {
  width: 18px;
  height: 18px;
  margin-top: 4px;
  accent-color: var(--brand);
  flex: 0 0 auto;
}
.terms-check a {
  color: var(--brand);
  font-weight: 900;
}
.phone-code-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 10px;
  align-items: stretch;
  margin-bottom: 16px;
}
.phone-code-row .input {
  margin: 0 !important;
}
.send-code-btn {
  white-space: nowrap;
  min-width: 160px;
  margin: 0 !important;
}
.auth-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.btn:disabled {
  opacity: .45;
  cursor: not-allowed;
  filter: grayscale(.35);
  box-shadow: none !important;
}
.gated-hint {
  margin: 6px 0 0 !important;
  font-size: 13px;
}

/* Mobile app-style auth screens */
.auth-shell {
  width: min(420px, calc(100vw - 32px)) !important;
  max-width: none !important;
  margin: 42px auto 72px !important;
  padding: 0 !important;
  overflow: visible;
  border: 0 !important;
  border-radius: 28px !important;
  background: transparent !important;
  box-shadow: 0 24px 80px rgba(15, 23, 42, .14) !important;
  position: relative;
}
.auth-shell:before {
  display: none;
}
.auth-shell:after {
  display: none;
}
.auth-logo {
  height: 128px !important;
  margin: 0 !important;
  padding: 28px 22px 42px !important;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: #0b0b0d !important;
  border-radius: 28px 28px 0 0;
}
.auth-logo img {
  height: auto !important;
  width: auto !important;
  max-height: 62px !important;
  max-width: 190px !important;
  filter: drop-shadow(0 10px 18px rgba(0,0,0,.2));
}
.auth-shell > .card {
  width: 100%;
  margin: 0 !important;
  padding: 28px 22px 24px !important;
  border-radius: 26px !important;
  transform: translateY(-18px);
  background: #151517 !important;
  border-color: rgba(255,255,255,.08) !important;
}
.auth-shell h1 {
  text-align: center;
  font-size: 21px;
  margin-bottom: 10px;
}
.auth-shell .muted {
  text-align: center;
  font-size: 12px;
  margin-bottom: 16px;
}
.auth-shell form,
.auth-tab-form {
  width: 100%;
}
.auth-shell label {
  width: 100%;
  font-size: 12px;
  margin-bottom: 12px;
}
.auth-shell .input {
  width: 100% !important;
  min-height: 42px !important;
  border-radius: 999px !important;
  margin-top: 6px !important;
  padding: 10px 15px !important;
  font-size: 16px !important;
  background: #f8fafc !important;
  color: #101114 !important;
  border: 0 !important;
}
.auth-shell .btn {
  width: 100% !important;
  min-height: 42px !important;
  border-radius: 999px !important;
  justify-content: center;
  background: linear-gradient(135deg, var(--brand), #18c6b5) !important;
  color: #fff !important;
  margin-top: 6px !important;
}
.auth-shell .btn.dark {
  background: rgba(255,255,255,.035) !important;
  border: 1px solid #14c8c7 !important;
  color: var(--text) !important;
}
.auth-shell .phone-code-row,
.auth-actions {
  grid-template-columns: 1fr !important;
  gap: 9px !important;
}
.send-code-btn {
  min-width: 0 !important;
  white-space: normal !important;
}
.auth-tab-radio {
  position: absolute;
  opacity: 0;
  pointer-events: none;
}
.auth-tabs {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
  padding: 4px;
  margin: 14px 0 18px;
  border-radius: 999px;
  background: rgba(255,255,255,.055);
  border: 1px solid rgba(255,255,255,.07);
}
.auth-tabs label {
  margin: 0;
  min-height: 42px;
  border-radius: 999px;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  color: var(--text-secondary);
  font-weight: 800;
}
#loginTabPassword:checked ~ .auth-tabs label[for="loginTabPassword"],
#loginTabCode:checked ~ .auth-tabs label[for="loginTabCode"] {
  background: linear-gradient(135deg, var(--brand), #18c6b5);
  color: #fff;
}
.auth-tab-panel {
  display: none;
}
#loginTabPassword:checked ~ .auth-tab-password,
#loginTabCode:checked ~ .auth-tab-code {
  display: grid;
  gap: 18px;
}
.auth-tab-code .muted {
  margin: 0;
}
.auth-tab-form > a.btn.dark,
.auth-shell form > .auth-actions + .btn.dark,
.auth-shell form > a.btn.dark:last-child {
  margin-top: 16px !important;
}
html[data-theme="light"] .auth-shell {
  background: transparent !important;
  box-shadow: 0 24px 80px rgba(15, 23, 42, .12) !important;
}
html[data-theme="light"] .auth-logo {
  background: #fff !important;
}
html[data-theme="light"] .auth-shell > .card {
  background: #f8fafc !important;
}
html[data-theme="light"] .auth-shell h1,
html[data-theme="light"] .auth-shell label {
  color: #0f172a !important;
}
html[data-theme="light"] .auth-shell .btn.dark {
  color: #0f172a !important;
}
.steps-section {
  position: relative;
  overflow: hidden;
}
.steps-section:before {
  content: "";
  position: absolute;
  inset: 88px 54px auto 54px;
  height: 2px;
  background: linear-gradient(90deg, transparent, rgba(16,185,129,.55), rgba(14,165,233,.55), transparent);
}
.steps-grid {
  position: relative;
  gap: 18px;
}
.steps-grid .clean-card {
  position: relative;
  min-height: 190px;
  text-align: center;
  justify-items: center;
  align-content: center;
  background:
    radial-gradient(circle at 50% 0%, rgba(16,185,129,.18), transparent 42%),
    linear-gradient(180deg, color-mix(in srgb, var(--card) 94%, white 4%), var(--card));
}
.steps-grid .clean-card b {
  width: 54px;
  height: 54px;
  border-radius: 20px;
  margin-top: -8px;
  box-shadow: 0 0 0 8px rgba(16,185,129,.08), 0 18px 40px rgba(16,185,129,.22);
}
.steps-grid .clean-card strong {
  font-size: 20px;
}
.steps-grid .clean-card:after {
  content: "";
  position: absolute;
  top: 26px;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #34d399;
  box-shadow: 0 0 22px rgba(52,211,153,.85);
}

@media (max-width: 900px) {
  .clean-hero { grid-template-columns: 1fr; padding: 22px; min-height: auto; border-radius: 28px; }
  .clean-copy h1 { font-size: 42px; }
  .clean-copy p { font-size: 16px; }
  .conversion-strip { align-items: flex-start; }
  .clean-points, .clean-grid { grid-template-columns: 1fr; }
  .clean-points span { white-space: normal; }
  .clean-visual { min-height: auto; gap: 14px; }
  .visual-chip { display: none; }
  .clean-phone { width: 100%; max-width: 310px; min-height: 560px; }
  .clean-price { position: static; width: 100%; max-width: 350px; }
  .clean-section { padding: 20px; border-radius: 24px; }
  .phone-code-row,
  .auth-actions {
    grid-template-columns: 1fr;
  }
  .send-code-btn {
    width: 100%;
  }
  .training-test-live .wa-compose-row {
    grid-template-columns: 1fr;
    border-radius: 20px;
  }
  .wa-test-live-preview {
    min-height: 300px;
  }
  .test-input-bubble,
  .test-reply-bubble {
    width: 96% !important;
  }
  .steps-section:before,
  .steps-grid .clean-card:after {
    display: none;
  }
}

/* ══════════════════════════════════════════════════════════════
   SAAS APP REDESIGN LAYER - MOBILE FIRST
   Central visual system that keeps existing routes/forms intact.
   ══════════════════════════════════════════════════════════════ */
:root {
  --app-bg: #0b1110;
  --app-bg-soft: #101816;
  --app-surface: rgba(255,255,255,.065);
  --app-surface-strong: rgba(255,255,255,.095);
  --app-line: rgba(255,255,255,.105);
  --app-text: #f8fafc;
  --app-muted: #a7b2bd;
  --app-brand: #0f766e;
  --app-brand-2: #14b8a6;
  --app-accent: #c8a75d;
  --app-danger: #ef4444;
  --app-warning: #f59e0b;
  --app-ok: #10b981;
  --app-radius-sm: 14px;
  --app-radius: 20px;
  --app-radius-lg: 28px;
  --app-shadow: 0 18px 54px rgba(0,0,0,.24);
  --app-shadow-soft: 0 10px 30px rgba(0,0,0,.14);
  --app-container: 1120px;
}

:root[data-theme="light"] {
  --app-bg: #f5f7f6;
  --app-bg-soft: #edf3f1;
  --app-surface: rgba(255,255,255,.88);
  --app-surface-strong: rgba(255,255,255,.96);
  --app-line: rgba(15,23,42,.09);
  --app-text: #101827;
  --app-muted: #64748b;
  --app-shadow: 0 18px 46px rgba(15,23,42,.08);
  --app-shadow-soft: 0 10px 26px rgba(15,23,42,.07);
}

html {
  scroll-behavior: smooth;
}

body {
  background:
    radial-gradient(circle at 86% -8%, color-mix(in srgb, var(--app-brand-2) 20%, transparent), transparent 360px),
    radial-gradient(circle at 2% 16%, color-mix(in srgb, var(--app-accent) 11%, transparent), transparent 320px),
    linear-gradient(180deg, var(--app-bg), var(--app-bg-soft)) !important;
  color: var(--app-text) !important;
}

.user-shell,
.admin-shell {
  max-width: 1480px;
}

.user-main,
.admin-main {
  width: 100%;
}

.user-main > *,
.admin-main > * {
  max-width: var(--app-container);
  margin-inline: auto;
}

.card,
.feature-card,
.price-card,
.flow-step,
.metric-chart,
.clean-card,
.clean-section {
  background: var(--app-surface) !important;
  border-color: var(--app-line) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

.card,
.price-card,
.feature-card,
.clean-card {
  border-radius: var(--app-radius-lg) !important;
}

.hero,
.user-main .hero {
  border: 1px solid var(--app-line) !important;
  background:
    linear-gradient(135deg, color-mix(in srgb, var(--app-brand) 28%, transparent), color-mix(in srgb, var(--app-accent) 10%, transparent)),
    var(--app-surface-strong) !important;
  box-shadow: var(--app-shadow) !important;
}

h1,
.title,
.human-title,
.clean-copy h1 {
  letter-spacing: -.035em !important;
}

.muted,
.section-sub,
.footer {
  color: var(--app-muted) !important;
}

.btn,
.mini-btn,
button {
  min-height: 44px;
}

.btn {
  border-radius: 999px !important;
  background: linear-gradient(135deg, var(--app-brand), var(--app-brand-2)) !important;
  box-shadow: 0 12px 26px color-mix(in srgb, var(--app-brand) 24%, transparent) !important;
}

.btn:hover {
  filter: brightness(1.05);
}

.btn.dark,
.mini-btn {
  border-radius: 999px !important;
  background: var(--app-surface-strong) !important;
  border-color: var(--app-line) !important;
}

.btn.red {
  background: linear-gradient(135deg, #dc2626, var(--app-danger)) !important;
}

.input,
textarea,
select.input {
  min-height: 48px;
  border-radius: 18px !important;
  background: var(--app-surface-strong) !important;
  border-color: var(--app-line) !important;
}

.input:focus,
textarea:focus {
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--app-brand-2) 16%, transparent);
}

.alert {
  border-radius: 18px !important;
  box-shadow: var(--app-shadow-soft);
}

.badge {
  border-radius: 999px !important;
  min-height: 28px;
  align-items: center;
}

.app-header,
.user-app-header {
  border-radius: 26px !important;
  background: color-mix(in srgb, var(--app-surface-strong) 92%, transparent) !important;
  border-color: var(--app-line) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

.user-side,
.admin-side {
  border-color: var(--app-line) !important;
  background: color-mix(in srgb, var(--app-bg-soft) 88%, transparent) !important;
}

.user-nav a,
.admin-nav a {
  min-height: 48px;
}

.user-nav a:before,
.admin-nav a .nav-dot {
  color: var(--app-brand-2);
}

.user-nav .active,
.admin-nav .active {
  background: linear-gradient(135deg, color-mix(in srgb, var(--app-brand) 28%, transparent), color-mix(in srgb, var(--app-brand-2) 16%, transparent)) !important;
}

.table-scroll {
  overflow: auto;
  width: 100%;
}

.data-table {
  min-width: 720px;
}

.data-table tr {
  transition: background .16s ease;
}

.data-table tbody tr:hover {
  background: color-mix(in srgb, var(--app-brand-2) 7%, transparent);
}

.empty-state,
.skeleton-card {
  display: grid;
  place-items: center;
  gap: 10px;
  min-height: 150px;
  padding: 24px;
  border-radius: var(--app-radius-lg);
  background: var(--app-surface);
  border: 1px dashed var(--app-line);
  color: var(--app-muted);
  text-align: center;
}

.skeleton-card:before {
  content: "";
  width: 72%;
  height: 14px;
  border-radius: 999px;
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--app-muted) 18%, transparent), transparent);
  animation: skeletonSlide 1.25s infinite;
}

@keyframes skeletonSlide {
  from { transform: translateX(35%); opacity: .45; }
  to { transform: translateX(-35%); opacity: 1; }
}

.toast,
.pwa-hint {
  position: fixed;
  inset-inline: 18px;
  top: 18px;
  z-index: 9999;
  max-width: 460px;
  margin-inline: auto;
  padding: 14px 16px;
  font-weight: 800;
  line-height: 1.6;
  opacity: 0;
  pointer-events: none;
  transform: translateY(-14px);
  transition: opacity .18s ease, transform .18s ease;
  border-radius: 18px !important;
  box-shadow: var(--app-shadow) !important;
  border: 1px solid var(--app-line);
  background: var(--app-surface-strong) !important;
  color: var(--app-text) !important;
}

.toast.show,
.pwa-hint.show {
  opacity: 1;
  transform: translateY(0);
}

.toast.ok {
  border-color: color-mix(in srgb, var(--app-ok) 36%, var(--app-line));
}

.toast.err {
  border-color: color-mix(in srgb, var(--app-danger) 36%, var(--app-line));
}

.is-loading {
  cursor: wait !important;
  opacity: .82;
}

@media (max-width: 900px) {
  input,
  textarea,
  select,
  .input,
  .auth-shell .input,
  .wa-bubble textarea,
  .wa-bubble input {
    font-size: 16px !important;
  }

  :root {
    --app-radius-lg: 24px;
  }

  body {
    background:
      linear-gradient(180deg, color-mix(in srgb, var(--app-brand-2) 10%, transparent), transparent 230px),
      var(--app-bg) !important;
  }

  .user-shell {
    width: min(100%, 460px) !important;
    padding-inline: 10px !important;
  }

  .app-header,
  .user-app-header {
    top: 8px !important;
    border-radius: 22px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
    gap: 10px;
    overflow: visible;
  }

  .header-actions {
    max-width: 100%;
    width: 100%;
    overflow-x: auto;
    scrollbar-width: none;
    justify-content: flex-start !important;
    padding-bottom: 2px;
  }

  .header-actions::-webkit-scrollbar {
    display: none;
  }

  .card,
  .user-main .card {
    padding: 16px !important;
  }

  .grid,
  .dashboard-insights,
  .admin-charts {
    grid-template-columns: 1fr !important;
  }

  .nav {
    border-radius: 26px !important;
    padding: 8px !important;
  }

  .nav a {
    min-height: 58px !important;
  }

  .table-card {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    padding: 0 !important;
  }

  .table-scroll {
    overflow: visible !important;
  }

  .data-table,
  .data-table thead,
  .data-table tbody,
  .data-table tr,
  .data-table td {
    display: block;
    width: 100%;
    min-width: 0;
  }

  .data-table thead {
    display: none;
  }

  .data-table tr {
    margin-bottom: 12px;
    padding: 14px;
    border: 1px solid var(--app-line);
    border-radius: var(--app-radius);
    background: var(--app-surface);
    box-shadow: var(--app-shadow-soft);
  }

  .data-table td {
    display: grid;
    grid-template-columns: minmax(92px, .85fr) minmax(0, 1.35fr);
    gap: 12px;
    align-items: center;
    border: 0 !important;
    padding: 8px 0 !important;
    text-align: start !important;
    word-break: break-word;
  }

  .data-table td:not(:last-child) {
    border-bottom: 1px solid var(--app-line) !important;
  }

  .data-table td:before {
    content: attr(data-label);
    color: var(--app-muted);
    font-size: 12px;
    font-weight: 800;
  }

  .form-actions,
  .send-test-actions,
  .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .form-actions .btn,
  .send-test-actions .btn,
  .hero-actions .btn,
  .hero-actions .btn.dark {
    width: 100%;
  }

  .training-save-bar {
    bottom: calc(92px + env(safe-area-inset-bottom, 0px));
    top: auto !important;
    position: sticky;
    box-shadow: var(--app-shadow);
  }

  .modal,
  [role="dialog"] {
    border-radius: 26px 26px 0 0 !important;
  }
}

@media (max-width: 420px) {
  .clean-copy h1,
  .title,
  .human-title {
    font-size: 36px !important;
  }

  .data-table td {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}

/* Performance pass: keep the app feeling native on low-end phones. */
:root {
  --app-shadow: 0 10px 26px rgba(0,0,0,.16);
  --app-shadow-soft: 0 4px 14px rgba(0,0,0,.10);
}

:root[data-theme="light"] {
  --app-shadow: 0 10px 24px rgba(15,23,42,.07);
  --app-shadow-soft: 0 4px 12px rgba(15,23,42,.055);
}

body {
  background: linear-gradient(180deg, var(--app-bg), var(--app-bg-soft)) !important;
}

/* Performance pass: removed backdrop-filter disable — kept for glassmorphism to work */
.visual-chip {
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.card:hover,
.btn:hover,
.mini-btn:hover,
.nav a:hover {
  transform: none !important;
}

.btn,
.mini-btn,
.nav a,
.training-style-toggle,
.fixed-reply-toggle {
  transition-property: background-color, border-color, color, opacity, box-shadow !important;
}

.phone-frame,
.clean-phone,
.auth-shell,
.auth-shell:before,
.auth-shell:after {
  box-shadow: var(--app-shadow-soft) !important;
}

@media (max-width: 900px) {
  body {
    background: var(--app-bg) !important;
  }

  .user-app-header,
  .nav,
  .data-table tr,
  .training-save-bar {
    box-shadow: var(--app-shadow-soft) !important;
  }

  .clean-phone,
  .clean-price,
  .visual-chip,
  .scene-art {
    box-shadow: none !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .001ms !important;
  }
}

/* Premium redesign pass: quiet, mobile-first, light SaaS app. */
:root[data-theme="light"] {
  --bg: #f7faf7;
  --bg2: #eef5ef;
  --surface: #ffffff;
  --surface-hover: #f4f8f5;
  --text: #13201b;
  --text-secondary: #66736d;
  --border: #e2ebe4;
  --brand: #0f8f6f;
  --brand-hover: #0b7359;
  --brand2: #7cb8a1;
  --app-bg: #f7faf7;
  --app-bg-soft: #edf6ef;
  --shadow: 0 10px 30px rgba(20, 48, 38, .07);
  --app-shadow: 0 14px 34px rgba(20, 48, 38, .08);
  --app-shadow-soft: 0 6px 18px rgba(20, 48, 38, .06);
  --radius: 14px;
  --radius-lg: 18px;
  --radius-xl: 22px;
}

html[data-theme="light"] { color-scheme: light; }

:root[data-theme="dark"] {
  --bg: #0d1512;
  --bg2: #13201b;
  --surface: #15231e;
  --surface-hover: #1b2d26;
  --text: #f4fbf7;
  --text-secondary: #a6b7af;
  --border: rgba(216, 236, 225, .13);
  --brand: #34c99c;
  --brand-hover: #22ad84;
  --brand2: #7dd3b3;
  --app-bg: #0d1512;
  --app-bg-soft: #13201b;
  --shadow: 0 12px 34px rgba(0, 0, 0, .28);
  --app-shadow: 0 16px 38px rgba(0, 0, 0, .26);
  --app-shadow-soft: 0 8px 22px rgba(0, 0, 0, .2);
  color-scheme: dark;
}

body {
  background-color: var(--app-bg) !important;
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.55), rgba(247,250,247,.86)),
    url("bg-premium-light.svg") !important;
  background-size: auto, cover !important;
  background-attachment: fixed !important;
  background-position: center top !important;
  color: var(--text) !important;
}

html[data-theme="dark"] body {
  background-color: var(--app-bg) !important;
  background-image:
    linear-gradient(180deg, rgba(13,21,18,.58), rgba(13,21,18,.94)),
    url("bg-premium-dark.svg") !important;
}

.user-shell {
  max-width: 1360px;
  padding: 20px !important;
  gap: 20px !important;
}

.user-side {
  width: 224px !important;
  min-width: 224px !important;
  height: calc(100vh - 40px) !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.86) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

html[data-theme="dark"] .user-side {
  background: rgba(21,35,30,.92) !important;
}

.user-brand {
  margin: 0 0 18px !important;
  padding: 14px 10px 18px !important;
  background: transparent !important;
  border: 0 !important;
}

.brand img,
.topbar img,
.auth-logo img {
  height: 42px !important;
}

.user-nav a {
  min-height: 42px !important;
  border-radius: 14px !important;
  padding: 10px 12px !important;
  color: #5f6e67 !important;
  font-weight: 700 !important;
}

.user-nav a:hover,
.user-nav .active {
  background: #edf8f2 !important;
  border-color: #cfe7da !important;
  color: var(--brand) !important;
}

html[data-theme="dark"] .user-nav a:hover,
html[data-theme="dark"] .user-nav .active {
  background: rgba(52,201,156,.14) !important;
  border-color: rgba(52,201,156,.22) !important;
}

.user-main {
  max-width: 1060px !important;
}

.user-app-header {
  top: 20px !important;
  margin-bottom: 18px !important;
  padding: 14px 18px !important;
  border-radius: 22px !important;
  background: rgba(255,255,255,.88) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

html[data-theme="dark"] .user-app-header {
  background: rgba(21,35,30,.92) !important;
}

.app-header strong {
  font-size: 17px !important;
  letter-spacing: -.01em;
}

.header-actions .quiet-action {
  min-width: 42px;
}

.card,
.feature-card,
.price-card,
.flow-step,
.clean-card {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

.landing-topbar,
.user-app-header,
.user-side,
.nav,
.auth-shell,
.clean-hero.premium-landing-hero,
.card,
.price-card,
.clean-card {
  backdrop-filter: saturate(1.08) blur(10px) !important;
  -webkit-backdrop-filter: saturate(1.08) blur(10px) !important;
}

.card {
  border-radius: 20px !important;
  padding: 20px !important;
  margin-bottom: 14px !important;
}

.card h2,
.card h3 {
  margin-bottom: 8px !important;
}

.card p:last-child,
.card .muted:last-child {
  margin-bottom: 0 !important;
}

.hero,
.user-main .hero {
  background: #ffffff !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

html[data-theme="dark"] .hero,
html[data-theme="dark"] .user-main .hero {
  background: var(--surface) !important;
}

h1 { font-size: clamp(24px, 3vw, 34px) !important; line-height: 1.18; }
h2 { font-size: 19px !important; line-height: 1.3; }
h3 { font-size: 16px !important; line-height: 1.35; }
.muted { color: var(--text-secondary) !important; }

.btn {
  min-height: 44px;
  border-radius: 15px !important;
  background: var(--brand) !important;
  color: #fff !important;
  box-shadow: 0 8px 18px rgba(15,143,111,.18) !important;
}

.btn.dark,
.mini-btn {
  background: #fff !important;
  color: var(--text) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .btn.dark,
html[data-theme="dark"] .mini-btn {
  background: var(--surface) !important;
}

.input,
textarea,
select {
  background: #fff !important;
  border-color: var(--border) !important;
  color: var(--text) !important;
  border-radius: 14px !important;
}

html[data-theme="dark"] .input,
html[data-theme="dark"] textarea,
html[data-theme="dark"] select {
  background: var(--surface) !important;
}

.badge,
.dot {
  border-radius: 12px !important;
  background: #edf8f2 !important;
  color: var(--brand) !important;
}

.stat {
  font-size: clamp(30px, 4vw, 44px) !important;
  color: var(--text) !important;
}

.app-section-title {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  margin: 22px 0 12px;
}

.app-section-title p { margin: 4px 0 0; }

.premium-hero,
.dashboard-hero,
.training-hero,
.decisions-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 18px;
}

.hero-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 10px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #edf8f2;
  color: var(--brand);
  font-size: 12px;
  font-weight: 800;
}

html[data-theme="dark"] .hero-kicker {
  background: rgba(52,201,156,.14);
}

.status-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 34px;
  padding: 7px 12px;
  border-radius: 999px;
  background: #edf8f2;
  color: var(--brand);
  border: 1px solid #d6eadf;
  font-size: 12px;
  font-weight: 800;
}

html[data-theme="dark"] .status-pill {
  background: rgba(52,201,156,.14);
  border-color: rgba(52,201,156,.22);
}

.premium-metric-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}

.premium-metric {
  display: grid;
  gap: 6px;
  padding: 16px;
  border-radius: 18px;
  background: #fff;
  border: 1px solid var(--border);
  box-shadow: var(--app-shadow-soft);
}

html[data-theme="dark"] .premium-metric {
  background: var(--surface);
}

.premium-metric span {
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
}

.premium-metric strong {
  color: var(--text);
  font-size: 26px;
  line-height: 1.1;
}

.premium-primary-card {
  background: linear-gradient(180deg, #ffffff, #f4fbf6) !important;
  border-color: #d7eadf !important;
}

html[data-theme="dark"] .premium-primary-card {
  background: var(--surface) !important;
  border-color: var(--border) !important;
}

.quick-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
}

.quick-actions .btn,
.quick-actions .mini-btn {
  min-height: 38px;
  padding-inline: 14px !important;
}

.clean-hero.premium-landing-hero {
  grid-template-columns: minmax(0, .96fr) minmax(300px, .72fr) !important;
  gap: 34px !important;
  padding: 42px !important;
  background:
    linear-gradient(135deg, rgba(255,255,255,.92), rgba(255,255,255,.78)),
    radial-gradient(circle at 92% 10%, rgba(15,143,111,.14), transparent 32%),
    var(--surface) !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow) !important;
}

html[data-theme="dark"] .clean-hero.premium-landing-hero {
  background:
    linear-gradient(135deg, rgba(21,35,30,.92), rgba(21,35,30,.78)),
    radial-gradient(circle at 92% 10%, rgba(52,201,156,.16), transparent 34%),
    var(--surface) !important;
}

.clean-hero .clean-points,
.trust-row {
  gap: 8px !important;
}

.clean-visual {
  isolation: isolate;
}

.visual-chip {
  display: none !important;
}

.clean-phone,
.phone-frame {
  background: #12251f !important;
  border-color: #1c372e !important;
  box-shadow: var(--app-shadow) !important;
}

.chat-area {
  background: #f3f6f2 !important;
  border-color: #dfe8e1 !important;
}

html[data-theme="dark"] .chat-area {
  background: #0d1512 !important;
  border-color: var(--border) !important;
}

.chat-bubble.incoming {
  background: #fff !important;
  color: #17231e !important;
}

.chat-bubble.bot {
  background: #dff4e8 !important;
  color: #103f31 !important;
}

.clean-price,
.mini-price-card {
  background: #fff !important;
  border-color: var(--border) !important;
}

html[data-theme="dark"] .clean-price,
html[data-theme="dark"] .mini-price-card {
  background: var(--surface) !important;
}

.premium-training-layout {
  display: grid;
  gap: 14px;
}

.training-save-bar {
  position: sticky;
  top: 92px;
  z-index: 40;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  background: #fff !important;
  border: 1px solid var(--border) !important;
  box-shadow: var(--app-shadow-soft) !important;
}

html[data-theme="dark"] .training-save-bar {
  background: var(--surface) !important;
}

.training-tabs {
  background: #eef7f1 !important;
  border: 1px solid #dbece2 !important;
  border-radius: 18px !important;
  padding: 6px !important;
}

html[data-theme="dark"] .training-tabs {
  background: rgba(52,201,156,.09) !important;
  border-color: var(--border) !important;
}

.training-tabs .mini-btn {
  border: 0 !important;
  background: transparent !important;
  box-shadow: none !important;
}

.decision-card {
  display: grid;
  gap: 12px;
}

.decision-card-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
  flex-wrap: wrap;
}

.decision-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
}

.decision-message {
  margin: 0 !important;
  padding: 12px 14px;
  border-radius: 16px;
  background: #f7faf7;
  border: 1px solid var(--border);
}

html[data-theme="dark"] .decision-message {
  background: #101c17;
}

.training-test-dialog,
#decision-simulator {
  overflow: hidden;
}

#decision-simulator form {
  display: grid;
  gap: 10px;
}

#decision-simulator label {
  margin-bottom: 4px;
}

.decision-card .feature {
  margin-top: 0 !important;
  padding: 10px 12px;
  border-radius: 14px;
  background: var(--surface-hover);
  border: 1px solid var(--border);
}

.usage-metric {
  border-bottom-color: var(--border) !important;
}

.auth-shell {
  width: min(420px, calc(100vw - 28px)) !important;
  margin-top: clamp(24px, 5vh, 54px) !important;
  border: 1px solid var(--border) !important;
  background: rgba(255,255,255,.88) !important;
  border-radius: 30px !important;
  box-shadow: var(--app-shadow) !important;
}

html[data-theme="dark"] .auth-shell {
  background: rgba(21,35,30,.9) !important;
}

.auth-shell:before,
.auth-shell:after {
  display: none !important;
}

.auth-logo {
  height: auto !important;
  min-height: 118px !important;
  margin: 0 -12px -22px !important;
  padding: 28px 22px 48px !important;
  background:
    radial-gradient(circle at 80% 20%, rgba(255,255,255,.28), transparent 28%),
    linear-gradient(135deg, #0f8f6f, #22c7b5) !important;
}

.auth-shell > .card {
  border-radius: 24px !important;
  padding: 26px 18px 20px !important;
  background: rgba(255,255,255,.94) !important;
}

html[data-theme="dark"] .auth-shell > .card {
  background: rgba(21,35,30,.96) !important;
}

.auth-shell h1 {
  font-size: 24px !important;
}

.auth-shell .input {
  height: 48px !important;
  border-radius: 16px !important;
  background: #fff !important;
  border: 1px solid var(--border) !important;
}

html[data-theme="dark"] .auth-shell .input {
  background: #101c17 !important;
}

.auth-shell .btn {
  min-height: 48px !important;
  border-radius: 16px !important;
}

.device-row,
.settings-summary-grid,
.dashboard-insights {
  align-items: stretch;
}

.device-row > *,
.usage-metric,
.premium-metric {
  min-width: 0;
}

@media (max-width: 900px) {
  body {
    background-attachment: scroll !important;
    background-size: auto, 1250px auto !important;
    background-position: center top !important;
  }

  .user-shell {
    width: min(100%, 430px) !important;
    padding: 10px 12px calc(140px + env(safe-area-inset-bottom, 0px)) !important;
    background: transparent !important;
  }

  .side,
  .user-side {
    position: static !important;
    width: auto !important;
    min-width: 0 !important;
    height: auto !important;
    top: auto !important;
    padding: 0 !important;
    margin: 0 !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
  }

  .user-brand {
    display: none !important;
  }

  .user-app-header {
    top: 8px !important;
    min-height: 72px !important;
    margin: 0 0 12px !important;
    border-radius: 18px !important;
    padding: 12px 14px !important;
    background: rgba(255,255,255,.88) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto;
    align-items: center !important;
    gap: 10px !important;
  }

  html[data-theme="dark"] .user-app-header {
    background: rgba(21,35,30,.9) !important;
  }

  .header-actions .quiet-action,
  .header-actions .install-btn {
    display: none !important;
  }

  .user-app-header .muted {
    display: none !important;
  }

  .user-app-header strong {
    font-size: 20px !important;
    line-height: 1.2 !important;
  }

  .header-actions {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-end !important;
    gap: 0 !important;
    flex-wrap: nowrap !important;
  }

  .account-btn {
    min-width: 62px !important;
    height: 42px !important;
    padding: 0 14px !important;
    border-radius: 999px !important;
    font-size: 13px !important;
  }

  .nav {
    grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
    left: max(10px, env(safe-area-inset-left, 0px)) !important;
    right: max(10px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(10px, env(safe-area-inset-bottom, 0px)) !important;
    border-radius: 22px !important;
    min-height: 76px !important;
    background: rgba(255,255,255,.9) !important;
    border: 1px solid var(--border) !important;
    box-shadow: 0 10px 28px rgba(20,48,38,.12) !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
  }

  html[data-theme="dark"] .nav {
    background: rgba(21,35,30,.92) !important;
  }

  .nav a {
    min-height: 58px !important;
    border-radius: 17px !important;
    color: #6b7b72 !important;
  }

  .user-nav .active {
    background: #e3f5eb !important;
    color: var(--brand) !important;
    border-color: transparent !important;
  }

  .nav a:before {
    background: transparent !important;
    color: inherit !important;
  }

  .nav a:after {
    font-size: 9px !important;
    font-weight: 800 !important;
  }

  .nav a[data-nav="settings"],
  .nav a[data-i18n="logout"] {
    display: none !important;
  }

  .card,
  .user-main .card {
    border-radius: 19px !important;
    padding: 17px !important;
    margin-bottom: 12px !important;
    background: rgba(255,255,255,.9) !important;
  }

  html[data-theme="dark"] .card,
  html[data-theme="dark"] .user-main .card {
    background: rgba(21,35,30,.92) !important;
  }

  .premium-hero,
  .dashboard-hero,
  .training-hero,
  .decisions-hero,
  .clean-hero.premium-landing-hero {
    grid-template-columns: 1fr !important;
    padding: 18px !important;
    gap: 12px !important;
  }

  .dashboard-hero .status-pill,
  .training-hero .status-pill,
  .decisions-hero .status-pill {
    width: 100%;
  }

  .premium-metric-grid {
    grid-template-columns: 1fr !important;
    gap: 10px;
  }

  .premium-metric {
    grid-template-columns: 1fr auto;
    align-items: center;
    padding: 14px;
  }

  .premium-primary-card {
    padding: 14px !important;
  }

  .premium-primary-card .premium-metric {
    min-height: 64px;
  }

  .hero-kicker {
    margin-bottom: 8px !important;
  }

  .status-pill {
    min-height: 38px !important;
  }

  .premium-metric strong {
    font-size: 24px;
  }

  .grid {
    grid-template-columns: 1fr !important;
  }

  .dashboard-secondary,
  .desktop-heavy {
    display: none !important;
  }

  .training-save-bar {
    position: fixed !important;
    left: max(18px, env(safe-area-inset-left, 0px)) !important;
    right: max(18px, env(safe-area-inset-right, 0px)) !important;
    top: auto !important;
    bottom: calc(98px + env(safe-area-inset-bottom, 0px)) !important;
    z-index: 130 !important;
    border-radius: 18px !important;
    padding: 10px !important;
    min-height: 66px !important;
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 10px !important;
  }

  .training-save-bar p {
    display: none;
  }

  .training-save-bar strong {
    font-size: 13px !important;
    line-height: 1.3 !important;
  }

  .training-save-bar .btn,
  .training-save-bar button {
    min-width: 112px;
    min-height: 42px !important;
    padding: 8px 14px !important;
  }

  .option-preview,
  .training-option-card .option-preview {
    display: none !important;
    visibility: hidden !important;
    max-height: 0 !important;
    overflow: hidden !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  .training-tabs {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 6px !important;
  }

  .training-tabs .mini-btn {
    min-height: 42px !important;
    font-size: 13px !important;
  }

  .whatsapp-test-box,
  .wa-compose-row {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  .training-test-head {
    display: grid !important;
    gap: 8px !important;
  }

  .wa-chat-preview {
    min-height: auto !important;
    padding: 14px 12px !important;
  }

  .wa-bubble {
    max-width: 100% !important;
  }

  #decision-simulator .input,
  #decision-simulator textarea,
  .training-test-dialog .input,
  .training-test-dialog textarea {
    min-height: 48px;
  }

  .decision-card {
    gap: 10px !important;
  }

  .decision-card-head {
    display: grid !important;
    gap: 8px !important;
  }

  .decision-meta {
    gap: 6px !important;
  }

  .decision-meta .badge,
  .decision-meta .badge.warn,
  .decision-meta .badge.danger {
    font-size: 11px !important;
    padding: 5px 8px !important;
  }

  .quick-actions .btn,
  .quick-actions .mini-btn {
    min-height: 36px !important;
    padding: 7px 11px !important;
    font-size: 12px !important;
  }

  .clean-section {
    padding: 24px 0 !important;
  }

  .clean-hero.premium-landing-hero {
    min-height: auto !important;
    margin-top: 16px !important;
  }

  .landing-topbar {
    margin-top: 14px !important;
    padding: 10px 12px !important;
    border-radius: 22px !important;
    background: rgba(255,255,255,.9) !important;
    border: 1px solid var(--border) !important;
    box-shadow: var(--app-shadow-soft) !important;
  }

  html[data-theme="dark"] .landing-topbar {
    background: rgba(21,35,30,.92) !important;
  }

  .landing-topbar .logo-shell img {
    height: 34px !important;
  }

  .landing-topbar .btn {
    min-height: 38px !important;
    padding: 7px 12px !important;
  }

  .clean-hero.premium-landing-hero .hero-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
  }

  .clean-hero.premium-landing-hero .clean-points span {
    color: var(--text-secondary) !important;
    opacity: 1 !important;
  }

  .auth-shell {
    margin-top: 18px !important;
    margin-bottom: 32px !important;
    border-radius: 28px !important;
  }

  .auth-shell > .card {
    padding: 22px 16px 18px !important;
  }

  .auth-shell h1 {
    font-size: 22px !important;
  }

  .auth-tabs {
    gap: 8px !important;
  }
}

@media (min-width: 901px) {
  .user-shell {
    align-items: flex-start !important;
  }

  .user-side {
    width: 206px !important;
    min-width: 206px !important;
    padding: 18px 12px !important;
  }

  .user-main {
    width: min(100%, 1040px) !important;
  }

  .user-app-header {
    min-height: 70px !important;
    top: 20px !important;
  }

  .brand img {
    height: 36px !important;
  }

  .user-nav a {
    min-height: 40px !important;
    padding: 9px 12px !important;
    font-size: 13px !important;
  }

  .premium-primary-card .premium-metric-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .dashboard-insights {
    grid-template-columns: minmax(0, 1fr) minmax(300px, .75fr) !important;
  }

  .card {
    padding: 18px !important;
  }

  .training-tabs {
    display: flex !important;
    justify-content: flex-start;
    gap: 6px;
  }

  .training-tabs .mini-btn {
    min-height: 36px;
    padding: 7px 12px !important;
  }

  .decisions-hero,
  .training-hero,
  .dashboard-hero {
    min-height: 132px;
  }
}

/* ══════════════════════════════════════════════════════════════
   GLASSMORPHISM & MESH BACKGROUND & MOBILE NAV (REWHATS AI REDESIGN)
   ══════════════════════════════════════════════════════════════ */
/* Mesh Background */
.mesh-bg {
    position: fixed;
    top: 0;
    left: 0;
    width: 100vw;
    height: 100vh;
    z-index: -1;
    overflow: hidden;
    background: #09090b;
}
html[data-theme="light"] .mesh-bg {
    background: #fdfdfd;
}
.mesh-blob {
    position: absolute;
    border-radius: 50%;
    filter: blur(80px);
    opacity: 0.6;
    animation: float 20s infinite ease-in-out alternate;
}
.mesh-blob-1 {
    width: 600px;
    height: 600px;
    background: radial-gradient(circle, rgba(16,185,129,0.4), transparent);
    top: -100px;
    left: -100px;
}
.mesh-blob-2 {
    width: 500px;
    height: 500px;
    background: radial-gradient(circle, rgba(14,165,233,0.3), transparent);
    bottom: -150px;
    right: -100px;
    animation-delay: -5s;
}
.mesh-blob-3 {
    width: 400px;
    height: 400px;
    background: radial-gradient(circle, rgba(139,92,246,0.3), transparent);
    top: 40%;
    left: 40%;
    animation-delay: -10s;
}
@keyframes float {
    0% { transform: translate(0, 0) scale(1); }
    100% { transform: translate(50px, 50px) scale(1.1); }
}

/* Glassmorphism Overrides */
.card, .user-side, .admin-side, .app-header {
    background: rgba(255, 255, 255, 0.05) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    box-shadow: 0 8px 32px rgba(0, 0, 0, 0.1) !important;
}
html[data-theme="light"] .card, 
html[data-theme="light"] .user-side,
html[data-theme="light"] .admin-side,
html[data-theme="light"] .app-header {
    background: rgba(255, 255, 255, 0.65) !important;
    border: 1px solid rgba(0, 0, 0, 0.05) !important;
}
.user-side {
    position: fixed !important;
    right: 18px !important;
    left: auto !important;
    top: 18px !important;
    height: calc(100vh - 36px) !important;
    z-index: 100;
}
html[dir="ltr"] .user-side {
    left: 18px !important;
    right: auto !important;
}
.wrap.user-shell {
    padding-right: 296px !important;
    padding-left: 18px !important;
}
html[dir="ltr"] .wrap.user-shell {
    padding-left: 296px !important;
    padding-right: 18px !important;
}
.wrap.admin-shell {
    padding-right: 260px !important;
}
html[dir="ltr"] .wrap.admin-shell {
    padding-left: 260px !important;
    padding-right: 0 !important;
}
.admin-side {
    position: fixed !important;
    right: 0 !important;
    left: auto !important;
    top: 0 !important;
    height: 100vh !important;
    z-index: 100;
}
html[dir="ltr"] .admin-side {
    left: 0 !important;
    right: auto !important;
}
.main {
    width: 100%;
}

/* Bottom Nav - Hidden on Desktop */
.bottom-nav {
    display: none;
    position: fixed;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 70px;
    background: rgba(20, 20, 25, 0.85);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    border-top: 1px solid rgba(255,255,255,0.1);
    z-index: 999;
    padding-bottom: env(safe-area-inset-bottom);
}
html[data-theme="light"] .bottom-nav {
    background: rgba(255, 255, 255, 0.85);
    border-top: 1px solid rgba(0,0,0,0.05);
}
.bottom-nav a {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--text-secondary);
    font-size: 11px;
    font-weight: 600;
    text-decoration: none;
    gap: 4px;
    transition: all var(--transition);
}
.bottom-nav a.active {
    color: var(--brand);
}
.bottom-nav .nav-icon {
    font-size: 20px;
    line-height: 1;
}

/* Mobile Overrides */
@media (max-width: 768px) {
    .wrap.user-shell, .wrap.admin-shell {
        padding-right: 0 !important;
        padding-left: 0 !important;
        padding-bottom: 90px !important;
    }
    .user-side, .admin-side {
        display: none !important;
    }
    .bottom-nav {
        display: grid;
        grid-template-columns: repeat(auto-fit, minmax(0, 1fr));
    }
    .user-app-header {
        position: static !important;
        margin-top: 18px;
    }
}

/* ══════════════════════════════════════════════════════════════
   LANDING PAGE REDESIGN
   ══════════════════════════════════════════════════════════════ */
.landing-clean {
    position: relative;
    z-index: 10;
}
.clean-hero {
    background: rgba(255, 255, 255, 0.03) !important;
    backdrop-filter: blur(24px) !important;
    -webkit-backdrop-filter: blur(24px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.4) !important;
    border-radius: var(--radius-xl) !important;
    overflow: visible;
}
html[data-theme="light"] .clean-hero {
    background: rgba(255, 255, 255, 0.6) !important;
    border: 1px solid rgba(255, 255, 255, 1) !important;
    box-shadow: 0 16px 50px rgba(0, 0, 0, 0.05) !important;
}
.clean-hero h1 {
    background: linear-gradient(135deg, #ffffff 0%, #94a3b8 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: 0 2px 20px rgba(0,0,0,0.1);
}
html[data-theme="light"] .clean-hero h1 {
    background: linear-gradient(135deg, #0f172a 0%, #334155 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    text-shadow: none;
}
.clean-card, .clean-phone {
    background: rgba(255, 255, 255, 0.02) !important;
    backdrop-filter: blur(12px) !important;
    -webkit-backdrop-filter: blur(12px) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: var(--radius-xl) !important;
    transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1) !important;
}
.clean-card:hover {
    transform: translateY(-8px) scale(1.02);
    background: rgba(255, 255, 255, 0.06) !important;
    border-color: rgba(255, 255, 255, 0.2) !important;
    box-shadow: 0 12px 30px rgba(16, 185, 129, 0.15) !important;
}
html[data-theme="light"] .clean-card, 
html[data-theme="light"] .clean-phone {
    background: rgba(255, 255, 255, 0.5) !important;
    border: 1px solid rgba(255, 255, 255, 0.8) !important;
}
html[data-theme="light"] .clean-card:hover {
    background: rgba(255, 255, 255, 0.9) !important;
    border-color: rgba(0, 0, 0, 0.05) !important;
    box-shadow: 0 12px 30px rgba(0, 0, 0, 0.06) !important;
}
.clean-section {
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
}
.landing-topbar {
    background: rgba(255, 255, 255, 0.03) !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    border: 1px solid rgba(255, 255, 255, 0.08) !important;
    border-radius: 100px !important;
    margin: 24px auto !important;
    padding: 12px 24px !important;
}
html[data-theme="light"] .landing-topbar {
    background: rgba(255, 255, 255, 0.6) !important;
    border: 1px solid rgba(255, 255, 255, 1) !important;
}
.landing-topbar .btn {
    border-radius: 100px !important;
}
.clean-phone {
    box-shadow: 0 30px 80px rgba(0,0,0,0.5) !important;
}
html[data-theme="light"] .clean-phone {
    box-shadow: 0 30px 80px rgba(0,0,0,0.1) !important;
}
.chat-bubble.bot {
    background: linear-gradient(135deg, var(--brand), var(--brand2)) !important;
    border: none !important;
    color: white !important;
    box-shadow: 0 8px 20px rgba(16, 185, 129, 0.2) !important;
}
.clean-phone .phone-top {
    background: rgba(255,255,255,0.05) !important;
    backdrop-filter: blur(10px) !important;
}
html[data-theme="light"] .clean-phone .phone-top {
    background: rgba(255,255,255,0.6) !important;
}

/* ══════════════════════════════════════════════════════════════
   LANDING PAGE FIXES (FONTS, OVERLAPS, BACKGROUNDS)
   ══════════════════════════════════════════════════════════════ */
/* Tajawal font is loaded from the page head */

body, .landing, .clean-hero, h1, h2, h3, p, a, button {
    font-family: "Tajawal", "Inter", system-ui, -apple-system, sans-serif !important;
}

/* Fix Logo squishing */
.theme-logo {
    height: 48px !important;
    width: auto !important;
    object-fit: contain !important;
}
.landing-topbar .logo-shell {
    display: flex;
    align-items: center;
}

/* Fix App Actions overlapping the topbar */
body:has(.landing-clean) .app-actions {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%) !important;
    top: 36px !important;
    z-index: 9999;
}

/* Remove old grid backgrounds that conflict with Mesh Background */
.clean-hero::before,
.clean-hero::after,
.clean-hero.premium-landing-hero::before,
.clean-hero.premium-landing-hero::after {
    display: none !important;
    background: none !important;
    background-image: none !important;
}

.clean-hero.premium-landing-hero,
.clean-phone {
    background-image: none !important; /* Removes the old linear-gradient grid */
}

/* Enhance Glassmorphism for Hero to ensure the mesh blobs shine through */
.clean-hero.premium-landing-hero {
    background: rgba(255, 255, 255, 0.03) !important;
    backdrop-filter: blur(24px) !important;
    -webkit-backdrop-filter: blur(24px) !important;
    border: 1px solid rgba(255, 255, 255, 0.1) !important;
}
html[data-theme="light"] .clean-hero.premium-landing-hero {
    background: rgba(255, 255, 255, 0.5) !important;
    border: 1px solid rgba(255, 255, 255, 1) !important;
}

/* ══════════════════════════════════════════════════════════════
   FINAL AUDIT FIXES — resolves all CSS conflicts detected
   مهم: هذا القسم يحل كل التعارضات — يجب أن يبقى في النهاية
   ══════════════════════════════════════════════════════════════ */

/* ── 1. Glassmorphism الصحيح — بدون تعارض ── */
/* الكاردات والسايدبار والهيدر في الوضع الداكن */
.card,
.user-side,
.user-app-header {
    backdrop-filter: blur(18px) saturate(1.6) !important;
    -webkit-backdrop-filter: blur(18px) saturate(1.6) !important;
}

/* Bottom nav glassmorphism */
@media (max-width: 900px) {
    .nav {
        backdrop-filter: blur(20px) saturate(1.5) !important;
        -webkit-backdrop-filter: blur(20px) saturate(1.5) !important;
    }
}

/* ── 2. Body Background — mesh يعمل مع .mesh-bg ── */
/* الـ body يكون شفافاً حتى يظهر mesh-bg */
body {
    background: transparent !important;
}

/* Mesh background يبقى ثابتاً خلف كل شيء */
.mesh-bg {
    position: fixed !important;
    top: 0 !important;
    left: 0 !important;
    width: 100vw !important;
    height: 100vh !important;
    z-index: -1 !important;
    overflow: hidden !important;
}

/* Dark mode background */
html:not([data-theme="light"]) .mesh-bg {
    background: #09090b !important;
}

/* Light mode background */
html[data-theme="light"] .mesh-bg {
    background: #f7faf7 !important;
}

/* ── 3. Desktop Sidebar — sticky في الـ flex layout ── */
@media (min-width: 769px) {
    /* إلغاء fixed positioning الذي يتداخل مع المحتوى */
    .user-side {
        position: sticky !important;
        top: 18px !important;
        right: auto !important;
        left: auto !important;
        height: calc(100vh - 36px) !important;
        z-index: 10 !important;
        width: 224px !important;
        min-width: 224px !important;
        flex-shrink: 0;
    }

    /* إزالة padding التي كانت تعوّض عن fixed positioning */
    .wrap.user-shell {
        padding-right: 18px !important;
        padding-left: 18px !important;
        gap: 18px !important;
        display: flex !important;
        align-items: flex-start;
    }

    html[dir="rtl"] .wrap.user-shell {
        padding-right: 18px !important;
        padding-left: 18px !important;
    }

    html[dir="ltr"] .wrap.user-shell {
        padding-left: 18px !important;
        padding-right: 18px !important;
    }

    /* Admin sidebar أيضاً */
    .admin-side {
        position: sticky !important;
        top: 0 !important;
        right: auto !important;
        left: auto !important;
        height: 100vh !important;
        z-index: 10 !important;
        flex-shrink: 0;
    }

    .wrap.admin-shell {
        padding-right: 0 !important;
        padding-left: 0 !important;
    }
}

/* ── 4. منع ازدواجية الـ navigation على الموبايل ── */
/* .bottom-nav مخصص فقط حين لا يوجد .nav */
/* عند وجود .user-shell، الـ .nav الداخلي يكفي */
@media (max-width: 768px) {
    /* إخفاء .user-side داخل user-shell على الموبايل */
    .wrap.user-shell .user-side {
        display: none !important;
    }

    /* .bottom-nav يكون مرئياً فقط خارج .user-shell */
    .bottom-nav {
        display: none !important;
    }

    /* الـ .nav داخل wrap يكون المتحكم */
    .wrap.user-shell {
        padding-bottom: 0 !important;
        display: block !important;
    }
}

/* ── 5. إصلاح كاردات الوضع الداكن على الموبايل ── */
/* تصحيح: الكاردات كانت تُجبر على background أبيض على الموبايل */
@media (max-width: 900px) {
    html[data-theme="dark"] .card,
    html[data-theme="dark"] .user-main .card,
    html[data-theme="dark"] .feature-card,
    html[data-theme="dark"] .price-card {
        background: rgba(21, 35, 30, 0.92) !important;
        border-color: rgba(216, 236, 225, 0.13) !important;
    }

    html[data-theme="dark"] .hero,
    html[data-theme="dark"] .user-main .hero {
        background: rgba(21, 35, 30, 0.95) !important;
    }
}

/* ── 6. Hero Section — زجاجي وفخم ── */
.user-main .hero {
    background:
        linear-gradient(135deg, rgba(15,118,110,0.22), rgba(20,184,166,0.10)),
        rgba(255,255,255,0.06) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    backdrop-filter: blur(20px) !important;
    -webkit-backdrop-filter: blur(20px) !important;
    box-shadow: 0 20px 60px rgba(0,0,0,0.18) !important;
}

html[data-theme="light"] .user-main .hero {
    background:
        linear-gradient(135deg, rgba(15,143,111,0.12), rgba(124,184,161,0.08)),
        rgba(255,255,255,0.88) !important;
    border: 1px solid rgba(15,143,111,0.15) !important;
}

/* ── 7. App Header — فخم زجاجي ── */
.user-app-header {
    background: rgba(13, 21, 18, 0.82) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
    box-shadow: 0 10px 40px rgba(0,0,0,0.22) !important;
}

html[data-theme="light"] .user-app-header {
    background: rgba(255,255,255,0.90) !important;
    border: 1px solid rgba(15,143,111,0.12) !important;
}

/* ── 8. Card Glass Effect ── */
.card,
.feature-card,
.price-card {
    background: rgba(255,255,255,0.05) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
}

html[data-theme="light"] .card,
html[data-theme="light"] .feature-card,
html[data-theme="light"] .price-card {
    background: rgba(255,255,255,0.72) !important;
    border: 1px solid rgba(15,143,111,0.10) !important;
}

/* ── 9. Sidebar glass ── */
.user-side {
    background: rgba(13, 21, 18, 0.88) !important;
    border: 1px solid rgba(255,255,255,0.08) !important;
}

html[data-theme="light"] .user-side {
    background: rgba(255,255,255,0.92) !important;
    border: 1px solid rgba(15,143,111,0.12) !important;
}

/* ── 10. Landing Hero - mesh يُرى بوضوح ── */
.clean-hero.premium-landing-hero,
.clean-hero {
    background: rgba(255,255,255,0.04) !important;
    backdrop-filter: blur(24px) saturate(1.5) !important;
    -webkit-backdrop-filter: blur(24px) saturate(1.5) !important;
    border: 1px solid rgba(255,255,255,0.12) !important;
    box-shadow: 0 24px 80px rgba(0,0,0,0.36) !important;
}

html[data-theme="light"] .clean-hero.premium-landing-hero,
html[data-theme="light"] .clean-hero {
    background: rgba(255,255,255,0.58) !important;
    border: 1px solid rgba(255,255,255,0.95) !important;
    box-shadow: 0 16px 60px rgba(0,0,0,0.06) !important;
}

/* ── 11. Landing Topbar Glass ── */
.landing-topbar {
    background: rgba(255,255,255,0.04) !important;
    backdrop-filter: blur(18px) !important;
    -webkit-backdrop-filter: blur(18px) !important;
    border: 1px solid rgba(255,255,255,0.10) !important;
}

html[data-theme="light"] .landing-topbar {
    background: rgba(255,255,255,0.72) !important;
    border: 1px solid rgba(255,255,255,0.95) !important;
}

/* ── 12. Font — ensure Arabic renders with Tajawal ── */
body,
h1, h2, h3, h4, h5, h6,
p, a, button, input, textarea, select, label {
    font-family: 'Tajawal', 'Inter', system-ui, -apple-system, sans-serif !important;
}

/* ── 13. Mobile padding correction ── */
@media (max-width: 900px) {
    .user-shell {
        padding: 10px 12px calc(110px + env(safe-area-inset-bottom, 0px)) !important;
    }
}

/* ── 14. Nav Mobile — واضح وأنيق ── */
@media (max-width: 900px) {
    .nav {
        grid-template-columns: repeat(5, minmax(0, 1fr)) !important;
        left: max(10px, env(safe-area-inset-left, 0px)) !important;
        right: max(10px, env(safe-area-inset-right, 0px)) !important;
        bottom: max(10px, env(safe-area-inset-bottom, 0px)) !important;
        z-index: 200 !important;
        background: rgba(13,21,18,0.96) !important;
        border: 1px solid rgba(255,255,255,0.10) !important;
        box-shadow: 0 -10px 40px rgba(0,0,0,0.28) !important;
        border-radius: 26px !important;
        min-height: 74px !important;
        padding: 6px !important;
    }

    html[data-theme="light"] .nav {
        background: rgba(255,255,255,0.98) !important;
        border: 1px solid rgba(15,143,111,0.12) !important;
        box-shadow: 0 -10px 30px rgba(15,48,38,0.10) !important;
    }

    .nav a {
        min-height: 58px !important;
        border-radius: 18px !important;
        color: #6b7b72 !important;
        font-size: 0 !important;
        display: grid !important;
        place-items: center;
        gap: 3px;
    }

    .user-nav .active {
        background: rgba(52,201,156,0.18) !important;
        color: #34c99c !important;
    }

    html[data-theme="light"] .user-nav .active {
        background: #e3f5eb !important;
        color: #0f8f6f !important;
    }
}

/* ── 15. Blob animations - ناعمة ── */
.mesh-blob {
    animation: meshFloat 18s ease-in-out infinite alternate !important;
    will-change: transform;
}

.mesh-blob-1 { animation-delay: 0s !important; }
.mesh-blob-2 { animation-delay: -6s !important; }
.mesh-blob-3 { animation-delay: -12s !important; }

@keyframes meshFloat {
    0%   { transform: translate(0px, 0px) scale(1); }
    33%  { transform: translate(30px, -20px) scale(1.05); }
    66%  { transform: translate(-20px, 30px) scale(0.97); }
    100% { transform: translate(50px, 50px) scale(1.08); }
}

@media (prefers-reduced-motion: reduce) {
    .mesh-blob { animation: none !important; }
}

/* Final mobile navigation fix: the sidebar is hidden on phones, so bottom-nav is the app nav. */
@media (max-width: 900px) {
  .wrap.user-shell {
    padding-bottom: calc(128px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .wrap.user-shell .user-side {
    display: none !important;
  }

  .bottom-nav {
    display: grid !important;
    grid-template-columns: repeat(6, minmax(0, 1fr)) !important;
    position: fixed !important;
    inset-inline: max(10px, env(safe-area-inset-left, 0px)) max(10px, env(safe-area-inset-right, 0px)) !important;
    bottom: max(10px, env(safe-area-inset-bottom, 0px)) !important;
    width: auto !important;
    height: 84px !important;
    padding: 8px !important;
    border-radius: 22px !important;
    z-index: 1000 !important;
    background: rgba(255,255,255,.92) !important;
    border: 1px solid var(--border) !important;
    box-shadow: 0 10px 28px rgba(20,48,38,.12) !important;
    backdrop-filter: saturate(1.1) blur(14px) !important;
    -webkit-backdrop-filter: saturate(1.1) blur(14px) !important;
  }

  html[data-theme="dark"] .bottom-nav {
    background: rgba(21,35,30,.94) !important;
    border-color: rgba(216,236,225,.13) !important;
    box-shadow: 0 10px 32px rgba(0,0,0,.28) !important;
  }

  .bottom-nav a {
    display: grid !important;
    place-items: center !important;
    gap: 4px !important;
    min-width: 0 !important;
    min-height: 66px !important;
    margin: 0 !important;
    padding: 7px 3px !important;
    border-radius: 18px !important;
    color: var(--text-secondary) !important;
    font-size: 9px !important;
    font-weight: 800 !important;
    line-height: 1.2 !important;
  }

  .bottom-nav a.active {
    background: #e3f5eb !important;
    color: var(--brand) !important;
  }

  html[data-theme="dark"] .bottom-nav a.active {
    background: rgba(52,201,156,.16) !important;
    color: #34c99c !important;
  }

  .bottom-nav .nav-icon {
    width: 34px !important;
    height: 34px !important;
    border-radius: 14px !important;
    display: grid !important;
    place-items: center !important;
    font-size: 0 !important;
    background: rgba(15,143,111,.08) !important;
    border: 1px solid rgba(15,143,111,.10) !important;
    color: currentColor !important;
  }

  .bottom-nav .nav-icon::before {
    content: "";
    width: 21px;
    height: 21px;
    display: block;
    background: currentColor;
    -webkit-mask: var(--nav-icon-mask) center / contain no-repeat;
    mask: var(--nav-icon-mask) center / contain no-repeat;
  }

  .bottom-nav a[data-nav="dashboard"] {
    --nav-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M3 10.4 12 3l9 7.4V21h-6.1v-6.3H9.1V21H3V10.4Zm2 1V19h2.1v-6.3h9.8V19H19v-7.6l-7-5.8-7 5.8Z'/%3E%3C/svg%3E");
  }

  .bottom-nav a[data-nav="subscribe"] {
    --nav-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2 3.5 8.2 6.8 20h10.4l3.3-11.8L12 2Zm0 2.5 6.2 4.5-2.5 9H8.3L5.8 9 12 4.5Zm-2.2 5.2h4.4L12 15.5 9.8 9.7Z'/%3E%3C/svg%3E");
  }

  .bottom-nav a[data-nav="device"] {
    --nav-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M8 2h8a3 3 0 0 1 3 3v14a3 3 0 0 1-3 3H8a3 3 0 0 1-3-3V5a3 3 0 0 1 3-3Zm0 2a1 1 0 0 0-1 1v14a1 1 0 0 0 1 1h8a1 1 0 0 0 1-1V5a1 1 0 0 0-1-1H8Zm2 13h4v2h-4v-2Z'/%3E%3C/svg%3E");
  }

  .bottom-nav a[data-nav="decisions"] {
    --nav-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2a10 10 0 1 1 0 20 10 10 0 0 1 0-20Zm0 2a8 8 0 1 0 0 16 8 8 0 0 0 0-16Zm4.7 5.3 1.4 1.4-6.8 6.8-4-4 1.4-1.4 2.6 2.6 5.4-5.4Z'/%3E%3C/svg%3E");
  }

  .bottom-nav a[data-nav="training"] {
    --nav-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 2 14.4 8l6.4 1-4.6 4.5 1.1 6.4L12 16.9 6.7 20l1.1-6.4L3.2 9l6.4-1L12 2Zm0 5.4-1 2.5-2.7.4 2 1.9-.5 2.7 2.2-1.3 2.2 1.3-.5-2.7 2-1.9-2.7-.4-1-2.5Z'/%3E%3C/svg%3E");
  }

  .bottom-nav a[data-nav="settings"] {
    --nav-icon-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='m19.4 13.5 1.4 1.1-2 3.5-1.7-.7a7.9 7.9 0 0 1-1.5.9l-.3 1.8h-4l-.3-1.8a7.9 7.9 0 0 1-1.5-.9l-1.7.7-2-3.5 1.4-1.1a7.4 7.4 0 0 1 0-1.8l-1.4-1.1 2-3.5 1.7.7c.5-.3 1-.6 1.5-.8l.3-1.8h4l.3 1.8c.5.2 1 .5 1.5.8l1.7-.7 2 3.5-1.4 1.1a7.4 7.4 0 0 1 0 1.8ZM13.3 7h-1.6l-.3 1.5-.7.2c-.5.2-1 .5-1.5.9l-.6.5-1.4-.6-.8 1.4 1.2 1-.1.8a5.6 5.6 0 0 0 0 1.8l.1.8-1.2 1 .8 1.4 1.4-.6.6.5c.5.4 1 .7 1.5.9l.7.2.3 1.5h1.6l.3-1.5.7-.2c.5-.2 1-.5 1.5-.9l.6-.5 1.4.6.8-1.4-1.2-1 .1-.8a5.6 5.6 0 0 0 0-1.8l-.1-.8 1.2-1-.8-1.4-1.4.6-.6-.5c-.5-.4-1-.7-1.5-.9l-.7-.2L13.3 7ZM12.5 10a3 3 0 1 1 0 6 3 3 0 0 1 0-6Zm0 2a1 1 0 1 0 0 2 1 1 0 0 0 0-2Z'/%3E%3C/svg%3E");
  }

  .bottom-nav a.active .nav-icon {
    background: rgba(15,143,111,.13) !important;
    border-color: rgba(15,143,111,.18) !important;
  }

  .bottom-nav .nav-label {
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    max-width: 100% !important;
  }
}

/* Final app header polish: visible logo plus premium theme/language controls. */
.app-header-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.app-header-logo {
  width: 92px;
  height: 42px;
  flex: 0 0 92px;
  display: inline-flex;
  place-items: center;
  align-items: center;
  justify-content: flex-start;
  border-radius: 0;
  background: transparent !important;
  border: 0 !important;
  overflow: visible;
  box-shadow: none !important;
}

.app-header-logo img {
  max-width: 88px !important;
  max-height: 34px !important;
  width: auto !important;
  height: auto !important;
  object-fit: contain;
  filter: none !important;
}

html[data-theme="dark"] .app-header-logo {
  background: transparent !important;
  border-color: transparent !important;
}

.header-actions {
  gap: 8px !important;
}

.theme-toggle-btn,
.lang-toggle-btn {
  width: 42px !important;
  min-width: 42px !important;
  height: 42px !important;
  padding: 0 !important;
  border-radius: 15px !important;
  font-size: 0 !important;
  background: rgba(255,255,255,.72) !important;
  color: var(--brand) !important;
  border: 1px solid var(--border) !important;
  box-shadow: none !important;
}

html[data-theme="dark"] .theme-toggle-btn,
html[data-theme="dark"] .lang-toggle-btn {
  background: rgba(13,21,18,.55) !important;
  color: #34c99c !important;
}

.theme-toggle-btn::before,
.lang-toggle-btn::before {
  content: "";
  width: 21px;
  height: 21px;
  display: block;
  margin: auto;
  background: currentColor;
}

.theme-toggle-btn::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 4a8 8 0 1 0 0 16V4Zm0-2a10 10 0 1 1 0 20 10 10 0 0 1 0-20Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M12 4a8 8 0 1 0 0 16V4Zm0-2a10 10 0 1 1 0 20 10 10 0 0 1 0-20Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.lang-toggle-btn::before {
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 4h10v2H9.8c-.2 1-.6 2-1 2.9.8.9 1.7 1.8 2.9 2.6l-1.2 1.6a14 14 0 0 1-2.7-2.4 15 15 0 0 1-3.6 3.7L3 12.8a12 12 0 0 0 3.5-3.6A11 11 0 0 1 5 6.7L6.8 6c.2.5.5 1 .8 1.5.2-.5.4-1 .5-1.5H4V4Zm11.7 5h2.2L22 20h-2.1l-.8-2.2h-4.6l-.8 2.2h-2.1l4.1-11Zm-.5 7h3.2l-1.6-4.4-1.6 4.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M4 4h10v2H9.8c-.2 1-.6 2-1 2.9.8.9 1.7 1.8 2.9 2.6l-1.2 1.6a14 14 0 0 1-2.7-2.4 15 15 0 0 1-3.6 3.7L3 12.8a12 12 0 0 0 3.5-3.6A11 11 0 0 1 5 6.7L6.8 6c.2.5.5 1 .8 1.5.2-.5.4-1 .5-1.5H4V4Zm11.7 5h2.2L22 20h-2.1l-.8-2.2h-4.6l-.8 2.2h-2.1l4.1-11Zm-.5 7h3.2l-1.6-4.4-1.6 4.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

@media (max-width: 900px) {
  .user-app-header {
    grid-template-columns: minmax(0, 1fr) auto !important;
    min-height: 70px !important;
    padding: 10px 11px !important;
  }

  .app-header-brand {
    gap: 9px;
  }

  .app-header-logo {
    width: 84px;
    height: 38px;
    flex-basis: 84px;
    border-radius: 0;
  }

  .app-header-logo img {
    max-width: 80px !important;
    max-height: 31px !important;
  }

  .header-actions .quiet-action {
    display: grid !important;
  }

  .header-actions {
    gap: 6px !important;
  }

  .theme-toggle-btn,
  .lang-toggle-btn {
    width: 40px !important;
    min-width: 40px !important;
    height: 40px !important;
    border-radius: 14px !important;
  }

  .account-btn {
    min-width: 54px !important;
    height: 40px !important;
    padding: 0 11px !important;
    font-size: 12px !important;
  }

  .user-app-header strong {
    font-size: 17px !important;
  }
}

/* English mobile fix: keep the app shell full-width and prevent duplicate nav labels. */
@media (max-width: 900px) {
  html[data-lang="en"] .wrap.user-shell,
  html[dir="ltr"][data-lang="en"] .wrap.user-shell {
    width: min(100%, 430px) !important;
    max-width: 430px !important;
    margin: 0 auto !important;
    padding: 10px 12px calc(128px + env(safe-area-inset-bottom, 0px)) !important;
    display: block !important;
  }

  html[data-lang="en"] .user-main,
  html[dir="ltr"][data-lang="en"] .user-main {
    width: 100% !important;
    max-width: none !important;
    padding: 0 !important;
    margin: 0 !important;
  }

  html[data-lang="en"] .bottom-nav a::after,
  html[dir="ltr"][data-lang="en"] .bottom-nav a::after {
    content: none !important;
    display: none !important;
  }

  html[data-lang="en"] .bottom-nav a {
    font-size: 9px !important;
  }

  html[data-lang="en"] .bottom-nav .nav-label {
    display: block !important;
    font-size: 9px !important;
    line-height: 1.05 !important;
  }

  html[data-lang="en"] .bottom-nav .nav-icon {
    margin-bottom: 1px !important;
  }

  html[data-lang="en"] .app-header-brand,
  html[dir="ltr"][data-lang="en"] .app-header-brand {
    direction: ltr;
    text-align: left;
  }

  html[data-lang="en"] .user-app-header,
  html[dir="ltr"][data-lang="en"] .user-app-header {
    direction: ltr;
  }

  html[data-lang="en"] .card,
  html[data-lang="en"] .premium-metric,
  html[data-lang="en"] .usage-metric {
    direction: ltr;
    text-align: left;
  }
}

/* Landing hero restore: keep copy sizing, bring back the rich WhatsApp scene. */
.clean-hero.premium-landing-hero {
  gap: 40px !important;
  padding: 46px !important;
  background:
    linear-gradient(90deg, rgba(5,13,23,.90) 0%, rgba(7,24,22,.84) 46%, rgba(7,32,27,.76) 100%),
    radial-gradient(circle at 18% 22%, rgba(52,211,153,.20), transparent 30%),
    url("https://cdn.texturize.app/textures/circuit-black-stealth/circuit-black-stealth.png") center / cover no-repeat,
    #07120f !important;
  border-color: rgba(216,236,225,.16) !important;
  box-shadow: 0 34px 110px rgba(0,0,0,.34) !important;
}

html[data-theme="dark"] .clean-hero.premium-landing-hero {
  background:
    linear-gradient(90deg, rgba(5,13,23,.90) 0%, rgba(7,24,22,.84) 46%, rgba(7,32,27,.76) 100%),
    radial-gradient(circle at 18% 22%, rgba(52,211,153,.20), transparent 30%),
    url("https://cdn.texturize.app/textures/circuit-black-stealth/circuit-black-stealth.png") center / cover no-repeat,
    #07120f !important;
}

.clean-hero.premium-landing-hero:before {
  background:
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px) !important;
  background-size: 46px 46px !important;
  opacity: .55;
  mask-image: linear-gradient(90deg, transparent, black 18%, black 70%, transparent);
}

.clean-hero.premium-landing-hero .clean-copy h1 {
  margin-top: 14px !important;
  margin-bottom: 16px !important;
}

.clean-hero.premium-landing-hero .clean-copy p {
  margin-top: 0 !important;
  margin-bottom: 0 !important;
}

.clean-hero.premium-landing-hero .hero-actions {
  margin-top: 24px !important;
}

.clean-hero.premium-landing-hero .clean-points {
  margin-top: 18px !important;
}

.clean-hero.premium-landing-hero .conversion-strip {
  margin-top: 18px !important;
  background: rgba(16,185,129,.18) !important;
  border-color: rgba(52,211,153,.24) !important;
}

.clean-visual {
  position: relative;
  min-height: 610px !important;
}

.visual-chip {
  display: grid !important;
  background: rgba(255,255,255,.13) !important;
  border-color: rgba(255,255,255,.18) !important;
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.chip-wa {
  top: 70px !important;
  inset-inline-end: 22px !important;
}

.chip-ai {
  top: 165px !important;
  inset-inline-start: 18px !important;
}

.chip-bot {
  bottom: 150px !important;
  inset-inline-end: 14px !important;
}

.clean-phone {
  width: 320px !important;
  min-height: 640px !important;
  padding: 14px !important;
  border-radius: 52px !important;
  background:
    linear-gradient(180deg, rgba(6,17,16,.96), rgba(3,8,8,.98)),
    radial-gradient(circle at 58% 0%, rgba(52,211,153,.22), transparent 40%) !important;
  border-color: rgba(255,255,255,.14) !important;
  box-shadow:
    0 32px 90px rgba(0,0,0,.34),
    inset 0 0 0 10px rgba(255,255,255,.055) !important;
}

.clean-phone .phone-top {
  height: 50px !important;
  border-radius: 28px 28px 16px 16px;
  background: rgba(255,255,255,.055);
  padding-inline: 18px;
}

.clean-phone .chat-area {
  min-height: 500px !important;
  border-radius: 34px !important;
  padding: 22px 14px 18px !important;
  gap: 13px !important;
  background:
    radial-gradient(circle at 82% 16%, rgba(52,211,153,.08), transparent 28%),
    #050807 !important;
  border-color: rgba(255,255,255,.08) !important;
}

.clean-phone .chat-date {
  background: rgba(255,255,255,.08) !important;
  color: rgba(255,255,255,.72) !important;
}

.clean-phone .chat-bubble.incoming {
  background: #f8fafc !important;
  color: #15231e !important;
}

.clean-phone .chat-bubble.bot {
  background: #18c68f !important;
  color: #ffffff !important;
}

.clean-phone .typing-pill {
  margin: 14px auto 0 !important;
  background: rgba(16,185,129,.14) !important;
  border-color: rgba(52,211,153,.18) !important;
}

.clean-price {
  background: rgba(8,18,16,.70) !important;
  border-color: rgba(255,255,255,.14) !important;
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
}

@media (max-width: 900px) {
  .clean-hero.premium-landing-hero {
    gap: 22px !important;
    padding: 22px !important;
    background-position: center top !important;
  }

  .clean-hero.premium-landing-hero .hero-actions {
    margin-top: 18px !important;
  }

  .clean-hero.premium-landing-hero .clean-points,
  .clean-hero.premium-landing-hero .conversion-strip {
    margin-top: 14px !important;
  }

  .clean-visual {
    min-height: auto !important;
  }

  .visual-chip {
    display: none !important;
  }

  .clean-phone {
    max-width: 320px !important;
    min-height: 560px !important;
  }

  .clean-phone .chat-area {
    min-height: 420px !important;
  }
}

/* Rewats premium backgrounds everywhere + WhatsApp support widgets. */
body {
  background-color: var(--app-bg) !important;
  background-image:
    linear-gradient(180deg, rgba(247,250,247,.70), rgba(247,250,247,.88)),
    url("bg-premium-light.svg") !important;
  background-size: auto, 1700px auto !important;
  background-position: center top, center top !important;
  animation: premiumBgDrift 28s ease-in-out infinite alternate !important;
}

html[data-theme="dark"] body {
  background-color: #0d1512 !important;
  background-image:
    linear-gradient(180deg, rgba(13,21,18,.42), rgba(13,21,18,.88)),
    url("bg-premium-dark.svg") !important;
}

.mesh-bg {
  position: fixed !important;
  inset: 0 !important;
  z-index: -2 !important;
  pointer-events: none !important;
  background-image: url("bg-premium-light.svg") !important;
  background-size: 1650px auto !important;
  background-position: center top !important;
  opacity: .72 !important;
  animation: premiumBgDrift 34s ease-in-out infinite alternate-reverse !important;
}

html[data-theme="dark"] .mesh-bg {
  background-image: url("bg-premium-dark.svg") !important;
  opacity: .58 !important;
}

.mesh-blob {
  opacity: .16 !important;
}

.landing-topbar,
.user-app-header,
.user-side,
.nav,
.auth-shell,
.card,
.price-card,
.clean-section,
.app-footer {
  background-image:
    linear-gradient(180deg, rgba(255,255,255,.62), rgba(255,255,255,.82)),
    url("bg-premium-light.svg") !important;
  background-size: auto, 1500px auto !important;
  background-position: center top, center top !important;
}

html[data-theme="dark"] .landing-topbar,
html[data-theme="dark"] .user-app-header,
html[data-theme="dark"] .user-side,
html[data-theme="dark"] .nav,
html[data-theme="dark"] .auth-shell,
html[data-theme="dark"] .card,
html[data-theme="dark"] .price-card,
html[data-theme="dark"] .clean-section,
html[data-theme="dark"] .app-footer {
  background-image:
    linear-gradient(180deg, rgba(13,21,18,.72), rgba(13,21,18,.90)),
    url("bg-premium-dark.svg") !important;
}

.clean-hero.premium-landing-hero {
  background:
    linear-gradient(90deg, rgba(5,13,23,.80) 0%, rgba(7,24,22,.72) 46%, rgba(7,32,27,.64) 100%),
    url("bg-premium-dark.svg") center / 1680px auto no-repeat !important;
  animation: premiumHeroBgDrift 26s ease-in-out infinite alternate !important;
}

html[data-theme="light"] .clean-hero.premium-landing-hero {
  background:
    linear-gradient(90deg, rgba(255,255,255,.58) 0%, rgba(247,250,247,.72) 48%, rgba(232,246,239,.68) 100%),
    url("bg-premium-light.svg") center / 1680px auto no-repeat !important;
}

.clean-hero.premium-landing-hero:before {
  display: block !important;
  background:
    linear-gradient(90deg, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px) !important;
  background-size: 44px 44px !important;
  opacity: .5 !important;
}

.support-whatsapp-btn,
.whatsapp-widget {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border: 1px solid rgba(16,185,129,.24);
  background: #18c68f;
  color: #fff !important;
  font-weight: 900;
  box-shadow: 0 14px 34px rgba(16,185,129,.20);
}

.support-whatsapp-btn {
  min-height: 38px;
  padding: 9px 13px;
  border-radius: 14px;
  font-size: 12px;
}

.support-whatsapp-btn::before,
.whatsapp-widget-icon {
  content: "";
  width: 18px;
  height: 18px;
  flex: 0 0 auto;
  background: currentColor;
  -webkit-mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M20.5 3.5A11.8 11.8 0 0 0 12.1 0C5.6 0 .3 5.3.3 11.8c0 2.1.6 4.1 1.6 5.9L0 24l6.5-1.7a11.7 11.7 0 0 0 5.6 1.4h.1c6.5 0 11.8-5.3 11.8-11.8 0-3.1-1.2-6.1-3.5-8.4ZM12.2 21.7h-.1c-1.8 0-3.5-.5-5-1.4l-.4-.2-3.8 1 1-3.7-.2-.4a9.8 9.8 0 0 1-1.5-5.2c0-5.4 4.4-9.8 9.9-9.8 2.6 0 5.1 1 7 2.9a9.8 9.8 0 0 1 2.9 7c0 5.4-4.4 9.8-9.8 9.8Zm5.4-7.3c-.3-.2-1.8-.9-2-.9-.3-.1-.5-.2-.7.2s-.8.9-.9 1.1c-.2.2-.3.2-.6.1-.3-.2-1.2-.5-2.3-1.4a8.6 8.6 0 0 1-1.6-2c-.2-.3 0-.5.1-.6l.5-.5c.1-.2.2-.3.3-.5.1-.2 0-.4 0-.5l-.9-2.1c-.2-.5-.5-.4-.7-.4h-.6c-.2 0-.5.1-.8.4-.3.3-1 1-1 2.5s1.1 3 1.3 3.2c.2.2 2.2 3.4 5.4 4.7.8.3 1.3.5 1.8.6.8.2 1.5.2 2 .1.6-.1 1.8-.7 2-1.4.3-.7.3-1.3.2-1.4 0-.2-.2-.3-.5-.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
  mask: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath fill='black' d='M20.5 3.5A11.8 11.8 0 0 0 12.1 0C5.6 0 .3 5.3.3 11.8c0 2.1.6 4.1 1.6 5.9L0 24l6.5-1.7a11.7 11.7 0 0 0 5.6 1.4h.1c6.5 0 11.8-5.3 11.8-11.8 0-3.1-1.2-6.1-3.5-8.4ZM12.2 21.7h-.1c-1.8 0-3.5-.5-5-1.4l-.4-.2-3.8 1 1-3.7-.2-.4a9.8 9.8 0 0 1-1.5-5.2c0-5.4 4.4-9.8 9.9-9.8 2.6 0 5.1 1 7 2.9a9.8 9.8 0 0 1 2.9 7c0 5.4-4.4 9.8-9.8 9.8Zm5.4-7.3c-.3-.2-1.8-.9-2-.9-.3-.1-.5-.2-.7.2s-.8.9-.9 1.1c-.2.2-.3.2-.6.1-.3-.2-1.2-.5-2.3-1.4a8.6 8.6 0 0 1-1.6-2c-.2-.3 0-.5.1-.6l.5-.5c.1-.2.2-.3.3-.5.1-.2 0-.4 0-.5l-.9-2.1c-.2-.5-.5-.4-.7-.4h-.6c-.2 0-.5.1-.8.4-.3.3-1 1-1 2.5s1.1 3 1.3 3.2c.2.2 2.2 3.4 5.4 4.7.8.3 1.3.5 1.8.6.8.2 1.5.2 2 .1.6-.1 1.8-.7 2-1.4.3-.7.3-1.3.2-1.4 0-.2-.2-.3-.5-.4Z'/%3E%3C/svg%3E") center / contain no-repeat;
}

.whatsapp-widget {
  position: fixed;
  inset-inline-end: 22px;
  bottom: 22px;
  z-index: 900;
  min-height: 58px;
  padding: 11px 15px;
  border-radius: 22px;
}

.whatsapp-widget span:last-child {
  display: grid;
  gap: 1px;
  line-height: 1.25;
}

.whatsapp-widget strong {
  font-size: 13px;
}

.whatsapp-widget small {
  color: rgba(255,255,255,.84);
  font-size: 11px;
  font-weight: 800;
}

.whatsapp-widget-icon {
  width: 28px;
  height: 28px;
}

@keyframes premiumBgDrift {
  0% { background-position: center top, center top; }
  50% { background-position: center top, calc(50% + 28px) calc(0% - 18px); }
  100% { background-position: center top, calc(50% - 28px) calc(0% + 24px); }
}

@keyframes premiumHeroBgDrift {
  0% { background-position: center, center top; }
  100% { background-position: center, calc(50% + 42px) calc(0% + 28px); }
}

@media (max-width: 900px) {
  body {
    background-size: auto, 1180px auto !important;
    animation-duration: 38s !important;
  }

  .mesh-bg {
    background-size: 1180px auto !important;
    animation-duration: 38s !important;
  }

  .clean-hero.premium-landing-hero {
    background-size: auto, 1180px auto !important;
  }

  .whatsapp-widget {
    inset-inline: 14px;
    bottom: calc(14px + env(safe-area-inset-bottom, 0px));
    min-height: 54px;
    border-radius: 18px;
  }
}

@media (max-width: 900px) {
  .wrap.user-shell .app-footer {
    margin-bottom: 10px;
  }

  .support-whatsapp-btn {
    width: 100%;
  }
}

/* Hero correction: no external social imagery, no text behind phone, cleaner iPhone body. */
.clean-hero.premium-landing-hero {
  overflow: hidden !important;
  background:
    radial-gradient(circle at 68% 44%, rgba(52,211,153,.22), transparent 18%),
    radial-gradient(circle at 78% 28%, rgba(59,130,246,.16), transparent 22%),
    linear-gradient(90deg, rgba(5,13,23,.88) 0%, rgba(7,24,22,.78) 52%, rgba(7,32,27,.70) 100%),
    url("bg-premium-dark.svg") center / 1680px auto no-repeat !important;
  animation: premiumHeroBgDrift 30s ease-in-out infinite alternate !important;
}

html[data-theme="light"] .clean-hero.premium-landing-hero {
  background:
    radial-gradient(circle at 68% 44%, rgba(16,185,129,.16), transparent 18%),
    radial-gradient(circle at 78% 28%, rgba(14,165,233,.10), transparent 22%),
    linear-gradient(90deg, rgba(255,255,255,.70) 0%, rgba(247,250,247,.82) 52%, rgba(232,246,239,.76) 100%),
    url("bg-premium-light.svg") center / 1680px auto no-repeat !important;
}

.clean-hero.premium-landing-hero::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  background:
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px) !important;
  background-size: 42px 42px !important;
  opacity: .42 !important;
  mask-image: linear-gradient(90deg, transparent 0%, black 18%, black 82%, transparent 100%) !important;
}

.clean-hero.premium-landing-hero::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 9% 38% 14% 8% !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .34 !important;
  background:
    radial-gradient(circle at 50% 48%, rgba(52,211,153,.28) 0 3px, transparent 4px),
    radial-gradient(circle at 24% 28%, rgba(125,211,252,.24) 0 3px, transparent 4px),
    radial-gradient(circle at 76% 32%, rgba(52,211,153,.22) 0 3px, transparent 4px),
    radial-gradient(circle at 32% 76%, rgba(125,211,252,.18) 0 3px, transparent 4px),
    linear-gradient(28deg, transparent 49%, rgba(125,211,252,.20) 50%, transparent 51%),
    linear-gradient(145deg, transparent 49%, rgba(52,211,153,.18) 50%, transparent 51%) !important;
  border-radius: 40px !important;
  filter: blur(.1px);
}

.clean-copy,
.clean-visual {
  position: relative !important;
  z-index: 2 !important;
}

.clean-visual {
  overflow: visible !important;
  isolation: isolate !important;
}

.visual-chip {
  display: none !important;
}

.clean-phone {
  position: relative !important;
  z-index: 4 !important;
  background: #07100e !important;
  background-image: none !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  box-shadow:
    0 34px 90px rgba(0,0,0,.42),
    inset 0 0 0 10px #111b18,
    inset 0 0 0 11px rgba(255,255,255,.08) !important;
}

html[data-theme="light"] .clean-phone {
  background: #07100e !important;
  border-color: rgba(255,255,255,.22) !important;
  box-shadow:
    0 28px 80px rgba(15,23,42,.22),
    inset 0 0 0 10px #111b18,
    inset 0 0 0 11px rgba(255,255,255,.08) !important;
}

.clean-phone .phone-top {
  background: #101b18 !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.clean-phone .chat-area {
  background: #050908 !important;
  background-image: none !important;
}

.clean-price {
  z-index: 5 !important;
}

@media (max-width: 900px) {
  .clean-hero.premium-landing-hero::after {
    inset: 44% 6% 10% 6% !important;
    opacity: .22 !important;
  }
}

/* Hard override: use a technology circuit texture for the hero. */
.landing-clean .clean-hero.premium-landing-hero,
html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero,
html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero {
  background-color: #07120f !important;
  background-image:
    linear-gradient(90deg, rgba(3,10,18,.96), rgba(7,31,27,.91)),
    radial-gradient(circle at 70% 32%, rgba(52,211,153,.18), transparent 30%),
    url("https://cdn.texturize.app/textures/circuit-black-stealth/circuit-black-stealth.png") !important;
  background-size: auto, auto, cover !important;
  background-position: center, center, center !important;
  background-repeat: no-repeat !important;
  background-blend-mode: normal, screen, multiply !important;
}

.landing-clean .clean-hero.premium-landing-hero::after {
  opacity: .12 !important;
  background:
    radial-gradient(circle at 20% 24%, rgba(52,211,153,.34) 0 2px, transparent 3px),
    radial-gradient(circle at 42% 58%, rgba(52,211,153,.20) 0 2px, transparent 3px),
    radial-gradient(circle at 76% 34%, rgba(52,211,153,.22) 0 2px, transparent 3px),
    linear-gradient(28deg, transparent 49.5%, rgba(52,211,153,.12) 50%, transparent 50.5%),
    linear-gradient(145deg, transparent 49.5%, rgba(52,211,153,.10) 50%, transparent 50.5%) !important;
}

.landing-clean .clean-hero.premium-landing-hero .clean-copy {
  text-shadow: 0 2px 18px rgba(0,0,0,.34);
}

.landing-clean .clean-phone,
html[data-theme="light"] .landing-clean .clean-phone,
html[data-theme="dark"] .landing-clean .clean-phone {
  background: #07100e !important;
  background-color: #07100e !important;
  background-image: none !important;
  border-color: rgba(255,255,255,.16) !important;
}

.landing-clean .clean-phone::before,
.landing-clean .clean-phone::after {
  display: none !important;
}

/* Restore the earlier landing hero composition: dark premium scene, phone, chips, and bubbles. */
.landing-clean .clean-hero.premium-landing-hero,
html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero,
html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero {
  grid-template-columns: minmax(0, .96fr) minmax(300px, .72fr) !important;
  gap: 38px !important;
  min-height: 660px !important;
  padding: 46px !important;
  overflow: hidden !important;
  border-radius: 42px !important;
  background-color: #07120f !important;
  background-image:
    linear-gradient(90deg, rgba(3,10,18,.72), rgba(6,25,24,.58)),
    radial-gradient(circle at 18% 22%, rgba(16,185,129,.18), transparent 30%),
    radial-gradient(circle at 80% 16%, rgba(20,184,166,.14), transparent 34%),
    url("bg-premium-dark.svg") !important;
  background-size: auto, auto, auto, cover !important;
  background-position: center, center, center, center !important;
  background-repeat: no-repeat !important;
  box-shadow: 0 34px 110px rgba(0,0,0,.34) !important;
}

.landing-clean .clean-hero.premium-landing-hero::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .48 !important;
  background:
    linear-gradient(90deg, rgba(255,255,255,.055) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.045) 1px, transparent 1px) !important;
  background-size: 46px 46px !important;
  mask-image: linear-gradient(90deg, black, transparent 84%) !important;
}

.landing-clean .clean-hero.premium-landing-hero::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .26 !important;
  background:
    radial-gradient(circle at 50% 44%, rgba(52,211,153,.22), transparent 18%),
    linear-gradient(28deg, transparent 49.5%, rgba(125,211,252,.18) 50%, transparent 50.5%),
    linear-gradient(145deg, transparent 49.5%, rgba(52,211,153,.14) 50%, transparent 50.5%) !important;
}

.landing-clean .clean-copy,
.landing-clean .clean-visual {
  position: relative !important;
  z-index: 2 !important;
}

.landing-clean .clean-visual {
  min-height: 590px !important;
  display: grid !important;
  place-items: center !important;
  overflow: visible !important;
  isolation: isolate !important;
}

.landing-clean .visual-chip {
  position: absolute !important;
  z-index: 5 !important;
  display: grid !important;
  place-items: center !important;
  border-radius: 24px !important;
  background: rgba(255,255,255,.10) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  color: #e0f2fe !important;
  font-weight: 900 !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.20) !important;
  backdrop-filter: blur(14px) !important;
  -webkit-backdrop-filter: blur(14px) !important;
}

.landing-clean .chip-wa {
  width: 126px !important;
  height: 54px !important;
  top: 54px !important;
  inset-inline-end: 34px !important;
  color: #bbf7d0 !important;
}

.landing-clean .chip-ai {
  width: 82px !important;
  height: 82px !important;
  top: 155px !important;
  inset-inline-start: 28px !important;
  color: #67e8f9 !important;
  font-size: 28px !important;
}

.landing-clean .chip-bot {
  width: 92px !important;
  height: 52px !important;
  bottom: 150px !important;
  inset-inline-end: 18px !important;
}

.landing-clean .clean-phone,
html[data-theme="light"] .landing-clean .clean-phone,
html[data-theme="dark"] .landing-clean .clean-phone {
  position: relative !important;
  z-index: 4 !important;
  width: 305px !important;
  min-height: 610px !important;
  padding: 15px !important;
  border-radius: 54px !important;
  background: #050807 !important;
  background-image: none !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow:
    0 34px 110px rgba(0,0,0,.34),
    inset 0 0 0 9px rgba(255,255,255,.055) !important;
}

.landing-clean .clean-phone .phone-top {
  height: 48px !important;
  border-radius: 32px 32px 16px 16px !important;
  background: rgba(255,255,255,.055) !important;
  border-bottom: 1px solid rgba(255,255,255,.07) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.landing-clean .clean-phone .chat-area {
  min-height: 470px !important;
  border-radius: 34px !important;
  padding: 18px 12px !important;
  gap: 12px !important;
  background: #050807 !important;
  background-image: none !important;
  border-color: rgba(255,255,255,.08) !important;
}

.landing-clean .clean-phone .chat-bubble {
  font-size: 12px !important;
  line-height: 1.65 !important;
  padding: 11px 13px !important;
  border-radius: 18px !important;
}

.landing-clean .clean-phone .chat-bubble.incoming {
  background: #f8fafc !important;
  color: #15231e !important;
}

.landing-clean .clean-phone .chat-bubble.bot {
  background: #18c68f !important;
  color: #ffffff !important;
}

.landing-clean .clean-price {
  z-index: 6 !important;
  position: absolute !important;
  inset-inline-start: 8px !important;
  bottom: 54px !important;
  width: 190px !important;
  padding: 20px !important;
  border-radius: 28px !important;
  background: rgba(8,18,16,.78) !important;
  border: 1px solid rgba(255,255,255,.16) !important;
  box-shadow: 0 22px 70px rgba(0,0,0,.24) !important;
  backdrop-filter: blur(18px) !important;
  -webkit-backdrop-filter: blur(18px) !important;
}

@media (max-width: 900px) {
  .landing-clean .clean-hero.premium-landing-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 22px !important;
    gap: 22px !important;
  }

  .landing-clean .visual-chip {
    display: none !important;
  }

  .landing-clean .clean-phone {
    width: 100% !important;
    max-width: 310px !important;
    min-height: 560px !important;
  }

  .landing-clean .clean-price {
    position: static !important;
    width: 100% !important;
    max-width: 350px !important;
  }
}

/* Final professional SaaS hero: calm, readable, and production-grade. */
.landing-clean {
  max-width: 1180px !important;
}

.landing-clean .clean-hero.premium-landing-hero,
html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero,
html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 440px) !important;
  align-items: center !important;
  gap: 54px !important;
  min-height: 640px !important;
  padding: 56px !important;
  overflow: hidden !important;
  border-radius: 38px !important;
  border: 1px solid rgba(148,163,184,.16) !important;
  background:
    linear-gradient(115deg, rgba(3,10,9,.96) 0%, rgba(5,21,18,.95) 54%, rgba(7,38,31,.90) 100%),
    url("bg-premium-dark.svg") center / cover no-repeat !important;
  box-shadow: 0 34px 90px rgba(0,0,0,.30) !important;
}

.landing-clean .clean-hero.premium-landing-hero::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .22 !important;
  background:
    linear-gradient(90deg, rgba(255,255,255,.07) 1px, transparent 1px),
    linear-gradient(rgba(255,255,255,.055) 1px, transparent 1px) !important;
  background-size: 48px 48px !important;
  mask-image: linear-gradient(90deg, transparent 0%, black 18%, black 80%, transparent 100%) !important;
}

.landing-clean .clean-hero.premium-landing-hero::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 10% 6% 8% 44% !important;
  z-index: 0 !important;
  pointer-events: none !important;
  opacity: .46 !important;
  background:
    radial-gradient(circle at 50% 50%, rgba(52,211,153,.28), transparent 38%),
    radial-gradient(circle at 72% 30%, rgba(20,184,166,.18), transparent 30%) !important;
  filter: blur(8px);
}

.landing-clean .clean-copy,
.landing-clean .clean-visual {
  position: relative !important;
  z-index: 2 !important;
}

.landing-clean .clean-copy {
  max-width: 650px !important;
  justify-self: end !important;
}

.landing-clean .clean-copy h1 {
  text-shadow: none !important;
}

.landing-clean .clean-copy p {
  color: rgba(226,232,240,.82) !important;
}

.landing-clean .hero-actions {
  margin-top: 26px !important;
}

.landing-clean .clean-points {
  margin-top: 20px !important;
}

.landing-clean .clean-points span {
  background: rgba(255,255,255,.075) !important;
  border-color: rgba(255,255,255,.12) !important;
  color: rgba(248,250,252,.86) !important;
}

.landing-clean .conversion-strip {
  max-width: 620px !important;
  margin-top: 20px !important;
  background: rgba(16,185,129,.14) !important;
  border-color: rgba(52,211,153,.20) !important;
}

.landing-clean .clean-visual {
  min-height: 560px !important;
  display: grid !important;
  place-items: center !important;
  overflow: visible !important;
}

.landing-clean .visual-chip {
  display: none !important;
}

.landing-clean .clean-phone,
html[data-theme="light"] .landing-clean .clean-phone,
html[data-theme="dark"] .landing-clean .clean-phone {
  position: relative !important;
  z-index: 3 !important;
  width: 305px !important;
  min-height: 590px !important;
  padding: 13px !important;
  border-radius: 48px !important;
  background: #050807 !important;
  background-color: #050807 !important;
  background-image: none !important;
  border: 1px solid rgba(255,255,255,.18) !important;
  box-shadow:
    0 34px 80px rgba(0,0,0,.36),
    inset 0 0 0 8px #101815,
    inset 0 0 0 9px rgba(255,255,255,.08) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.landing-clean .clean-phone .phone-top {
  height: 48px !important;
  border-radius: 30px 30px 16px 16px !important;
  background: #101815 !important;
  border: 0 !important;
  color: #34d399 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.landing-clean .clean-phone .chat-area {
  min-height: 450px !important;
  border-radius: 32px !important;
  padding: 20px 13px 17px !important;
  gap: 12px !important;
  background: #050807 !important;
  background-image: none !important;
  border: 1px solid rgba(255,255,255,.08) !important;
}

.landing-clean .clean-phone .chat-date {
  background: rgba(255,255,255,.08) !important;
  color: rgba(255,255,255,.72) !important;
}

.landing-clean .clean-phone .chat-bubble {
  max-width: 84% !important;
  padding: 11px 13px !important;
  border-radius: 18px !important;
  font-size: 12px !important;
  line-height: 1.65 !important;
  box-shadow: none !important;
}

.landing-clean .clean-phone .chat-bubble.incoming {
  background: #f8fafc !important;
  color: #15231e !important;
}

.landing-clean .clean-phone .chat-bubble.bot {
  background: #18c68f !important;
  color: #fff !important;
}

.landing-clean .clean-phone .typing-pill {
  margin: 14px auto 0 !important;
  background: rgba(16,185,129,.13) !important;
  border-color: rgba(52,211,153,.18) !important;
}

.landing-clean .clean-price {
  z-index: 4 !important;
  inset-inline-start: 0 !important;
  bottom: 42px !important;
  width: 178px !important;
  padding: 18px !important;
  border-radius: 24px !important;
  background: rgba(8,18,16,.82) !important;
  border: 1px solid rgba(255,255,255,.14) !important;
  box-shadow: 0 22px 60px rgba(0,0,0,.24) !important;
}

@media (max-width: 900px) {
  .landing-clean .clean-hero.premium-landing-hero,
  html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero,
  html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero {
    grid-template-columns: 1fr !important;
    min-height: auto !important;
    padding: 22px !important;
    gap: 24px !important;
    border-radius: 28px !important;
  }

  .landing-clean .clean-hero.premium-landing-hero::after {
    inset: 42% 4% 6% 4% !important;
    opacity: .32 !important;
  }

  .landing-clean .clean-copy {
    max-width: none !important;
    justify-self: stretch !important;
  }

  .landing-clean .clean-visual {
    min-height: auto !important;
  }

  .landing-clean .clean-phone {
    width: 100% !important;
    max-width: 310px !important;
    min-height: 548px !important;
  }

  .landing-clean .clean-phone .chat-area {
    min-height: 410px !important;
  }

  .landing-clean .clean-price {
    position: static !important;
    width: 100% !important;
    max-width: 350px !important;
  }
}

/* Landing typography: restore the clearer Arabic headline font. */
.landing-clean .clean-hero.premium-landing-hero,
.landing-clean .clean-hero.premium-landing-hero h1,
.landing-clean .clean-hero.premium-landing-hero h2,
.landing-clean .clean-hero.premium-landing-hero p,
.landing-clean .clean-hero.premium-landing-hero a,
.landing-clean .clean-hero.premium-landing-hero button,
.landing-clean .clean-hero.premium-landing-hero span,
.landing-clean .clean-hero.premium-landing-hero strong {
  font-family: "Tajawal", "Inter", system-ui, -apple-system, sans-serif !important;
}

.landing-clean .clean-copy h1 {
  font-family: "Tajawal", system-ui, sans-serif !important;
  font-weight: 900 !important;
  letter-spacing: -.025em !important;
  line-height: 1.03 !important;
}

.landing-clean .clean-copy p {
  font-family: "Tajawal", system-ui, sans-serif !important;
  font-weight: 500 !important;
}

/* Global typography preference. Keep Tajawal first across the entire product. */
html,
body,
button,
input,
textarea,
select,
label,
a,
p,
span,
strong,
small,
h1,
h2,
h3,
h4,
h5,
h6,
.landing,
.clean-hero,
.card,
.btn,
.mini-btn,
.nav,
.bottom-nav,
.app-footer {
  font-family: "Tajawal", "Inter", system-ui, -apple-system, sans-serif !important;
}

/* ============================================================
   PRODUCTION DESIGN SYSTEM — final consolidated layer
   Mobile-first, calm, trustworthy. No decoration for its own sake.
   ============================================================ */
:root {
  --ds-bg: #f6f7f5;
  --ds-bg-elevated: #ffffff;
  --ds-surface: #ffffff;
  --ds-surface-2: #f1f3f0;
  --ds-text: #0f1a16;
  --ds-text-secondary: #5a6a64;
  --ds-text-tertiary: #8a9692;
  --ds-border: #e6e9e5;
  --ds-border-strong: #d4d8d2;
  --ds-brand: #128a6b;
  --ds-brand-strong: #0f7a5e;
  --ds-brand-soft: #e6f4ee;
  --ds-danger: #c0392b;
  --ds-warning: #b97a1a;
  --ds-success: #128a6b;
  --ds-radius-sm: 10px;
  --ds-radius: 14px;
  --ds-radius-lg: 18px;
  --ds-radius-xl: 22px;
  --ds-space-1: 4px;
  --ds-space-2: 8px;
  --ds-space-3: 12px;
  --ds-space-4: 16px;
  --ds-space-5: 24px;
  --ds-space-6: 32px;
  --ds-space-7: 48px;
  --ds-tap: 44px;
  --ds-shadow-sm: 0 1px 2px rgba(15,23,42,.04);
  --ds-shadow: 0 1px 2px rgba(15,23,42,.04), 0 6px 16px rgba(15,23,42,.06);
  --ds-shadow-lg: 0 1px 2px rgba(15,23,42,.04), 0 12px 32px rgba(15,23,42,.08);
}

:root[data-theme="dark"] {
  --ds-bg: #0c1310;
  --ds-bg-elevated: #121a16;
  --ds-surface: #121a16;
  --ds-surface-2: #182521;
  --ds-text: #f1f5f3;
  --ds-text-secondary: #a3b1ab;
  --ds-text-tertiary: #6e7d77;
  --ds-border: #1f2a26;
  --ds-border-strong: #2a3631;
  --ds-brand: #25b889;
  --ds-brand-strong: #2ec99a;
  --ds-brand-soft: rgba(37,184,137,.14);
  --ds-shadow-sm: 0 1px 2px rgba(0,0,0,.30);
  --ds-shadow: 0 1px 2px rgba(0,0,0,.30), 0 8px 22px rgba(0,0,0,.34);
  --ds-shadow-lg: 0 1px 2px rgba(0,0,0,.30), 0 18px 42px rgba(0,0,0,.42);
}

html,
body {
  background: var(--ds-bg) !important;
  background-image: none !important;
  color: var(--ds-text) !important;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  animation: none !important;
}

body::before,
body::after {
  display: none !important;
}

.mesh-bg,
.mesh-blob {
  display: none !important;
}

::selection {
  background: var(--ds-brand-soft);
  color: var(--ds-text);
}

*:focus-visible {
  outline: 2px solid var(--ds-brand) !important;
  outline-offset: 2px;
}

/* Headings — realistic SaaS scale, not Dribbble. */
h1, .clean-copy h1, .landing-clean h1, .premium-hero h1, .dashboard-hero h1, .training-hero h1, .decisions-hero h1 {
  font-weight: 800 !important;
  letter-spacing: -.018em !important;
  line-height: 1.18 !important;
  color: var(--ds-text) !important;
  -webkit-background-clip: initial !important;
  -webkit-text-fill-color: currentColor !important;
  background: none !important;
  text-shadow: none !important;
}

h2 {
  font-weight: 800 !important;
  letter-spacing: -.012em !important;
  line-height: 1.25 !important;
  color: var(--ds-text) !important;
}

h3 {
  font-weight: 700 !important;
  letter-spacing: -.008em !important;
  line-height: 1.3 !important;
  color: var(--ds-text) !important;
}

p, .muted, .section-sub {
  line-height: 1.7;
  color: var(--ds-text-secondary) !important;
}

a {
  color: var(--ds-brand) !important;
}

/* Buttons — consistent, accessible, calm. */
.btn,
.mini-btn,
.cta-primary,
.support-whatsapp-btn,
button.btn,
button.mini-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-height: var(--ds-tap) !important;
  padding: 0 18px !important;
  border-radius: var(--ds-radius) !important;
  border: 1px solid var(--ds-border) !important;
  background: var(--ds-surface) !important;
  color: var(--ds-text) !important;
  font-weight: 700 !important;
  font-size: 14px !important;
  line-height: 1 !important;
  box-shadow: var(--ds-shadow-sm) !important;
  transition: background .15s ease, border-color .15s ease, transform .05s ease, box-shadow .15s ease !important;
  cursor: pointer;
  text-shadow: none !important;
}

.btn:hover,
.mini-btn:hover {
  background: var(--ds-surface-2) !important;
}

.btn:active,
.mini-btn:active {
  transform: translateY(1px);
}

.btn:not(.dark):not(.red):not(.quiet-action),
.cta-primary,
.btn.primary {
  background: var(--ds-brand) !important;
  border-color: var(--ds-brand) !important;
  color: #ffffff !important;
  box-shadow: var(--ds-shadow-sm) !important;
}

.btn:not(.dark):not(.red):not(.quiet-action):hover,
.cta-primary:hover {
  background: var(--ds-brand-strong) !important;
  border-color: var(--ds-brand-strong) !important;
}

.btn.dark {
  background: var(--ds-surface) !important;
  border-color: var(--ds-border) !important;
  color: var(--ds-text) !important;
}

.btn.red {
  background: var(--ds-danger) !important;
  border-color: var(--ds-danger) !important;
  color: #ffffff !important;
}

.quiet-action {
  background: transparent !important;
  border-color: transparent !important;
}

/* Inputs — clean, 16px to avoid iOS zoom, real focus rings. */
.input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
input[type="url"],
input[type="date"],
input[type="time"],
textarea,
select {
  width: 100%;
  min-height: var(--ds-tap) !important;
  padding: 12px 14px !important;
  border-radius: var(--ds-radius) !important;
  border: 1px solid var(--ds-border) !important;
  background: var(--ds-surface) !important;
  color: var(--ds-text) !important;
  font-family: inherit !important;
  font-size: 16px !important;
  line-height: 1.4 !important;
  box-shadow: none !important;
  transition: border-color .15s ease, background .15s ease;
}

.input:focus,
input:focus,
textarea:focus,
select:focus {
  border-color: var(--ds-brand) !important;
  outline: none !important;
  background: var(--ds-bg-elevated) !important;
}

label {
  display: block;
  margin-bottom: 16px;
  font-weight: 600;
  color: var(--ds-text) !important;
  font-size: 14px;
}

/* Cards — single surface, single border, no inner gradient, no blur. */
.card,
.user-main .card,
.feature-card,
.price-card,
.flow-step,
.clean-card,
.clean-section,
.auth-shell {
  background: var(--ds-surface) !important;
  background-image: none !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  color: var(--ds-text) !important;
}

.card {
  padding: 20px !important;
  margin-bottom: 16px !important;
}

.clean-section {
  padding: 28px !important;
  margin-top: 16px !important;
}

.clean-card {
  padding: 20px !important;
  min-height: 0 !important;
}

.clean-card strong {
  color: var(--ds-text) !important;
  font-size: 16px !important;
  font-weight: 700 !important;
}

.clean-card span {
  color: var(--ds-text-secondary) !important;
  font-size: 14px !important;
}

.clean-card b {
  width: 32px !important;
  height: 32px !important;
  border-radius: 10px !important;
  background: var(--ds-brand-soft) !important;
  color: var(--ds-brand) !important;
  font-size: 14px !important;
  font-weight: 800 !important;
  box-shadow: none !important;
}

.card:hover {
  background: var(--ds-surface) !important;
  border-color: var(--ds-border-strong) !important;
}

/* Hero — calm, single brand accent, realistic copy size. */
.landing-clean .clean-hero.premium-landing-hero,
.landing-clean .clean-hero.premium-landing-hero[class],
html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero,
html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero {
  position: relative !important;
  display: grid !important;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 380px) !important;
  align-items: center !important;
  gap: 40px !important;
  min-height: 0 !important;
  padding: 40px 36px !important;
  margin-top: 20px !important;
  border-radius: var(--ds-radius-xl) !important;
  border: 1px solid var(--ds-border) !important;
  background: var(--ds-surface) !important;
  background-image: none !important;
  box-shadow: var(--ds-shadow) !important;
  overflow: hidden !important;
  animation: none !important;
}

.landing-clean .clean-hero.premium-landing-hero::before,
.landing-clean .clean-hero.premium-landing-hero::after {
  content: none !important;
  display: none !important;
}

.landing-clean .clean-copy {
  position: relative !important;
  z-index: 2 !important;
  max-width: 560px !important;
  justify-self: stretch !important;
}

.landing-clean .clean-copy .eyebrow {
  display: inline-block !important;
  padding: 6px 12px !important;
  background: var(--ds-brand-soft) !important;
  color: var(--ds-brand) !important;
  border-radius: 999px !important;
  font-size: 12px !important;
  font-weight: 700 !important;
  border: 0 !important;
  margin-bottom: 18px !important;
}

.landing-clean .clean-copy h1 {
  margin: 0 0 14px !important;
  font-size: clamp(28px, 4.2vw, 44px) !important;
  font-weight: 800 !important;
  letter-spacing: -.018em !important;
  line-height: 1.18 !important;
  color: var(--ds-text) !important;
}

.landing-clean .clean-copy h1 span {
  display: block !important;
  color: var(--ds-text) !important;
  background: none !important;
  -webkit-text-fill-color: currentColor !important;
}

.landing-clean .clean-copy h1 span:nth-child(2) {
  color: var(--ds-brand) !important;
}

.landing-clean .clean-copy p {
  margin: 0 !important;
  font-size: 16px !important;
  line-height: 1.7 !important;
  color: var(--ds-text-secondary) !important;
  font-weight: 400 !important;
  text-shadow: none !important;
}

.landing-clean .hero-actions {
  display: flex !important;
  gap: 10px !important;
  flex-wrap: wrap !important;
  margin-top: 20px !important;
}

.landing-clean .clean-points {
  display: flex !important;
  flex-wrap: wrap !important;
  gap: 8px !important;
  margin-top: 16px !important;
  grid-template-columns: none !important;
  max-width: none !important;
}

.landing-clean .clean-points span {
  padding: 6px 12px !important;
  border-radius: 999px !important;
  background: var(--ds-surface-2) !important;
  border: 1px solid var(--ds-border) !important;
  color: var(--ds-text-secondary) !important;
  font-weight: 600 !important;
  font-size: 12px !important;
  white-space: normal !important;
}

.landing-clean .conversion-strip {
  display: none !important;
}

/* Visual side: clean iPhone-style mockup, single color. */
.landing-clean .clean-visual {
  position: relative !important;
  min-height: 0 !important;
  display: flex !important;
  justify-content: center !important;
  isolation: isolate !important;
}

.landing-clean .visual-chip {
  display: none !important;
}

.landing-clean .clean-phone {
  position: relative !important;
  z-index: 2 !important;
  width: 280px !important;
  min-height: 0 !important;
  padding: 10px !important;
  border-radius: 36px !important;
  background: #0f1a16 !important;
  background-image: none !important;
  border: 1px solid #1c2925 !important;
  box-shadow:
    0 1px 2px rgba(15,23,42,.06),
    0 18px 40px rgba(15,23,42,.18),
    inset 0 0 0 6px #0f1a16 !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.landing-clean .clean-phone .phone-top {
  height: 26px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  background: transparent !important;
  border: 0 !important;
  border-radius: 0 !important;
  padding: 0 !important;
}

.landing-clean .clean-phone .phone-top strong {
  font-size: 11px !important;
  color: rgba(255,255,255,.65) !important;
  font-weight: 600 !important;
}

.landing-clean .clean-phone .phone-top span {
  width: 6px !important;
  height: 6px !important;
  border-radius: 50% !important;
  background: var(--ds-brand) !important;
}

.landing-clean .clean-phone .chat-area {
  min-height: 360px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
  padding: 16px 12px !important;
  border-radius: 24px !important;
  background: #0f1a16 !important;
  background-image: none !important;
  border: 0 !important;
}

.landing-clean .clean-phone .chat-date {
  align-self: center !important;
  padding: 3px 10px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.06) !important;
  color: rgba(255,255,255,.55) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
}

.landing-clean .clean-phone .chat-bubble {
  max-width: 82% !important;
  padding: 9px 12px !important;
  border-radius: 14px !important;
  font-size: 13px !important;
  line-height: 1.5 !important;
  box-shadow: none !important;
}

.landing-clean .clean-phone .chat-bubble.incoming {
  align-self: flex-start !important;
  background: #1c2925 !important;
  color: rgba(255,255,255,.92) !important;
}

.landing-clean .clean-phone .chat-bubble.bot {
  align-self: flex-end !important;
  background: var(--ds-brand) !important;
  color: #ffffff !important;
}

.landing-clean .clean-phone .typing-pill {
  align-self: center !important;
  margin-top: 6px !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  background: rgba(255,255,255,.06) !important;
  border: 0 !important;
  color: rgba(255,255,255,.6) !important;
  font-size: 10px !important;
  font-weight: 600 !important;
}

.landing-clean .clean-price {
  position: absolute !important;
  inset-inline-start: -20px !important;
  bottom: 32px !important;
  z-index: 3 !important;
  width: 150px !important;
  padding: 14px !important;
  border-radius: var(--ds-radius-lg) !important;
  background: var(--ds-surface) !important;
  border: 1px solid var(--ds-border) !important;
  box-shadow: var(--ds-shadow) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  display: grid !important;
  gap: 4px !important;
}

.landing-clean .clean-price small {
  color: var(--ds-text-tertiary) !important;
  font-size: 11px !important;
  font-weight: 600 !important;
}

.landing-clean .clean-price strong {
  color: var(--ds-text) !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  letter-spacing: -.01em !important;
}

.landing-clean .clean-price span {
  color: var(--ds-text-secondary) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
}

/* Landing sections — neutral, readable. */
.landing-clean .clean-section {
  background: var(--ds-surface) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-xl) !important;
  padding: 28px !important;
  box-shadow: var(--ds-shadow-sm) !important;
}

.landing-clean .clean-section h2 {
  text-align: center !important;
  font-size: 22px !important;
  margin-bottom: 6px !important;
}

.landing-clean .clean-section > p {
  text-align: center !important;
  font-size: 14px !important;
  color: var(--ds-text-secondary) !important;
  max-width: 580px !important;
  margin: 0 auto 20px !important;
}

.landing-clean .clean-grid {
  display: grid !important;
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 12px !important;
}

.landing-clean .steps-section::before,
.landing-clean .steps-grid .clean-card::after {
  display: none !important;
}

.landing-clean .final-cta-section {
  text-align: center !important;
  background: var(--ds-brand-soft) !important;
  border-color: rgba(18,138,107,.18) !important;
}

.landing-clean .final-cta-section h2 {
  color: var(--ds-text) !important;
  font-size: 24px !important;
}

.landing-clean .final-actions {
  justify-content: center !important;
}

/* Topbar — simple, sticky-friendly, no glass on landing. */
.landing-topbar {
  margin-top: 16px !important;
  padding: 12px 16px !important;
  background: var(--ds-surface) !important;
  background-image: none !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.landing-topbar img {
  width: auto !important;
  max-width: 130px !important;
  max-height: 36px !important;
}

/* App header — production-grade sticky header. */
.user-app-header {
  position: sticky !important;
  top: 0 !important;
  z-index: 50 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 12px 16px !important;
  background: color-mix(in srgb, var(--ds-surface) 88%, transparent) !important;
  background-image: none !important;
  border: 0 !important;
  border-bottom: 1px solid var(--ds-border) !important;
  border-radius: 0 !important;
  box-shadow: none !important;
  backdrop-filter: saturate(1.4) blur(10px) !important;
  -webkit-backdrop-filter: saturate(1.4) blur(10px) !important;
  margin: 0 0 16px !important;
}

.user-app-header .app-header-brand {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-width: 0 !important;
}

.user-app-header .app-header-logo {
  display: inline-flex !important;
  align-items: center !important;
  height: 36px !important;
  padding: 0 !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
}

.user-app-header .app-header-logo img {
  height: 28px !important;
  width: auto !important;
  max-width: 130px !important;
}

.user-app-header strong {
  display: block;
  font-size: 15px !important;
  font-weight: 700 !important;
  color: var(--ds-text) !important;
  line-height: 1.2 !important;
}

.user-app-header .header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}

.user-app-header .mini-btn,
.user-app-header .theme-toggle-btn,
.user-app-header .lang-toggle-btn,
.user-app-header .account-btn {
  min-height: 40px !important;
  min-width: 40px !important;
  padding: 0 12px !important;
  border-radius: var(--ds-radius) !important;
  font-size: 13px !important;
}

/* Sidebar — calm, single border, no glass. */
.user-side {
  background: var(--ds-surface) !important;
  background-image: none !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
}

.nav a {
  border-radius: var(--ds-radius) !important;
  font-weight: 600 !important;
  color: var(--ds-text-secondary) !important;
}

.nav a.active,
.nav a:hover {
  background: var(--ds-brand-soft) !important;
  color: var(--ds-brand) !important;
}

/* Bottom nav — iOS/Android standard sizing, no excessive blur. */
@media (max-width: 900px) {
  .wrap.user-shell {
    padding: 0 12px calc(76px + env(safe-area-inset-bottom, 0px)) !important;
  }

  .user-app-header {
    margin: 0 -12px 12px !important;
    border-radius: 0 !important;
  }

  .bottom-nav {
    position: fixed !important;
    inset-inline: 0 !important;
    bottom: 0 !important;
    width: 100% !important;
    height: calc(60px + env(safe-area-inset-bottom, 0px)) !important;
    padding: 6px 4px env(safe-area-inset-bottom, 6px) !important;
    border-radius: 0 !important;
    border: 0 !important;
    border-top: 1px solid var(--ds-border) !important;
    background: color-mix(in srgb, var(--ds-surface) 92%, transparent) !important;
    box-shadow: none !important;
    backdrop-filter: saturate(1.4) blur(12px) !important;
    -webkit-backdrop-filter: saturate(1.4) blur(12px) !important;
    display: flex !important;
    align-items: center !important;
    justify-content: space-around !important;
    gap: 0 !important;
  }

  .bottom-nav a {
    flex: 1 1 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    min-width: 0 !important;
    min-height: 0 !important;
    padding: 4px 2px !important;
    border-radius: var(--ds-radius-sm) !important;
    color: var(--ds-text-tertiary) !important;
    font-size: 10px !important;
    font-weight: 600 !important;
    background: transparent !important;
    gap: 2px !important;
    text-align: center !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    white-space: nowrap !important;
  }

  .bottom-nav a.active {
    background: transparent !important;
    color: var(--ds-brand) !important;
  }

  .bottom-nav .nav-icon {
    width: 24px !important;
    height: 24px !important;
    border: 0 !important;
    background: transparent !important;
    box-shadow: none !important;
    color: currentColor !important;
  }

  .bottom-nav .nav-icon::before {
    background-color: currentColor !important;
  }
}

/* Footer — quiet. */
.app-footer {
  background: var(--ds-surface) !important;
  background-image: none !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: none !important;
  padding: 16px 18px !important;
  margin-top: 16px !important;
}

.app-footer strong {
  font-size: 14px !important;
}

.app-footer .muted,
.app-footer p {
  font-size: 12px !important;
  margin: 4px 0 0 !important;
}

.app-footer-meta {
  gap: 8px !important;
}

.version-pill {
  background: var(--ds-surface-2) !important;
  color: var(--ds-text-secondary) !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  border: 0 !important;
}

/* Support / WhatsApp widgets — restrained, single brand button. */
.support-whatsapp-btn {
  background: var(--ds-brand) !important;
  border: 1px solid var(--ds-brand) !important;
  color: #ffffff !important;
  min-height: 38px !important;
  padding: 0 14px !important;
  border-radius: var(--ds-radius) !important;
  font-size: 13px !important;
  box-shadow: var(--ds-shadow-sm) !important;
}

.whatsapp-widget {
  position: fixed !important;
  inset-inline-end: 16px !important;
  bottom: 16px !important;
  z-index: 800 !important;
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  padding: 10px 14px !important;
  min-height: 48px !important;
  border-radius: 999px !important;
  background: var(--ds-brand) !important;
  border: 0 !important;
  color: #ffffff !important;
  font-weight: 700 !important;
  box-shadow: var(--ds-shadow) !important;
}

.whatsapp-widget strong {
  font-size: 13px !important;
}

.whatsapp-widget small {
  font-size: 11px !important;
  color: rgba(255,255,255,.85) !important;
}

@media (max-width: 900px) {
  .whatsapp-widget {
    inset-inline-end: 12px !important;
    bottom: calc(72px + env(safe-area-inset-bottom, 0px)) !important;
    padding: 10px 12px !important;
    min-height: 44px !important;
  }

  .whatsapp-widget span:last-child {
    display: none !important;
  }
}

/* Status pills — calm, single accent. */
.status-pill,
.pill,
.badge {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  padding: 4px 10px !important;
  border-radius: 999px !important;
  background: var(--ds-surface-2) !important;
  border: 1px solid var(--ds-border) !important;
  color: var(--ds-text-secondary) !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  box-shadow: none !important;
}

.status-pill.success,
.pill.success,
.badge.success {
  background: var(--ds-brand-soft) !important;
  border-color: rgba(18,138,107,.18) !important;
  color: var(--ds-brand) !important;
}

.status-pill.danger,
.pill.danger,
.badge.danger {
  background: rgba(192,57,43,.10) !important;
  border-color: rgba(192,57,43,.22) !important;
  color: var(--ds-danger) !important;
}

.status-pill.warning,
.pill.warning,
.badge.warning {
  background: rgba(185,122,26,.10) !important;
  border-color: rgba(185,122,26,.22) !important;
  color: var(--ds-warning) !important;
}

/* Alerts — clear, not loud. */
.alert {
  padding: 12px 14px !important;
  border-radius: var(--ds-radius) !important;
  border: 1px solid var(--ds-border) !important;
  background: var(--ds-surface) !important;
  color: var(--ds-text) !important;
  font-size: 14px !important;
  box-shadow: none !important;
  margin-bottom: 12px !important;
}

.alert.ok {
  background: var(--ds-brand-soft) !important;
  border-color: rgba(18,138,107,.18) !important;
  color: var(--ds-brand) !important;
}

.alert.err {
  background: rgba(192,57,43,.08) !important;
  border-color: rgba(192,57,43,.20) !important;
  color: var(--ds-danger) !important;
}

/* Internal hero variants (dashboard, training, decisions) — quiet. */
.user-main .hero,
.premium-hero,
.dashboard-hero,
.training-hero,
.decisions-hero {
  background: var(--ds-surface) !important;
  background-image: none !important;
  border: 1px solid var(--ds-border) !important;
  border-top: 0 !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: var(--ds-shadow-sm) !important;
  padding: 22px !important;
}

.hero-kicker {
  background: var(--ds-brand-soft) !important;
  color: var(--ds-brand) !important;
  border-radius: 999px !important;
  padding: 4px 10px !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  border: 0 !important;
}

.user-main .hero h1 {
  font-size: 22px !important;
}

.user-main .hero p {
  font-size: 14px !important;
}

/* Tables / data — clean rows. */
.data-table {
  width: 100%;
  border-collapse: separate !important;
  border-spacing: 0 !important;
  background: var(--ds-surface) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-lg) !important;
  overflow: hidden;
}

.data-table th {
  background: var(--ds-surface-2) !important;
  color: var(--ds-text-secondary) !important;
  font-weight: 700 !important;
  font-size: 12px !important;
  padding: 10px 14px !important;
  border-bottom: 1px solid var(--ds-border) !important;
}

.data-table td {
  padding: 12px 14px !important;
  border-bottom: 1px solid var(--ds-border) !important;
  font-size: 14px !important;
  color: var(--ds-text) !important;
}

.data-table tbody tr:last-child td {
  border-bottom: 0 !important;
}

.data-table tbody tr:hover {
  background: var(--ds-surface-2) !important;
}

/* Decisions / training cards — quiet hierarchy. */
.decision-card,
.training-option-body,
.collapsible-section {
  background: var(--ds-surface) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-lg) !important;
  box-shadow: none !important;
  padding: 16px !important;
}

.training-tabs {
  background: var(--ds-surface-2) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: 999px !important;
  padding: 4px !important;
}

.training-tabs .mini-btn {
  min-height: 36px !important;
  padding: 0 14px !important;
  border-radius: 999px !important;
  background: transparent !important;
  border: 0 !important;
  box-shadow: none !important;
  font-size: 13px !important;
  color: var(--ds-text-secondary) !important;
}

.training-tabs .mini-btn.active,
.training-tabs .mini-btn[aria-pressed="true"] {
  background: var(--ds-surface) !important;
  color: var(--ds-text) !important;
  box-shadow: var(--ds-shadow-sm) !important;
}

.training-save-bar {
  background: var(--ds-surface) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: var(--ds-radius-xl) !important;
  box-shadow: var(--ds-shadow) !important;
  padding: 12px 16px !important;
}

/* Auth / login — calm card. */
.auth-shell {
  background: var(--ds-surface) !important;
  border: 1px solid var(--ds-border) !important;
  border-radius: 24px !important;
  box-shadow: var(--ds-shadow) !important;
  padding: 24px !important;
}

.auth-shell h1 {
  font-size: 22px !important;
}

.auth-shell .input {
  background: var(--ds-bg) !important;
  border-color: var(--ds-border) !important;
  color: var(--ds-text) !important;
}

.auth-shell .btn {
  width: 100%;
}

/* Disable animations that signal "AI demo" feel. */
@keyframes meshFloat { 0%, 100% { transform: none; } }
@keyframes premiumBgDrift { 0%, 100% { background-position: center; } }
@keyframes premiumHeroBgDrift { 0%, 100% { background-position: center; } }

/* Mobile refinements — production-grade. */
@media (max-width: 900px) {
  .landing-clean {
    padding: 0 12px 64px !important;
  }

  .landing-clean .clean-hero.premium-landing-hero,
  html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero,
  html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero {
    grid-template-columns: 1fr !important;
    padding: 24px 20px !important;
    gap: 24px !important;
    border-radius: var(--ds-radius-xl) !important;
  }

  .landing-clean .clean-copy {
    max-width: none !important;
  }

  .landing-clean .clean-copy h1 {
    font-size: 26px !important;
  }

  .landing-clean .clean-copy p {
    font-size: 15px !important;
  }

  .landing-clean .hero-actions .btn,
  .landing-clean .hero-actions .cta-primary {
    flex: 1 1 auto !important;
  }

  .landing-clean .clean-visual {
    order: -1 !important;
  }

  .landing-clean .clean-phone {
    width: 240px !important;
  }

  .landing-clean .clean-phone .chat-area {
    min-height: 280px !important;
  }

  .landing-clean .clean-price {
    position: static !important;
    width: 100% !important;
    max-width: 280px !important;
    margin: 12px auto 0 !important;
  }

  .landing-clean .clean-section {
    padding: 20px !important;
  }

  .landing-clean .clean-section h2 {
    font-size: 18px !important;
  }

  .landing-clean .clean-grid {
    grid-template-columns: 1fr 1fr !important;
    gap: 10px !important;
  }
}

@media (max-width: 480px) {
  .landing-clean .clean-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Dashboard monthly chart: fit every day inside the card, no horizontal slider. */
.usage-chart {
  display: flex !important;
  width: 100% !important;
  min-width: 0 !important;
  overflow-x: hidden !important;
  gap: clamp(1px, .45vw, 5px) !important;
  padding-inline: 8px !important;
}

.usage-day {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  max-width: none !important;
  gap: clamp(1px, .35vw, 4px) !important;
}

.usage-day > .usage-bar {
  width: clamp(3px, .55vw, 8px) !important;
  min-width: 2px !important;
}

.usage-day small {
  font-size: clamp(8px, .8vw, 10px) !important;
  letter-spacing: -.02em !important;
  overflow: visible !important;
}

/* Landing hero background: intentionally subtle so copy stays readable. */
.landing-clean .clean-hero.premium-landing-hero::before,
html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero::before,
html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 0 !important;
  background:
    linear-gradient(90deg, var(--ds-surface) 0%, color-mix(in srgb, var(--ds-surface) 68%, transparent) 50%, var(--ds-surface) 100%),
    url("hero-ai-bg.png") center / cover no-repeat !important;
  opacity: .28 !important;
  pointer-events: none !important;
}

.landing-clean .clean-copy,
.landing-clean .clean-visual,
.landing-clean .clean-price {
  position: relative !important;
  z-index: 2 !important;
}

/* Final typography lock: Tajawal only, with deliberate production weights. */
html,
body,
button,
input,
textarea,
select,
label,
a,
p,
span,
strong,
small,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-family: 'Tajawal', sans-serif !important;
}

body,
p,
span,
small,
label,
input,
textarea,
select,
td,
th,
.muted,
.section-sub,
.nav a,
.bottom-nav a,
.usage-metric,
.clean-card span {
  font-weight: 500 !important;
}

h1,
.landing-clean .clean-copy h1,
.premium-hero h1,
.dashboard-hero h1,
.training-hero h1,
.decisions-hero h1 {
  font-family: 'Tajawal', sans-serif !important;
  font-weight: 900 !important;
}

h2,
h3,
.card h2,
.clean-card strong,
.premium-metric strong,
.usage-metric strong,
.status-pill,
.badge,
.pill {
  font-family: 'Tajawal', sans-serif !important;
  font-weight: 800 !important;
}

button,
.btn,
.mini-btn,
.cta-primary,
.support-whatsapp-btn,
.account-btn,
.theme-toggle-btn,
.lang-toggle-btn {
  font-family: 'Tajawal', sans-serif !important;
  font-weight: 700 !important;
}

/* Final hero phone polish: realistic proportions, cleaner screen, less visual weight. */
.landing-clean .clean-visual {
  align-items: center !important;
  min-height: 400px !important;
  padding: 12px 28px !important;
}

.landing-clean .clean-phone,
html[data-theme="light"] .landing-clean .clean-phone,
html[data-theme="dark"] .landing-clean .clean-phone {
  width: min(238px, 31vw) !important;
  aspect-ratio: 9 / 18.8 !important;
  min-height: 0 !important;
  display: flex !important;
  flex-direction: column !important;
  padding: 9px !important;
  border-radius: 34px !important;
  background: #050706 !important;
  border: 1px solid rgba(255,255,255,.12) !important;
  box-shadow:
    0 1px 2px rgba(0,0,0,.28),
    0 16px 34px rgba(0,0,0,.22),
    inset 0 0 0 4px #0b0e0c !important;
  transform: none !important;
}

.landing-clean .clean-phone::before {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  top: 10px !important;
  left: 50% !important;
  width: 68px !important;
  height: 16px !important;
  transform: translateX(-50%) !important;
  border-radius: 999px !important;
  background: #050706 !important;
  z-index: 4 !important;
  box-shadow: inset 0 0 0 1px rgba(255,255,255,.05) !important;
}

.landing-clean .clean-phone::after {
  content: "" !important;
  display: block !important;
  position: absolute !important;
  inset: 9px !important;
  border-radius: 26px !important;
  pointer-events: none !important;
  border: 1px solid rgba(255,255,255,.06) !important;
  z-index: 3 !important;
}

.landing-clean .clean-phone .phone-top {
  height: 30px !important;
  padding-top: 8px !important;
  flex: 0 0 auto !important;
  position: relative !important;
  z-index: 5 !important;
}

.landing-clean .clean-phone .phone-top strong {
  font-size: 9px !important;
  letter-spacing: .02em !important;
}

.landing-clean .clean-phone .phone-top span {
  width: 5px !important;
  height: 5px !important;
}

.landing-clean .clean-phone .chat-area {
  flex: 1 1 auto !important;
  min-height: 0 !important;
  height: auto !important;
  justify-content: center !important;
  gap: 9px !important;
  padding: 34px 13px 16px !important;
  border-radius: 25px !important;
  background:
    radial-gradient(circle at 70% 10%, rgba(18,138,107,.12), transparent 34%),
    #0c1713 !important;
  overflow: hidden !important;
}

.landing-clean .clean-phone .chat-date {
  padding: 3px 9px !important;
  font-size: 9px !important;
  background: rgba(255,255,255,.055) !important;
}

.landing-clean .clean-phone .chat-bubble {
  max-width: 84% !important;
  padding: 8px 11px !important;
  border-radius: 13px !important;
  font-size: 11.5px !important;
  line-height: 1.55 !important;
  font-weight: 600 !important;
}

.landing-clean .clean-phone .chat-bubble.incoming {
  background: #1b2824 !important;
  color: rgba(255,255,255,.9) !important;
}

.landing-clean .clean-phone .chat-bubble.bot {
  background: #2ec49a !important;
  color: #07231b !important;
}

.landing-clean .clean-phone .typing-pill {
  margin-top: 4px !important;
  padding: 4px 9px !important;
  font-size: 9px !important;
  background: rgba(255,255,255,.075) !important;
}

.landing-clean .clean-price {
  inset-inline-start: 8px !important;
  bottom: 64px !important;
  width: 136px !important;
  padding: 12px !important;
  z-index: 5 !important;
  border-radius: 18px !important;
  background: color-mix(in srgb, var(--ds-surface) 90%, transparent) !important;
  backdrop-filter: blur(8px) !important;
  -webkit-backdrop-filter: blur(8px) !important;
  box-shadow: 0 12px 28px rgba(0,0,0,.16) !important;
}

@media (max-width: 900px) {
  .landing-clean .clean-hero.premium-landing-hero::before,
  html[data-theme="light"] .landing-clean .clean-hero.premium-landing-hero::before,
  html[data-theme="dark"] .landing-clean .clean-hero.premium-landing-hero::before {
    background:
      linear-gradient(180deg, var(--ds-surface) 0%, color-mix(in srgb, var(--ds-surface) 72%, transparent) 48%, var(--ds-surface) 100%),
      url("hero-ai-bg.png") center / cover no-repeat !important;
    opacity: .23 !important;
  }

  .landing-clean .clean-visual {
    min-height: auto !important;
    padding: 0 !important;
  }

  .landing-clean .clean-phone,
  html[data-theme="light"] .landing-clean .clean-phone,
  html[data-theme="dark"] .landing-clean .clean-phone {
    width: min(224px, 70vw) !important;
  }

  .landing-clean .clean-price {
    inset-inline-start: auto !important;
    bottom: auto !important;
    width: 100% !important;
    max-width: 260px !important;
    margin-top: 12px !important;
  }
}

@media (max-width: 520px) {
  .usage-chart {
    gap: 1px !important;
    padding-inline: 6px !important;
  }

  .usage-day {
    gap: 1px !important;
  }

  .usage-day > .usage-bar {
    width: 3px !important;
  }

  .usage-day small {
    font-size: 8px !important;
  }
}

/* Hero breathing room and rotating point chips polish. */
.landing-clean .clean-hero.premium-landing-hero .clean-copy {
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 0 !important;
}

.landing-clean .clean-hero.premium-landing-hero .clean-copy .eyebrow {
  margin-bottom: 22px !important;
}

.landing-clean .clean-hero.premium-landing-hero .clean-copy h1 {
  margin: 0 0 24px !important;
}

.landing-clean .clean-hero.premium-landing-hero .clean-copy p {
  margin: 0 0 30px !important;
  max-width: 650px !important;
}

.landing-clean .clean-hero.premium-landing-hero .hero-actions {
  margin: 0 0 24px !important;
}

.landing-clean .clean-hero.premium-landing-hero .clean-points {
  margin-top: 0 !important;
  gap: 12px !important;
}

.landing-clean .clean-hero.premium-landing-hero .clean-points span {
  min-height: 38px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  padding: 8px 16px !important;
}

@media (max-width: 900px) {
  .landing-clean .clean-hero.premium-landing-hero .clean-copy .eyebrow {
    margin-bottom: 16px !important;
  }

  .landing-clean .clean-hero.premium-landing-hero .clean-copy h1 {
    margin-bottom: 18px !important;
  }

  .landing-clean .clean-hero.premium-landing-hero .clean-copy p {
    margin-bottom: 22px !important;
  }

  .landing-clean .clean-hero.premium-landing-hero .hero-actions {
    margin-bottom: 18px !important;
  }

  .landing-clean .clean-hero.premium-landing-hero .clean-points {
    gap: 8px !important;
  }
}

/* Reduce motion preference. */
@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation: none !important;
    transition-duration: .01ms !important;
  }
}

/* ============================================================
   FINAL UNIFIED TYPE SYSTEM
   One font, one scale, predictable weights across every page.
   ============================================================ */
:root {
  --type-font: 'Tajawal', sans-serif;
  --type-xs: 12px;
  --type-sm: 13px;
  --type-body: 15px;
  --type-body-lg: 16px;
  --type-h3: 18px;
  --type-h2: 22px;
  --type-h1: clamp(28px, 4vw, 46px);
  --type-hero: clamp(34px, 5.2vw, 58px);
  --type-line-tight: 1.2;
  --type-line-body: 1.75;
}

html,
body,
.wrap,
.landing,
.user-shell,
.admin-shell,
.main,
.card,
.clean-section,
.auth-shell,
button,
input,
textarea,
select,
label,
a,
p,
span,
strong,
small,
h1,
h2,
h3,
h4,
h5,
h6,
table,
th,
td {
  font-family: var(--type-font) !important;
}

body,
p,
li,
td,
th,
label,
input,
textarea,
select,
.muted,
.section-sub,
.feature,
.clean-card span,
.app-footer,
.usage-metric span,
.premium-metric span,
.decision-card,
.training-option-body {
  font-size: var(--type-body) !important;
  font-weight: 500 !important;
  line-height: var(--type-line-body) !important;
}

small,
.eyebrow,
.badge,
.pill,
.status-pill,
.version-pill,
.nav-label,
.bottom-nav a,
.usage-legend,
.usage-day small,
.chat-date,
.typing-pill {
  font-size: var(--type-xs) !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
}

h1,
.title,
.human-title,
.hero h1,
.premium-hero h1,
.dashboard-hero h1,
.training-hero h1,
.decisions-hero h1,
.landing-clean .clean-copy h1 {
  font-size: var(--type-h1) !important;
  font-weight: 900 !important;
  line-height: var(--type-line-tight) !important;
  letter-spacing: -.018em !important;
}

.landing-clean .clean-copy h1 {
  font-size: var(--type-hero) !important;
  font-weight: 900 !important;
}

h2,
.card h2,
.clean-section h2,
.app-header strong,
.section-collapse-toggle strong {
  font-size: var(--type-h2) !important;
  font-weight: 800 !important;
  line-height: 1.28 !important;
  letter-spacing: -.01em !important;
}

h3,
.clean-card strong,
.premium-metric strong,
.usage-metric strong,
.stat,
.price,
.clean-price strong,
.metric-chart-head strong {
  font-size: var(--type-h3) !important;
  font-weight: 800 !important;
  line-height: 1.3 !important;
}

.premium-metric strong,
.usage-metric strong,
.stat,
.price {
  font-size: clamp(22px, 3vw, 34px) !important;
  font-weight: 900 !important;
}

button,
.btn,
.mini-btn,
.cta-primary,
.support-whatsapp-btn,
.account-btn,
.theme-toggle-btn,
.lang-toggle-btn,
.install-btn,
.training-tabs .mini-btn,
input[type="submit"] {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.2 !important;
}

.input,
input[type="text"],
input[type="email"],
input[type="password"],
input[type="tel"],
input[type="number"],
input[type="search"],
input[type="url"],
textarea,
select {
  font-size: 16px !important;
  font-weight: 500 !important;
  line-height: 1.45 !important;
}

.nav a,
.user-nav a,
.admin-nav a {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.35 !important;
}

.app-header p,
.auth-shell .muted,
.terms-check span,
.clean-price small,
.clean-price span,
.mini-price-card span,
.mini-price-card small {
  font-size: var(--type-sm) !important;
  font-weight: 500 !important;
}

.landing-clean .clean-copy p {
  font-size: var(--type-body-lg) !important;
  font-weight: 500 !important;
  line-height: 1.8 !important;
}

.landing-clean .clean-points span {
  font-size: 13px !important;
  font-weight: 700 !important;
}

h1 span,
h2 span,
h3 span,
.title span,
.human-title span,
.landing-clean .clean-copy h1 span,
.premium-hero h1 span,
.dashboard-hero h1 span,
.training-hero h1 span,
.decisions-hero h1 span {
  font-family: var(--type-font) !important;
  font-weight: inherit !important;
  font-size: inherit !important;
  line-height: inherit !important;
}

.btn span,
.mini-btn span,
button span,
.nav a span,
.bottom-nav a span,
.status-pill span,
.badge span,
.pill span {
  font-family: var(--type-font) !important;
  font-weight: inherit !important;
}

@media (max-width: 900px) {
  :root {
    --type-body: 14px;
    --type-body-lg: 15px;
    --type-h3: 17px;
    --type-h2: 19px;
    --type-h1: clamp(24px, 7vw, 34px);
    --type-hero: clamp(30px, 9vw, 42px);
  }

  .bottom-nav a {
    font-size: 10px !important;
    font-weight: 700 !important;
  }
}

/* ============================================================
   FINAL MOBILE HERO + WHATSAPP WIDGET FIX
   Keep the phone, price card, and support action clean on mobile.
   ============================================================ */
@media (max-width: 900px) {
  .landing-clean .clean-hero.premium-landing-hero {
    padding: 20px 16px 22px !important;
    gap: 18px !important;
    overflow: hidden !important;
  }

  .landing-clean .clean-hero.premium-landing-hero .clean-visual {
    order: 2 !important;
    width: 100% !important;
    min-height: 0 !important;
    display: grid !important;
    grid-template-columns: minmax(104px, .82fr) minmax(116px, 1fr) !important;
    align-items: center !important;
    justify-items: center !important;
    gap: 12px !important;
    padding: 8px 0 0 !important;
  }

  .landing-clean .clean-phone,
  html[data-theme="light"] .landing-clean .clean-phone,
  html[data-theme="dark"] .landing-clean .clean-phone {
    grid-column: 2 !important;
    grid-row: 1 !important;
    width: min(136px, 38vw) !important;
    border-radius: 24px !important;
    padding: 5px !important;
    box-shadow:
      0 1px 2px rgba(0,0,0,.24),
      0 12px 26px rgba(0,0,0,.20),
      inset 0 0 0 3px #0b0e0c !important;
  }

  .landing-clean .clean-phone::before {
    top: 6px !important;
    width: 42px !important;
    height: 10px !important;
  }

  .landing-clean .clean-phone::after {
    inset: 5px !important;
    border-radius: 20px !important;
  }

  .landing-clean .clean-phone .phone-top {
    height: 20px !important;
    padding-top: 5px !important;
    gap: 3px !important;
  }

  .landing-clean .clean-phone .phone-top strong {
    font-size: 7px !important;
  }

  .landing-clean .clean-phone .phone-top span {
    width: 4px !important;
    height: 4px !important;
  }

  .landing-clean .clean-phone .chat-area {
    justify-content: center !important;
    gap: 6px !important;
    padding: 22px 8px 10px !important;
    border-radius: 19px !important;
  }

  .landing-clean .clean-phone .chat-date,
  .landing-clean .clean-phone .typing-pill {
    font-size: 7px !important;
    padding: 3px 6px !important;
  }

  .landing-clean .clean-phone .chat-bubble {
    max-width: 88% !important;
    padding: 6px 7px !important;
    border-radius: 9px !important;
    font-size: 8.5px !important;
    line-height: 1.45 !important;
  }

  .landing-clean .clean-price {
    grid-column: 1 !important;
    grid-row: 1 !important;
    position: relative !important;
    inset: auto !important;
    width: 100% !important;
    max-width: 132px !important;
    margin: 0 !important;
    padding: 12px 10px !important;
    border-radius: 16px !important;
    text-align: center !important;
    justify-self: stretch !important;
    align-self: center !important;
  }

  .landing-clean .clean-price small,
  .landing-clean .clean-price span {
    font-size: 10px !important;
    line-height: 1.4 !important;
  }

  .landing-clean .clean-price strong {
    font-size: 20px !important;
    line-height: 1.1 !important;
    white-space: nowrap !important;
  }

  .landing-clean .clean-visual .eyebrow,
  .landing-clean .visual-chip {
    display: none !important;
  }

  .whatsapp-widget,
  html[dir="rtl"] .whatsapp-widget,
  html[dir="ltr"] .whatsapp-widget {
    inset-inline-start: 14px !important;
    inset-inline-end: auto !important;
    bottom: calc(78px + env(safe-area-inset-bottom, 0px)) !important;
    width: 56px !important;
    height: 56px !important;
    min-width: 56px !important;
    min-height: 56px !important;
    padding: 0 !important;
    border-radius: 999px !important;
    justify-content: center !important;
    box-shadow: 0 10px 26px rgba(0,0,0,.22) !important;
  }

  .whatsapp-widget span:last-child {
    display: none !important;
  }

  .whatsapp-widget-icon {
    width: 28px !important;
    height: 28px !important;
  }
}

@media (max-width: 380px) {
  .landing-clean .clean-hero.premium-landing-hero .clean-visual {
    grid-template-columns: 1fr !important;
  }

  .landing-clean .clean-phone,
  html[data-theme="light"] .landing-clean .clean-phone,
  html[data-theme="dark"] .landing-clean .clean-phone,
  .landing-clean .clean-price {
    grid-column: 1 !important;
  }

  .landing-clean .clean-phone {
    grid-row: 1 !important;
    width: min(150px, 52vw) !important;
  }

  .landing-clean .clean-price {
    grid-row: 2 !important;
    max-width: 210px !important;
    justify-self: center !important;
    margin-top: 6px !important;
  }
}

/* FINAL TYPOGRAPHY CONTRACT
   Agreed site-wide font: Tajawal only.
   Headings: 800/900, body: 500, buttons/nav: 700. */
html,
body,
body *,
button,
input,
textarea,
select {
  font-family: "Tajawal", sans-serif !important;
}

body,
p,
li,
small,
span,
label,
.muted,
.feature,
.clean-card span,
.chat-bubble,
.wa-bubble,
.alert,
.input,
textarea,
select {
  font-weight: 500 !important;
}

h1,
.clean-copy h1,
.landing-clean h1,
.premium-hero h1,
.dashboard-hero h1,
.training-hero h1,
.decisions-hero h1,
.auth-copy h1 {
  font-family: "Tajawal", sans-serif !important;
  font-weight: 900 !important;
}

h2,
.section-title,
.card h2,
.clean-section h2 {
  font-family: "Tajawal", sans-serif !important;
  font-weight: 800 !important;
}

h3,
h4,
.stat,
.premium-metric strong,
.clean-card strong,
.training-option-head strong,
.custom-training-card strong {
  font-family: "Tajawal", sans-serif !important;
  font-weight: 800 !important;
}

a.btn,
.btn,
button,
input[type="submit"],
.mini-btn,
.nav a,
.bottom-nav a,
.landing-topbar a,
.badge,
.status-pill {
  font-family: "Tajawal", sans-serif !important;
  font-weight: 700 !important;
}

h1 span,
h2 span,
h3 span,
.btn span,
.mini-btn span,
.premium-metric strong span,
.clean-card strong span {
  font-family: inherit !important;
  font-weight: inherit !important;
}

/* Premium dashboard experience */
.dashboard-command {
  display: grid;
  grid-template-columns: minmax(0, 1.65fr) minmax(280px, .85fr);
  gap: 14px;
  align-items: stretch;
}

.dashboard-hero-premium {
  min-height: 230px;
  background:
    radial-gradient(circle at 10% 10%, rgba(52,201,156,.18), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,.96), rgba(241,251,246,.9)) !important;
}

html[data-theme="dark"] .dashboard-hero-premium {
  background:
    radial-gradient(circle at 12% 12%, rgba(52,201,156,.18), transparent 34%),
    linear-gradient(135deg, rgba(18,36,30,.96), rgba(12,22,18,.9)) !important;
}

.dashboard-status-stack {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: flex-end;
}

.dashboard-health-row {
  display: grid;
  grid-template-columns: auto auto minmax(160px, 260px);
  gap: 12px;
  align-items: center;
  margin-top: 22px;
  max-width: 520px;
}

.dashboard-health-row span,
.dashboard-progress-head span,
.dashboard-kpi span,
.smart-tip span {
  color: var(--text-secondary);
}

.dashboard-health-row strong {
  color: var(--brand);
  font-size: 28px;
  font-weight: 900 !important;
}

.dashboard-health-row i,
.dashboard-progress-track {
  display: block;
  height: 12px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(15,143,111,.12);
  border: 1px solid rgba(15,143,111,.16);
}

.dashboard-health-row b,
.dashboard-progress-track i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: linear-gradient(90deg, #10b981, #34d399);
}

.dashboard-smart-card {
  display: grid;
  align-content: start;
  gap: 12px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.96), rgba(255,255,255,.82)),
    radial-gradient(circle at 100% 0, rgba(16,185,129,.14), transparent 34%) !important;
}

html[data-theme="dark"] .dashboard-smart-card {
  background:
    linear-gradient(180deg, rgba(18,32,27,.96), rgba(14,24,21,.9)),
    radial-gradient(circle at 100% 0, rgba(52,201,156,.16), transparent 36%) !important;
}

.smart-tip-list {
  display: grid;
  gap: 10px;
}

.smart-tip {
  display: grid;
  gap: 4px;
  padding: 12px;
  border-radius: 16px;
  background: rgba(15,143,111,.08);
  border: 1px solid rgba(15,143,111,.12);
}

.smart-tip strong {
  color: var(--text);
  font-weight: 800 !important;
}

.smart-tip span {
  font-size: 13px;
  line-height: 1.8;
}

.dashboard-strip {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.dashboard-progress-card {
  display: grid;
  gap: 12px;
}

.dashboard-progress-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.dashboard-progress-head strong {
  color: var(--text);
  font-size: 22px;
  font-weight: 900 !important;
}

.dashboard-progress-track {
  height: 14px;
}

.dashboard-progress-track.green i {
  background: linear-gradient(90deg, #0ea5e9, #34d399);
}

.dashboard-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
}

.dashboard-kpi {
  position: relative;
  overflow: hidden;
  min-height: 128px;
  display: grid;
  align-content: center;
  gap: 7px;
}

.dashboard-kpi:before {
  content: "";
  position: absolute;
  inset-inline-start: 14px;
  top: 14px;
  width: 38px;
  height: 38px;
  border-radius: 14px;
  background: rgba(16,185,129,.12);
}

.dashboard-kpi strong {
  color: var(--text);
  font-size: clamp(30px, 3vw, 44px);
  line-height: 1;
  font-weight: 900 !important;
}

.dashboard-kpi small {
  color: var(--text-secondary);
  line-height: 1.7;
}

.dashboard-chart-premium .usage-chart {
  min-height: 230px;
}

.dashboard-summary-card,
.dashboard-actions-card {
  display: grid;
  gap: 12px;
}

.dashboard-training-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin: 12px 0;
}

.dashboard-top-options {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}

.dashboard-actions-card {
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
}

@media (max-width: 1100px) {
  .dashboard-command,
  .dashboard-strip,
  .dashboard-actions-card {
    grid-template-columns: 1fr;
  }

  .dashboard-status-stack {
    align-items: stretch;
  }

  .dashboard-kpi-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 700px) {
  .dashboard-health-row {
    grid-template-columns: 1fr;
    gap: 8px;
  }

  .dashboard-kpi-grid,
  .dashboard-training-grid {
    grid-template-columns: 1fr;
  }

  .dashboard-kpi {
    min-height: 96px;
  }
}
