/* ============================================================
   CosmosPanel Members — Modern Light Design System 2025
   ============================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,300..900;1,14..32,300..900&display=swap');

/* ── DESIGN TOKENS ── */
:root {
  /* Backgrounds */
  --white:      #ffffff;
  --bg-soft:    #f7f9ff;
  --bg-subtle:  #f0f4ff;
  --bg-muted:   #e8eef8;

  /* Brand */
  --blue:       #2563eb;
  --blue-lt:    #3b82f6;
  --blue-dk:    #1d4ed8;
  --blue-50:    #eff6ff;
  --violet:     #7c3aed;
  --violet-lt:  #8b5cf6;
  --violet-50:  #f5f3ff;
  --cyan:       #0891b2;
  --green:      #16a34a;
  --green-lt:   #22c55e;
  --green-50:   #f0fdf4;
  --amber:      #d97706;
  --amber-50:   #fffbeb;
  --red:        #dc2626;
  --red-50:     #fef2f2;
  --pink:       #db2777;
  --pink-50:    #fdf2f8;

  /* Text */
  --t1:  #0f172a;
  --t2:  #1e293b;
  --t3:  #475569;
  --t4:  #94a3b8;
  --t5:  #cbd5e1;

  /* Borders */
  --border:       #e2e8f0;
  --border-focus: #93c5fd;
  --border-dk:    #cbd5e1;

  /* Gradients */
  --grad:         linear-gradient(135deg, #2563eb 0%, #7c3aed 100%);
  --grad-hero:    linear-gradient(135deg, #f0f7ff 0%, #f5f0ff 50%, #fff0f9 100%);
  --grad-green:   linear-gradient(135deg, #16a34a 0%, #2563eb 100%);
  --grad-amber:   linear-gradient(135deg, #d97706 0%, #dc2626 100%);
  --grad-text:    linear-gradient(135deg, #2563eb 0%, #7c3aed 60%, #db2777 100%);

  /* Shadows */
  --shadow-xs:  0 1px 2px rgba(15,23,42,.05);
  --shadow-sm:  0 2px 8px rgba(15,23,42,.06), 0 1px 2px rgba(15,23,42,.04);
  --shadow-md:  0 4px 20px rgba(15,23,42,.08), 0 2px 6px rgba(15,23,42,.04);
  --shadow-lg:  0 12px 40px rgba(15,23,42,.10), 0 4px 12px rgba(15,23,42,.06);
  --shadow-xl:  0 24px 64px rgba(15,23,42,.12), 0 8px 20px rgba(15,23,42,.07);
  --shadow-blue: 0 8px 32px rgba(37,99,235,.25);
  --shadow-violet: 0 8px 32px rgba(124,58,237,.2);

  /* Radius */
  --r-sm:  8px;
  --r-md:  12px;
  --r-lg:  16px;
  --r-xl:  24px;
  --r-2xl: 32px;
  --r-full: 9999px;
}

/* ── RESET ── */
*,*::before,*::after { box-sizing:border-box; margin:0; padding:0; }
html { scroll-behavior:smooth; -webkit-text-size-adjust:100%; }
body {
  background:var(--white);
  color:var(--t1);
  font-family:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  line-height:1.6;
  overflow-x:hidden;
}
a { text-decoration:none; color:inherit; }
img { display:block; max-width:100%; }
button { cursor:pointer; border:none; outline:none; font-family:inherit; }
input,textarea,select { font-family:inherit; outline:none; }
ul,ol { list-style:none; }

::-webkit-scrollbar { width:6px; height:6px; }
::-webkit-scrollbar-track { background:var(--bg-soft); }
::-webkit-scrollbar-thumb { background:var(--border-dk); border-radius:var(--r-full); }
::-webkit-scrollbar-thumb:hover { background:var(--t4); }

/* ── ANIMATIONS ── */
@keyframes float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-12px)} }
@keyframes floatSlow { 0%,100%{transform:translateY(0) rotate(-2deg)} 50%{transform:translateY(-8px) rotate(2deg)} }
@keyframes pulse { 0%,100%{opacity:1;transform:scale(1)} 50%{opacity:.6;transform:scale(.85)} }
@keyframes blobDrift {
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(40px,-30px) scale(1.08)}
  66%{transform:translate(-20px,30px) scale(.95)}
  100%{transform:translate(0,0) scale(1)}
}
@keyframes blobDrift2 {
  0%{transform:translate(0,0) scale(1)}
  33%{transform:translate(-50px,20px) scale(1.05)}
  66%{transform:translate(30px,-40px) scale(.92)}
  100%{transform:translate(0,0) scale(1)}
}
@keyframes shimmer {
  0%{background-position:200% center}
  100%{background-position:-200% center}
}
@keyframes slideUp {
  from{opacity:0;transform:translateY(28px)}
  to{opacity:1;transform:translateY(0)}
}
@keyframes fadeIn {
  from{opacity:0} to{opacity:1}
}
@keyframes scaleIn {
  from{opacity:0;transform:scale(.92)}
  to{opacity:1;transform:scale(1)}
}
@keyframes badgePop {
  0%{opacity:0;transform:scale(.7) translateY(10px)}
  70%{transform:scale(1.08) translateY(-2px)}
  100%{opacity:1;transform:scale(1) translateY(0)}
}
@keyframes counterTick {
  from{transform:translateY(-100%);opacity:0}
  to{transform:translateY(0);opacity:1}
}
@keyframes gradientMove {
  0%{background-position:0% 50%}
  50%{background-position:100% 50%}
  100%{background-position:0% 50%}
}
@keyframes spin { to{transform:rotate(360deg)} }
@keyframes confettiFall {
  0%{transform:translateY(-10px) rotateZ(0deg);opacity:1}
  100%{transform:translateY(100vh) rotateZ(720deg);opacity:0}
}
@keyframes notifSlide {
  0%{opacity:0;transform:translateX(20px)}
  15%{opacity:1;transform:translateX(0)}
  85%{opacity:1;transform:translateX(0)}
  100%{opacity:0;transform:translateX(20px)}
}
@keyframes ripple {
  0%{transform:scale(0);opacity:.6}
  100%{transform:scale(4);opacity:0}
}

/* ── REVEAL ON SCROLL ── */
.reveal { opacity:0; transform:translateY(32px); transition:opacity .6s cubic-bezier(.22,1,.36,1), transform .6s cubic-bezier(.22,1,.36,1); }
.reveal.visible { opacity:1; transform:translateY(0); }
.reveal-delay-1 { transition-delay:.1s; }
.reveal-delay-2 { transition-delay:.2s; }
.reveal-delay-3 { transition-delay:.3s; }
.reveal-delay-4 { transition-delay:.4s; }
.reveal-delay-5 { transition-delay:.5s; }
.reveal-scale { opacity:0; transform:scale(.94); transition:opacity .5s ease, transform .5s cubic-bezier(.22,1,.36,1); }
.reveal-scale.visible { opacity:1; transform:scale(1); }

/* ────────────────────────────────────────────────
   NAVIGATION
   ──────────────────────────────────────────────── */
.app-nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  height:68px;
  display:flex; align-items:center; justify-content:space-between;
  padding:0 48px;
  background:rgba(255,255,255,.85);
  backdrop-filter:blur(16px) saturate(180%);
  -webkit-backdrop-filter:blur(16px) saturate(180%);
  border-bottom:1px solid rgba(226,232,240,.8);
  transition:background .3s, box-shadow .3s;
}
.app-nav.scrolled { background:rgba(255,255,255,.95); box-shadow:var(--shadow-sm); }
.nav-logo { display:flex; align-items:center; gap:0; font-size:18px; font-weight:800; letter-spacing:-.8px; }
.nav-logo .cosmos {
  background:var(--grad-text);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  background-size:200% auto; animation:shimmer 4s linear infinite;
}
.nav-logo .panel { color:var(--t1); }
.nav-logo .badge {
  margin-left:8px; font-size:9px; font-weight:700; letter-spacing:.8px;
  background:var(--grad); color:#fff; padding:3px 8px; border-radius:var(--r-full);
  text-transform:uppercase; -webkit-text-fill-color:#fff;
}
.nav-links { display:flex; gap:4px; align-items:center; }
.nav-links a {
  font-size:14px; font-weight:500; color:var(--t3);
  padding:6px 14px; border-radius:var(--r-full);
  transition:all .2s;
}
.nav-links a:hover { color:var(--blue); background:var(--blue-50); }
.nav-auth { display:flex; gap:10px; align-items:center; }
.btn-ghost {
  padding:8px 18px; background:transparent; border:1.5px solid var(--border);
  border-radius:var(--r-full); font-size:13px; font-weight:600; color:var(--t2);
  transition:all .2s;
}
.btn-ghost:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-50); }
.btn-primary {
  padding:9px 22px; background:var(--grad); border-radius:var(--r-full);
  font-size:13px; font-weight:700; color:#fff;
  box-shadow:var(--shadow-blue);
  transition:all .25s; position:relative; overflow:hidden;
  border:none;
}
.btn-primary::after {
  content:''; position:absolute; inset:0; background:rgba(255,255,255,.15);
  opacity:0; transition:opacity .2s;
}
.btn-primary:hover { transform:translateY(-2px); box-shadow:0 12px 36px rgba(37,99,235,.35); }
.btn-primary:hover::after { opacity:1; }
.btn-primary:active { transform:translateY(0); }
.nav-hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:6px; }
.nav-hamburger span { display:block; width:22px; height:2.5px; background:var(--t3); border-radius:2px; transition:all .25s; }
.nav-mobile { display:none; }

@media(max-width:960px) {
  .app-nav { padding:0 20px; }
  .nav-links,.nav-auth { display:none; }
  .nav-hamburger { display:flex; }
  .nav-mobile.open {
    display:flex; flex-direction:column;
    position:fixed; top:68px; left:0; right:0;
    background:rgba(255,255,255,.98); backdrop-filter:blur(20px);
    border-bottom:1px solid var(--border); z-index:199;
    padding:10px 0 18px; box-shadow:var(--shadow-lg);
  }
  .nav-mobile a { padding:12px 24px; font-size:15px; color:var(--t2); border-bottom:1px solid var(--border); }
  .nav-mobile .btn-primary { margin:12px 20px; text-align:center; display:block; padding:13px; border-radius:var(--r-lg); }
}

/* ────────────────────────────────────────────────
   HERO
   ──────────────────────────────────────────────── */
.hero {
  min-height:100vh;
  padding:100px 48px 80px;
  background:var(--white);
  display:flex; align-items:center;
  position:relative; overflow:hidden;
}

/* Gradient blob bg */
.hero-blobs { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.blob {
  position:absolute; border-radius:50%; filter:blur(72px); opacity:.55;
}
.blob-1 {
  width:600px; height:600px; top:-80px; right:-100px;
  background:radial-gradient(circle, rgba(37,99,235,.18) 0%, rgba(124,58,237,.12) 60%, transparent 80%);
  animation:blobDrift 18s ease-in-out infinite;
}
.blob-2 {
  width:500px; height:500px; bottom:-100px; left:-80px;
  background:radial-gradient(circle, rgba(219,39,119,.12) 0%, rgba(124,58,237,.10) 60%, transparent 80%);
  animation:blobDrift2 22s ease-in-out infinite;
}
.blob-3 {
  width:350px; height:350px; top:40%; left:35%;
  background:radial-gradient(circle, rgba(8,145,178,.10) 0%, transparent 70%);
  animation:blobDrift 28s ease-in-out infinite reverse;
}
/* Dot grid */
.hero-dots {
  position:absolute; inset:0; pointer-events:none;
  background-image:radial-gradient(rgba(15,23,42,.05) 1.5px, transparent 1.5px);
  background-size:28px 28px;
}

.hero-inner {
  max-width:1160px; margin:0 auto; width:100%;
  display:grid; grid-template-columns:1fr 1fr; gap:72px; align-items:center;
  position:relative; z-index:1;
}

.hero-tag {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg, var(--blue-50), var(--violet-50));
  border:1px solid rgba(37,99,235,.15);
  border-radius:var(--r-full); padding:7px 16px;
  font-size:12px; font-weight:700; color:var(--blue); letter-spacing:.4px;
  margin-bottom:22px; -webkit-text-fill-color:var(--blue);
  animation:slideUp .6s ease both;
}
.hero-tag .live-dot {
  width:7px; height:7px; background:var(--green); border-radius:50%;
  box-shadow:0 0 0 0 rgba(22,163,74,.4);
  animation:livePulse 2s infinite;
}
@keyframes livePulse {
  0%{box-shadow:0 0 0 0 rgba(22,163,74,.5)}
  70%{box-shadow:0 0 0 8px rgba(22,163,74,0)}
  100%{box-shadow:0 0 0 0 rgba(22,163,74,0)}
}
.hero-title {
  font-size:clamp(36px,5.5vw,62px);
  font-weight:900; line-height:1.05;
  letter-spacing:-2.5px; color:var(--t1);
  margin-bottom:22px;
  animation:slideUp .7s .05s ease both;
}
.hero-title .grad {
  background:var(--grad-text);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
  background-size:200% auto; animation:shimmer 4s linear infinite;
  display:inline;
}
.hero-sub {
  font-size:17px; color:var(--t3); line-height:1.75; max-width:500px;
  margin-bottom:34px;
  animation:slideUp .7s .1s ease both;
}

/* Stats row */
.hero-stats {
  display:flex; gap:0; margin-bottom:36px; border:1px solid var(--border);
  border-radius:var(--r-xl); background:var(--bg-soft); overflow:hidden;
  animation:slideUp .7s .15s ease both;
}
.hstat {
  flex:1; padding:16px 20px; text-align:center;
  border-right:1px solid var(--border);
}
.hstat:last-child { border-right:none; }
.hstat-val {
  font-size:22px; font-weight:800; color:var(--t1); letter-spacing:-.8px;
  line-height:1;
}
.hstat-val.blue { color:var(--blue); }
.hstat-val.green { color:var(--green); }
.hstat-val.violet { color:var(--violet); }
.hstat-lbl { font-size:11px; color:var(--t4); margin-top:4px; font-weight:500; }

/* CTA group */
.hero-cta { display:flex; gap:12px; align-items:center; flex-wrap:wrap; animation:slideUp .7s .2s ease both; }
.btn-google {
  display:flex; align-items:center; gap:10px; padding:13px 22px;
  background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-full);
  font-size:14px; font-weight:700; color:var(--t1);
  box-shadow:var(--shadow-md); transition:all .25s; cursor:pointer;
}
.btn-google:hover { border-color:var(--blue); box-shadow:var(--shadow-lg); transform:translateY(-2px); }
.btn-google svg { width:20px; height:20px; flex-shrink:0; }
.btn-outline-cta {
  padding:13px 22px; background:transparent; border:1.5px solid var(--border);
  border-radius:var(--r-full); font-size:14px; font-weight:600; color:var(--t2);
  transition:all .2s; cursor:pointer;
}
.btn-outline-cta:hover { border-color:var(--violet); color:var(--violet); background:var(--violet-50); }
.hero-trust {
  margin-top:16px; font-size:12px; color:var(--t4);
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;
  animation:slideUp .7s .25s ease both;
}
.hero-trust-item { display:flex; align-items:center; gap:4px; }
.hero-trust-item .ck { color:var(--green); font-size:13px; font-weight:700; }

/* ── Hero visual ── */
.hero-visual {
  position:relative;
  animation:fadeIn .8s .3s ease both;
}
.hero-card-wrap {
  position:relative;
  transform-style:preserve-3d;
  animation:float 6s ease-in-out infinite;
}
.hero-card-wrap:hover { animation-play-state:paused; }
.dash-card {
  background:var(--white);
  border:1px solid var(--border);
  border-radius:var(--r-2xl);
  padding:0;
  box-shadow:var(--shadow-xl), 0 0 0 1px rgba(37,99,235,.06);
  overflow:hidden;
}
.dc-topbar {
  background:var(--bg-soft);
  padding:12px 18px;
  display:flex; align-items:center; justify-content:space-between;
  border-bottom:1px solid var(--border);
}
.dc-dots { display:flex; gap:6px; }
.dc-dots span { width:10px; height:10px; border-radius:50%; }
.dc-dots span:nth-child(1){background:#ff6058}
.dc-dots span:nth-child(2){background:#ffbd2e}
.dc-dots span:nth-child(3){background:#28ca40}
.dc-url { font-size:11px; color:var(--t4); font-weight:500; }
.dc-body { padding:18px; }
.dc-balance {
  background:var(--grad);
  border-radius:var(--r-xl); padding:18px 20px; margin-bottom:14px;
  position:relative; overflow:hidden;
}
.dc-balance::before {
  content:''; position:absolute;
  width:120px; height:120px; border-radius:50%;
  background:rgba(255,255,255,.12); top:-30px; right:-20px; pointer-events:none;
}
.dc-balance::after {
  content:''; position:absolute;
  width:80px; height:80px; border-radius:50%;
  background:rgba(255,255,255,.08); bottom:-20px; right:40px; pointer-events:none;
}
.dc-balance-lbl { font-size:11px; color:rgba(255,255,255,.75); margin-bottom:4px; }
.dc-balance-amt { font-size:32px; font-weight:800; color:#fff; letter-spacing:-1.5px; }
.dc-balance-sub { font-size:11px; color:rgba(255,255,255,.7); margin-top:4px; }
.dc-surveys { display:flex; flex-direction:column; gap:8px; }
.dc-survey {
  background:var(--bg-soft); border:1px solid var(--border);
  border-radius:var(--r-md); padding:11px 14px;
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  transition:all .2s;
}
.dc-survey:hover { background:var(--blue-50); border-color:var(--border-focus); }
.dc-s-info .t { font-size:13px; font-weight:600; color:var(--t1); }
.dc-s-info .m { font-size:11px; color:var(--t4); margin-top:2px; }
.dc-s-reward { font-size:14px; font-weight:800; color:var(--green); white-space:nowrap; }

/* Floating badges */
.hero-badge {
  position:absolute;
  background:var(--white); border:1px solid var(--border);
  border-radius:var(--r-lg); padding:10px 14px;
  box-shadow:var(--shadow-lg);
  display:flex; align-items:center; gap:10px;
  white-space:nowrap;
}
.hero-badge-1 { top:-18px; right:-20px; animation:badgePop .6s .8s both, floatSlow 5s 1.4s ease-in-out infinite; }
.hero-badge-2 { bottom:20px; left:-28px; animation:badgePop .6s 1s both, floatSlow 6s 1.6s ease-in-out infinite reverse; }
.hb-icon { width:32px; height:32px; border-radius:var(--r-sm); display:flex; align-items:center; justify-content:center; font-size:16px; flex-shrink:0; }
.hb-val { font-size:13px; font-weight:700; color:var(--t1); }
.hb-lbl { font-size:10px; color:var(--t4); margin-top:1px; }

@media(max-width:960px) {
  .hero { padding:100px 24px 60px; }
  .hero-inner { grid-template-columns:1fr; gap:48px; }
  .hero-visual { display:none; }
}

/* ────────────────────────────────────────────────
   MARQUEE / PARTNER STRIP
   ──────────────────────────────────────────────── */
.marquee-strip {
  overflow:hidden; background:var(--bg-soft);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:18px 0;
}
.marquee-track {
  display:flex; gap:48px; width:max-content;
  animation:marqueeScroll 28s linear infinite;
}
.marquee-track:hover { animation-play-state:paused; }
@keyframes marqueeScroll { from{transform:translateX(0)} to{transform:translateX(-50%)} }
.marquee-item {
  display:flex; align-items:center; gap:8px;
  font-size:13px; font-weight:600; color:var(--t4);
  white-space:nowrap;
}
.marquee-item .ico { font-size:18px; }

/* ────────────────────────────────────────────────
   SECTIONS SHARED
   ──────────────────────────────────────────────── */
.section { padding:96px 48px; }
.section-alt { background:var(--bg-soft); }
.container { max-width:1160px; margin:0 auto; }
.section-label {
  display:inline-flex; align-items:center; gap:6px;
  font-size:11px; font-weight:700; letter-spacing:1.2px; text-transform:uppercase;
  color:var(--blue); background:var(--blue-50); border:1px solid rgba(37,99,235,.15);
  padding:5px 13px; border-radius:var(--r-full); margin-bottom:14px;
}
.section-title {
  font-size:clamp(28px,4.2vw,46px); font-weight:800; letter-spacing:-1.5px;
  color:var(--t1); line-height:1.1; margin-bottom:14px;
}
.section-title .grad {
  background:var(--grad-text); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  background-size:200% auto; animation:shimmer 5s linear infinite;
}
.section-sub { font-size:16px; color:var(--t3); max-width:580px; line-height:1.75; }
.text-center { text-align:center; }
.text-center .section-sub { margin:0 auto; }
@media(max-width:768px) { .section { padding:64px 24px; } }

/* ────────────────────────────────────────────────
   BENTO GRID — Why CosmosPanel
   ──────────────────────────────────────────────── */
.bento-grid {
  display:grid;
  grid-template-columns:repeat(12, 1fr);
  grid-template-rows:auto;
  gap:16px; margin-top:56px;
}
.bento { border-radius:var(--r-2xl); padding:28px; position:relative; overflow:hidden; }
.bento:hover { transform:translateY(-4px); }
.bento { transition:transform .3s cubic-bezier(.22,1,.36,1), box-shadow .3s; }
.bento:hover { box-shadow:var(--shadow-xl); }

.bento-1 { grid-column:span 5; background:var(--blue-50); border:1px solid rgba(37,99,235,.12); }
.bento-2 { grid-column:span 4; background:var(--violet-50); border:1px solid rgba(124,58,237,.12); }
.bento-3 { grid-column:span 3; background:var(--green-50); border:1px solid rgba(22,163,74,.12); }
.bento-4 { grid-column:span 3; background:var(--amber-50); border:1px solid rgba(217,119,6,.12); }
.bento-5 { grid-column:span 5; background:linear-gradient(135deg,#f0f7ff 0%,#f5f0ff 100%); border:1px solid rgba(37,99,235,.1); }
.bento-6 { grid-column:span 4; background:var(--white); border:1px solid var(--border); }

@media(max-width:960px) {
  .bento-grid { grid-template-columns:repeat(2,1fr); }
  .bento-1,.bento-2,.bento-3,.bento-4,.bento-5,.bento-6 { grid-column:span 1; }
}
@media(max-width:600px) {
  .bento-grid { grid-template-columns:1fr; }
  .bento-1,.bento-2,.bento-3,.bento-4,.bento-5,.bento-6 { grid-column:span 1; }
}

.bento-icon { font-size:32px; margin-bottom:16px; display:block; }
.bento-title { font-size:16px; font-weight:800; color:var(--t1); margin-bottom:8px; }
.bento-desc { font-size:13px; color:var(--t3); line-height:1.65; }
.bento-num {
  font-size:40px; font-weight:900; letter-spacing:-2px;
  color:var(--blue); line-height:1;
}
.bento-num.violet { color:var(--violet); }
.bento-num.green { color:var(--green); }
.bento-num.amber { color:var(--amber); }
.bento-tag {
  display:inline-block; font-size:10px; font-weight:700;
  letter-spacing:.8px; text-transform:uppercase;
  padding:4px 10px; border-radius:var(--r-full);
  margin-bottom:12px;
}
.bento-tag-blue { background:rgba(37,99,235,.12); color:var(--blue); }
.bento-tag-violet { background:rgba(124,58,237,.12); color:var(--violet); }
.bento-tag-green { background:rgba(22,163,74,.12); color:var(--green); }
.bento-tag-amber { background:rgba(217,119,6,.12); color:var(--amber); }

/* ────────────────────────────────────────────────
   HOW IT WORKS
   ──────────────────────────────────────────────── */
.steps-row {
  display:grid; grid-template-columns:repeat(3,1fr); gap:0; margin-top:60px;
  position:relative;
}
.steps-row::before {
  content:''; position:absolute; top:36px; left:calc(16.67% + 24px); right:calc(16.67% + 24px);
  height:2px;
  background:linear-gradient(90deg, var(--blue) 0%, var(--violet) 50%, var(--green) 100%);
  z-index:0;
}
@media(max-width:768px) { .steps-row { grid-template-columns:1fr; } .steps-row::before { display:none; } }
.step-item { text-align:center; padding:0 24px; position:relative; }
.step-circle {
  width:72px; height:72px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin:0 auto 22px; font-size:26px;
  border:3px solid var(--white);
  position:relative; z-index:1;
  box-shadow:0 0 0 4px rgba(37,99,235,.1), var(--shadow-md);
  transition:transform .3s;
}
.step-item:hover .step-circle { transform:scale(1.1); }
.sc-1 { background:linear-gradient(135deg, var(--blue-50), var(--violet-50)); }
.sc-2 { background:linear-gradient(135deg, var(--violet-50), var(--pink-50)); }
.sc-3 { background:linear-gradient(135deg, var(--green-50), var(--blue-50)); }
.step-num-label { font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--t4); margin-bottom:10px; }
.step-item h3 { font-size:18px; font-weight:800; color:var(--t1); margin-bottom:10px; }
.step-item p { font-size:14px; color:var(--t3); line-height:1.7; }

/* ────────────────────────────────────────────────
   REWARDS GRID
   ──────────────────────────────────────────────── */
.rewards-flex {
  display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-top:52px;
}
@media(max-width:900px) { .rewards-flex { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px) { .rewards-flex { grid-template-columns:1fr; } }
.rwd-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); padding:22px 18px;
  display:flex; flex-direction:column; align-items:center; text-align:center; gap:10px;
  transition:all .25s; cursor:default;
}
.rwd-card:hover {
  border-color:var(--blue); transform:translateY(-6px);
  box-shadow:var(--shadow-lg), 0 0 0 4px rgba(37,99,235,.06);
}
.rwd-icon {
  width:56px; height:56px; border-radius:var(--r-lg);
  display:flex; align-items:center; justify-content:center; font-size:26px;
  background:var(--bg-soft); transition:transform .3s;
}
.rwd-card:hover .rwd-icon { transform:scale(1.12) rotate(-4deg); }
.rwd-name { font-size:14px; font-weight:700; color:var(--t1); }
.rwd-desc { font-size:12px; color:var(--t4); }
.rwd-range {
  font-size:11px; font-weight:700; padding:4px 11px; border-radius:var(--r-full);
  background:var(--green-50); color:var(--green);
}

/* ────────────────────────────────────────────────
   STATS BAND — Counter
   ──────────────────────────────────────────────── */
.stats-band {
  background:var(--white);
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  padding:56px 48px;
}
.stats-inner {
  max-width:1160px; margin:0 auto;
  display:grid; grid-template-columns:repeat(4,1fr); gap:24px; text-align:center;
}
@media(max-width:768px) { .stats-inner { grid-template-columns:repeat(2,1fr); } }
.stat-item { padding:24px 16px; }
.stat-num {
  font-size:48px; font-weight:900; letter-spacing:-2.5px; line-height:1;
  background:var(--grad-text); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
}
.stat-desc { font-size:13px; color:var(--t4); margin-top:6px; font-weight:500; }
.stat-sub { font-size:11px; color:var(--t5); margin-top:2px; }

/* ────────────────────────────────────────────────
   TESTIMONIALS
   ──────────────────────────────────────────────── */
.testi-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:20px; margin-top:52px;
}
@media(max-width:768px) { .testi-grid { grid-template-columns:1fr; } }
.testi-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); padding:26px;
  transition:all .3s;
  position:relative;
}
.testi-card:hover { border-color:var(--violet); transform:translateY(-4px); box-shadow:var(--shadow-lg); }
.testi-card::before {
  content:'"'; position:absolute; top:14px; right:22px;
  font-size:60px; line-height:1; color:var(--bg-muted);
  font-family:Georgia, serif; font-weight:900;
}
.testi-stars { color:var(--amber); font-size:15px; letter-spacing:2px; margin-bottom:12px; }
.testi-text { font-size:14px; color:var(--t2); line-height:1.75; margin-bottom:18px; }
.testi-author { display:flex; align-items:center; gap:12px; }
.tav {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:16px; color:#fff; flex-shrink:0;
  overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.12);
  border:2px solid var(--white);
}
.tav img {
  width:100%; height:100%;
  object-fit:cover; object-position:center top;
  border-radius:50%; display:block;
}
.tav-1 { background:linear-gradient(135deg,var(--blue),var(--violet)); }
.tav-2 { background:linear-gradient(135deg,var(--violet),var(--pink)); }
.tav-3 { background:linear-gradient(135deg,var(--green),var(--cyan)); }
.tav-4 { background:linear-gradient(135deg,var(--amber),var(--red)); }
.tav-5 { background:linear-gradient(135deg,var(--cyan),var(--blue)); }
.tav-6 { background:linear-gradient(135deg,var(--pink),var(--violet)); }
.ta-name { font-size:14px; font-weight:700; color:var(--t1); }
.ta-loc { font-size:12px; color:var(--t4); margin-top:1px; }
.ta-earn {
  margin-left:auto; font-size:13px; font-weight:700; color:var(--green);
  background:var(--green-50); padding:4px 10px; border-radius:var(--r-full);
  white-space:nowrap;
}

/* ────────────────────────────────────────────────
   FAQ
   ──────────────────────────────────────────────── */
.faq-list { max-width:740px; margin:52px auto 0; display:flex; flex-direction:column; gap:10px; }
.faq-item {
  background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-xl);
  overflow:hidden; transition:border-color .2s;
}
.faq-item:hover { border-color:var(--blue); }
.faq-item.open { border-color:var(--blue); box-shadow:0 0 0 4px rgba(37,99,235,.06); }
.faq-q {
  padding:20px 24px; display:flex; align-items:center; justify-content:space-between;
  cursor:pointer; font-size:15px; font-weight:600; color:var(--t1); user-select:none;
  transition:background .2s;
}
.faq-q:hover { background:var(--bg-soft); }
.faq-icon {
  width:24px; height:24px; border-radius:var(--r-sm); flex-shrink:0; margin-left:16px;
  background:var(--bg-muted); display:flex; align-items:center; justify-content:center;
  font-size:14px; color:var(--t3); font-weight:700; transition:all .3s;
}
.faq-item.open .faq-icon { background:var(--blue); color:#fff; transform:rotate(45deg); }
.faq-a {
  max-height:0; overflow:hidden; padding:0 24px;
  font-size:14px; color:var(--t3); line-height:1.75;
  transition:max-height .35s ease, padding .3s ease;
}
.faq-item.open .faq-a { max-height:300px; padding:0 24px 20px; }

/* ────────────────────────────────────────────────
   CTA BAND
   ──────────────────────────────────────────────── */
.cta-band {
  background:var(--grad);
  padding:90px 48px; text-align:center;
  position:relative; overflow:hidden;
}
.cta-band-orb {
  position:absolute; border-radius:50%; filter:blur(60px); pointer-events:none;
  width:400px; height:400px;
  background:rgba(255,255,255,.1); top:-80px; left:50%; transform:translateX(-50%);
}
.cta-band-orb-2 {
  width:300px; height:300px;
  background:rgba(255,255,255,.08); bottom:-80px; right:10%;
  position:absolute; border-radius:50%; filter:blur(60px);
}
.cta-band h2 { font-size:clamp(28px,4.5vw,48px); font-weight:800; color:#fff; letter-spacing:-1.5px; margin-bottom:14px; position:relative; }
.cta-band p { font-size:17px; color:rgba(255,255,255,.8); max-width:480px; margin:0 auto 36px; position:relative; }
.cta-band-btns { display:flex; gap:14px; justify-content:center; flex-wrap:wrap; position:relative; }
.btn-white {
  display:flex; align-items:center; justify-content:center; gap:10px;
  padding:14px 28px; background:#fff; border-radius:var(--r-full);
  font-size:15px; font-weight:700; color:var(--blue);
  box-shadow:0 8px 32px rgba(0,0,0,.15); transition:all .25s;
  border:none; cursor:pointer;
}
.btn-white:hover { transform:translateY(-3px); box-shadow:0 16px 48px rgba(0,0,0,.2); }
.btn-outline-white {
  padding:14px 28px; background:transparent;
  border:2px solid rgba(255,255,255,.5);
  border-radius:var(--r-full); font-size:15px; font-weight:600; color:#fff;
  transition:all .2s; cursor:pointer;
}
.btn-outline-white:hover { background:rgba(255,255,255,.1); border-color:#fff; }

/* ────────────────────────────────────────────────
   FOOTER
   ──────────────────────────────────────────────── */
.app-footer {
  background:var(--t1); color:rgba(255,255,255,.7);
  padding:64px 48px 36px;
}
.footer-top {
  max-width:1160px; margin:0 auto;
  display:grid; grid-template-columns:2.5fr 1fr 1fr 1fr; gap:48px;
  padding-bottom:48px; border-bottom:1px solid rgba(255,255,255,.08);
}
@media(max-width:960px) { .app-footer{padding:44px 24px 28px} .footer-top{grid-template-columns:1fr 1fr;gap:28px} .footer-brand{grid-column:1/-1} }
@media(max-width:480px) { .footer-top{grid-template-columns:1fr} }
.footer-logo { font-size:18px; font-weight:800; letter-spacing:-.8px; margin-bottom:12px; }
.footer-logo .cosmos {
  background:var(--grad-text); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
}
.footer-logo .panel { color:#fff; }
.footer-brand > p { font-size:13px; line-height:1.75; max-width:260px; margin-top:8px; }
.footer-social { display:flex; gap:8px; margin-top:18px; }
.footer-social a {
  width:34px; height:34px; border-radius:var(--r-sm);
  border:1px solid rgba(255,255,255,.1); background:rgba(255,255,255,.06);
  display:flex; align-items:center; justify-content:center;
  color:rgba(255,255,255,.5); font-size:14px; transition:all .2s;
}
.footer-social a:hover { background:rgba(255,255,255,.12); color:#fff; }
.footer-col h5 { font-size:11px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:#fff; margin-bottom:14px; }
.footer-col ul { display:flex; flex-direction:column; gap:9px; }
.footer-col ul li a { font-size:13px; color:rgba(255,255,255,.5); transition:color .2s; }
.footer-col ul li a:hover { color:#fff; }
.footer-bottom {
  max-width:1160px; margin:24px auto 0;
  display:flex; align-items:center; justify-content:space-between; flex-wrap:wrap; gap:10px;
}
.footer-bottom p { font-size:12px; color:rgba(255,255,255,.3); }
.footer-badges { display:flex; gap:8px; }
.footer-badge { font-size:10px; color:rgba(255,255,255,.35); border:1px solid rgba(255,255,255,.1); border-radius:var(--r-sm); padding:3px 9px; }

/* ────────────────────────────────────────────────
   AUTH PAGE
   ──────────────────────────────────────────────── */
.auth-page {
  min-height:100vh; background:var(--bg-soft);
  display:flex; align-items:center; justify-content:center;
  padding:90px 24px; position:relative; overflow:hidden;
}
.auth-bg-blob-1 { position:absolute; width:500px; height:500px; border-radius:50%; filter:blur(80px); top:-150px; right:-100px; background:radial-gradient(circle,rgba(37,99,235,.12) 0%,transparent 70%); }
.auth-bg-blob-2 { position:absolute; width:400px; height:400px; border-radius:50%; filter:blur(80px); bottom:-120px; left:-80px; background:radial-gradient(circle,rgba(124,58,237,.10) 0%,transparent 70%); }
.auth-card {
  width:100%; max-width:480px;
  background:var(--white);
  border:1.5px solid var(--border);
  border-radius:var(--r-2xl); padding:40px;
  box-shadow:var(--shadow-xl); position:relative; z-index:1;
  animation:scaleIn .4s ease both;
}
.auth-logo { text-align:center; margin-bottom:28px; }
.auth-logo-text { font-size:22px; font-weight:800; letter-spacing:-.8px; }
.auth-logo-text .cosmos {
  background:var(--grad-text); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  background-size:200% auto; animation:shimmer 4s linear infinite;
}
.auth-logo p { font-size:13px; color:var(--t3); margin-top:5px; }
.auth-tabs {
  display:flex; background:var(--bg-soft); border-radius:var(--r-lg);
  padding:4px; margin-bottom:28px; border:1px solid var(--border);
}
.auth-tab {
  flex:1; padding:10px; text-align:center;
  font-size:14px; font-weight:600; color:var(--t3);
  border-radius:var(--r-md); cursor:pointer; transition:all .25s;
  background:transparent; border:none;
}
.auth-tab.active {
  background:var(--white); color:var(--t1);
  box-shadow:var(--shadow-md);
}
.btn-google-full {
  width:100%; display:flex; align-items:center; justify-content:center; gap:10px;
  padding:13px 20px; background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); font-size:14px; font-weight:600; color:var(--t1);
  cursor:pointer; box-shadow:var(--shadow-sm); transition:all .25s; margin-bottom:16px;
}
.btn-google-full:hover { border-color:var(--blue); box-shadow:var(--shadow-md); transform:translateY(-1px); }
.btn-google-full svg { width:18px; height:18px; }
.auth-divider {
  display:flex; align-items:center; gap:12px; margin:16px 0;
  color:var(--t4); font-size:12px; font-weight:500;
}
.auth-divider::before,.auth-divider::after { content:''; flex:1; height:1.5px; background:var(--border); }
.form-group { margin-bottom:16px; }
.form-label { font-size:12px; font-weight:700; color:var(--t2); display:block; margin-bottom:6px; letter-spacing:.3px; }
.form-input {
  width:100%; padding:12px 16px;
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-lg); font-size:14px; color:var(--t1);
  transition:all .2s;
}
.form-input:focus { border-color:var(--blue); box-shadow:0 0 0 4px rgba(37,99,235,.1); }
.form-input::placeholder { color:var(--t5); }
select.form-input { appearance:none; cursor:pointer; background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E"); background-repeat:no-repeat; background-position:right 14px center; padding-right:38px; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.form-check { display:flex; align-items:flex-start; gap:10px; font-size:13px; color:var(--t3); margin-bottom:20px; }
.form-check input { margin-top:2px; accent-color:var(--blue); cursor:pointer; }
.form-check a { color:var(--blue); font-weight:600; }
.btn-submit {
  width:100%; padding:14px; background:var(--grad);
  border-radius:var(--r-xl); font-size:14px; font-weight:700; color:#fff;
  border:none; cursor:pointer; box-shadow:var(--shadow-blue);
  transition:all .25s; position:relative; overflow:hidden;
}
.btn-submit::after { content:''; position:absolute; inset:0; background:rgba(255,255,255,.12); opacity:0; transition:opacity .2s; }
.btn-submit:hover { transform:translateY(-2px); box-shadow:0 12px 36px rgba(37,99,235,.35); }
.btn-submit:hover::after { opacity:1; }
.btn-submit:disabled { opacity:.6; cursor:not-allowed; transform:none; }
.form-panel { display:none; }
.form-panel.active { display:block; animation:slideUp .35s ease; }
.auth-footer-text { text-align:center; margin-top:18px; font-size:13px; color:var(--t3); }
.auth-footer-text a { color:var(--blue); font-weight:600; }
.auth-error {
  background:var(--red-50); border:1px solid rgba(220,38,38,.2);
  border-radius:var(--r-md); padding:11px 14px; font-size:13px; color:var(--red);
  margin-bottom:14px; display:none; animation:slideUp .3s ease;
}
.auth-error.show { display:block; }
.auth-success {
  background:var(--green-50); border:1px solid rgba(22,163,74,.2);
  border-radius:var(--r-md); padding:11px 14px; font-size:13px; color:var(--green);
  margin-bottom:14px; display:none; animation:slideUp .3s ease;
}
.auth-success.show { display:block; }
.password-wrap { position:relative; }
.password-toggle { position:absolute; right:12px; top:50%; transform:translateY(-50%); background:none; border:none; color:var(--t4); cursor:pointer; font-size:16px; padding:4px; transition:color .2s; }
.password-toggle:hover { color:var(--t2); }
.form-input.pr { padding-right:42px; }

/* ────────────────────────────────────────────────
   DASHBOARD
   ──────────────────────────────────────────────── */
.dash-layout { display:flex; min-height:100vh; background:var(--bg-soft); }

/* Sidebar */
.dash-sidebar {
  width:248px; flex-shrink:0;
  background:var(--white);
  border-right:1.5px solid var(--border);
  position:fixed; top:0; left:0; bottom:0;
  display:flex; flex-direction:column; z-index:100;
  overflow:hidden;
}
.sidebar-logo {
  padding:20px 20px 0; display:flex; align-items:center; justify-content:space-between;
}
.sidebar-logo-text { font-size:17px; font-weight:800; letter-spacing:-.7px; }
.sidebar-logo-text .cosmos {
  background:var(--grad-text); -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  background-size:200% auto; animation:shimmer 4s linear infinite;
}
.sidebar-logo-text .badge {
  font-size:9px; font-weight:700; background:var(--grad); color:#fff;
  padding:3px 8px; border-radius:var(--r-full); margin-left:7px;
  text-transform:uppercase; letter-spacing:.5px; -webkit-text-fill-color:#fff;
}
.sidebar-user {
  margin:16px 12px; padding:13px; background:var(--bg-soft);
  border:1px solid var(--border); border-radius:var(--r-xl);
  display:flex; align-items:center; gap:10px;
}
.sidebar-avatar {
  width:38px; height:38px; border-radius:50%;
  background:var(--grad); display:flex; align-items:center; justify-content:center;
  font-weight:700; font-size:14px; color:#fff; flex-shrink:0; overflow:hidden;
}
.sidebar-avatar img { width:100%; height:100%; object-fit:cover; border-radius:50%; }
.sidebar-user-name { font-size:13px; font-weight:700; color:var(--t1); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.sidebar-user-level { font-size:10px; color:var(--blue); font-weight:700; margin-top:2px; }
.dash-nav { flex:1; padding:6px 10px; overflow-y:auto; }
.dash-nav-section { font-size:10px; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--t4); padding:12px 10px 5px; }
.dash-nav a {
  display:flex; align-items:center; gap:10px;
  padding:10px 12px; border-radius:var(--r-lg);
  font-size:13px; font-weight:500; color:var(--t3); transition:all .2s; margin-bottom:2px;
}
.dash-nav a:hover { background:var(--bg-soft); color:var(--t1); }
.dash-nav a.active { background:var(--blue-50); color:var(--blue); font-weight:700; }
.dash-nav a .n-icon { font-size:16px; width:20px; text-align:center; }
.dash-nav a .n-badge { margin-left:auto; background:var(--blue); color:#fff; font-size:10px; font-weight:700; padding:2px 7px; border-radius:var(--r-full); }
.sidebar-bottom { padding:12px; border-top:1.5px solid var(--border); }
.sidebar-points-box {
  background:var(--grad); border-radius:var(--r-xl); padding:16px; text-align:center;
  position:relative; overflow:hidden;
}
.sidebar-points-box::before { content:''; position:absolute; width:80px; height:80px; background:rgba(255,255,255,.1); border-radius:50%; top:-20px; right:-10px; }
.pts-val { font-size:24px; font-weight:800; color:#fff; letter-spacing:-1px; position:relative; }
.pts-lbl { font-size:11px; color:rgba(255,255,255,.75); margin-top:2px; position:relative; }
.btn-cashout { margin-top:10px; width:100%; padding:9px; background:rgba(255,255,255,.2); border:1.5px solid rgba(255,255,255,.3); border-radius:var(--r-lg); font-size:12px; font-weight:700; color:#fff; cursor:pointer; transition:all .2s; position:relative; }
.btn-cashout:hover { background:rgba(255,255,255,.3); }

/* Dash main */
.dash-main { flex:1; margin-left:248px; min-height:100vh; }
.dash-topbar {
  position:sticky; top:0; z-index:50;
  height:60px; background:rgba(255,255,255,.9); backdrop-filter:blur(16px);
  border-bottom:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:space-between; padding:0 28px;
}
.topbar-title { font-size:15px; font-weight:700; color:var(--t1); }
.topbar-right { display:flex; align-items:center; gap:10px; }
.topbar-notif {
  width:36px; height:36px; border-radius:var(--r-md);
  background:var(--bg-soft); border:1.5px solid var(--border);
  display:flex; align-items:center; justify-content:center;
  cursor:pointer; position:relative; font-size:16px; color:var(--t3); transition:all .2s;
}
.topbar-notif:hover { border-color:var(--blue); color:var(--blue); background:var(--blue-50); }
.topbar-notif .dot { position:absolute; top:6px; right:6px; width:7px; height:7px; border-radius:50%; background:var(--red); border:2px solid var(--white); }
.topbar-avatar { width:34px; height:34px; border-radius:50%; background:var(--grad); display:flex; align-items:center; justify-content:center; font-weight:700; font-size:13px; color:#fff; cursor:pointer; overflow:hidden; flex-shrink:0; }
.topbar-avatar img { width:100%; height:100%; object-fit:cover; }
.dash-content { padding:24px; }

/* Welcome banner */
.welcome-banner {
  background:var(--grad);
  border-radius:var(--r-2xl); padding:28px 32px;
  display:flex; align-items:center; justify-content:space-between;
  margin-bottom:22px; position:relative; overflow:hidden;
}
.welcome-banner::before { content:''; position:absolute; width:200px; height:200px; border-radius:50%; background:rgba(255,255,255,.1); top:-60px; right:10%; filter:blur(40px); }
.welcome-text h2 { font-size:21px; font-weight:800; color:#fff; }
.welcome-text p { font-size:14px; color:rgba(255,255,255,.8); margin-top:4px; }
.welcome-action .btn-white { font-size:13px; padding:10px 20px; }
@media(max-width:600px) { .welcome-banner{flex-direction:column;gap:14px;align-items:flex-start} }

/* Dash stats */
.dash-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:14px; margin-bottom:24px; }
@media(max-width:1000px) { .dash-stats { grid-template-columns:repeat(2,1fr); } }
.dstat-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); padding:20px;
  transition:all .25s;
}
.dstat-card:hover { border-color:var(--blue); transform:translateY(-3px); box-shadow:var(--shadow-md); }
.dstat-icon-wrap {
  width:44px; height:44px; border-radius:var(--r-md);
  display:flex; align-items:center; justify-content:center; font-size:20px; margin-bottom:14px;
}
.dstat-icon-1 { background:var(--green-50); }
.dstat-icon-2 { background:var(--blue-50); }
.dstat-icon-3 { background:var(--violet-50); }
.dstat-icon-4 { background:var(--amber-50); }
.dstat-val { font-size:26px; font-weight:800; color:var(--t1); letter-spacing:-.8px; line-height:1; }
.dstat-lbl { font-size:12px; color:var(--t4); margin-top:5px; font-weight:500; }
.dstat-chg { font-size:11px; font-weight:700; margin-top:8px; display:flex; align-items:center; gap:4px; }
.chg-up { color:var(--green); }
.chg-new { color:var(--blue); }

/* Section header */
.sec-hdr { display:flex; align-items:center; justify-content:space-between; margin-bottom:16px; }
.sec-hdr h3 { font-size:16px; font-weight:800; color:var(--t1); }
.sec-hdr a { font-size:13px; color:var(--blue); font-weight:600; transition:color .2s; }
.sec-hdr a:hover { color:var(--blue-dk); }

/* Survey cards */
.surveys-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:28px; }
@media(max-width:1100px) { .surveys-grid { grid-template-columns:repeat(2,1fr); } }
@media(max-width:600px) { .surveys-grid { grid-template-columns:1fr; } }
.survey-card {
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); padding:18px; cursor:pointer;
  transition:all .25s; display:flex; flex-direction:column; gap:10px;
}
.survey-card:hover { border-color:var(--blue); transform:translateY(-4px); box-shadow:var(--shadow-lg), 0 0 0 4px rgba(37,99,235,.06); }
.sc-top { display:flex; align-items:flex-start; justify-content:space-between; gap:8px; }
.sc-cat { font-size:10px; font-weight:700; letter-spacing:.4px; text-transform:uppercase; padding:4px 10px; border-radius:var(--r-full); }
.cat-tech { background:rgba(37,99,235,.1); color:var(--blue); }
.cat-health { background:rgba(22,163,74,.1); color:var(--green); }
.cat-finance { background:rgba(217,119,6,.1); color:var(--amber); }
.cat-lifestyle { background:rgba(124,58,237,.1); color:var(--violet); }
.cat-travel { background:rgba(8,145,178,.1); color:var(--cyan); }
.cat-retail { background:rgba(220,38,38,.1); color:var(--red); }
.cat-business { background:rgba(99,102,241,.1); color:#6366f1; }
.sc-reward { font-size:17px; font-weight:800; color:var(--green); white-space:nowrap; }
.survey-card h4 { font-size:14px; font-weight:700; color:var(--t1); line-height:1.4; }
.sc-meta { display:flex; gap:12px; }
.sc-meta span { font-size:12px; color:var(--t4); display:flex; align-items:center; gap:4px; }
.sc-fill-bar { height:4px; background:var(--bg-muted); border-radius:var(--r-full); overflow:hidden; }
.sc-fill-inner { height:100%; border-radius:var(--r-full); background:var(--grad); transition:width .6s ease; }
.sc-fill-lbl { display:flex; justify-content:space-between; font-size:10px; color:var(--t4); margin-bottom:4px; }
.btn-take {
  width:100%; padding:10px; background:var(--bg-soft);
  border:1.5px solid var(--border); border-radius:var(--r-lg);
  font-size:13px; font-weight:700; color:var(--blue); cursor:pointer; transition:all .2s;
}
.btn-take:hover { background:var(--blue); color:#fff; border-color:var(--blue); box-shadow:var(--shadow-blue); }

/* Activity table */
.activity-table { background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-xl); overflow:hidden; }
.at-head { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; padding:12px 20px; border-bottom:1px solid var(--border); font-size:11px; font-weight:700; letter-spacing:.5px; color:var(--t4); text-transform:uppercase; background:var(--bg-soft); }
.at-row { display:grid; grid-template-columns:2fr 1fr 1fr 1fr; padding:14px 20px; border-bottom:1px solid var(--border); font-size:13px; color:var(--t2); align-items:center; transition:background .15s; }
.at-row:last-child { border-bottom:none; }
.at-row:hover { background:var(--bg-soft); }
.at-status { display:inline-flex; align-items:center; gap:5px; font-size:11px; font-weight:700; padding:4px 10px; border-radius:var(--r-full); }
.status-complete { background:var(--green-50); color:var(--green); }
.status-pending { background:var(--amber-50); color:var(--amber); }
.status-screened { background:var(--violet-50); color:var(--violet); }
.at-earn { font-weight:700; color:var(--green); }
@media(max-width:700px) { .at-head .c2,.at-head .c3,.at-row .c2,.at-row .c3{display:none} .at-head{grid-template-columns:2fr 1fr} .at-row{grid-template-columns:2fr 1fr} }

/* Mobile sidebar */
.dash-menu-btn { display:none; align-items:center; justify-content:center; width:36px; height:36px; border-radius:var(--r-md); background:var(--bg-soft); border:1.5px solid var(--border); color:var(--t3); font-size:18px; cursor:pointer; }
.dash-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,.35); z-index:99; backdrop-filter:blur(2px); }
@media(max-width:760px) {
  .dash-sidebar { transform:translateX(-100%); transition:transform .3s cubic-bezier(.22,1,.36,1); }
  .dash-sidebar.open { transform:translateX(0); box-shadow:var(--shadow-xl); }
  .dash-main { margin-left:0; }
  .dash-content { padding:14px; }
  .dash-menu-btn { display:flex; }
  .dash-overlay.show { display:block; }
}

/* Profile */
.profile-grid { display:grid; grid-template-columns:1fr 2fr; gap:22px; align-items:start; }
@media(max-width:900px) { .profile-grid { grid-template-columns:1fr; } }
.profile-card { background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-2xl); padding:28px; text-align:center; }
.profile-pic { width:84px; height:84px; border-radius:50%; background:var(--grad); display:flex; align-items:center; justify-content:center; font-weight:800; font-size:30px; color:#fff; margin:0 auto 16px; overflow:hidden; border:3px solid var(--white); box-shadow:var(--shadow-blue); }
.profile-pic img { width:100%; height:100%; object-fit:cover; }
.profile-name { font-size:19px; font-weight:800; color:var(--t1); }
.profile-email { font-size:13px; color:var(--t4); margin-top:3px; }
.profile-badge { display:inline-flex; align-items:center; gap:6px; margin-top:12px; background:var(--blue-50); border:1px solid rgba(37,99,235,.15); color:var(--blue); font-size:12px; font-weight:700; padding:6px 14px; border-radius:var(--r-full); }
.profile-stats { display:grid; grid-template-columns:repeat(3,1fr); gap:10px; margin-top:20px; }
.ps-item { background:var(--bg-soft); border:1px solid var(--border); border-radius:var(--r-lg); padding:12px 8px; text-align:center; }
.ps-item .v { font-size:18px; font-weight:800; color:var(--t1); }
.ps-item .l { font-size:10px; color:var(--t4); margin-top:2px; }
.form-section { background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-2xl); padding:28px; }
.form-section h3 { font-size:16px; font-weight:800; color:var(--t1); margin-bottom:22px; padding-bottom:16px; border-bottom:1px solid var(--border); }
.form-actions { display:flex; justify-content:flex-end; gap:10px; margin-top:22px; }
.btn-save { padding:11px 26px; background:var(--grad); border-radius:var(--r-full); font-size:13px; font-weight:700; color:#fff; border:none; cursor:pointer; transition:all .2s; box-shadow:var(--shadow-blue); }
.btn-save:hover { transform:translateY(-1px); box-shadow:0 12px 30px rgba(37,99,235,.3); }
.btn-cancel { padding:11px 20px; background:transparent; border:1.5px solid var(--border); border-radius:var(--r-full); font-size:13px; font-weight:600; color:var(--t3); cursor:pointer; transition:all .2s; }
.btn-cancel:hover { border-color:var(--red); color:var(--red); background:var(--red-50); }
.completeness-bar { height:6px; background:var(--bg-muted); border-radius:var(--r-full); overflow:hidden; margin-bottom:6px; margin-top:12px; }
.completeness-fill { height:100%; border-radius:var(--r-full); background:var(--grad); transition:width .8s cubic-bezier(.22,1,.36,1); }

/* Rewards page */
.rewards-options { display:grid; grid-template-columns:repeat(3,1fr); gap:14px; margin-bottom:26px; }
@media(max-width:900px) { .rewards-options { grid-template-columns:repeat(2,1fr); } }
@media(max-width:480px) { .rewards-options { grid-template-columns:1fr; } }
.reward-opt { background:var(--white); border:2px solid var(--border); border-radius:var(--r-xl); padding:20px; cursor:pointer; transition:all .2s; display:flex; flex-direction:column; align-items:center; gap:10px; text-align:center; }
.reward-opt:hover { border-color:var(--blue); box-shadow:var(--shadow-md); transform:translateY(-3px); }
.reward-opt.selected { border-color:var(--blue); background:var(--blue-50); box-shadow:0 0 0 4px rgba(37,99,235,.08); }
.reward-opt .ico { font-size:28px; }
.reward-opt .nm { font-size:14px; font-weight:700; color:var(--t1); }
.reward-opt .mn { font-size:11px; color:var(--t4); }
.cashout-box { background:var(--white); border:1.5px solid var(--border); border-radius:var(--r-2xl); padding:28px; max-width:480px; }
.cashout-box h3 { font-size:16px; font-weight:800; color:var(--t1); margin-bottom:20px; }
.pts-to-cash { display:flex; align-items:center; justify-content:space-between; padding:14px 16px; background:var(--bg-soft); border:1px solid var(--border); border-radius:var(--r-lg); margin-bottom:16px; font-size:13px; color:var(--t3); }
.pts-to-cash .eq { font-size:18px; font-weight:800; color:var(--green); }

/* ── Floating notification ── */
.floating-notif {
  position:fixed; bottom:24px; right:24px; z-index:999;
  background:var(--white); border:1.5px solid var(--border);
  border-radius:var(--r-xl); padding:14px 18px;
  display:flex; align-items:center; gap:12px;
  box-shadow:var(--shadow-xl); min-width:260px;
  animation:notifSlide 5s ease forwards;
  pointer-events:none;
}
.fn-icon { width:38px; height:38px; border-radius:var(--r-md); background:var(--green-50); display:flex; align-items:center; justify-content:center; font-size:18px; flex-shrink:0; }
.fn-title { font-size:13px; font-weight:700; color:var(--t1); }
.fn-sub { font-size:12px; color:var(--t4); margin-top:1px; }

/* Confetti */
.confetti-piece { position:fixed; width:8px; height:8px; top:-20px; animation:confettiFall linear forwards; pointer-events:none; z-index:9999; border-radius:2px; }

/* ── Utility ── */
.mt-4{margin-top:4px}.mt-8{margin-top:8px}.mt-16{margin-top:16px}.mt-24{margin-top:24px}
.mb-16{margin-bottom:16px}.mb-24{margin-bottom:24px}
.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}
.gap-8{gap:8px}.gap-12{gap:12px}.gap-16{gap:16px}
.ml-auto{margin-left:auto}
.text-green{color:var(--green)}.text-blue{color:var(--blue)}.text-amber{color:var(--amber)}.text-red{color:var(--red)}
.fw-700{font-weight:700}.fw-800{font-weight:800}
.fs-12{font-size:12px}.fs-13{font-size:13px}.fs-14{font-size:14px}
.color-t3{color:var(--t3)}.color-t4{color:var(--t4)}
.hidden{display:none!important}
.w-full{width:100%}
.rounded-full{border-radius:var(--r-full)}
.bg-white{background:var(--white)}
.border{border:1.5px solid var(--border)}
