:root {
  --bg:         #070d1c;
  --bg-card:    #0d1a2e;
  --bg-card2:   #111f38;
  --bg-hover:   #152342;
  --border:     #1a2d48;
  --border-hi:  #243d60;
  --accent:     #4f7ef7;
  --accent-dim: rgba(79,126,247,0.08);
  --accent-border: rgba(79,126,247,0.22);
  --text:       #d8eaf8;
  --text-muted: #526e8c;
  --text-dim:   #3a5470;
  --danger:     #f05252;
  --danger-dim: rgba(240,82,82,0.08);
  --success:    #22c55e;
  --success-dim:rgba(34,197,94,0.08);
  --warning:    #f59e0b;
  --warning-dim:rgba(245,158,11,0.08);
  --purple:     #a78bfa;
  --purple-dim: rgba(167,139,250,0.08);
  --font: 'Segoe UI', system-ui, -apple-system, sans-serif;
  --radius: 12px;
  --transition: 0.18s ease;
}

*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  min-height: 100vh;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
}

::-webkit-scrollbar { width: 5px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border-hi); border-radius: 99px; }

::selection { background: var(--accent); color: #fff; }

/* ─── STATUS BAR ────────────────────────────────────────────── */
.status-bar {
  display:flex; align-items:center; justify-content:space-between;
  padding:0.28rem 1.5rem;
  background:#050b17; border-bottom:1px solid var(--border);
  font-size:0.68rem; font-family:monospace; letter-spacing:0.04em;
  color:var(--text-muted); flex-wrap:wrap; gap:0.4rem;
  position:sticky; top:0; z-index:400;
}
.status-left  { display:flex; align-items:center; gap:0.5rem; }
.status-right { display:flex; gap:0.35rem; }
.status-dot   { width:6px; height:6px; border-radius:50%; flex-shrink:0; }
.status-dot.green { background:var(--success); box-shadow:0 0 5px var(--success); }
.status-label strong { color:var(--success); }
.src-badge {
  padding:0.1rem 0.4rem; border-radius:3px; font-size:0.62rem;
  background:var(--success-dim); color:var(--success);
  border:1px solid rgba(34,197,94,0.15);
}
.src-badge.inactive { background:var(--danger-dim); color:var(--danger); border-color:rgba(240,82,82,0.15); }

/* ─── SCREENS ───────────────────────────────────────────────── */
.screen { display:none; }
.screen.active { display:block; }

/* ─── REGISTRATION ──────────────────────────────────────────── */
.register-layout {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
}

.register-hero {
  background: linear-gradient(150deg, #0a1628 0%, #0e2246 60%, #091830 100%);
  border-right: 1px solid var(--border);
  padding: 3.5rem;
  display: flex; flex-direction: column; justify-content: center;
  position: relative; overflow: hidden;
}
.hero-grid-bg {
  position:absolute; inset:0;
  background-image: linear-gradient(var(--border) 1px, transparent 1px),
                    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size: 40px 40px;
  opacity: 0.25;
}
.hero-glow {
  position:absolute; top:-120px; right:-120px;
  width:500px; height:500px;
  background: radial-gradient(circle, rgba(79,126,247,0.1) 0%, transparent 65%);
  pointer-events:none;
}
.hero-content { position:relative; z-index:1; }

.hero-logo-wrap { position:relative; display:inline-block; margin-bottom:1.5rem; }
.hero-logo {
  width: 64px; height: 64px;
  background: linear-gradient(135deg, #4f7ef7, #7c9ff7);
  border-radius: 18px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; font-weight: 900; color: #fff;
  box-shadow: 0 8px 24px rgba(79,126,247,0.35);
}
.hero-logo-ring {
  position:absolute; inset:-6px;
  border:1px solid rgba(79,126,247,0.3);
  border-radius:24px;
  animation: ring-spin 8s linear infinite;
}
@keyframes ring-spin { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }

.hero-brand { font-size:2.6rem; font-weight:800; letter-spacing:-0.03em; margin-bottom:0.4rem; }
.hero-tagline { color:var(--text-muted); font-size:0.95rem; line-height:1.6; margin-bottom:2rem; }

.hero-features { list-style:none; display:flex; flex-direction:column; gap:0.65rem; margin-bottom:2.25rem; }
.hero-features li { display:flex; align-items:center; gap:0.7rem; font-size:0.88rem; color:var(--text); }
.feat-icon {
  width:24px; height:24px; background:var(--accent-dim);
  border:1px solid var(--accent-border);
  border-radius:6px;
  display:flex; align-items:center; justify-content:center;
  font-size:0.8rem; flex-shrink:0;
}
.hero-stat-row { display:flex; align-items:center; gap:1.5rem; margin-bottom:1.5rem; }
.hero-stat { text-align:center; }
.hs-val { font-size:1.6rem; font-weight:800; color:var(--accent); }
.hs-lab { font-size:0.68rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.06em; }
.hero-divider { width:1px; height:32px; background:var(--border); }
.hero-trust { font-size:0.74rem; color:var(--text-dim); }

/* Form side */
.register-form-wrap {
  display:flex; align-items:center; justify-content:center;
  padding:2rem; background:var(--bg);
}
.register-form-card { width:100%; max-width:420px; }
.form-logo-sm {
  width:36px; height:36px; background:var(--accent); border-radius:9px;
  display:flex; align-items:center; justify-content:center;
  font-weight:900; font-size:1rem; color:#fff; margin-bottom:1rem;
}
.register-form-card h2 { font-size:1.5rem; font-weight:700; margin-bottom:0.3rem; letter-spacing:-0.02em; }
.form-sub { color:var(--text-muted); font-size:0.83rem; margin-bottom:1.75rem; line-height:1.5; }

/* ─── FORMS ─────────────────────────────────────────────────── */
.form-group { margin-bottom:1rem; }
.form-group label {
  display:block; font-size:0.7rem; text-transform:uppercase;
  letter-spacing:0.07em; color:var(--text-muted); margin-bottom:0.4rem; font-weight:600;
}
.form-group input, .form-group select {
  width:100%; background:var(--bg-card);
  border:1px solid var(--border); color:var(--text);
  padding:0.7rem 0.9rem; border-radius:8px;
  font-size:0.9rem; font-family:var(--font); outline:none;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.form-group input::placeholder { color:var(--text-muted); }
.form-group input:focus, .form-group select:focus {
  border-color:var(--accent);
  box-shadow:0 0 0 3px rgba(79,126,247,0.12);
}
.form-group select { cursor:pointer; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:0.75rem; }

/* ─── BUTTONS ───────────────────────────────────────────────── */
.btn {
  width:100%; padding:0.85rem;
  border:none; border-radius:9px;
  font-size:0.83rem; font-weight:700; letter-spacing:0.07em;
  cursor:pointer; transition:all var(--transition); font-family:var(--font);
}
.btn-primary {
  background:linear-gradient(135deg, var(--accent), #6b95fa);
  color:#fff; box-shadow:0 4px 16px rgba(79,126,247,0.3);
}
.btn-primary:hover { transform:translateY(-1px); box-shadow:0 6px 24px rgba(79,126,247,0.4); }
.btn-primary:active { transform:none; box-shadow:0 2px 8px rgba(79,126,247,0.2); }
.btn-primary:disabled { opacity:0.55; cursor:not-allowed; transform:none; }
.btn-sm {
  padding:0.3rem 0.7rem; border:1px solid var(--border);
  background:transparent; color:var(--text-muted); border-radius:6px;
  cursor:pointer; font-size:0.76rem; transition:all var(--transition);
}
.btn-sm:hover { border-color:var(--accent); color:var(--text); }
.error-msg { color:var(--danger); font-size:0.82rem; margin-top:0.5rem; text-align:center; }

/* ─── NAVBAR ────────────────────────────────────────────────── */
.navbar {
  display:flex; align-items:center;
  background:rgba(13,26,46,0.96);
  backdrop-filter:blur(12px);
  border-bottom:1px solid var(--border);
  padding:0 1rem; height:50px;
  position:sticky; top:26px; z-index:300; gap:0.5rem;
}
.nav-brand { display:flex; align-items:center; gap:0.5rem; flex-shrink:0; }
.brand-name { font-weight:700; font-size:0.95rem; color:var(--text); }
.logo-sm {
  width:26px; height:26px;
  background:linear-gradient(135deg, var(--accent), #6b95fa);
  border-radius:7px;
  display:flex; align-items:center; justify-content:center;
  font-size:0.72rem; font-weight:900; color:#fff;
}
.nav-tabs { display:flex; gap:0.05rem; flex:1; justify-content:center; overflow:hidden; }
.nav-tab {
  background:transparent; border:none; color:var(--text-muted);
  padding:0.3rem 0.65rem; border-radius:7px;
  cursor:pointer; font-size:0.77rem; transition:all var(--transition);
  display:flex; align-items:center; gap:0.3rem; white-space:nowrap;
  position:relative;
}
.nav-tab:hover { color:var(--text); background:var(--accent-dim); }
.nav-tab.active { color:var(--accent); font-weight:600; background:var(--accent-dim); }
.nav-tab.active::after {
  content:''; position:absolute; bottom:-1px; left:10%; right:10%; height:2px;
  background:var(--accent); border-radius:99px;
}
.tab-icon { font-size:0.85rem; }
.tab-label { }
.tab-dot {
  width:5px; height:5px; background:var(--success); border-radius:50%;
  position:absolute; top:3px; right:3px;
  animation:blink 1.5s ease-in-out infinite;
}
.nav-user { display:flex; align-items:center; gap:0.5rem; flex-shrink:0; }
.nav-avatar {
  width:26px; height:26px; border-radius:50%;
  background:linear-gradient(135deg, var(--accent), #6b95fa);
  color:#fff; font-size:0.7rem; font-weight:700;
  display:flex; align-items:center; justify-content:center;
}
.nav-name { font-size:0.8rem; color:var(--text-muted); }
.live-badge {
  background:var(--danger); color:#fff;
  font-size:0.58rem; font-weight:800; padding:0.15rem 0.45rem;
  border-radius:4px; letter-spacing:0.08em;
  animation:blink 1.3s ease-in-out infinite;
}
@keyframes blink { 0%,100%{opacity:1}50%{opacity:0.35} }

/* ─── TABS ───────────────────────────────────────────────────── */
.tab-content { display:none; padding:1.4rem 1.5rem; max-width:1240px; margin:0 auto; }
.tab-content.active { display:block; animation:tab-in 0.22s ease; }
@keyframes tab-in { from{opacity:0;transform:translateY(5px)} to{opacity:1;transform:none} }

/* ─── CARDS ─────────────────────────────────────────────────── */
.card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.35rem;
  margin-bottom:1.2rem;
  transition:border-color var(--transition), box-shadow var(--transition);
}
.card:hover { border-color:var(--border-hi); }
.card-heading {
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:1rem;
}
.card-heading h3 { font-size:0.92rem; font-weight:700; }

/* ─── PAGE HEADER ───────────────────────────────────────────── */
.page-header {
  display:flex; align-items:flex-start; justify-content:space-between;
  margin-bottom:1.2rem;
}
.page-header h2 { font-size:1.3rem; font-weight:700; letter-spacing:-0.02em; margin-bottom:0.15rem; }
.page-sub { color:var(--text-muted); font-size:0.82rem; }
.page-header-right { flex-shrink:0; margin-top:0.25rem; }

/* ─── TOP BAR ───────────────────────────────────────────────── */
.top-bar { margin-bottom:1rem; }
.live-panel {
  display:flex; align-items:center; gap:1rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:0.8rem 1.2rem; flex-wrap:wrap;
}
.live-left { display:flex; align-items:center; gap:0.6rem; }
.live-label { font-size:0.65rem; font-weight:800; letter-spacing:0.12em; color:var(--text-muted); text-transform:uppercase; }
.live-hint { font-size:0.76rem; color:var(--text-muted); }
.toggle-switch { position:relative; display:inline-block; width:38px; height:20px; }
.toggle-switch input { opacity:0; width:0; height:0; }
.slider { position:absolute; inset:0; background:var(--border-hi); border-radius:99px; cursor:pointer; transition:0.3s; }
.slider:before { content:""; position:absolute; height:14px; width:14px; left:3px; top:3px; background:#fff; border-radius:50%; transition:0.3s; }
input:checked+.slider { background:var(--accent); }
input:checked+.slider:before { transform:translateX(18px); }
.live-decision-display { display:flex; align-items:center; gap:0.85rem; flex:1; }
.live-rec { font-size:0.82rem; font-weight:700; padding:0.35rem 0.85rem; border-radius:6px; white-space:nowrap; }
.rec-success { background:var(--success-dim); color:var(--success); border:1px solid rgba(34,197,94,0.2); }
.rec-warning { background:var(--warning-dim); color:var(--warning); border:1px solid rgba(245,158,11,0.2); }
.rec-danger  { background:var(--danger-dim);  color:var(--danger);  border:1px solid rgba(240,82,82,0.2); }
.live-details { display:flex; flex-direction:column; gap:0.12rem; }
.live-earning { font-size:0.83rem; font-weight:600; }
.live-reason  { font-size:0.73rem; color:var(--text-muted); }
.btn-geo {
  background:var(--bg-card2); border:1px solid var(--border);
  color:var(--text-muted); padding:0.38rem 0.8rem;
  border-radius:7px; cursor:pointer; font-size:0.78rem;
  transition:all var(--transition); white-space:nowrap; margin-left:auto;
}
.btn-geo:hover { border-color:var(--accent); color:var(--text); }

/* ─── WEATHER BANNER ────────────────────────────────────────── */
.weather-banner {
  display:flex; align-items:center; gap:1rem;
  padding:0.55rem 1.2rem;
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:9px;
  margin-bottom:1rem; flex-wrap:wrap;
}
.w-item { display:flex; align-items:center; gap:0.35rem; font-size:0.8rem; color:var(--text-muted); }
.w-icon { font-size:0.85rem; }
.w-sep { width:1px; height:14px; background:var(--border); }
.w-city { font-weight:600; color:var(--text); }
.w-source-badge { margin-left:auto; font-size:0.62rem; font-weight:700; letter-spacing:0.06em; color:var(--accent); background:var(--accent-dim); border:1px solid var(--accent-border); padding:0.1rem 0.4rem; border-radius:4px; }

/* ─── RISK CHIP ─────────────────────────────────────────────── */
.risk-chip { font-size:0.72rem; font-weight:700; padding:0.25rem 0.65rem; border-radius:5px; letter-spacing:0.04em; }
.rc-low  { background:var(--success-dim); color:var(--success); border:1px solid rgba(34,197,94,0.2); }
.rc-med  { background:var(--warning-dim); color:var(--warning); border:1px solid rgba(245,158,11,0.2); }
.rc-high { background:var(--danger-dim);  color:var(--danger);  border:1px solid rgba(240,82,82,0.2); }

/* ─── STAT GRID ─────────────────────────────────────────────── */
.stat-grid {
  display:grid; grid-template-columns:repeat(4,1fr);
  gap:0.85rem; margin-bottom:1.2rem;
}
.stat-card {
  background:var(--bg-card);
  border:1px solid var(--border);
  border-radius:var(--radius);
  padding:1.1rem 1.2rem;
  position:relative; overflow:hidden;
  transition:all var(--transition);
}
.stat-card:hover { transform:translateY(-2px); border-color:var(--border-hi); box-shadow:0 8px 24px rgba(0,0,0,0.2); }
.stat-card::before {
  content:''; position:absolute; top:0; left:0;
  width:3px; height:100%; border-radius:3px 0 0 3px;
}
.sc-blue::before   { background:var(--accent); }
.sc-orange::before { background:var(--warning); }
.sc-green::before  { background:var(--success); }
.sc-purple::before { background:var(--purple); }

.sc-icon { font-size:1.3rem; margin-bottom:0.4rem; opacity:0.8; }
.stat-label { font-size:0.67rem; text-transform:uppercase; letter-spacing:0.08em; color:var(--text-muted); margin-bottom:0.4rem; font-weight:600; }
.stat-value { font-size:1.5rem; font-weight:800; letter-spacing:-0.02em; margin-bottom:0.25rem; }
.sc-blue   .stat-value { color:var(--accent); }
.sc-orange .stat-value { color:var(--warning); }
.sc-green  .stat-value { color:var(--success); }
.sc-purple .stat-value { color:var(--purple); }
.stat-trend { font-size:0.7rem; color:var(--text-muted); }
.risk-bar-wrap { height:4px; background:var(--bg-card2); border-radius:99px; margin-top:0.5rem; overflow:hidden; }
.risk-bar { height:100%; border-radius:99px; transition:width 0.5s, background 0.5s; }

/* ─── TWO COL ───────────────────────────────────────────────── */
.two-col { display:grid; grid-template-columns:1fr 1fr; gap:1.2rem; }

/* ─── ALERTS ────────────────────────────────────────────────── */
.auto-payout-alert {
  display:flex; align-items:center; gap:0.6rem; padding:0.7rem 1rem;
  background:var(--success-dim); border:1px solid rgba(34,197,94,0.18);
  border-radius:8px; font-size:0.83rem; color:var(--success); margin-bottom:1rem;
  animation:slide-in 0.25s ease;
}
.auto-switch-alert {
  border:1px solid var(--accent-border); background:var(--accent-dim);
  border-radius:8px; padding:0.85rem 1rem; margin-bottom:1rem; animation:slide-in 0.25s ease;
}
.auto-switch-header {
  display:flex; align-items:center; justify-content:space-between;
  font-size:0.68rem; font-weight:800; letter-spacing:0.09em; color:var(--accent);
  text-transform:uppercase; margin-bottom:0.55rem;
}
.switch-tag {
  background:var(--danger-dim); color:var(--danger);
  border:1px solid rgba(240,82,82,0.18); padding:0.1rem 0.4rem; border-radius:3px; font-size:0.62rem;
}
.switch-suggestion { display:flex; align-items:center; gap:0.7rem; padding:0.5rem 0.7rem; background:var(--bg-card); border-radius:7px; border:1px solid var(--border); }
.switch-gain { margin-left:auto; font-weight:700; color:var(--success); font-size:0.85rem; }
.switch-title { font-weight:600; font-size:0.83rem; }
.switch-reason { font-size:0.73rem; color:var(--text-muted); }
.switch-info { display:flex; flex-direction:column; gap:0.12rem; }
.pulse-dot { width:8px; height:8px; background:var(--success); border-radius:50%; flex-shrink:0; animation:blink 1s infinite; }
@keyframes slide-in { from{transform:translateY(-6px);opacity:0} to{transform:none;opacity:1} }

/* ─── TRIGGERS ──────────────────────────────────────────────── */
.trigger-item { display:flex; align-items:flex-start; gap:0.6rem; padding:0.6rem 0; border-bottom:1px solid var(--border); }
.trigger-item:last-child { border-bottom:none; }
.trigger-badge { padding:0.12rem 0.45rem; border-radius:4px; font-size:0.62rem; font-weight:700; text-transform:uppercase; flex-shrink:0; letter-spacing:0.04em; }
.badge-high,.badge-critical { background:var(--danger-dim); color:var(--danger); border:1px solid rgba(240,82,82,0.18); }
.badge-medium { background:var(--warning-dim); color:var(--warning); border:1px solid rgba(245,158,11,0.18); }
.badge-low { background:var(--success-dim); color:var(--success); border:1px solid rgba(34,197,94,0.18); }
.trigger-text { font-size:0.82rem; line-height:1.4; }
.trigger-cities { font-size:0.72rem; color:var(--text-muted); margin-top:0.18rem; }
.trigger-payout { font-size:0.72rem; color:var(--success); margin-top:0.18rem; }
.refresh-dot { display:inline-block; width:6px; height:6px; border-radius:50%; }
.dot-alert { background:var(--danger); animation:blink 1s infinite; }
.dot-ok    { background:var(--success); }

/* ─── DAILY PLAN ────────────────────────────────────────────── */
.plan-row { display:flex; gap:0.5rem; align-items:flex-start; padding:0.42rem 0; border-bottom:1px solid var(--border); font-size:0.82rem; }
.plan-row:last-child { border-bottom:none; }
.plan-label { color:var(--text-muted); font-size:0.67rem; min-width:72px; flex-shrink:0; text-transform:uppercase; letter-spacing:0.05em; font-weight:600; padding-top:0.1rem; }

/* ─── SKELETON ──────────────────────────────────────────────── */
.skeleton-rows { display:flex; flex-direction:column; gap:0.6rem; }
.skeleton-row { height:14px; background:linear-gradient(90deg, var(--bg-card2) 0%, var(--bg-hover) 50%, var(--bg-card2) 100%); background-size:200%; border-radius:4px; animation:shimmer 1.4s infinite; }
.skeleton-row.short { width:65%; }
@keyframes shimmer { from{background-position:200% 0} to{background-position:-200% 0} }

/* ─── SHIFT TRACKER ─────────────────────────────────────────── */
.tracker-date-chip {
  font-size:0.78rem; color:var(--text-muted);
  background:var(--bg-card); border:1px solid var(--border);
  padding:0.3rem 0.7rem; border-radius:6px; white-space:nowrap;
}
.tracker-hero {
  display:flex; align-items:center; gap:2.5rem;
  padding:1.75rem 2rem; flex-wrap:wrap;
  background:linear-gradient(140deg, var(--bg-card) 0%, #0f213d 100%);
  border-color:var(--accent-border);
}
.timer-section { flex:1; min-width:220px; }
.timer-label { font-size:0.65rem; font-weight:800; letter-spacing:0.14em; text-transform:uppercase; color:var(--text-muted); margin-bottom:0.5rem; }
.timer-display {
  font-size:3rem; font-weight:900; letter-spacing:0.04em;
  font-family:monospace; color:var(--text); margin-bottom:1rem;
  transition:color 0.3s;
}
.timer-display.running { color:var(--success); }
.timer-actions { display:flex; gap:0.65rem; margin-bottom:0.75rem; }
.btn-shift-start {
  background:linear-gradient(135deg, var(--success), #16a34a);
  color:#fff; border:none; padding:0.65rem 1.2rem;
  border-radius:8px; cursor:pointer; font-size:0.82rem; font-weight:700;
  font-family:var(--font); transition:all var(--transition);
  box-shadow:0 4px 12px rgba(34,197,94,0.3);
}
.btn-shift-start:hover { transform:translateY(-1px); box-shadow:0 6px 18px rgba(34,197,94,0.4); }
.btn-shift-end {
  background:linear-gradient(135deg, var(--danger), #c0392b);
  color:#fff; border:none; padding:0.65rem 1.2rem;
  border-radius:8px; cursor:pointer; font-size:0.82rem; font-weight:700;
  font-family:var(--font); transition:all var(--transition);
  box-shadow:0 4px 12px rgba(240,82,82,0.3);
}
.btn-shift-end:hover { transform:translateY(-1px); }
.shift-status { font-size:0.76rem; color:var(--text-muted); line-height:1.5; }

.tracker-divider { width:1px; height:140px; background:var(--border); flex-shrink:0; }

.target-section { display:flex; align-items:center; gap:1.75rem; flex-wrap:wrap; }
.target-ring-wrap { position:relative; width:120px; height:120px; flex-shrink:0; }
.target-ring { width:100%; height:100%; transform:rotate(-90deg); }
.ring-track { fill:none; stroke:var(--bg-card2); stroke-width:8; }
.ring-fill { fill:none; stroke:var(--accent); stroke-width:8; stroke-linecap:round; transition:stroke-dashoffset 0.6s ease, stroke 0.4s; }
.ring-inner {
  position:absolute; inset:0; display:flex; flex-direction:column;
  align-items:center; justify-content:center;
}
.ring-pct { font-size:1.3rem; font-weight:800; }
.ring-label { font-size:0.62rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; }
.target-info { display:flex; flex-direction:column; gap:0.55rem; }
.target-row { display:flex; flex-direction:column; }
.target-key { font-size:0.67rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-muted); font-weight:600; }
.target-val { font-size:0.95rem; font-weight:700; margin-top:0.05rem; }
.earned-val { color:var(--success); }

/* Log Earnings */
.log-form { display:flex; flex-direction:column; gap:0; }
.log-time-row { display:flex; gap:0.75rem; }
.log-success { color:var(--success); font-size:0.83rem; padding:0.5rem; border-radius:6px; background:var(--success-dim); border:1px solid rgba(34,197,94,0.18); margin-top:0.75rem; }

/* AI Tips */
.ai-tip-card {
  display:flex; gap:0.75rem; align-items:flex-start;
  padding:0.9rem; background:var(--bg-card2);
  border:1px solid var(--border); border-radius:8px;
}
.ai-tip-icon { font-size:1.4rem; flex-shrink:0; }
.ai-tip-text { font-size:0.83rem; line-height:1.55; color:var(--text-muted); }
.ai-tip-conditions { margin-top:0.8rem; display:flex; flex-direction:column; gap:0.35rem; }
.cond-row { display:flex; justify-content:space-between; font-size:0.8rem; padding:0.35rem 0; border-bottom:1px solid var(--border); }
.cond-row:last-child { border-bottom:none; }
.cond-key { color:var(--text-muted); }

/* Hourly Log */
.log-empty { display:flex; flex-direction:column; align-items:center; gap:0.5rem; padding:1.5rem; color:var(--text-muted); font-size:0.83rem; }
.log-empty-icon { font-size:2rem; opacity:0.5; }
.log-total-chip { background:var(--accent-dim); color:var(--accent); border:1px solid var(--accent-border); border-radius:5px; padding:0.15rem 0.55rem; font-size:0.72rem; font-weight:700; }
.log-table { width:100%; border-collapse:collapse; }
.log-table th { font-size:0.65rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--text-muted); font-weight:600; padding:0 0 0.6rem; text-align:left; border-bottom:1px solid var(--border); }
.log-table td { font-size:0.83rem; padding:0.55rem 0; border-bottom:1px solid var(--border); vertical-align:middle; }
.log-table tr:last-child td { border-bottom:none; }
.log-amount-cell { font-weight:700; color:var(--success); }
.log-del-btn { background:none; border:none; color:var(--text-muted); cursor:pointer; padding:0.1rem 0.3rem; border-radius:4px; transition:color 0.15s; }
.log-del-btn:hover { color:var(--danger); }

/* EOD Summary */
.eod-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.85rem; margin-bottom:1rem; }
.eod-box { background:var(--bg-card2); border:1px solid var(--border); border-radius:8px; padding:0.9rem; text-align:center; }
.eod-val { font-size:1.25rem; font-weight:800; margin-bottom:0.15rem; }
.eod-key { font-size:0.68rem; text-transform:uppercase; letter-spacing:0.05em; color:var(--text-muted); }
.eod-ai-tip { padding:0.9rem; background:var(--accent-dim); border:1px solid var(--accent-border); border-radius:8px; font-size:0.83rem; line-height:1.55; color:var(--text); }

/* ─── INCOME SHIELD ─────────────────────────────────────────── */
.shield-hero-card {
  display:flex; align-items:center; gap:2rem; padding:1.75rem;
  flex-wrap:wrap;
  background:linear-gradient(140deg, var(--bg-card) 0%, #0e2240 100%);
  border-color:var(--accent-border);
}
.shield-left { display:flex; flex-direction:column; align-items:center; gap:0.75rem; }
.shield-visual { position:relative; width:88px; height:88px; display:flex; align-items:center; justify-content:center; }
.shield-ring { position:absolute; border-radius:50%; border:1.5px solid rgba(79,126,247,0.3); animation:shield-pulse 2.5s ease-in-out infinite; }
.shield-ring.outer { width:88px; height:88px; }
.shield-ring.inner { width:64px; height:64px; animation-delay:0.6s; }
@keyframes shield-pulse { 0%,100%{transform:scale(1);opacity:0.25} 50%{transform:scale(1.06);opacity:0.65} }
.shield-icon-wrap { z-index:1; }
.shield-emoji { font-size:2.2rem; }
.shield-status-wrap { display:flex; align-items:center; gap:0.38rem; }
.shield-status-dot { width:6px; height:6px; background:var(--success); border-radius:50%; animation:blink 2s infinite; box-shadow:0 0 6px var(--success); }
.shield-status-label { font-size:0.62rem; font-weight:800; letter-spacing:0.12em; color:var(--success); text-transform:uppercase; }
.shield-center { flex:1; }
.shield-tier { font-size:0.68rem; font-weight:700; letter-spacing:0.12em; text-transform:uppercase; color:var(--accent); margin-bottom:0.25rem; }
.shield-coverage-label { font-size:0.72rem; color:var(--text-muted); margin-bottom:0.2rem; }
.shield-coverage-val { font-size:2.4rem; font-weight:800; letter-spacing:-0.03em; margin-bottom:0.9rem; }
.shield-meta-row { display:flex; gap:1.5rem; flex-wrap:wrap; }
.shield-meta { display:flex; flex-direction:column; gap:0.12rem; }
.sm-label { font-size:0.65rem; text-transform:uppercase; letter-spacing:0.05em; color:var(--text-muted); }
.sm-val { font-size:0.85rem; font-weight:600; }
.shield-right { display:flex; flex-direction:column; align-items:center; gap:0.85rem; }
.sos-btn {
  display:flex; flex-direction:column; align-items:center; gap:0.18rem;
  background:linear-gradient(135deg, var(--danger), #c0392b);
  color:#fff; border:none; border-radius:10px;
  padding:0.9rem 1.4rem; cursor:pointer;
  transition:all var(--transition); font-family:var(--font); min-width:130px;
  box-shadow:0 4px 14px rgba(240,82,82,0.3);
}
.sos-btn:hover { transform:translateY(-2px); box-shadow:0 8px 24px rgba(240,82,82,0.4); }
.sos-icon { font-size:1.4rem; }
.sos-btn span:nth-child(2) { font-size:0.73rem; font-weight:800; letter-spacing:0.07em; }
.sos-sub { font-size:0.62rem; opacity:0.8; }
.shield-days-wrap { text-align:center; }
.shield-days-val { font-size:1.9rem; font-weight:800; color:var(--accent); }
.shield-days-label { font-size:0.67rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.05em; }
.cov-row { display:flex; align-items:center; gap:1rem; padding:0.8rem 0; border-bottom:1px solid var(--border); }
.cov-row:last-child { border-bottom:none; }
.cov-info { flex:1; }
.cov-label { font-size:0.84rem; font-weight:600; margin-bottom:0.12rem; }
.cov-sub { font-size:0.71rem; color:var(--text-muted); }
.cov-right { display:flex; flex-direction:column; align-items:flex-end; gap:0.3rem; min-width:95px; }
.cov-val { font-size:0.88rem; font-weight:700; }
.cov-bar-wrap { width:75px; height:4px; background:var(--bg-card2); border-radius:99px; overflow:hidden; }
.cov-bar { height:100%; border-radius:99px; }
.blue-bar   { background:var(--accent); }
.orange-bar { background:var(--warning); }
.purple-bar { background:var(--purple); }
.red-bar    { background:var(--danger); }
.prot-item { display:flex; align-items:flex-start; gap:0.8rem; padding:0.7rem 0; border-bottom:1px solid var(--border); }
.prot-item:last-child { border-bottom:none; }
.prot-icon { font-size:1.2rem; flex-shrink:0; }
.prot-title { font-size:0.84rem; font-weight:600; margin-bottom:0.12rem; }
.prot-desc { font-size:0.76rem; color:var(--text-muted); line-height:1.4; }
.event-item { display:flex; align-items:flex-start; gap:0.7rem; padding:0.7rem 0; border-bottom:1px solid var(--border); }
.event-item:last-child { border-bottom:none; }
.event-icon { font-size:1.1rem; flex-shrink:0; }
.event-title { font-size:0.83rem; font-weight:600; margin-bottom:0.1rem; }
.event-detail { font-size:0.73rem; color:var(--text-muted); }
.event-amount { margin-left:auto; font-size:0.88rem; font-weight:700; color:var(--success); white-space:nowrap; }
.badge-count { font-size:0.7rem; background:var(--accent-dim); color:var(--accent); border:1px solid var(--accent-border); border-radius:4px; padding:0.1rem 0.4rem; }

/* ─── SCENARIO LAB ──────────────────────────────────────────── */
.lab-layout { display:grid; grid-template-columns:290px 1fr; gap:1.2rem; align-items:start; }
.lab-controls { margin-bottom:0; }
.slider-group { margin-bottom:1.35rem; }
.slider-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:0.45rem; }
.slider-header label { font-size:0.82rem; font-weight:600; }
.slider-val { font-size:0.73rem; font-weight:700; color:var(--accent); font-family:monospace; }
.range-input {
  width:100%; -webkit-appearance:none;
  height:4px; border-radius:99px;
  background:var(--bg-card2); outline:none; cursor:pointer;
}
.range-input::-webkit-slider-thumb {
  -webkit-appearance:none; width:16px; height:16px;
  border-radius:50%; background:var(--accent); cursor:pointer; border:2px solid var(--bg-card);
  box-shadow:0 0 6px rgba(79,126,247,0.4);
}
.slider-marks { display:flex; justify-content:space-between; font-size:0.6rem; color:var(--text-muted); margin-top:0.28rem; }
.risk-meter { background:var(--bg-card2); border:1px solid var(--border); border-radius:8px; padding:0.75rem; margin-top:0.25rem; }
.risk-meter-label { font-size:0.65rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--text-muted); margin-bottom:0.38rem; }
.risk-meter-bar-wrap { height:6px; background:var(--bg); border-radius:99px; overflow:hidden; margin-bottom:0.28rem; }
.risk-meter-fill { height:100%; border-radius:99px; transition:width 0.4s, background 0.4s; }
.risk-meter-val { font-size:0.8rem; font-weight:700; font-family:monospace; }
.lab-results { display:flex; flex-direction:column; }
.lab-rec-card { padding:1.1rem 1.3rem; }
.lab-rec-level { font-size:0.68rem; font-weight:800; letter-spacing:0.14em; text-transform:uppercase; margin-bottom:0.3rem; }
.lab-rec-text { font-size:0.85rem; line-height:1.5; }
.rec-safe .lab-rec-level     { color:var(--success); }
.rec-moderate .lab-rec-level { color:var(--warning); }
.rec-warning .lab-rec-level  { color:#ff9a00; }
.rec-critical .lab-rec-level { color:var(--danger); }
.lab-switch-card { margin-bottom:1.2rem; padding:0.85rem 1.1rem; border-color:var(--accent-border); background:var(--accent-dim); }
.lab-switch-header { font-size:0.65rem; font-weight:800; letter-spacing:0.12em; color:var(--accent); text-transform:uppercase; margin-bottom:0.6rem; }
.lab-switch-body { display:flex; flex-direction:column; gap:0.4rem; }
.lab-switch-row { display:flex; align-items:center; justify-content:space-between; padding:0.5rem 0.65rem; background:var(--bg-card2); border-radius:6px; border:1px solid var(--border); font-size:0.82rem; }
.lab-switch-gain { font-weight:700; color:var(--success); }
.chart-legend { display:flex; align-items:center; gap:0.3rem; font-size:0.72rem; color:var(--text-muted); margin-bottom:0.6rem; }
.legend-dot { width:7px; height:7px; border-radius:50%; display:inline-block; }
.proj-chart { display:flex; align-items:flex-end; gap:3px; height:100px; }
.proj-col { flex:1; display:flex; flex-direction:column-reverse; align-items:center; }
.proj-bar { width:100%; border-radius:3px 3px 0 0; min-height:2px; }
.proj-bar.base-bar { background:var(--accent); opacity:0.6; }
.proj-bar.prot-bar { background:var(--success); opacity:0.3; position:relative; top:-2px; }
.proj-chart-labels { display:flex; gap:3px; margin-top:4px; }
.proj-label { flex:1; text-align:center; font-size:0.56rem; color:var(--text-muted); }
.proj-label.current { color:var(--accent); font-weight:700; }
.compare-grid { display:grid; grid-template-columns:1fr auto 1fr; gap:0.9rem; align-items:center; margin-bottom:1rem; }
.compare-box { border-radius:9px; padding:1rem; border:1px solid var(--border); }
.danger-box  { background:var(--danger-dim);  border-color:rgba(240,82,82,0.18); }
.success-box { background:var(--success-dim); border-color:rgba(34,197,94,0.18); }
.compare-label { font-size:0.67rem; text-transform:uppercase; letter-spacing:0.06em; color:var(--text-muted); margin-bottom:0.35rem; }
.compare-val { font-size:1.6rem; font-weight:800; margin-bottom:0.18rem; }
.danger-box  .compare-val { color:var(--danger); }
.success-box .compare-val { color:var(--success); }
.compare-sub { font-size:0.71rem; color:var(--text-muted); }
.compare-arrow { font-size:1.2rem; color:var(--text-muted); text-align:center; font-weight:700; }
.compare-list { margin-top:0.6rem; list-style:none; display:flex; flex-direction:column; gap:0.3rem; }
.compare-list li { font-size:0.76rem; }
.compare-detail { border-top:1px solid var(--border); padding-top:0.8rem; display:flex; flex-direction:column; gap:0.38rem; }
.compare-row { display:flex; justify-content:space-between; font-size:0.82rem; }
.compare-row span:first-child { color:var(--text-muted); }
.red   { color:var(--danger); font-weight:600; }
.green { color:var(--success); font-weight:600; }

/* ─── MAP ────────────────────────────────────────────────────── */
.city-selector-wrap { display:flex; align-items:center; }
.city-selector-dropdown {
  background:var(--bg-card); color:var(--text); border:1px solid var(--border);
  border-radius:8px; padding:0.5rem 1rem; font-size:0.85rem; font-family:var(--font);
  cursor:pointer; min-width:180px; outline:none;
  transition:border-color .2s;
}
.city-selector-dropdown:hover, .city-selector-dropdown:focus { border-color:var(--accent); }
.city-selector-dropdown option { background:var(--bg-card2); }
.map-layout { display:grid; grid-template-columns:1fr 300px; gap:1.2rem; }
.india-map { height:500px; border-radius:var(--radius); border:1px solid var(--border); overflow:hidden; }
.leaflet-container { background:#09152a !important; }
.city-detail { margin-bottom:0; }
.detail-row { display:flex; justify-content:space-between; padding:0.42rem 0; border-bottom:1px solid var(--border); font-size:0.82rem; }
.detail-row:last-child { border-bottom:none; }
.detail-key { color:var(--text-muted); }
.detail-val { font-weight:600; }
.map-refresh-bar { text-align:right; font-size:0.68rem; color:var(--text-muted); margin-top:0.35rem; font-family:monospace; }
.leaflet-popup-content-wrapper { background:var(--bg-card) !important; border:1px solid var(--border) !important; border-radius:8px !important; color:var(--text) !important; box-shadow:0 8px 24px rgba(0,0,0,0.5) !important; }
.leaflet-popup-tip { background:var(--bg-card) !important; }
.leaflet-popup-content { margin:0 !important; }
.map-popup { padding:0.8rem; min-width:200px; font-family:var(--font); }
.map-popup-city { font-weight:700; font-size:0.95rem; margin-bottom:0.35rem; }
.map-popup-row { display:flex; justify-content:space-between; font-size:0.76rem; padding:0.16rem 0; color:#7a9ab8; }
.map-popup-rec { margin-top:0.5rem; padding:0.4rem; background:var(--accent-dim); border-radius:5px; font-size:0.72rem; color:#8aacf5; line-height:1.4; }

/* ─── CLAIMS PIPELINE ───────────────────────────────────────── */
.claim-pipeline-card { margin-bottom:1.2rem; }
.pipeline { display:flex; align-items:center; gap:0.35rem; flex-wrap:wrap; }
.pipeline-step { display:flex; align-items:center; gap:0.35rem; flex:1; min-width:65px; }
.pipeline-step.last { flex:0; }
.pipe-icon { width:38px; height:38px; border-radius:9px; background:var(--bg-card2); border:1px solid var(--border); display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; transition:all 0.3s; }
.pipe-label { font-size:0.65rem; color:var(--text-muted); line-height:1.3; }
.pipe-arrow { color:var(--text-muted); font-size:0.9rem; flex-shrink:0; }
.pipeline-step.active .pipe-icon { background:var(--accent-dim); border-color:var(--accent); }
.pipeline-step.done   .pipe-icon { background:var(--success-dim); border-color:rgba(34,197,94,0.3); }
.trust-score-box { margin-top:1rem; padding:0.85rem; background:var(--bg-card2); border:1px solid var(--border); border-radius:8px; }
.trust-score-header { font-size:0.65rem; text-transform:uppercase; letter-spacing:0.07em; color:var(--text-muted); margin-bottom:0.38rem; }
.trust-score-val { font-size:1.35rem; font-weight:700; color:var(--success); margin-bottom:0.3rem; }
.trust-score-bar-wrap { height:5px; background:var(--bg); border-radius:99px; overflow:hidden; margin-bottom:0.38rem; }
.trust-score-bar { height:100%; background:var(--success); border-radius:99px; transition:width 0.5s; }
.trust-reason { font-size:0.75rem; color:var(--text-muted); }
.claim-item { padding:0.65rem 0; border-bottom:1px solid var(--border); font-size:0.82rem; }
.claim-item:last-child { border-bottom:none; }
.claim-header { display:flex; justify-content:space-between; margin-bottom:0.18rem; }
.claim-id { font-weight:700; color:var(--accent); }
.claim-status { padding:0.1rem 0.4rem; border-radius:3px; font-size:0.62rem; font-weight:700; letter-spacing:0.04em; }
.status-auto     { background:var(--success-dim); color:var(--success); border:1px solid rgba(34,197,94,0.18); }
.status-approved { background:var(--warning-dim); color:var(--warning); border:1px solid rgba(245,158,11,0.18); }
.status-flagged  { background:var(--danger-dim);  color:var(--danger);  border:1px solid rgba(240,82,82,0.18); }
.claim-meta { color:var(--text-muted); font-size:0.72rem; }
.claim-explain { font-size:0.73rem; color:var(--accent); margin:0.18rem 0; }
.claim-result-ok   { color:var(--success); margin-top:0.65rem; font-size:0.82rem; }
.claim-result-warn { color:var(--warning); margin-top:0.65rem; font-size:0.82rem; }

/* ─── INSIGHTS ──────────────────────────────────────────────── */
.bar-chart { display:flex; align-items:flex-end; gap:0.45rem; height:140px; padding-top:0.75rem; }
.bar-chart .bar-col { flex:1; display:flex; flex-direction:column; align-items:center; gap:0.18rem; }
.bar-chart .bar-col .bar-fill { width:100%; background:var(--accent); border-radius:3px 3px 0 0; min-height:3px; transition:height 0.4s; }
.bar-chart .bar-col .bar-day { font-size:0.66rem; color:var(--text-muted); }
.bar-chart .bar-col .bar-amt { font-size:0.63rem; color:var(--text-muted); }
.inline-select { background:var(--bg-card2); color:var(--text-muted); border:1px solid var(--border); border-radius:6px; padding:3px 7px; font-size:0.76rem; outline:none; cursor:pointer; }
.explain-confidence { font-size:0.76rem; color:var(--text-muted); margin-bottom:0.65rem; padding-bottom:0.65rem; border-bottom:1px solid var(--border); }
.explain-factor { display:flex; align-items:center; gap:0.65rem; padding:0.55rem 0; border-bottom:1px solid var(--border); font-size:0.82rem; }
.explain-factor:last-child { border-bottom:none; }
.factor-bar-wrap { flex:1; height:4px; background:var(--bg-card2); border-radius:99px; overflow:hidden; }
.factor-bar { height:100%; background:var(--accent); border-radius:99px; }
.factor-name { min-width:160px; }
.factor-val { color:var(--text-muted); font-size:0.73rem; min-width:60px; text-align:right; }
.explain-summary { margin-top:0.8rem; font-size:0.78rem; color:var(--text-muted); line-height:1.6; }
.insights-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.8rem; }
.insight-card { background:var(--bg-card2); border:1px solid var(--border); border-radius:8px; padding:0.85rem; transition:border-color var(--transition); }
.insight-card:hover { border-color:var(--border-hi); }
.insight-icon { font-size:1.3rem; margin-bottom:0.35rem; }
.insight-title { font-size:0.7rem; font-weight:700; margin-bottom:0.18rem; color:var(--text-muted); text-transform:uppercase; letter-spacing:0.04em; }
.insight-value { font-size:1rem; font-weight:700; color:var(--accent); margin-bottom:0.18rem; }
.insight-desc { font-size:0.71rem; color:var(--text-muted); line-height:1.4; }
.rec-item { display:flex; align-items:flex-start; gap:0.65rem; padding:0.75rem 0; border-bottom:1px solid var(--border); }
.rec-item:last-child { border-bottom:none; }
.rec-num { width:21px; height:21px; border-radius:50%; background:var(--accent-dim); color:var(--accent); display:flex; align-items:center; justify-content:center; font-size:0.67rem; font-weight:700; flex-shrink:0; }
.rec-text { font-size:0.82rem; line-height:1.5; }
.rec-impact { font-size:0.72rem; color:var(--success); font-weight:600; margin-top:0.12rem; }
.metrics-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:0.8rem; }
.metric-box { background:var(--bg-card2); border-radius:8px; border:1px solid var(--border); padding:0.85rem; text-align:center; }
.metric-box-val { font-size:1.25rem; font-weight:700; color:var(--accent); }
.metric-box-label { font-size:0.66rem; color:var(--text-muted); margin-top:0.18rem; text-transform:uppercase; letter-spacing:0.04em; }

/* ─── MISC ──────────────────────────────────────────────────── */
.loading { color:var(--text-muted); font-size:0.82rem; padding:0.8rem 0; }

/* ─── RESPONSIVE ────────────────────────────────────────────── */
@media (max-width:1024px) {
  .lab-layout  { grid-template-columns:1fr; }
  .map-layout  { grid-template-columns:1fr; }
  .india-map   { height:380px; }
  .shield-hero-card { flex-direction:column; }
  .tracker-hero { flex-direction:column; }
  .tracker-divider { display:none; }
}
@media (max-width:768px) {
  .register-layout { grid-template-columns:1fr; }
  .register-hero { padding:2rem; }
  .hero-brand { font-size:1.9rem; }
  .stat-grid { grid-template-columns:1fr 1fr; }
  .two-col   { grid-template-columns:1fr; }
  .nav-tabs  { gap:0; overflow-x:auto; }
  .nav-tab   { padding:0.28rem 0.45rem; font-size:0.7rem; }
  .tab-label { display:none; }
  .metrics-grid  { grid-template-columns:1fr 1fr; }
  .insights-grid { grid-template-columns:1fr 1fr; }
  .compare-grid  { grid-template-columns:1fr; }
  .compare-arrow { text-align:center; }
  .pipeline { flex-direction:column; align-items:flex-start; }
  .eod-grid  { grid-template-columns:1fr 1fr; }
}
