/* EJM Digital — site styles (v2, polished) */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap');

:root {
  --ink: #14151a;
  --ink-soft: #3c3f49;
  --muted: #6b7180;
  --line: #ebecf0;
  --bg: #ffffff;
  --soft: #f6f7f9;
  --brand: #7c3aed;
  --brand-2: #ec4899;
  --accent: #7c3aed;
  --accent-dark: #6d28d9;
  --grad: linear-gradient(110deg, #6366f1 0%, #a855f7 38%, #ec4899 70%, #fb923c 100%);
  --radius: 22px;
  --shadow-sm: 0 1px 2px rgba(20, 21, 26, .05);
  --shadow: 0 2px 6px rgba(20, 21, 26, .05), 0 18px 40px -20px rgba(20, 21, 26, .22);
  --shadow-lg: 0 30px 70px -30px rgba(20, 21, 26, .35);
  --display: "Space Grotesk", -apple-system, BlinkMacSystemFont, sans-serif;
  --font: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
  margin: 0;
  font-family: var(--font);
  color: var(--ink);
  background: var(--bg);
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
a { color: inherit; }
img { display: block; max-width: 100%; }
h1, h2, h3, h4 { font-family: var(--display); line-height: 1.08; letter-spacing: -0.02em; margin: 0; font-weight: 600; }
p { margin: 0; }

.wrap { width: 100%; max-width: 1120px; margin: 0 auto; padding: 0 24px; }
.section { padding: 76px 0; }
.eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-family: var(--display); font-size: 12.5px; font-weight: 600; letter-spacing: .14em;
  text-transform: uppercase; color: var(--muted);
}
.eyebrow::before { content: ""; width: 18px; height: 1.5px; background: currentColor; opacity: .5; }

/* ---------- header ---------- */
.site-header {
  position: sticky; top: 0; z-index: 50;
  background: rgba(255, 255, 255, .72);
  backdrop-filter: saturate(180%) blur(18px);
  -webkit-backdrop-filter: saturate(180%) blur(18px);
  border-bottom: 1px solid var(--line);
}
.site-header::after { content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 3px; background: var(--grad); opacity: .9; }
.site-header { position: sticky; }
.site-header .wrap { display: flex; align-items: center; justify-content: space-between; height: 70px; }
.brand { display: flex; align-items: center; gap: 11px; font-family: var(--display); font-weight: 700; letter-spacing: -0.02em; text-decoration: none; font-size: 19px; }
.brand { gap: 12px; font-size: 21px; }
.brand .logo-mark { width: 44px; height: 44px; display: block; }
.brand .brand-name { line-height: 1; }
.grad { background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }
.brand small { display: block; font-family: var(--font); font-weight: 500; font-size: 11px; letter-spacing: .12em; text-transform: uppercase; color: var(--muted); margin-top: -2px; }
.nav { display: flex; gap: 8px; align-items: center; }
.nav a { text-decoration: none; color: var(--muted); font-weight: 500; font-size: 15px; padding: 8px 14px; border-radius: 10px; transition: color .15s, background .15s; }
.nav a:hover { color: var(--ink); background: var(--soft); }
.nav a.btn { background: var(--ink); color: #fff; }
.nav a.btn:hover { background: #000; }
@media (max-width: 600px) { .nav a.hide-sm { display: none; } }

/* ---------- hero ---------- */
.hero { position: relative; padding: 110px 0 70px; text-align: center; overflow: hidden; }
.hero::before {
  content: ""; position: absolute; inset: -30% -10% auto -10%; height: 720px; z-index: -1;
  background:
    radial-gradient(42% 58% at 18% 12%, rgba(99, 102, 241, .42), transparent 60%),
    radial-gradient(40% 52% at 82% 8%, rgba(251, 146, 60, .34), transparent 60%),
    radial-gradient(46% 60% at 52% 4%, rgba(236, 72, 153, .38), transparent 62%),
    radial-gradient(50% 60% at 70% 64%, rgba(168, 85, 247, .34), transparent 64%);
  filter: blur(20px);
}
.hero h1 { font-size: clamp(40px, 7vw, 76px); font-weight: 700; letter-spacing: -0.035em; }
.hero .lead { color: var(--ink-soft); font-size: clamp(17px, 2.3vw, 21px); max-width: 600px; margin: 24px auto 0; }
.hero .eyebrow { margin-bottom: 22px; }
.hero-cta { display: inline-flex; gap: 12px; margin-top: 34px; flex-wrap: wrap; justify-content: center; }
.btn-primary { display: inline-flex; align-items: center; gap: 8px; background: var(--grad); background-size: 160% 160%; color: #fff; text-decoration: none; padding: 14px 24px; border-radius: 12px; font-weight: 600; font-size: 15px; box-shadow: 0 10px 26px -8px rgba(124, 58, 237, .55); transition: transform .15s, box-shadow .15s, background-position .4s; }
.btn-primary:hover { transform: translateY(-2px); box-shadow: 0 16px 34px -8px rgba(236, 72, 153, .6); background-position: 100% 0; }
.btn-ghost { display: inline-flex; align-items: center; gap: 8px; background: var(--bg); color: var(--ink); text-decoration: none; padding: 13px 22px; border-radius: 12px; font-weight: 600; font-size: 15px; border: 1px solid var(--line); transition: border-color .15s; }
.btn-ghost:hover { border-color: var(--muted); }

/* ---------- app grid ---------- */
.section-head { margin-bottom: 34px; }
.section-head h2 { font-size: clamp(26px, 4vw, 38px); font-weight: 700; letter-spacing: -0.03em; margin-top: 12px; }
.section-head p { color: var(--muted); margin-top: 10px; font-size: 17px; max-width: 560px; }

.app-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 24px; }
.app-card {
  display: flex; flex-direction: column; text-decoration: none; color: inherit;
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.app-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); border-color: transparent; }
.app-card .card-head { height: 96px; position: relative; }
.app-card .card-head::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 140% at 15% 0%, rgba(255,255,255,.28), transparent 55%); }
.app-card .icon-tile {
  position: absolute; left: 22px; bottom: -26px; width: 66px; height: 66px; border-radius: 17px;
  box-shadow: 0 8px 22px -8px rgba(0,0,0,.4), inset 0 0 0 1px rgba(255,255,255,.18); object-fit: cover; background: #fff; z-index: 2;
}
.app-card .icon-tile.mono { display: grid; place-items: center; color: #fff; font-family: var(--display); font-weight: 700; font-size: 23px; }
.app-card .card-body { padding: 38px 24px 22px; }
.app-card h3 { font-size: 21px; font-weight: 700; letter-spacing: -0.02em; }
.app-card .cat { color: var(--muted); font-size: 13px; margin-top: 3px; font-weight: 500; }
.app-card .card-body p { color: var(--ink-soft); font-size: 15px; margin-top: 12px; }
.badges-row { display: flex; flex-wrap: wrap; gap: 7px; margin-top: 16px; }
.pill { font-size: 11.5px; font-weight: 600; padding: 4px 10px; border-radius: 999px; background: var(--soft); color: var(--muted); letter-spacing: .01em; }
.card-cta { margin-top: auto; padding: 16px 24px; border-top: 1px solid var(--line); font-family: var(--display); font-weight: 600; font-size: 14.5px; display: flex; align-items: center; justify-content: space-between; }
.card-cta .arrow { transition: transform .2s ease; }
.app-card:hover .card-cta .arrow { transform: translateX(5px); }

/* ---------- app page ---------- */
.app-hero { position: relative; padding: 50px 0 28px; overflow: hidden; }
.app-hero::before {
  content: ""; position: absolute; inset: -40% 0 auto 0; height: 560px; z-index: -1;
  background: radial-gradient(50% 60% at 30% 0%, color-mix(in srgb, var(--accent) 26%, transparent), transparent 62%);
  filter: blur(12px);
}
.app-hero .top { display: flex; gap: 22px; align-items: center; flex-wrap: wrap; }
.app-hero .icon-tile { width: 88px; height: 88px; border-radius: 21px; box-shadow: var(--shadow); object-fit: cover; }
.app-hero .icon-tile.mono { display: grid; place-items: center; color: #fff; font-family: var(--display); font-weight: 700; font-size: 32px; }
.app-hero h1 { font-size: clamp(34px, 5.5vw, 52px); font-weight: 700; letter-spacing: -0.035em; margin-top: 10px; }
.app-hero .tagline { font-family: var(--display); font-size: clamp(19px, 2.7vw, 25px); color: var(--ink); margin-top: 20px; max-width: 720px; font-weight: 500; letter-spacing: -0.02em; }
.app-hero .blurb { color: var(--muted); font-size: 17px; margin-top: 14px; max-width: 700px; }

/* store buttons */
.store-row { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 28px; }
.store-btn {
  display: inline-flex; align-items: center; gap: 11px; text-decoration: none;
  background: #111418; color: #fff; padding: 11px 18px; border-radius: 13px;
  min-width: 170px; transition: transform .15s, box-shadow .15s;
}
.store-btn:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.store-btn svg { flex: none; }
.store-btn .st-text { display: inline-flex; flex-direction: column; align-items: flex-start; justify-content: center; line-height: 1; }
.store-btn .st-small { display: block; font-size: 10px; line-height: 1.1; opacity: .82; text-transform: uppercase; letter-spacing: .06em; white-space: nowrap; }
.store-btn .st-big { display: block; font-family: var(--display); font-size: 16px; font-weight: 600; line-height: 1.1; margin-top: 3px; white-space: nowrap; }
.store-btn.web { background: var(--accent); }
.store-btn.web:hover { filter: brightness(1.05); }
.store-btn.disabled { background: var(--soft); color: #a3a8b3; cursor: default; pointer-events: none; box-shadow: none; }
.store-btn.disabled svg { opacity: .5; }

/* screenshots gallery */
.gallery { position: relative; }
.shots { display: flex; gap: 20px; overflow-x: auto; padding: 8px 2px 22px; scroll-snap-type: x mandatory; scrollbar-width: none; -ms-overflow-style: none; }
.shots::-webkit-scrollbar { display: none; }
.gnav {
  position: absolute; top: 44%; transform: translateY(-50%); z-index: 6;
  width: 50px; height: 50px; border-radius: 50%; cursor: pointer;
  background: rgba(255, 255, 255, .92); -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px);
  border: 1px solid var(--line); box-shadow: var(--shadow); color: var(--ink);
  display: grid; place-items: center; transition: transform .15s ease, opacity .2s ease, background .15s;
}
.gnav:hover { transform: translateY(-50%) scale(1.08); background: #fff; }
.gnav.prev { left: -8px; }
.gnav.next { right: -8px; }
.gnav:disabled { opacity: 0; pointer-events: none; }
.gnav svg { width: 22px; height: 22px; }
@media (max-width: 560px) { .gnav { width: 42px; height: 42px; } .gnav.prev { left: 2px; } .gnav.next { right: 2px; } .gnav svg { width: 18px; height: 18px; } }
.phone {
  flex: none; width: 240px; scroll-snap-align: center;
  border-radius: 34px; padding: 9px; background: #111418;
  box-shadow: var(--shadow); border: 1px solid rgba(255,255,255,.06);
}
.phone img { border-radius: 26px; width: 100%; }
.browser {
  flex: none; width: min(440px, 82vw); scroll-snap-align: center;
  border-radius: 16px; overflow: hidden; box-shadow: var(--shadow-lg); background: #fff;
  border: 1px solid rgba(20, 21, 26, .07);
}
.browser .bar { display: none; }
.browser img { width: 100%; display: block; }

/* features */
.feature-list { display: grid; grid-template-columns: repeat(auto-fit, minmax(264px, 1fr)); gap: 26px; }
.feature .dot { width: 38px; height: 38px; border-radius: 11px; display: grid; place-items: center; color: #fff; font-family: var(--display); font-weight: 700; margin-bottom: 14px; box-shadow: var(--shadow-sm); }
.feature h4 { font-size: 17px; margin: 0 0 6px; font-weight: 600; }
.feature p { color: var(--muted); font-size: 15px; }

.note { background: var(--soft); border-radius: var(--radius); padding: 18px 22px; color: var(--ink-soft); font-size: 15px; margin-top: 30px; }

/* meta strip */
.app-meta { display: flex; flex-wrap: wrap; gap: 28px; margin-top: 26px; font-size: 14px; padding-top: 24px; border-top: 1px solid var(--line); }
.app-meta .label { color: var(--muted); display: block; font-size: 11px; text-transform: uppercase; letter-spacing: .07em; margin-bottom: 4px; font-weight: 600; }
.app-meta .val { font-weight: 600; }
.legal-links { display: inline-flex; gap: 16px; }
.legal-links a { color: var(--accent-dark); font-weight: 600; text-decoration: none; font-size: 14px; }
.legal-links a:hover { text-decoration: underline; }

/* breadcrumb */
.crumbs { font-size: 14px; color: var(--muted); padding-top: 28px; }
.crumbs a { text-decoration: none; color: var(--accent-dark); font-weight: 500; }
.crumbs a:hover { text-decoration: underline; }

/* legal pages */
.legal { max-width: 760px; }
.legal .updated { color: var(--muted); font-size: 13.5px; margin-bottom: 8px; font-family: var(--display); letter-spacing: .02em; }
.legal h1 { font-size: clamp(30px, 4.5vw, 44px); font-weight: 700; letter-spacing: -0.03em; }
.legal .intro { color: var(--ink-soft); font-size: 18px; margin-top: 16px; }
.legal section { margin-top: 34px; }
.legal h2 { font-size: 21px; font-weight: 600; }
.legal section p { color: var(--ink-soft); margin-top: 8px; }
.legal-toc { display: flex; flex-wrap: wrap; gap: 9px; margin-top: 30px; padding-bottom: 6px; }
.legal-toc a { font-size: 13px; color: var(--accent-dark); background: color-mix(in srgb, var(--accent) 9%, var(--soft)); padding: 6px 12px; border-radius: 999px; text-decoration: none; font-weight: 500; }
.legal-toc a:hover { background: color-mix(in srgb, var(--accent) 16%, var(--soft)); }

/* support */
.support-card { position: relative; overflow: hidden; text-align: center; background: var(--ink); color: #fff; border-radius: 28px; padding: 60px 28px; }
.support-card::before { content: ""; position: absolute; inset: 0; background:
  radial-gradient(40% 110% at 28% 0%, rgba(99,102,241,.55), transparent 60%),
  radial-gradient(40% 110% at 72% 6%, rgba(236,72,153,.5), transparent 60%),
  radial-gradient(46% 120% at 52% 0%, rgba(168,85,247,.45), transparent 62%); }
.support-card > * { position: relative; }
.support-card h2 { font-size: clamp(26px, 4vw, 38px); font-weight: 700; letter-spacing: -0.03em; }
.support-card p { color: rgba(255,255,255,.72); max-width: 520px; margin: 14px auto 0; font-size: 17px; }
.email-btn { display: inline-flex; align-items: center; gap: 9px; margin-top: 26px; background: #fff; color: var(--ink); text-decoration: none; padding: 13px 24px; border-radius: 12px; font-weight: 600; transition: transform .15s; }
.email-btn:hover { transform: translateY(-2px); }

/* footer */
.site-footer { border-top: 1px solid var(--line); padding: 56px 0 64px; margin-top: 30px; color: var(--muted); font-size: 14px; }
.site-footer .cols { display: flex; flex-wrap: wrap; gap: 44px 64px; justify-content: space-between; }
.site-footer h5 { font-family: var(--display); font-size: 12px; text-transform: uppercase; letter-spacing: .08em; color: var(--ink); margin: 0 0 14px; }
.site-footer ul { list-style: none; margin: 0; padding: 0; display: grid; gap: 9px; }
.site-footer a { text-decoration: none; color: var(--muted); }
.site-footer a:hover { color: var(--ink); }
.site-footer .legal-line { margin-top: 40px; padding-top: 26px; border-top: 1px solid var(--line); font-size: 13px; line-height: 1.8; }

/* ===================== HOME v3 — immersive ===================== */
.hero { padding: 96px 0 30px; text-align: center; overflow: clip; }
.hero h1 { font-size: clamp(42px, 8.4vw, 92px); font-weight: 700; letter-spacing: -0.045em; line-height: .96; }
.hero .lead { font-size: clamp(17px, 2.3vw, 22px); max-width: 640px; }
.hero::before { height: 860px; filter: blur(26px); }

/* fanned device cluster */
.hero-devices { display: flex; justify-content: center; align-items: flex-end; margin-top: clamp(40px, 7vw, 76px); }
.hero-devices .phone { width: clamp(120px, 18vw, 206px); margin: 0 calc(-1 * clamp(28px, 4vw, 40px)); border-radius: 30px; padding: 8px; box-shadow: 0 30px 60px -24px rgba(20,21,26,.5); transition: transform .45s cubic-bezier(.2,.7,.2,1); }
.hero-devices .phone img { border-radius: 23px; }
.hero-devices .fan-0 { transform: rotate(-16deg) translateY(40px); z-index: 1; }
.hero-devices .fan-1 { transform: rotate(-8deg) translateY(12px); z-index: 2; }
.hero-devices .fan-2 { transform: rotate(0) translateY(-8px) scale(1.07); z-index: 3; }
.hero-devices .fan-3 { transform: rotate(8deg) translateY(12px); z-index: 2; }
.hero-devices .fan-4 { transform: rotate(16deg) translateY(40px); z-index: 1; }
.hero-devices:hover .fan-0 { transform: rotate(-22deg) translateY(20px) translateX(-22px); }
.hero-devices:hover .fan-1 { transform: rotate(-11deg) translateY(4px) translateX(-10px); }
.hero-devices:hover .fan-3 { transform: rotate(11deg) translateY(4px) translateX(10px); }
.hero-devices:hover .fan-4 { transform: rotate(22deg) translateY(20px) translateX(22px); }
@media (max-width: 720px) { .hero-devices .fan-0, .hero-devices .fan-4 { display: none; } }

/* app icon strip */
.iconstrip { display: flex; flex-direction: column; align-items: center; gap: 18px; padding: 54px 0 10px; }
.iconstrip .row { display: flex; gap: 18px; flex-wrap: wrap; justify-content: center; }
.iconstrip .row img, .iconstrip .row .icon-tile { width: 52px; height: 52px; border-radius: 14px; box-shadow: var(--shadow-sm); filter: grayscale(.15); transition: transform .2s, filter .2s; }
.iconstrip .row a:hover img, .iconstrip .row a:hover .icon-tile { transform: translateY(-4px); filter: none; }
.iconstrip .cap { font-family: var(--display); font-size: 12.5px; letter-spacing: .14em; text-transform: uppercase; color: var(--muted); }
.iconstrip .row .icon-tile.mono { display: grid; place-items: center; color: #fff; font-family: var(--display); font-weight: 700; font-size: 17px; }

/* showcase feature rows */
.showcase { padding: 30px 0; }
.feature-row { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(28px, 6vw, 86px); align-items: center; padding: clamp(48px, 8vw, 104px) 0; }
.feature-row:nth-child(even) .feature-media { order: 2; }
.feature-media { position: relative; display: flex; align-items: center; justify-content: center; min-height: clamp(360px, 42vw, 480px); }
.feature-media .panel { position: absolute; inset: 4% 6%; border-radius: 34px; background: linear-gradient(155deg, color-mix(in srgb, var(--accent) 22%, #fff), color-mix(in srgb, var(--accent) 4%, #fff)); border: 1px solid color-mix(in srgb, var(--accent) 18%, var(--line)); overflow: hidden; }
.feature-media .panel::after { content: ""; position: absolute; width: 70%; height: 70%; left: -10%; top: -20%; background: radial-gradient(circle, color-mix(in srgb, var(--accent) 45%, transparent), transparent 70%); filter: blur(20px); }
.feature-media .phone { position: relative; z-index: 2; width: clamp(190px, 24vw, 248px); transform: rotate(-5deg); box-shadow: var(--shadow-lg); }
.feature-media .phone.peek { position: absolute; z-index: 1; width: clamp(160px, 20vw, 210px); transform: rotate(9deg) translate(46px, 18px); opacity: .96; box-shadow: 0 24px 50px -22px rgba(20,21,26,.5); }
.feature-media .browser { position: relative; z-index: 2; width: min(94%, 460px); transform: rotate(-1.5deg); }
.feature-copy .icon-tile { width: 62px; height: 62px; border-radius: 16px; box-shadow: var(--shadow); margin-bottom: 18px; object-fit: cover; }
.feature-copy .icon-tile.mono { display: grid; place-items: center; color: #fff; font-family: var(--display); font-weight: 700; font-size: 24px; }
.feature-copy .kicker { font-family: var(--display); font-size: 12.5px; letter-spacing: .12em; text-transform: uppercase; color: var(--accent-dark); font-weight: 600; }
.feature-copy h2 { font-size: clamp(28px, 4.2vw, 46px); font-weight: 700; letter-spacing: -0.035em; margin: 10px 0 0; line-height: 1.02; }
.feature-copy .ftag { font-family: var(--display); font-size: clamp(16px, 2vw, 20px); color: var(--ink); margin-top: 14px; font-weight: 500; }
.feature-copy .fblurb { color: var(--muted); font-size: 16px; margin-top: 12px; max-width: 520px; }
.feat-list { list-style: none; margin: 22px 0 0; padding: 0; display: grid; gap: 12px; max-width: 520px; }
.feat-list li { display: flex; gap: 12px; align-items: flex-start; font-size: 15px; }
.feat-list .tick { flex: none; width: 22px; height: 22px; border-radius: 7px; background: linear-gradient(135deg, var(--accent), var(--accent-dark)); color: #fff; display: grid; place-items: center; font-size: 12px; margin-top: 1px; }
.feat-list b { font-weight: 600; }
.feat-list span.t { color: var(--ink); }
.feature-copy .store-row { margin-top: 26px; }
.feature-copy .more { display: inline-flex; align-items: center; gap: 7px; margin-top: 18px; font-family: var(--display); font-weight: 600; font-size: 15px; color: var(--accent-dark); text-decoration: none; }
.feature-copy .more:hover .arrow { transform: translateX(5px); }
.feature-copy .more .arrow { transition: transform .2s; }
@media (max-width: 860px) {
  .feature-row { grid-template-columns: 1fr; gap: 30px; }
  .feature-row:nth-child(even) .feature-media { order: 0; }
  .feature-media { min-height: 360px; }
}

/* values trio + home CTA */
.values { display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 22px; }
.value { border: 1px solid var(--line); border-radius: 22px; padding: 32px 28px; background: var(--bg); transition: box-shadow .2s, transform .2s, border-color .2s; }
.value:hover { box-shadow: var(--shadow); transform: translateY(-4px); border-color: transparent; }
.value .vnum { font-family: var(--display); font-weight: 700; font-size: 19px; background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; }
.value h3 { font-size: 20px; font-weight: 600; letter-spacing: -0.02em; margin-top: 14px; }
.value p { color: var(--muted); font-size: 15px; margin-top: 9px; }
.home-cta { text-align: center; padding: 40px 0 96px; }
.home-cta h2 { font-size: clamp(30px, 5vw, 50px); font-weight: 700; letter-spacing: -0.035em; }
.home-cta p { color: var(--muted); font-size: 18px; margin-top: 12px; }
.home-cta .btn-primary { margin-top: 28px; }

/* scroll reveal */
[data-reveal] { opacity: 0; transform: translateY(34px); transition: opacity .8s ease, transform .8s cubic-bezier(.2,.7,.2,1); }
[data-reveal].in { opacity: 1; transform: none; }
@media (prefers-reduced-motion: reduce) { [data-reveal] { opacity: 1; transform: none; transition: none; } }

/* big support block */
.support-xl { padding: 30px 0 90px; }
.support-xl .support-card { padding: clamp(54px, 8vw, 92px) 28px; border-radius: 36px; }
.support-xl .support-card h2 { font-size: clamp(30px, 5vw, 52px); }
.support-xl .support-card .sub-eyebrow { color: rgba(255,255,255,.6); font-family: var(--display); font-size: 12.5px; letter-spacing: .14em; text-transform: uppercase; display: block; margin-bottom: 16px; }
.support-card .sub-eyebrow { color: rgba(255,255,255,.62); font-family: var(--display); font-size: 12.5px; letter-spacing: .14em; text-transform: uppercase; display: block; margin-bottom: 14px; }

/* support page — per-app help cards */
.support-apps { display: grid; grid-template-columns: repeat(auto-fill, minmax(290px, 1fr)); gap: 18px; }
.sup-app { display: flex; gap: 16px; align-items: flex-start; border: 1px solid var(--line); border-radius: 18px; padding: 18px 20px; background: var(--bg); transition: box-shadow .18s, transform .18s; }
.sup-app:hover { box-shadow: var(--shadow); transform: translateY(-3px); }
.sup-app .icon-tile { width: 52px; height: 52px; border-radius: 14px; flex: none; object-fit: cover; box-shadow: var(--shadow-sm); }
.sup-app .icon-tile.mono { display: grid; place-items: center; color: #fff; font-family: var(--display); font-weight: 700; font-size: 18px; }
.sup-app h3 { font-size: 17px; font-weight: 600; }
.sup-app p { color: var(--muted); font-size: 13px; margin-top: 2px; }
.sup-links { display: flex; gap: 14px; margin-top: 10px; flex-wrap: wrap; }
.sup-links a { font-size: 13.5px; color: var(--accent-dark); font-weight: 600; text-decoration: none; }
.sup-links a:hover { text-decoration: underline; }
