/* HOME PAGE */
.section-head { display: grid; grid-template-columns: 1fr 1fr; gap: 48px; align-items: end; }
.section-head p { margin-left: auto; }
@media (max-width: 900px) { .section-head { grid-template-columns: 1fr; } .section-head p { margin-left: 0; } }

.hero { padding: 56px 0 96px; position: relative; overflow: hidden; }
.hero::before { content: ''; position: absolute; inset: 0; background: radial-gradient(900px 480px at 80% 0%, rgba(91,141,239,0.10), transparent 60%), radial-gradient(700px 400px at 10% 30%, rgba(91,141,239,0.05), transparent 60%); pointer-events: none; }
.hero > .shell { position: relative; z-index: 1; }

.hero-split { display: grid; grid-template-columns: 1.05fr 1fr; gap: 64px; align-items: center; min-height: 600px; }
@media (max-width: 980px) { .hero-split { grid-template-columns: 1fr; gap: 48px; } }
.hero-split__cta { display: flex; gap: 12px; flex-wrap: wrap; }
.hero-split__meta-row { display: flex; gap: 12px; align-items: center; margin-top: 8px; font-size: 13px; font-weight: 500; color: var(--text-secondary); }
.hero-split__meta-row span:nth-child(even) { color: var(--text-muted); }

.hero-art { position: relative; width: 100%; aspect-ratio: 1/1; max-height: 560px; border-radius: var(--r-xl); background: radial-gradient(circle at 75% 25%, rgba(91,141,239,0.35), transparent 55%), radial-gradient(circle at 25% 80%, rgba(91,141,239,0.10), transparent 55%), linear-gradient(135deg, #eef3fb 0%, #dde7f5 100%); overflow: hidden; }
.hero-art__glow { position: absolute; width: 70%; height: 70%; top: -20%; right: -20%; background: radial-gradient(circle, rgba(91,141,239,0.55), transparent 60%); filter: blur(20px); pointer-events: none; }
.hero-art__grid { position: absolute; inset: 0; background-image: linear-gradient(rgba(11,18,32,0.05) 1px, transparent 1px), linear-gradient(90deg, rgba(11,18,32,0.05) 1px, transparent 1px); background-size: 40px 40px; mask-image: radial-gradient(circle at center, black 30%, transparent 80%); pointer-events: none; }
.hero-art__card { position: absolute; background: #fff; border-radius: var(--r-md); padding: 16px; box-shadow: 0 1px 2px rgba(11,18,32,0.06), 0 12px 32px rgba(11,18,32,0.10); border: 1px solid var(--border-subtle); }
.hero-art__card--1 { left: 6%; top: 14%; width: 62%; display: flex; flex-direction: column; gap: 12px; }
.hero-art__card--2 { right: 6%; top: 46%; width: 60%; background: var(--bg-dark); border-color: var(--bg-dark); color: #fff; }
.hero-art__card--3 { left: 12%; bottom: 8%; width: 38%; }
.hero-art__card-head { display: flex; align-items: center; gap: 10px; }
.hero-art__mark { width: 28px; height: 28px; border-radius: 7px; display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #fff; }
.hero-art__mark--trades { background: linear-gradient(135deg, #5b8def, #2c5fd6); }
.hero-art__card-title { font-size: 13px; font-weight: 600; color: var(--text-primary); }
.hero-art__card-sub { font-size: 11px; color: var(--text-tertiary); }
.hero-art__metric { display: flex; align-items: baseline; gap: 8px; }
.hero-art__metric-num { font-family: var(--font-display); font-size: 34px; font-weight: 600; letter-spacing: -0.025em; color: var(--text-primary); }
.hero-art__metric-delta { font-size: 12px; font-weight: 600; color: var(--blue-deep); background: var(--blue-soft); padding: 3px 8px; border-radius: 999px; }
.hero-art__sparkline svg { width: 100%; height: 48px; display: block; }
.hero-art__chip { display: inline-flex; align-items: center; gap: 8px; font-size: 11px; font-weight: 600; color: var(--lime); letter-spacing: 0.04em; text-transform: uppercase; }
.hero-art__chip-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--lime); box-shadow: 0 0 0 4px rgba(197,240,74,0.18); }
.hero-art__chip-body { font-size: 13px; line-height: 1.5; color: rgba(255,255,255,0.9); margin-top: 10px; }
.hero-art__shape { position: absolute; pointer-events: none; }
.hero-art__shape--1 { width: 110px; height: 110px; top: 6%; right: 6%; animation: spin 30s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.hero-art__shape--2 { width: 80px; height: 80px; right: 14%; bottom: 14%; }

/* Platform feature cards */
.featcard { background: var(--bg-dark-card); border: 1px solid var(--border-dark-subtle); border-radius: var(--r-lg); padding: 28px; display: flex; flex-direction: column; gap: 10px; color: var(--text-on-dark); }
.featcard .t-body { color: var(--text-on-dark-secondary); }
.featcard__icon { width: 40px; height: 40px; border-radius: 10px; display: inline-flex; align-items: center; justify-content: center; background: var(--blue); color: #fff; margin-bottom: 8px; }
.featcard__icon svg { width: 20px; height: 20px; }
.featcard__icon--lime { background: var(--lime); color: var(--btn-dark); }
.featcard--accent { background: linear-gradient(180deg, rgba(91,141,239,0.10), rgba(91,141,239,0.02)); border: 1px solid rgba(91,141,239,0.25); }

/* Own-it / Bundle */
.ownit { display: grid; grid-template-columns: 1.05fr 1fr; gap: 80px; align-items: center; }
@media (max-width: 980px) { .ownit { grid-template-columns: 1fr; gap: 48px; } }
.ownit__bullets { display: flex; flex-direction: column; gap: 28px; }
.ownit__bullet { display: grid; grid-template-columns: 40px 1fr; gap: 16px; align-items: start; }
.ownit__bullet-mark { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: var(--blue-deep); letter-spacing: -0.02em; }

.bundle { background: var(--bg-card); border-radius: var(--r-lg); padding: 28px; display: flex; flex-direction: column; gap: 20px; }
.bundle__head { display: flex; align-items: flex-end; justify-content: space-between; }
.bundle__total { display: flex; align-items: baseline; gap: 8px; }
.bundle__total-old { font-size: 16px; color: var(--text-muted); text-decoration: line-through; }
.bundle__total-new { font-family: var(--font-display); font-size: 40px; font-weight: 600; letter-spacing: -0.025em; color: var(--text-primary); }
.bundle__list { display: flex; flex-direction: column; gap: 8px; }
.bundle__row { display: grid; grid-template-columns: 32px 1fr auto; gap: 14px; align-items: center; padding: 14px 16px; background: #fff; border-radius: var(--r-md); border: 1px solid var(--border-subtle); }
.bundle__row--off { background: transparent; border-style: dashed; color: var(--text-tertiary); }
.bundle__row .nav__tab-mark { width: 32px; height: 32px; font-size: 13px; }
.bundle__row-label { font-size: 14px; font-weight: 600; color: var(--text-primary); line-height: 1.4; }
.bundle__row--off .bundle__row-label { color: var(--text-tertiary); }
.bundle__row-price { font-family: var(--font-display); font-size: 18px; font-weight: 600; color: var(--text-primary); letter-spacing: -0.01em; }
.bundle__row--off .bundle__row-price { color: var(--text-tertiary); }
.bundle__savings { display: flex; align-items: center; padding: 14px 16px; background: #fff; border-radius: var(--r-md); border: 1px dashed var(--blue); }

.finalcta { background: var(--bg-card); border-radius: var(--r-xl); padding: 56px 64px; display: grid; grid-template-columns: 1.4fr 1fr; gap: 48px; align-items: center; }
.finalcta__cta { display: flex; gap: 12px; flex-wrap: wrap; justify-content: flex-end; }
@media (max-width: 900px) { .finalcta { grid-template-columns: 1fr; padding: 40px 32px; } .finalcta__cta { justify-content: flex-start; } }

/* ═══ What we stand for — connected strip ═══ */
.standfor-grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 0;
  margin-top: 48px;
  border-radius: var(--r-xl);
  overflow: hidden;
  border: 1px solid var(--border-light);
}
.standfor-grid > div {
  padding: 48px 36px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  border-right: 1px solid var(--border-light);
}
.standfor-grid > div:last-child {
  border-right: none;
}
@media (max-width: 640px) {
  .standfor-grid {
    display: flex;
    flex-wrap: nowrap;
    overflow-x: auto;
    overflow-y: hidden;
    -webkit-overflow-scrolling: touch;
    scroll-snap-type: x mandatory;
    scrollbar-width: none;
    border-radius: var(--r-lg);
  }
  .standfor-grid::-webkit-scrollbar { display: none; }
  .standfor-grid > div {
    min-width: 280px;
    flex-shrink: 0;
    scroll-snap-align: start;
    border-bottom: none;
    position: relative;
    overflow: hidden;
  }
  .standfor-fade {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    width: 56px;
    pointer-events: none;
    z-index: 3;
  }
  .standfor-fade--white {
    background: linear-gradient(to right, rgba(255,255,255,0), rgba(255,255,255,1));
  }
  .standfor-grid > div:nth-child(2),
  .standfor-grid > div:nth-child(3) {
    opacity: 1 !important;
    transform: translateY(0) !important;
    transition: none !important;
  }
  .standfor-wrap {
    position: relative;
  }
  .standfor-dots {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 16px;
  }
  .standfor-dots span {
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: var(--border-light);
    transition: background 200ms;
  }
  .standfor-dots span.is-active {
    background: var(--blue-deep);
    width: 18px;
    border-radius: 3px;
  }
}
@media (min-width: 641px) {
  .standfor-wrap::after { display: none; }
  .standfor-dots { display: none; }
  #standfor-grad { display: none !important; }
  .standfor-fade { display: none; }
}

/* ═══ What we believe — two column ═══ */
.believe-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 64px;
  align-items: center;
}
@media (max-width: 640px) {
  .believe-grid {
    grid-template-columns: 1fr;
    gap: 32px;
  }
}