:root{
  --brand:  #7C3AED;   /* vivid violet */
  --brand2: #A78BFA;   /* soft lavender accent */
  --accent: #38BDF8;   /* bright sky blue */
  --accent2:#0EA5E9;   /* calm aqua */

  --bg:     #F9FAFB;   /* airy neutral */
  --ink:    #1E1B4B;   /* dark indigo ink */
  --muted:  #6B7280;
  --line:   #E2E8F0;   /* cool border */
  --good:   #10B981;
  --warn:   #FBBF24;

  --card:   rgba(255,255,255,.92);
  --glass:  rgba(255,255,255,.68);
  --shadow: 0 14px 36px rgba(124,58,237,.16), 0 4px 12px rgba(14,165,233,.1);
  --radius: 18px;
}

*{box-sizing:border-box}
html,body{margin:0;background:var(--bg);color:var(--ink);font:16px/1.6 "Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif}
a{color:var(--accent2);text-decoration:none} a:hover{opacity:.95}
.wrap{max-width:1180px;margin:0 auto;padding:28px}
.bg{position:fixed; inset:-10vh; z-index:-1;
  background:
    radial-gradient(1200px 600px at 10% 10%, rgba(124,58,237,.10), transparent 55%),
    radial-gradient(1000px 600px at 90% 0%, rgba(56,189,248,.12), transparent 60%),
    linear-gradient(180deg, #ffffff 0%, #f8fbff 100%);
}
.blob{position:absolute; width:48vmax; height:48vmax; border-radius:50%; filter: blur(70px); opacity:.16; animation: float 26s ease-in-out infinite}
.blob.one{ background: radial-gradient(circle at 30% 30%, var(--brand), transparent 60%); top:-12vmax; left:-10vmax}
.blob.two{ background: radial-gradient(circle at 70% 70%, var(--accent), transparent 60%); bottom:-12vmax; right:-8vmax; animation-delay:6s}
@keyframes float{0%,100%{ transform: translate(0,0) scale(1)} 50%{ transform: translate(2vmax,-1.5vmax) scale(1.04)}}
.nav{display:flex;align-items:center;justify-content:space-between}
.brand{display:flex;gap:12px;align-items:center}
.logo{width:40px;height:40px;border-radius:12px;
  background: conic-gradient(from 220deg at 50% 50%, var(--brand), var(--accent), var(--brand));
  box-shadow: var(--shadow);
}
.brand h1{margin:0;font-size:18px;font-weight:800;letter-spacing:.2px}
.nav .right a{margin-left:16px}
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 16px;border-radius:14px;font-weight:700;transition:transform .08s ease, box-shadow .2s ease, filter .2s}
.btn:hover{transform:translateY(-1px); filter:saturate(1.02)}
.btn-primary{color:#fff;background:linear-gradient(135deg,var(--brand),var(--accent)); box-shadow:0 10px 22px rgba(124,58,237,.25)}
.btn-ghost{border:1px solid var(--line);background:#fff;color:var(--ink)}
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:36px;align-items:center;padding:58px 0}
.hero h2{font-size:48px;line-height:1.06;margin:.1em 0 .3em; letter-spacing:-.02em}
.hero p{color:var(--muted);margin:0 0 20px; font-size:18px}
.pill{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;border:1px solid #e9e5ff;background:#f5f3ff;color:#5b21b6;font-weight:700;font-size:13px}
.card{position:relative; background: var(--glass); backdrop-filter: blur(10px);
  border-radius: var(--radius); overflow:hidden; box-shadow: var(--shadow);
}
.card::before{content:""; position:absolute; inset:0; padding:1px; border-radius:inherit;
  background: linear-gradient(135deg, rgba(124,58,237,.55), rgba(56,189,248,.55));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor; mask-composite: exclude; pointer-events:none;
}
.ribbon{position:absolute; top:14px; left:-8px; background:linear-gradient(135deg,var(--brand),var(--accent));
  color:#fff; padding:6px 12px; font-weight:700; border-radius:10px; box-shadow:0 8px 18px rgba(124,58,237,.25);
}
.dash{padding:22px}
.stats{display:flex;gap:16px;flex-wrap:wrap; align-items:center; justify-content:space-between}
.stat{position:relative; background:#fff; border-radius:16px; padding:14px 16px; min-width:170px;
  border:1px solid #ecebff; box-shadow: 0 10px 20px rgba(88,28,135,.08); transition: transform .15s ease, box-shadow .2s ease;
}
.stat:hover{ transform: translateY(-2px); box-shadow:0 16px 32px rgba(88,28,135,.12)}
.stat .label{color:#6d28d9;font-size:12px;font-weight:700; letter-spacing:.2px}
.stat .value{font-size:26px;font-weight:800;letter-spacing:.2px}
.ring{position:relative; width:120px; height:120px; display:grid; place-items:center;}
.ring svg{transform:rotate(-90deg)}
.ring .txt{position:absolute; font-weight:800}
.bars{display:flex;gap:6px;align-items:flex-end;height:120px;margin-top:12px}
.bar{width:10px;border-radius:6px 6px 0 0;background:#e6e9f8;transform:scaleY(.1);transform-origin:bottom;opacity:.95}
.bar.ok{background:linear-gradient(180deg, #34D399, #10B981)}
.legend{color:var(--muted);font-size:12px;margin-top:8px}
.section{padding:18px 0 8px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.tile{position:relative; background:var(--card); border-radius:20px; padding:20px; border:1px solid var(--line);
  box-shadow: var(--shadow); transition: transform .16s ease, box-shadow .2s ease, filter .2s;
}
.tile::after{content:""; position:absolute; inset:0; border-radius:inherit; pointer-events:none;
  background: linear-gradient(180deg, rgba(255,255,255,.55), transparent 40%); mix-blend-mode: screen; opacity:.7;
}
.tile:hover{ transform: translateY(-3px); box-shadow:0 18px 38px rgba(91,33,182,.14); filter:saturate(1.03)}
.tile h3{margin:.2em 0 .3em; font-size:18px}
.tile .ico{font-size:20px; margin-right:6px}
.join{display:flex;justify-content:space-between;gap:18px;flex-wrap:wrap;align-items:center;
  padding:18px;margin:36px 0;background:#fff;border:1px solid #ecebff;border-radius:20px;box-shadow: var(--shadow)
}
.footer{padding:26px 0;color:var(--muted);border-top:1px solid var(--line);margin-top:24px}
.reveal{opacity:0; transform: translateY(16px); transition: opacity .5s ease, transform .5s ease}
.reveal.show{opacity:1; transform:none}
@media (max-width: 980px){ .hero{grid-template-columns:1fr} }

/* =========================
   MOBILE + SMALL TABLETS FIXES
   Paste at the bottom of assets/css/landing.css
   ========================= */

/* Base tweaks for small viewports */
@media (max-width: 1024px){
  .wrap { padding: 20px; }
  .hero { grid-template-columns: 1fr; gap: 24px; padding: 36px 0; }
  .hero h2 { font-size: 38px; }
  .stats { justify-content: flex-start; }
  .bars { height: 100px; }
}

@media (max-width: 820px){
  /* Navigation */
  .brand h1 { font-size: 16px; }
  .logo { width: 32px; height: 32px; border-radius: 10px; }
  .nav .right a { margin-left: 10px; }
  .btn { padding: 12px 14px; border-radius: 12px; }

  /* Hero + preview */
  .hero { padding: 28px 0; }
  .hero h2 { font-size: 32px; line-height: 1.15; }
  .hero p { font-size: 16px; }

  .dash { padding: 16px; }
  .ribbon { transform: scale(.9); left: -6px; top: 10px; }

  /* Stats cards stack nicely */
  .stats { gap: 12px; }
  .stat { min-width: 140px; padding: 12px 12px; }
  .stat .value { font-size: 22px; }

  /* Ring shrinks */
  .ring { width: 96px; height: 96px; }
  .ring svg circle[r="52"] { r: 42; }   /* safe fallback if your bundler inlines; otherwise ignore */

  /* Bars smaller / denser */
  .bars { height: 90px; gap: 4px; }
  .bar { width: 8px; }

  /* Tiles grid -> 2 columns */
  .grid3 { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .tile { padding: 16px; border-radius: 16px; }
}

@media (max-width: 600px){
  .wrap { padding: 16px; }

  /* Make buttons comfy tap targets and wrap to full width where needed */
  .btn { padding: 14px 16px; font-weight: 700; }
  .hero .btn { width: 100%; text-align: center; }
  .nav .right .btn { padding: 10px 12px; } /* nav stays smaller */

  /* Hero text */
  .hero h2 { font-size: 28px; }
  .pill { font-size: 12px; padding: 5px 9px; }

  /* Preview card compact */
  .dash { padding: 14px; }
  .ribbon { display: none; } /* more room on small screens */

  .stats { flex-direction: row; flex-wrap: wrap; }
  .stat { flex: 1 1 46%; min-width: 140px; }
  .stat .label { font-size: 11px; }
  .stat .value { font-size: 20px; }

  /* Progress ring compact */
  .ring { width: 84px; height: 84px; }
  .ring .txt { font-size: 14px; }

  /* Bars tighter */
  .bars { height: 78px; gap: 3px; }
  .bar { width: 6px; }

  /* Tiles grid -> 1 column */
  .grid3 { grid-template-columns: 1fr; }
  .tile { padding: 14px; }

  /* Join section: stack buttons under text */
  .join { padding: 14px; gap: 12px; }
  .join .btn { width: 100%; }
}

/* Ultra-small phones */
@media (max-width: 380px){
  .hero h2 { font-size: 24px; }
  .stat { min-width: 120px; }
  .stat .value { font-size: 18px; }
  .bars { height: 68px; }
}

/* Background blob restraint to prevent overflow & perf issues on mobile */
@media (max-width: 820px){
  .blob { width: 60vw; height: 60vw; filter: blur(60px); opacity: .14; }
  .blob.one { top: -20vw; left: -20vw; }
  .blob.two { bottom: -24vw; right: -18vw; }
}

/* Reduce motion preferences: tone down animations for users who prefer less motion */
@media (prefers-reduced-motion: reduce){
  .bar { transition: none !important; }
  .reveal { transition: none !important; transform: none !important; opacity: 1 !important; }
  .blob { animation: none !important; }
}

