@charset "utf-8";

@font-face {
  font-family: 'Satoshi';
  src: url('/fonts/Satoshi-Variable.woff2') format('woff2'),
       url('/fonts/Satoshi-Variable.woff') format('woff');
  font-weight: 300 900;
  font-display: swap;
  font-style: normal;
}

:root { --paper: #f3f1ec; --paper-2: #ebe8e1; --paper-3: #e3dfd6; --ink: #15161a; --ink-2: #2b2d33; --ink-3: #5e6168; --muted: #91959d; --line: rgba(21,22,26,0.08); --line-2: rgba(21,22,26,0.14); --card: #fbfaf6; --dark: #15161a; --plum: #1e1633; --plum-2: #2a1f4d; --teal-deep: #08323a; --aurora: #14182a; --grad: linear-gradient(120deg, #2bd4d9 0%, #b86cff 45%, #ff5fa3 70%, #e88638 100%); --signal: #2bd4d9; --r-xl: 28px; --r-lg: 22px; --r-md: 16px; --r-pill: 999px; --shadow-card: 0 1px 0 rgba(255,255,255,0.6) inset, 0 18px 40px -28px rgba(21,22,26,0.18); --shadow-soft: 0 1px 0 rgba(255,255,255,0.5) inset, 0 8px 24px -16px rgba(21,22,26,0.12); --font-display: 'Satoshi', 'General Sans', ui-sans-serif, system-ui, sans-serif; --font-body: 'Satoshi', ui-sans-serif, system-ui, sans-serif; --font-mono: 'Inter', ui-sans-serif, sans-serif; }

@media (prefers-reduced-motion: reduce) {
  *, ::before, ::after { animation-duration: 0.01ms !important; animation-iteration-count: 1 !important; transition-duration: 0.01ms !important; }
}

:focus-visible { outline: rgb(184, 108, 255) solid 2px; outline-offset: 3px; border-radius: 4px; }

*, ::before, ::after { box-sizing: border-box; -webkit-tap-highlight-color: transparent; }

html, body { margin: 0px; padding: 0px; }

html { background: var(--paper); }

body { font-family: var(--font-body); color: var(--ink); background: var(--paper); -webkit-font-smoothing: antialiased; text-rendering: optimizeLegibility; line-height: 1.45; }

a { color: inherit; text-decoration: none; }

button { font: inherit; color: inherit; background: none; border: 0px; cursor: pointer; padding: 0px; }

img { display: block; max-width: 100%; }

body::before { content: ""; position: fixed; inset: 0px; pointer-events: none; z-index: 0; background-image: radial-gradient(circle at 25% 0%, rgba(184, 108, 255, 0.06) 0%, transparent 40%), radial-gradient(circle at 75% 100%, rgba(43, 212, 217, 0.05) 0%, transparent 45%); }

.shell { position: relative; z-index: 1; max-width: 1280px; margin: 0px auto; padding: 14px 16px 88px; }

@media (min-width: 768px) {
  .shell { padding: 28px 32px 120px; }
}

@media (min-width: 1024px) {
  .shell { padding: 36px 48px 140px; }
}

.topbar { display: flex; align-items: center; justify-content: space-between; gap: 12px; padding-top: 10px; position: relative; }

@media (min-width: 768px) {
  .topbar { padding-top: 18px; }
}

.brand { display: inline-flex; align-items: baseline; gap: 7px; text-decoration: none; line-height: 1; flex-shrink: 0; }

.brand-name { font-family: var(--font-display); font-weight: 700; font-size: 19px; letter-spacing: -0.015em; background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; padding-bottom: 3px; }

.brand-sub { font-family: var(--font-display); font-weight: 300; font-size: 19px; color: var(--ink-3); letter-spacing: -0.015em; }

@media (min-width: 768px) {
  .brand-name { font-size: 22px; }
  .brand-sub { font-size: 22px; }
}

.nav-desktop { display: none; gap: 2px; align-items: center; position: absolute; left: 50%; transform: translateX(-50%); }

@media (min-width: 768px) {
  .nav-desktop { display: flex; }
}

.nav-link { padding: 9px 13px; font-size: 14px; white-space: nowrap; font-weight: 500; color: var(--ink-2); text-decoration: none; border-radius: 10px; transition: color 0.15s, background 0.15s; background: transparent; border: 0px; cursor: pointer; font-family: inherit; letter-spacing: 0px; }

.nav-link:hover { color: var(--ink); background: rgba(0, 0, 0, 0.04); }

.nav-link-dd { display: inline-flex; align-items: center; gap: 5px; }

.nav-link-dd .caret { transition: transform 0.2s; opacity: 0.55; display: inline-flex; }

.nav-link-dd.open .caret { transform: rotate(180deg); }

.nav-dd { position: relative; }

.nav-panel { position: absolute; top: calc(100% + 6px); left: -4px; min-width: 320px; background: var(--card); border: 1px solid var(--line); border-radius: 16px; padding: 8px; box-shadow: var(--shadow-soft); opacity: 0; pointer-events: none; transform: translateY(-4px); transition: opacity 0.18s, transform 0.18s; z-index: 20; }

.nav-panel.open { opacity: 1; pointer-events: auto; transform: translateY(0px); }

.nav-panel-item { display: flex; align-items: flex-start; gap: 12px; padding: 10px 12px; border-radius: 10px; text-decoration: none; color: var(--ink); transition: background 0.15s; }

.nav-panel-item:hover { background: var(--paper-2); }

.nav-panel-ico { width: 36px; height: 36px; border-radius: 11px; background: var(--paper-2); display: grid; place-items: center; color: var(--ink-2); flex-shrink: 0; margin-top: 1px; transition: background 0.25s, color 0.25s; }

.nav-panel-item:nth-child(1):hover .nav-panel-ico { background: linear-gradient(135deg, rgba(43, 212, 217, 0.18), rgba(184, 108, 255, 0.18)); color: rgb(43, 212, 217); }

.nav-panel-item:nth-child(2):hover .nav-panel-ico { background: linear-gradient(135deg, rgba(184, 108, 255, 0.18), rgba(255, 95, 163, 0.18)); color: rgb(184, 108, 255); }

.nav-panel-item:nth-child(3):hover .nav-panel-ico { background: linear-gradient(135deg, rgba(255, 95, 163, 0.18), rgba(255, 162, 87, 0.18)); color: rgb(255, 95, 163); }

.nav-panel-item:nth-child(4):hover .nav-panel-ico { background: linear-gradient(135deg, rgba(255, 162, 87, 0.18), rgba(255, 215, 110, 0.22)); color: rgb(255, 150, 87); }

.nav-panel-t { display: block; font-size: 14px; font-weight: 600; color: var(--ink); letter-spacing: 0px; }

.nav-panel-d { display: block; font-size: 12.5px; color: var(--ink-3); margin-top: 2px; line-height: 1.4; }

.social-link { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; background: rgba(255, 255, 255, 0.34); border: 1px solid rgba(21, 22, 26, 0.043); color: rgba(43, 45, 51, 0.72); cursor: pointer; text-decoration: none; transition: color 0.18s, background 0.18s, border-color 0.18s, box-shadow 0.18s; }

.social-link:not(a):not(button) { cursor: default; }

.social-link svg { opacity: 0.9; }

.social-link:hover { color: var(--ink); background: rgba(251, 250, 246, 0.72); border-color: rgba(21, 22, 26, 0.08); box-shadow: rgba(21, 22, 26, 0.35) 0px 8px 22px -18px; }

.topbar-icons { display: flex; gap: 6px; align-items: center; }

.hamburger { display: grid; place-items: center; width: 42px; height: 42px; background: var(--card); border-radius: 12px; box-shadow: var(--shadow-soft); color: var(--ink); }

@media (min-width: 768px) {
  .hamburger { display: none; }
}

.menu-close { display: grid; place-items: center; width: 42px; height: 42px; background: var(--card); border-radius: 12px; box-shadow: var(--shadow-soft); color: var(--ink); border: 0; cursor: pointer; font: inherit; }

.topbar-icons.mobile-hide { display: none; }

@media (min-width: 768px) {
  .topbar-icons.mobile-hide { display: flex; }
}

.mobile-menu { position: fixed; inset: 0px; z-index: 100; background: var(--paper); padding: 22px; display: flex; flex-direction: column; transform: translateY(-100%); transition: transform 0.3s; }

.mobile-menu.open { transform: translateY(0px); }

.mobile-menu-head { display: flex; justify-content: space-between; align-items: center; }

.mobile-menu nav { margin-top: 36px; display: flex; flex-direction: column; gap: 4px; }

.mobile-menu nav a { font-family: var(--font-display); font-size: 32px; font-weight: 500; letter-spacing: 0px; color: var(--ink); padding: 10px 0px; border-bottom: 1px solid var(--line); display: block; }

.mobile-menu nav .mobile-nav-parent { border-bottom: none; padding-bottom: 4px; }

.mobile-nav-sub { border-bottom: 1px solid var(--line); padding-bottom: 10px; display: flex; flex-direction: column; }

.mobile-menu nav .mobile-nav-sub a { font-size: 20px; font-weight: 400; color: var(--ink-3); padding: 6px 0; border-bottom: none; letter-spacing: 0; }

.mobile-menu .socials { margin-top: auto; display: flex; gap: 8px; padding-top: 24px; }

.hero { margin-top: 24px; max-width: 1120px; }

@media (min-width: 768px) {
  .hero { margin-top: 40px; }
}

@media (min-width: 1024px) {
  .hero { margin-top: 52px; }
}

.hero-main { display: grid; grid-template-columns: 1fr; gap: 16px; align-items: start; }

@media (min-width: 860px) {
  .hero-main { grid-template-columns: 154px minmax(0px, 1fr); gap: 24px; }
}

.hero-avatar-stack { display: flex; flex-direction: column; align-items: flex-start; gap: 16px; }

.hero-avatar { width: 106px; height: 106px; border-radius: 24px; overflow: hidden; box-shadow: rgba(184, 108, 255, 0.4) 0px 10px 30px -12px, rgba(255, 255, 255, 0.6) 0px 1px 0px inset; }

.hero-avatar img { width: 100%; height: 100%; object-fit: cover; }

@media (min-width: 768px) {
  .hero-avatar { width: 124px; height: 124px; border-radius: 28px; }
}

.h1 { font-family: var(--font-display); font-weight: 700; font-size: 34px; line-height: 1.127; letter-spacing: -0.025em; margin: 0px; color: var(--ink); text-wrap: balance; }

@media (min-width: 768px) {
  .h1 { font-size: 58px; }
}

@media (min-width: 1100px) {
  .h1 { font-size: 76px; }
}

.desktop-break { display: none; }

@media (min-width: 1024px) {
  .desktop-break { display: block; }
}

.geo-break { display: none; }

.geo-sep { display: inline; }

@media (min-width: 860px) {
  .geo-break { display: block; }
  .geo-sep { display: none; }
}

.grad-text { background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent; font-weight: inherit; }

.geo-chip { display: block; font-family: var(--font-display); font-size: 10px; font-weight: 500; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); line-height: 1.45; max-width: 22ch; }

@media (min-width: 860px) {
  .geo-chip { line-height: 1.55; max-width: 15ch; }
}

@media (max-width: 540px) {
  .geo-chip { max-width: none; font-size: 9.5px; letter-spacing: 0px; }
}

.hero-sub { margin-top: 22px; color: var(--ink-2); font-size: 17px; line-height: 1.5; max-width: 56ch; font-weight: 400; letter-spacing: 0px; }

@media (min-width: 768px) {
  .hero-sub { font-size: 19px; }
}

@media (min-width: 1024px) {
  .hero-sub { font-size: 21px; }
}

.cta-row { margin-top: 35px; display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }

.btn { display: inline-flex; align-items: center; gap: 8px; padding: 14px 34px; border-radius: var(--r-pill); font-family: var(--font-display); font-size: 14.5px; font-weight: 600; letter-spacing: 0px; border: 1px solid transparent; text-decoration: none; cursor: pointer; transition: transform 0.15s, filter 0.15s, box-shadow 0.2s, background 0.2s, border-color 0.15s; white-space: nowrap; }

.btn:active { transform: scale(0.98); }

.btn-primary { background: var(--grad); background-origin: border-box; color: rgb(255, 255, 255); box-shadow: rgba(184, 108, 255, 0.55) 0px 12px 32px -16px; }

.btn-primary:hover { filter: brightness(1.06); box-shadow: rgba(184, 108, 255, 0.6) 0px 14px 36px -14px; }

.btn-secondary { background: transparent; color: var(--ink); border-color: var(--line-2); }

.btn-secondary:hover { background: var(--paper-2); border-color: var(--ink-3); }

.btn-arrow { transition: transform 0.2s; display: inline-block; }

.btn:hover .btn-arrow { transform: translateX(3px); }

.trust-row { margin-top: 28px; display: grid; grid-template-columns: repeat(2, 1fr); max-width: 920px; gap: 0px 18px; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }

.trust { padding: 22px 18px 22px 0px; border-bottom: 1px solid var(--line); }

.trust:nth-child(2n) { padding-right: 0px; padding-left: 0px; }

.trust:nth-last-child(-n+2) { border-bottom: 0px; }

@media (min-width: 768px) {
  .trust-row { grid-template-columns: repeat(4, 1fr); margin-top: 30px; gap: 0px 28px; }
  .trust { padding: 24px 0px; border-bottom: 0px; }
  .trust:nth-child(2n) { padding-left: 0px; }
}

@media (min-width: 860px) {
  .trust-row { margin-left: 178px; max-width: 920px; }
}

.trust-n { font-family: var(--font-display); font-size: 38px; font-weight: 600; line-height: 1; letter-spacing: 0px; color: var(--ink); }

@media (min-width: 768px) {
  .trust-n { font-size: 48px; }
}

.trust-plus { background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; font-weight: 700; }

.trust-l { margin-top: 8px; font-family: var(--font-display); font-size: 11px; font-weight: 500; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); line-height: 1.3; }

.section { margin-top: 48px; }

@media (min-width: 768px) {
  .section { margin-top: 68px; }
}

@media (min-width: 1024px) {
  .section { margin-top: 88px; }
}

.section-head { display: grid; grid-template-columns: 1fr; gap: 14px; margin-bottom: 24px; }

@media (min-width: 768px) {
  .section-head { grid-template-columns: 1fr 1fr; align-items: end; gap: 32px; margin-bottom: 32px; }
}

.section-head h2 { margin: 0px; font-family: var(--font-display); font-weight: 700; font-size: 30px; line-height: 1.02; letter-spacing: -0.02em; color: var(--ink); text-wrap: balance; }

@media (min-width: 768px) {
  .section-head h2 { font-size: 40px; }
}

@media (min-width: 1024px) {
  .section-head h2 { font-size: 48px; }
}

.section-head .desc { color: var(--ink-3); font-size: 15px; line-height: 1.55; max-width: 44ch; margin: 0px; }

@media (min-width: 768px) {
  .section-head .desc { font-size: 16px; }
}

@media (min-width: 1024px) {
  .section-head .desc { font-size: 17px; }
}

.grid { display: grid; grid-template-columns: 1fr; gap: 14px; }

@media (min-width: 768px) {
  .grid.cols-2 { grid-template-columns: 1fr 1fr; }
}

@media (min-width: 1024px) {
  .grid { gap: 18px; }
  .grid.cols-3 { grid-template-columns: repeat(3, 1fr); }
  .grid.cols-2-1 { grid-template-columns: 2fr 1fr; }
  .grid.cols-1-2 { grid-template-columns: 1fr 2fr; }
}

.card { background: var(--card); border-radius: var(--r-xl); padding: 22px; position: relative; overflow: hidden; box-shadow: var(--shadow-card); }

@media (min-width: 768px) {
  .card { padding: 28px; }
}

.card.aurora { background: linear-gradient(155deg, rgb(26, 18, 48) 0%, rgb(13, 14, 26) 100%); color: rgb(255, 255, 255); box-shadow: none; }

.card.aurora p { color: rgba(255, 255, 255, 0.78); }

.card.teal { background: linear-gradient(155deg, rgb(14, 26, 34) 0%, rgb(7, 16, 26) 100%); color: rgb(255, 255, 255); box-shadow: none; }

.card.teal p { color: rgba(255, 255, 255, 0.7); }

.card.dark { background: var(--dark); color: rgb(255, 255, 255); box-shadow: none; }

.card.dark p { color: rgba(255, 255, 255, 0.7); }

.card.dark h3, .card.aurora h3, .card.teal h3 { color: rgb(255, 255, 255); }

.card.aurora .card-label, .card.teal .card-label, .card.dark .card-label { color: rgba(255, 255, 255, 0.78); }

.card-label { display: inline-flex; align-items: center; gap: 8px; font-family: var(--font-display); font-size: 11px; font-weight: 500; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); }

.card-label .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--grad); }

.card h3 { font-family: var(--font-display); font-weight: 700; font-size: 25px; line-height: 1.1; letter-spacing: -0.02em; margin: 14px 0px 12px; text-wrap: balance; }

@media (min-width: 768px) {
  .card h3 { font-size: 28px; }
}

@media (min-width: 1024px) {
  .card h3 { font-size: 30px; }
}

.card p { margin: 0px; font-size: 16px; line-height: 1.55; color: var(--ink-3); }

.about-card { position: relative; border-radius: var(--r-xl); overflow: hidden; background-size: cover; background-position: center 25%; min-height: 540px; display: flex; align-items: flex-end; box-shadow: var(--shadow-card); color: rgb(255, 255, 255); }

.about-card::before { content: ""; position: absolute; inset: 0px; background: linear-gradient(rgba(5, 6, 10, 0.46) 0%, rgba(5, 6, 10, 0.66) 38%, rgba(5, 6, 10, 0.96) 92%), radial-gradient(92% 72% at 18% 100%, rgba(5, 6, 10, 0.88) 0%, rgba(5, 6, 10, 0.64) 46%, transparent 76%); }

.about-body { position: relative; z-index: 1; padding: 36px 32px; max-width: 720px; text-shadow: rgba(0, 0, 0, 0.38) 0px 1px 18px; }

.about-card .card-label { color: rgba(255, 255, 255, 0.85); }

.about-card h3 { margin: 14px 0px 18px; font-family: var(--font-display); font-weight: 600; font-size: 30px; letter-spacing: -0.02em; line-height: 1.05; color: rgb(255, 255, 255); }

@media (min-width: 768px) {
  .about-card h3 { font-size: 38px; }
}

@media (min-width: 1024px) {
  .about-card h3 { font-size: 42px; }
}

.about-card p { margin: 0px 0px 12px; font-size: 15px; line-height: 1.6; color: rgba(255, 255, 255, 0.92); max-width: 56ch; }

.about-card p:last-child { margin-bottom: 0px; }

@media (min-width: 768px) {
  .about-card { min-height: 640px; }
  .about-body { padding: 44px; }
}

@media (min-width: 1024px) {
  .about-card { min-height: 720px; background-position: center 30%; }
  .about-body { padding: 56px; }
}

.pain-list { margin: 20px 0px 0px; padding: 0px; list-style: none; display: grid; grid-template-columns: 1fr; gap: 12px; }

@media (min-width: 768px) {
  .pain-list { grid-template-columns: 1fr 1fr; gap: 14px 28px; }
}

.pain { padding: 6px 4px 6px 28px; font-size: 16px; color: var(--ink-2); line-height: 1.45; position: relative; }

@media (min-width: 768px) {
  .pain { font-size: 17px; }
}

.pain::before { content: ""; position: absolute; left: 4px; top: 14px; width: 8px; height: 8px; border-radius: 50%; background: var(--grad); }

@media (min-width: 768px) {
  .pain { padding-right: 24px; }
  .pain:nth-child(2n+1) { padding-right: 24px; }
  .pain:nth-child(2n) { padding-left: 28px; }
}

.shift-list { margin-top: 20px; display: flex; flex-direction: column; gap: 8px; }

.shift-row { display: grid; grid-template-columns: 32px 1fr; align-items: center; gap: 16px; padding: 16px 18px; background: rgba(255, 255, 255, 0.04); border: 1px solid rgba(255, 255, 255, 0.08); border-radius: 16px; }

.shift-row .n { font-family: var(--font-mono); font-size: 11px; color: rgba(255, 255, 255, 0.4); align-self: start; padding-top: 4px; }

.shift-item { display: flex; flex-direction: column; gap: 4px; }

.shift-row .lbl { font-size: 18px; font-weight: 500; letter-spacing: 0px; color: rgb(255, 255, 255); }

.shift-row .meta { font-size: 15px; color: rgba(255, 255, 255, 0.45); line-height: 1.5; }

.shift-arrow { height: 24px; display: grid; place-items: center; color: rgba(255, 255, 255, 0.3); }

.steps { margin-top: 20px; }

.step { display: grid; grid-template-columns: 56px 1fr; gap: 16px; padding: 22px 0px; min-height: 56px; border-bottom: 1px solid var(--line); align-items: center; }

.step:last-child { border-bottom: 0px; }

.step .num { font-family: var(--font-mono); font-size: 11px; font-weight: 400; align-self: start; padding-top: 4px; }

.steps .step:nth-child(1) .num { color: #2bd4d9; }
.steps .step:nth-child(2) .num { color: #56aeff; }
.steps .step:nth-child(3) .num { color: #b86cff; }
.steps .step:nth-child(4) .num { color: #e060c8; }
.steps .step:nth-child(5) .num { color: #ff5fa3; }
.steps .step:nth-child(6) .num { color: #ff7a56; }
.steps .step:nth-child(7) .num { color: #e88638; }
.steps .step:nth-child(8) .num { color: #f5c43a; }

.step h4 { margin: 0px 0px 4px; font-size: 18px; font-weight: 500; letter-spacing: 0px; }

@media (min-width: 768px) {
  .step h4 { font-size: 19px; }
  .shift-row .lbl { font-size: 19px; }
}

@media (min-width: 1024px) {
  .step h4 { font-size: 20px; }
  .shift-row .lbl { font-size: 20px; }
}

.step p { margin: 0px; font-size: 15px; color: var(--ink-3); line-height: 1.5; }

.tradeoffs { display: grid; grid-template-columns: 1fr; gap: 16px; margin-top: 20px; }

@media (min-width: 768px) {
  .tradeoffs { grid-template-columns: 1fr 1fr; gap: 12px; }
}

.tradeoff { padding: 18px; border: 1px solid rgba(255, 255, 255, 0.1); background: rgba(255, 255, 255, 0.04); border-radius: 16px; }

.tradeoff .lbl { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0px; text-transform: uppercase; color: rgba(255, 255, 255, 0.5); }

.tradeoff h4 { margin: 5px 0px 4px; font-size: 16px; font-weight: 500; color: rgb(255, 255, 255); letter-spacing: 0px; }

.tradeoff p { margin: 0px; font-size: 14px; color: rgba(255, 255, 255, 0.6); line-height: 1.5; }

.resource-stack { display: grid; grid-template-columns: 1fr; gap: 14px; }

.resource-banner { display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 18px; padding: 22px 24px; background: var(--card); border: 1px solid var(--line); border-radius: 18px; text-decoration: none; color: inherit; transition: box-shadow 0.2s, border-color 0.2s; }

.resource-banner:hover { border-color: var(--line-2); box-shadow: var(--shadow-soft); }

.resource-ico { width: 52px; height: 52px; border-radius: 14px; background: var(--paper-2); display: grid; place-items: center; color: var(--ink); flex-shrink: 0; transition: background 0.25s, color 0.25s; }

.resource-banner:hover .resource-ico { background: var(--grad); color: rgb(255, 255, 255); }

.resource-body { display: flex; flex-direction: column; gap: 4px; min-width: 0px; }

.resource-body h4 { margin: 0px; font-family: var(--font-display); font-size: 18px; font-weight: 600; letter-spacing: 0px; color: var(--ink); }

@media (min-width: 768px) {
  .resource-body h4 { font-size: 19px; }
}

.resource-body p { margin: 0px; font-size: 15px; color: var(--ink-3); line-height: 1.45; }

.resource-meta { font-family: var(--font-display); font-size: 10.5px; font-weight: 600; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 2px; }

.resource-cta { display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display); font-size: 13px; font-weight: 600; color: var(--ink-2); white-space: nowrap; flex-shrink: 0; }

.resource-banner:hover .resource-cta { color: var(--ink); }

@media (max-width: 640px) {
  .resource-banner { grid-template-columns: auto 1fr; padding: 20px; gap: 16px; }
  .resource-cta { grid-column: 1 / -1; padding-left: 68px; margin-top: -4px; }
}

.blog-tabs { display: flex; gap: 6px; overflow-x: auto; margin-bottom: 18px; scrollbar-width: none; mask-image: linear-gradient(90deg, rgb(0, 0, 0) 0%, rgb(0, 0, 0) 92%, transparent 100%); }

.blog-tabs::-webkit-scrollbar { display: none; }

.blog-tab { padding: 9px 16px; border-radius: 999px; font-size: 12.5px; font-weight: 500; font-family: var(--font-display); background: var(--card); color: var(--ink-3); white-space: nowrap; transition: 0.18s; border: 1px solid var(--line); cursor: pointer; }

.blog-tab.active { background: var(--ink); color: rgb(255, 255, 255); border-color: var(--ink); }

.blog-tab:not(.active):hover { color: var(--ink); }

.blog-grid { display: grid; grid-template-columns: 1fr; gap: 36px 28px; }

@media (min-width: 768px) {
  .blog-grid { grid-template-columns: 1fr 1fr; gap: 44px 32px; }
}

@media (min-width: 1024px) {
  .blog-grid { grid-template-columns: repeat(3, 1fr); gap: 48px 32px; }
}

.post { text-decoration: none; color: inherit; display: flex; flex-direction: column; gap: 12px; transition: transform 0.25s; }

.post:hover { transform: scale(1.01); }

.post-thumb { aspect-ratio: 2 / 1; border-radius: 14px; background-size: cover; background-position: center center; background-color: var(--paper-2); transition: filter 0.2s; }

.post:hover .post-thumb { filter: brightness(0.97); }

.post-meta { margin-top: 4px; display: inline-flex; align-items: center; gap: 6px; font-family: var(--font-display); font-size: 11px; font-weight: 500; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); }

.post-cat { color: var(--ink-2); }

.post-dot { opacity: 0.5; }

.post h4 { margin: 0px; font-family: var(--font-display); font-size: 18px; font-weight: 600; letter-spacing: -0.015em; line-height: 1.25; color: var(--ink); }

@media (min-width: 768px) {
  .post h4 { font-size: 19px; }
}

@media (min-width: 1024px) {
  .post h4 { font-size: 20px; }
}

.post-arrow { margin-top: 2px; font-size: 13px; font-weight: 500; color: var(--ink-3); transition: color 0.15s; }

.post:hover .post-arrow { color: var(--ink); }

.tool-cat { margin-top: 20px; }

.tool-cat-title { display: flex; align-items: center; gap: 12px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 10px; }

.tool-cat-title .line { flex: 1 1 0%; height: 1px; background: var(--line); }

.tools-grid { display: grid; grid-template-columns: 1fr; gap: 0px; }

@media (min-width: 768px) {
  .tools-grid { grid-template-columns: 1fr 1fr; gap: 0px 24px; }
}

.tool { display: grid; grid-template-columns: 44px 1fr auto; gap: 14px; padding: 14px 0px; align-items: center; border-bottom: 1px solid var(--line); }

.tool-logo { width: 44px; height: 44px; border-radius: 12px; display: grid; place-items: center; font-weight: 600; font-size: 16px; color: rgb(255, 255, 255); letter-spacing: 0px; }

.tool h5 { margin: 0px; font-size: 14px; font-weight: 500; letter-spacing: 0px; }

.tool p { margin: 2px 0px 0px; font-size: 12.5px; color: var(--ink-3); }

.tool .ext { color: var(--muted); }

.coaching-flow { display: grid; grid-template-columns: 1fr; gap: 14px; align-items: stretch; }

@media (min-width: 900px) {
  .coaching-flow { grid-template-columns: 1fr auto 1.4fr; gap: 20px; }
}

.coach-step { background: var(--card); border: 1px solid var(--line); border-radius: var(--r-xl); padding: 28px; display: flex; flex-direction: column; gap: 14px; box-shadow: var(--shadow-soft); }

.coach-step.paid { background: linear-gradient(155deg, rgb(26, 18, 48) 0%, rgb(13, 14, 26) 100%); color: rgb(255, 255, 255); border-color: transparent; box-shadow: none; }

.coach-step.paid p { color: rgba(255, 255, 255, 0.78); }

.coach-step.paid h3 { color: rgb(255, 255, 255); }

.coach-step-tag { display: inline-flex; align-items: center; align-self: flex-start; padding: 6px 12px; border-radius: 999px; background: var(--paper-2); font-family: var(--font-display); font-size: 10.5px; font-weight: 600; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-2); }

.coach-step.paid .coach-step-tag { background: rgba(255, 255, 255, 0.12); color: rgb(255, 255, 255); }

.coach-step h3 { margin: 0px; font-family: var(--font-display); font-weight: 600; font-size: 25px; letter-spacing: -0.02em; line-height: 1.15; }

@media (min-width: 768px) {
  .coach-step h3 { font-size: 27px; }
}

@media (min-width: 1024px) {
  .coach-step h3 { font-size: 28px; }
}

.coach-step p { margin: 0px; font-size: 16px; line-height: 1.55; color: var(--ink-3); }

.coach-step .btn { align-self: flex-start; margin-top: auto; }

.coach-price { font-family: var(--font-display); font-weight: 700; font-size: 36px; letter-spacing: 0px; color: rgb(255, 255, 255); line-height: 1; display: flex; align-items: baseline; gap: 10px; margin-top: 4px; }

.coach-price small { font-size: 12px; font-weight: 500; letter-spacing: 0px; text-transform: uppercase; color: rgba(255, 255, 255, 0.55); }

.coach-checks { list-style: none; margin: 0px; padding: 0px; display: flex; flex-direction: column; gap: 10px; }

.coach-checks li { display: flex; align-items: flex-start; gap: 10px; font-size: 14px; color: rgba(255, 255, 255, 0.85); line-height: 1.45; }

.coach-checks .ck { width: 18px; height: 18px; border-radius: 50%; background: rgba(43, 212, 217, 0.22); color: var(--signal); display: grid; place-items: center; flex: 0 0 18px; margin-top: 2px; }

.coach-arrow { display: grid; place-items: center; color: var(--ink-3); transform: rotate(90deg); padding: 6px 0px; }

@media (min-width: 900px) {
  .coach-arrow { transform: none; padding: 0px 4px; }
}

.btn-white { background: rgb(255, 255, 255); color: var(--ink); box-shadow: rgba(0, 0, 0, 0.6) 0px 12px 32px -16px; }

.btn-white:hover { background: rgba(255, 255, 255, 0.94); }

.newsletter { padding: 56px 36px; border-radius: var(--r-xl); background: var(--card); border: 1px solid var(--line); text-align: center; box-shadow: var(--shadow-soft); position: relative; overflow: hidden; }

.newsletter::before { content: ""; position: absolute; inset: 0px; background: radial-gradient(60% 60% at 50% 0%, rgba(184, 108, 255, 0.12) 0%, transparent 70%); pointer-events: none; }

.newsletter > * { position: relative; z-index: 1; }

@media (max-width: 540px) {
  .newsletter { padding: 36px 20px; }
  .newsletter-title { font-size: 22px; margin: 16px 0px 10px; }
  .newsletter-desc { font-size: 14px; }
  .newsletter-desc-2 { display: none; }
  .newsletter-bullets { display: none; }
  .newsletter-consent { font-size: 11px; margin-top: 12px; }
  .newsletter-meta { display: none; }
}

.newsletter-eyebrow { display: inline-flex; align-items: center; gap: 8px; padding: 6px 14px; border-radius: 999px; background: var(--paper-2); font-family: var(--font-display); font-size: 11px; font-weight: 600; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-2); }

.newsletter-dot { width: 7px; height: 7px; border-radius: 50%; background: var(--grad); box-shadow: rgba(184, 108, 255, 0.18) 0px 0px 0px 3px; }

.newsletter-title { margin: 30px 0px 12px; font-family: var(--font-display); font-weight: 600; font-size: 30px; line-height: 1.05; letter-spacing: 0px; color: var(--ink); }

@media (min-width: 768px) {
  .newsletter-title { font-size: 40px; }
}

@media (min-width: 1024px) {
  .newsletter-title { font-size: 44px; }
}

.newsletter-desc { margin: 0px auto; max-width: 50ch; font-size: 15px; color: var(--ink-3); line-height: 1.55; }

.newsletter-desc-2 { margin-top: 8px; margin-bottom: 0px; }

@media (min-width: 768px) {
  .newsletter-desc { font-size: 16px; }
}

@media (min-width: 1024px) {
  .newsletter-desc { font-size: 17px; }
}

.newsletter-bullets { list-style: none; margin: 24px auto 28px; padding: 0px; display: inline-flex; flex-direction: column; gap: 10px; text-align: left; }

.newsletter-bullets li { display: flex; align-items: center; gap: 10px; font-size: 14.5px; color: var(--ink-2); }

.newsletter-bullets .ck { width: 20px; height: 20px; border-radius: 50%; background: var(--grad); color: rgb(255, 255, 255); display: grid; place-items: center; flex-shrink: 0; }

.newsletter-form { display: flex; gap: 8px; max-width: 460px; margin: 0px auto; background: var(--paper); border: 1px solid var(--line-2); border-radius: 999px; padding: 6px 6px 6px 22px; transition: border-color 0.15s, box-shadow 0.2s; }

.newsletter-form:focus-within { border-color: var(--ink-3); box-shadow: rgba(184, 108, 255, 0.12) 0px 0px 0px 4px; }

.newsletter-form input { flex: 1 1 0%; min-width: 0px; border: 0px; outline: 0px; background: transparent; font-family: inherit; font-size: 14.5px; padding: 12px 0px; color: var(--ink); }

.newsletter-form input::placeholder { color: var(--ink-3); }

.newsletter-form button { padding: 12px 28px; border-radius: 999px; border: 0px; background: var(--grad); color: rgb(255, 255, 255); font-family: var(--font-display); font-weight: 600; font-size: 14px; letter-spacing: 0px; cursor: pointer; box-shadow: rgba(184, 108, 255, 0.55) 0px 8px 22px -10px; transition: filter 0.15s, transform 0.15s; white-space: nowrap; }

.newsletter-form button:hover { filter: brightness(1.06); }

@media (max-width: 540px) {
  .newsletter-form { flex-direction: column; background: transparent; border: none; box-shadow: none; padding: 0; gap: 8px; margin: 4px auto 0; max-width: 300px; }
  .newsletter-form:focus-within { box-shadow: none; border-color: transparent; }
  .newsletter-form input { flex: none; width: 100%; height: 52px; padding: 0 20px; border: 1px solid var(--line-2); border-radius: var(--r-pill); background: var(--paper); font-size: 15px; box-sizing: border-box; }
  .newsletter-form button { width: 100%; height: 52px; padding: 0 20px; border-radius: var(--r-pill); box-sizing: border-box; }
}

.newsletter-consent { margin: 14px auto 0px; max-width: 420px; font-size: 11.5px; color: var(--muted); line-height: 1.5; }

.newsletter-consent a { color: var(--muted); text-decoration: underline; text-underline-offset: 2px; }

.newsletter-consent a:hover { color: var(--ink-3); }

.newsletter-meta { margin-top: 12px; font-family: var(--font-display); font-size: 12px; font-weight: 500; color: var(--ink-3); }

.newsletter-status { min-height: 1.4em; margin-top: 10px; font-size: 14px; }
.newsletter-status-ok { color: var(--grad-from, #7c3aed); font-weight: 600; }
.newsletter-status-err { color: #e05252; }

.beliefs { display: grid; grid-template-columns: 1fr; gap: 0px; border-top: 1px solid var(--line); }

@media (min-width: 768px) {
  .beliefs { grid-template-columns: 1fr 1fr; }
}

.belief { padding: 26px 0px; border-bottom: 1px solid var(--line); }

@media (min-width: 768px) {
  .belief { padding: 28px 28px 28px 0px; }
  .belief:nth-child(2n+1) { border-right: 1px solid var(--line); }
  .belief:nth-child(2n) { padding-left: 28px; padding-right: 0px; }
}

.belief-num { font-family: var(--font-display); font-size: 11px; font-weight: 500; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); margin-bottom: 14px; }

.belief-h { margin: 0px 0px 10px; font-family: var(--font-display); font-size: 23px; font-weight: 600; letter-spacing: 0px; line-height: 1.15; display: flex; flex-wrap: wrap; align-items: baseline; gap: 10px; }

@media (min-width: 768px) {
  .belief-h { font-size: 26px; }
}

@media (min-width: 1024px) {
  .belief-h { font-size: 28px; }
}

.belief-h .strike { text-decoration: line-through; color: var(--ink-3); font-weight: 500; opacity: 0.6; }

.belief-h .new { background: var(--grad); -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent; color: transparent; }

.belief p { margin: 0px; font-size: 15px; color: var(--ink-3); line-height: 1.55; max-width: 42ch; }

@media (min-width: 768px) {
  .belief p { font-size: 16px; }
}

.faq-list { display: flex; flex-direction: column; gap: 10px; }

.faq-item { background: var(--card); border-radius: 18px; padding: 22px; border: 1px solid var(--line); cursor: pointer; transition: border-color 0.18s, background 0.18s; }

.faq-item:hover { border-color: var(--line-2); }

.faq-q { display: flex; align-items: center; gap: 12px; font-size: 17px; font-weight: 500; letter-spacing: 0px; }

.faq-q .plus { margin-left: auto; width: 22px; height: 22px; display: grid; place-items: center; color: var(--ink-3); transition: transform 0.25s; flex-shrink: 0; }

.faq-item.open .faq-q .plus { transform: rotate(45deg); color: var(--ink); }

.faq-a { max-height: 0px; overflow: hidden; transition: max-height 0.35s, margin-top 0.25s; font-size: 15.5px; color: var(--ink-3); line-height: 1.55; }

.faq-item.open .faq-a { max-height: 280px; margin-top: 12px; }

.footer { margin-top: 100px; padding: 40px 0px 0px; border-top: 1px solid var(--line); }

.footer-grid { display: grid; grid-template-columns: 1fr; gap: 32px; }

@media (min-width: 768px) {
  .footer-grid { grid-template-columns: 1.4fr 1fr 1fr; gap: 48px; }
}

.footer-brand p { margin: 0px; font-size: 14px; color: var(--ink-3); max-width: 36ch; line-height: 1.55; }

.footer-socials { display: flex; gap: 8px; margin-top: 18px; }

.footer-logo { margin-bottom: 16px; display: inline-flex; }

.footer-col h6 { margin: 0px 0px 14px; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0px; text-transform: uppercase; color: var(--ink-3); font-weight: 500; }

.footer-col a { display: block; padding: 6px 0px; font-size: 14px; color: var(--ink-2); transition: color 0.18s; }

.footer-col a:hover { color: var(--ink); }

.footer-meta { margin-top: 48px; padding: 24px 0px; border-top: 1px solid var(--line); display: flex; justify-content: space-between; align-items: center; flex-wrap: wrap; gap: 12px; font-family: var(--font-mono); font-size: 11px; color: var(--muted); letter-spacing: 0px; text-transform: uppercase; }

.footer-meta .live { display: inline-flex; align-items: center; gap: 8px; }

.footer-meta .live-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--signal); box-shadow: 0 0 8px var(--signal); animation: 1.6s ease-out 0s infinite normal none running livePulse; }

@keyframes livePulse { 
  0% { box-shadow: rgba(43, 212, 217, 0.6) 0px 0px 0px 0px; }
  100% { box-shadow: rgba(43, 212, 217, 0) 0px 0px 0px 8px; }
}

svg { display: block; }

/* Astro secondary page extensions using the captured front-page system. */
.page-main { position: relative; z-index: 1; max-width: 1280px; margin: 0 auto; padding: 14px 22px 88px; }
@media (min-width: 768px) { .page-main { padding: 28px 32px 120px; } }
@media (min-width: 1024px) { .page-main { padding: 36px 48px 140px; } }
.page-hero { margin-top: 64px; max-width: 920px; }
.page-hero h1 { margin: 0; font-family: var(--font-display); font-weight: 700; font-size: clamp(38px, 7vw, 76px); line-height: 0.98; letter-spacing: 0; color: var(--ink); text-wrap: balance; }
.page-hero .lede { margin-top: 22px; color: var(--ink-2); font-size: clamp(17px, 1.6vw, 21px); line-height: 1.5; max-width: 56ch; }
.page-eyebrow { display: inline-flex; align-items: center; gap: 8px; margin-bottom: 18px; font-size: 11px; font-weight: 500; text-transform: uppercase; color: var(--ink-3); }
.content-page { max-width: 760px; margin-top: 36px; }
.content-page h2 { margin: 40px 0 12px; font-size: 30px; line-height: 1.08; letter-spacing: 0; }
.content-page p, .content-page li { color: var(--ink-3); font-size: 16px; line-height: 1.65; }
.content-page a { color: var(--ink); font-weight: 600; text-decoration: underline; text-decoration-color: var(--line-2); text-underline-offset: 4px; }
.page-actions { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 10px; }
.site-shell { max-width: 1280px; margin-left: auto; margin-right: auto; }
.button-row { margin-top: 28px; display: flex; flex-wrap: wrap; gap: 10px; }
.button { display: inline-flex; align-items: center; gap: 8px; padding: 14px 34px; border-radius: var(--r-pill); font-family: var(--font-display); font-size: 14.5px; font-weight: 600; border: 1px solid transparent; text-decoration: none; cursor: pointer; transition: transform .15s ease, filter .15s ease, box-shadow .2s ease, background .2s ease, border-color .15s ease; white-space: nowrap; background: var(--grad); color: #fff; box-shadow: 0 12px 32px -16px rgba(184,108,255,0.55); }
.button.secondary { background: transparent; color: var(--ink); border-color: var(--line-2); box-shadow: none; }
.button.light { background: #fff; color: var(--ink); box-shadow: none; }
.grid.two { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid.three { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid.four { grid-template-columns: repeat(4, minmax(0, 1fr)); }
.grid.two, .grid.three, .grid.four { align-items: stretch; }
@media (max-width: 900px) { .grid.two, .grid.three, .grid.four { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .grid.two, .grid.three, .grid.four { grid-template-columns: 1fr; } }
.resource-list, .post-list { display: grid; gap: 12px; }
.resource-row { display: flex; gap: 14px; align-items: center; padding: 20px; border-radius: var(--r-lg); background: var(--card); box-shadow: var(--shadow-soft); }
.resource-row h3, .post-row h3 { margin: 0 0 4px; font-size: 22px; line-height: 1.1; }
.resource-row p, .post-row p { margin: 0; color: var(--ink-3); font-size: 14px; }
.post-row { min-height: 170px; padding: 24px; border-radius: var(--r-xl); background: var(--card); box-shadow: var(--shadow-card); display: flex; flex-direction: column; justify-content: space-between; }
.skip-link { position: absolute; left: 1rem; top: 1rem; z-index: 20; transform: translateY(-150%); background: var(--ink); color: var(--paper); padding: .6rem .8rem; border-radius: 8px; }
.skip-link:focus { transform: translateY(0); }

/* Coaching page extras */
.coach-fit-list { margin: 16px 0 0; padding-left: 0; list-style: none; display: flex; flex-direction: column; gap: 10px; }
.coach-fit-list li { font-size: 14.5px; color: var(--ink-2); padding-left: 20px; position: relative; line-height: 1.45; }
.coach-fit-list li::before { content: "→"; position: absolute; left: 0; color: var(--signal); font-size: 13px; }
.coach-fit-no li::before { content: "✕"; color: var(--muted); }
.coach-note { margin-top: 16px; font-size: 13px; color: var(--muted); font-style: italic; }
.coach-mini-h { font-size: 13px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.04em; color: var(--ink-3); margin: 20px 0 10px; font-family: var(--font-mono); }

/* About section layout extras */
.about-close { color: var(--signal); font-size: 1.05em; margin-top: 1rem !important; }
.about-link { display: inline-block; margin-top: 0.75rem; color: var(--signal); font-size: 0.9rem; text-decoration: underline; text-underline-offset: 4px; opacity: 0.85; transition: opacity 0.15s; }
.about-link:hover { opacity: 1; }

/* Coaching qualifier note */
.coach-qualifier { font-size: 13px; color: var(--muted); margin-top: 8px !important; margin-bottom: 0 !important; font-style: italic; }

/* Testimonials */
.testimonials { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
@media (max-width: 900px) { .testimonials { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .testimonials { grid-template-columns: 1fr; } }
.testimonial-card { background: #0d0d10; border: 1px solid rgba(255,255,255,0.07); border-radius: 18px; padding: 20px; display: flex; flex-direction: column; gap: 14px; box-shadow: 0 0 0 1px rgba(43,212,217,0.06), 0 24px 48px -24px rgba(0,0,0,0.6); }
.testimonial-chrome { display: flex; justify-content: flex-end; }
.testimonial-platform { font-family: var(--font-mono); font-size: 10px; text-transform: uppercase; letter-spacing: 0.08em; color: rgba(255,255,255,0.25); background: rgba(255,255,255,0.06); padding: 3px 8px; border-radius: 99px; }
.testimonial-meta { display: flex; align-items: center; gap: 10px; }
.testimonial-avatar { width: 36px; height: 36px; border-radius: 50%; background: linear-gradient(135deg, #2bd4d9, #b86cff); display: flex; align-items: center; justify-content: center; font-family: var(--font-mono); font-size: 14px; font-weight: 700; color: #fff; flex-shrink: 0; }
.testimonial-name { display: block; font-size: 14px; font-weight: 600; color: rgba(255,255,255,0.88); line-height: 1.2; }
.testimonial-role { display: block; font-size: 11.5px; color: rgba(255,255,255,0.38); margin-top: 2px; font-family: var(--font-mono); }
.testimonial-bubble { font-size: 15px; line-height: 1.6; color: rgba(255,255,255,0.65); font-style: italic; position: relative; padding-left: 14px; border-left: 2px solid rgba(43,212,217,0.3); margin-top: 4px; }

/* ── trust card ── */
.trust-card { margin-top: 43px; background: var(--card); border-radius: var(--r-xl); box-shadow: var(--shadow-card); overflow: hidden; }
@media (min-width: 768px) { .trust-card { margin-top: 58px; } }
.trust-card .trust-row { border: none; margin-top: 0; max-width: none; gap: 0; }
@media (min-width: 860px) { .trust-card .trust-row { margin-left: 0; } }
.trust-card .trust { padding: 18px 16px; border: none; text-align: center; position: relative; }
.trust-card .trust-n { font-size: 30px; }
@media (min-width: 768px) {
  .trust-card .trust { padding: 30px 24px; }
  .trust-card .trust-n { font-size: 48px; }
  .trust-card .trust:not(:last-child)::after { content: ''; position: absolute; right: 0; top: 50%; transform: translateY(-50%); height: 50%; width: 1px; background: var(--line-2); }
}

/* ── section-head inside a card ── */
.card .section-head { margin-bottom: 0; }
