/* ============================================================
   SOLUNA — home.css   (index.html only)
   ============================================================ */

/* ── HERO ──────────────────────────────────────────────── */
.hero {
  min-height: 100vh; padding: calc(var(--nav-h) + 72px) 80px 80px;
  position: relative; overflow: hidden; display: flex; align-items: center;
}
.hero__mesh {
  position: absolute; inset: 0; pointer-events: none;
  background:
    radial-gradient(ellipse 65% 70% at 72% 28%, rgba(37,99,235,.07), transparent 68%),
    radial-gradient(ellipse 55% 65% at 22% 72%, rgba(124,58,237,.06), transparent 70%),
    radial-gradient(ellipse 45% 55% at 88% 82%, rgba(236,72,153,.05), transparent 70%);
}
.hero__grid-dots {
  position: absolute; inset: 0; pointer-events: none;
  background-image: radial-gradient(circle, rgba(37,99,235,.1) 1px, transparent 1px);
  background-size: 32px 32px;
  mask-image: radial-gradient(ellipse 85% 85% at 62% 38%, black 0%, transparent 70%);
}
.hero__blob {
  position: absolute; border-radius: 50%; filter: blur(70px); pointer-events: none;
  animation: blobFloat 14s ease-in-out infinite alternate;
}
.hero__blob--1 { width: 520px; height: 520px; background: rgba(37,99,235,.09);  top: -120px; right: -80px; }
.hero__blob--2 { width: 380px; height: 380px; background: rgba(124,58,237,.07); bottom: -40px; left: -60px; animation-delay: -6s; }
.hero__blob--3 { width: 260px; height: 260px; background: rgba(236,72,153,.06); top: 42%; left: 44%; animation-delay: -11s; }
@keyframes blobFloat { from { transform: translate(0,0) scale(1); } to { transform: translate(28px, 18px) scale(1.06); } }

.hero__inner {
  display: grid; grid-template-columns: 1fr 1fr; gap: 80px;
  align-items: center; max-width: var(--max-w); margin: 0 auto; width: 100%;
  position: relative;
}

/* Hero left */
.hero__badge {
  display: inline-flex; align-items: center; gap: 10px;
  background: white; border: 1px solid rgba(37,99,235,.2);
  padding: 8px 18px 8px 10px; border-radius: 50px;
  margin-bottom: 28px; box-shadow: 0 4px 20px rgba(37,99,235,.1);
}
.hero__badge-icon {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--g-brand); display: flex; align-items: center;
  justify-content: center; font-size: 13px; flex-shrink: 0;
}
.hero__badge-text { font-size: 12px; font-weight: 600; color: var(--ink); letter-spacing: .01em; }
.hero__badge-dot  { width: 5px; height: 5px; border-radius: 50%; background: #22c55e; animation: livePulse 1.8s infinite; }
@keyframes livePulse { 0%,100%{opacity:1} 50%{opacity:.3} }

.hero__headline {
  font-family: 'Fraunces', serif;
  font-size: clamp(52px, 6.5vw, 88px);
  font-weight: 700; line-height: .98; letter-spacing: -.045em;
  color: var(--ink); margin-bottom: 28px;
}
.hero__headline .line-accent { font-style: italic; background: var(--g-brand); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text; }

.hero__sub   { font-size: 18px; color: var(--muted); line-height: 1.75; max-width: 480px; margin-bottom: 44px; }
.hero__btns  { display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 56px; }
.hero__trust { display: flex; align-items: center; gap: 18px; flex-wrap: wrap; }
.hero__avatars { display: flex; }
.hero__avatar {
  width: 36px; height: 36px; border-radius: 50%; border: 2.5px solid white;
  background: var(--g-brand); display: flex; align-items: center;
  justify-content: center; font-size: 12px; font-weight: 700; color: white;
  margin-left: -10px;
}
.hero__avatar:first-child { margin-left: 0; }
.hero__trust-text { font-size: 13px; font-weight: 500; color: var(--muted); }
.hero__trust-text strong { color: var(--ink); }

/* Hero right — live dashboard */
.hero__dashboard-wrap { position: relative; padding: 20px 36px 20px 0; }
.hero__dashboard {
  background: white; border-radius: 22px; box-shadow: var(--sh-xl);
  border: 1px solid var(--border); overflow: hidden;
  animation: dashboardFloat 9s ease-in-out infinite;
}
@keyframes dashboardFloat {
  0%,100% { transform: translateY(0)   rotate(0deg);   }
  33%     { transform: translateY(-12px) rotate(.3deg);  }
  66%     { transform: translateY(-5px)  rotate(-.2deg); }
}
.db-header {
  padding: 16px 22px; border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
}
.db-dots { display: flex; gap: 6px; }
.db-dot  { width: 11px; height: 11px; border-radius: 50%; }
.db-title { font-size: 12px; font-weight: 600; color: var(--muted); }
.db-live {
  display: flex; align-items: center; gap: 5px;
  background: #dcfce7; color: #16a34a;
  padding: 3px 10px; border-radius: 50px; font-size: 11px; font-weight: 700;
}
.db-live-dot { width: 5px; height: 5px; border-radius: 50%; background: #22c55e; animation: livePulse 1.5s infinite; }

.db-body { padding: 22px; }
.db-kpi { margin-bottom: 18px; }
.db-kpi-label { font-size: 11px; font-weight: 600; color: var(--muted-2); text-transform: uppercase; letter-spacing: .08em; margin-bottom: 5px; }
.db-kpi-val {
  font-family: 'Fraunces', serif; font-size: 46px; font-weight: 700;
  letter-spacing: -.04em; line-height: 1;
  background: var(--g-brand); -webkit-background-clip: text; -webkit-text-fill-color: transparent; background-clip: text;
}
.db-kpi-change {
  display: inline-flex; align-items: center; gap: 4px;
  background: #dcfce7; color: #16a34a; padding: 3px 10px;
  border-radius: 50px; font-size: 12px; font-weight: 700; margin-top: 8px;
}

.db-chart { background: var(--off); border-radius: 12px; padding: 14px; margin-bottom: 16px; }
.db-chart-bars { display: flex; gap: 4px; align-items: flex-end; height: 56px; }
.db-bar { flex: 1; border-radius: 4px 4px 0 0; }
.db-chart-labels { display: flex; gap: 4px; margin-top: 8px; }
.db-chart-labels span { flex: 1; font-size: 9px; color: var(--muted-2); text-align: center; font-family: 'DM Mono', monospace; }

.db-pills { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.db-pill {
  background: var(--off); border-radius: 10px; padding: 11px 14px;
  display: flex; align-items: center; gap: 10px;
}
.db-pill-icon { width: 30px; height: 30px; border-radius: 8px; display: flex; align-items: center; justify-content: center; font-size: 14px; }
.db-pill-label { font-size: 10px; color: var(--muted); font-weight: 500; }
.db-pill-val   { font-size: 14px; font-weight: 700; color: var(--ink); }

/* Floating mini cards */
.db-mini {
  position: absolute; background: white; border-radius: 14px;
  box-shadow: 0 12px 40px rgba(0,0,0,.14); padding: 12px 16px;
  border: 1px solid var(--border);
}
.db-mini--bl { bottom: -16px; left: -32px; display: flex; align-items: center; gap: 12px; min-width: 175px; }
.db-mini--tr { top: -14px; right: -24px; text-align: center; min-width: 130px; }
.db-mini-icon { width: 34px; height: 34px; border-radius: 9px; display: flex; align-items: center; justify-content: center; font-size: 15px; }
.db-mini-label { font-size: 10px; color: var(--muted); font-weight: 500; }
.db-mini-val   { font-size: 15px; font-weight: 800; color: var(--ink); letter-spacing: -.02em; }

/* ── FEATURES STRIP ─────────────────────────────────────── */
.features { padding: 100px 80px; background: var(--off); position: relative; overflow: hidden; }
.features__bg {
  position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(ellipse 60% 80% at 50% 0%, rgba(37,99,235,.04), transparent);
}
.features__grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 64px; }
.feature-card {
  background: white; border: 1px solid var(--border); border-radius: var(--r-lg);
  padding: 36px 32px; position: relative; overflow: hidden; cursor: default;
  transition: all .35s cubic-bezier(.16,1,.3,1);
}
.feature-card::after {
  content: ''; position: absolute; inset: 0; background: var(--g-brand);
  opacity: 0; transition: opacity .35s;
}
.feature-card:hover { transform: translateY(-8px); box-shadow: 0 24px 64px rgba(37,99,235,.13); border-color: transparent; }
.feature-card:hover::after { opacity: 1; }
.feature-card:hover .feature-card__icon { background: rgba(255,255,255,.18); border-color: rgba(255,255,255,.25); }
.feature-card:hover .feature-card__title,
.feature-card:hover .feature-card__item { color: white; }
.feature-card:hover .feature-card__item::before { color: rgba(255,255,255,.7); }

.feature-card__icon {
  width: 52px; height: 52px; border-radius: 14px;
  background: var(--off); border: 1px solid var(--border-2);
  display: flex; align-items: center; justify-content: center;
  margin-bottom: 22px; position: relative; z-index: 1; transition: all .35s;
}
.feature-card__icon svg { width: 24px; height: 24px; }
.feature-card__title { font-size: 18px; font-weight: 700; color: var(--ink); margin-bottom: 16px; position: relative; z-index: 1; transition: color .35s; letter-spacing: -.02em; }
.feature-card__list  { list-style: none; display: flex; flex-direction: column; gap: 9px; position: relative; z-index: 1; }
.feature-card__item  { font-size: 14px; color: var(--muted); display: flex; align-items: center; gap: 9px; transition: color .35s; }
.feature-card__item::before { content: '✓'; font-weight: 800; font-size: 12px; color: var(--blue); flex-shrink: 0; transition: color .35s; }

/* Certifications row */
.cert-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 18px; margin-top: 72px; }
.cert-card {
  background: white; border: 1px solid var(--border); border-radius: var(--r);
  padding: 22px 18px; text-align: center; transition: all .3s;
}
.cert-card:hover { background: white; box-shadow: var(--sh); transform: translateY(-3px); }
.cert-card__emoji { font-size: 28px; margin-bottom: 10px; }
.cert-card__name  { font-size: 13px; font-weight: 700; color: var(--ink); margin-bottom: 3px; letter-spacing: -.01em; }
.cert-card__sub   { font-size: 11px; color: var(--muted); }

@media (max-width: 1024px) {
  .hero { padding: calc(var(--nav-h) + 48px) 40px 64px; }
  .hero__inner { grid-template-columns: 1fr; gap: 60px; }
  .hero__dashboard-wrap { display: none; }
  .features { padding: 80px 40px; }
  .features__grid { grid-template-columns: 1fr; gap: 16px; }
  .cert-row { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 640px) {
  .hero { padding: calc(var(--nav-h) + 36px) 20px 52px; }
  .features { padding: 60px 20px; }
  .cert-row { grid-template-columns: 1fr 1fr; gap: 12px; }
}
