/* =====================================================================
   FL ECOSYSTEM — Pricing page
   Builds on legacy-homepage-style.css (tokens, nav, buttons, theme toggle,
   reveal). This file adds the standard header brand lockup, the pricing
   sections, the ecosystem flow, the enquiry band, the steps and the
   signed-off editorial footer — light + dark.
   ===================================================================== */

/* ---------- Page canvas + soft ambient hazes ---------- */
.pricing-main {
  position: relative;
  overflow: hidden;
}
.pricing-main::before,
.pricing-main::after {
  content: "";
  position: absolute;
  z-index: -1;
  pointer-events: none;
  border-radius: 50%;
  filter: blur(90px);
  opacity: .5;
}
.pricing-main::before {
  width: 720px; height: 720px; top: -190px; right: -220px;
  background:
    radial-gradient(circle at 28% 30%, rgba(255,106,0,.11), transparent 56%),
    radial-gradient(circle at 72% 38%, rgba(0,123,255,.14), transparent 58%),
    radial-gradient(circle at 54% 72%, rgba(138,43,226,.12), transparent 58%);
}
.pricing-main::after {
  width: 680px; height: 680px; top: 760px; left: -260px;
  background:
    radial-gradient(circle at 46% 44%, rgba(255,196,0,.10), transparent 58%),
    radial-gradient(circle at 60% 60%, rgba(255,106,0,.10), transparent 62%);
}
html[data-theme="dark"] .pricing-main::before { opacity: .6; }
html[data-theme="dark"] .pricing-main::after  { opacity: .42; }

/* =====================================================================
   HEADER BRAND — match the signed-off solution-page lockup
   ===================================================================== */
.pricing .brand__logo-wrap {
  position: relative; display: inline-flex; flex: none; isolation: isolate;
}
.pricing .brand__logo-wrap::before {
  content: ""; position: absolute; z-index: -1; pointer-events: none;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: 122%; height: 122%;
  background:
    radial-gradient(circle at 24% 26%, rgba(255,106,0,.30), transparent 26%),
    radial-gradient(circle at 76% 26%, rgba(0,123,255,.26), transparent 26%),
    radial-gradient(circle at 26% 76%, rgba(138,43,226,.26), transparent 26%),
    radial-gradient(circle at 76% 76%, rgba(255,196,0,.24), transparent 26%);
  filter: blur(7px);
}
.pricing .brand__logo {
  position: relative; width: 56px; height: 56px; flex: none;
  object-fit: contain;
  filter: saturate(1.12) drop-shadow(0 2px 5px rgba(40,20,80,.14));
}
.pricing .brand__name {
  font-weight: 600; font-size: .96rem; letter-spacing: .24em;
  text-transform: uppercase; color: var(--ink-2); white-space: nowrap;
}
/* Active "Pricing" header chip */
.pricing .nav__actions .btn--ghost[aria-current="page"] {
  color: var(--ink); border-color: color-mix(in srgb, var(--connect) 42%, var(--border-2));
}

/* =====================================================================
   SHARED — gradient text + section rhythm
   ===================================================================== */
.grad-text {
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.pricing-main section { scroll-margin-top: calc(var(--nav-h) + 16px); }

/* =====================================================================
   HERO
   ===================================================================== */
.price-hero {
  position: relative;
  min-height: min(760px, 78svh);
  display: grid;
  place-items: center;
  padding: calc(var(--nav-h) + clamp(54px, 8vw, 106px)) var(--pad) clamp(58px, 9vw, 118px);
  text-align: center;
  isolation: isolate;
}
.price-hero__glow {
  position: absolute; z-index: -1; pointer-events: none;
  top: 18%; left: 50%; transform: translateX(-50%);
  width: min(900px, 92vw); height: 430px;
  background:
    radial-gradient(ellipse at 30% 42%, rgba(255,106,0,.13), transparent 58%),
    radial-gradient(ellipse at 64% 38%, rgba(138,43,226,.16), transparent 62%),
    radial-gradient(ellipse at 76% 64%, rgba(0,123,255,.13), transparent 62%);
  filter: blur(42px); opacity: .9;
}
.price-hero::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: clamp(28px, 6vw, 82px);
  z-index: -1;
  width: min(760px, 72vw);
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, rgba(255,106,0,.22), rgba(138,43,226,.20), rgba(0,123,255,.22), transparent);
}
.price-hero__inner { max-width: 940px; margin: 0 auto; }

.price-eyebrow {
  display: inline-flex; align-items: center; gap: 9px;
  padding: 8px 16px 8px 12px; border-radius: 999px;
  background: rgba(255,255,255,.70); border: 1px solid rgba(255,255,255,.84); box-shadow: var(--sh-sm);
  backdrop-filter: blur(14px) saturate(150%);
  -webkit-backdrop-filter: blur(14px) saturate(150%);
  font-size: .84rem; font-weight: 600; letter-spacing: 0; text-transform: none;
  color: var(--muted);
  margin-bottom: clamp(22px, 3vw, 30px);
}
.price-eyebrow::before {
  content: ""; width: 9px; height: 9px; border-radius: 50%;
  background: var(--grad);
  box-shadow: 0 0 0 4px rgba(138,43,226,.12);
}
.price-title {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; letter-spacing: -.025em; color: var(--ink);
  font-size: clamp(3.05rem, 7vw, 6.35rem); line-height: .98;
}
.price-lede {
  margin: clamp(24px, 3vw, 34px) auto 0; max-width: 48ch;
  font-size: clamp(1.06rem, 1.45vw, 1.22rem); color: var(--body);
}

/* =====================================================================
   PRICING CARDS
   ===================================================================== */
.price-plans {
  max-width: var(--maxw); margin: 0 auto;
  padding: clamp(54px, 8vw, 104px) var(--pad) clamp(28px, 5vw, 64px);
}
.price-grid {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(18px, 2.8vw, 42px);
  align-items: stretch;
}
/* Editorial, low-box cards: soft brand-tinted surface, hairline edge and a
   diffuse shadow — no hard borders or SaaS top-bars. */
.price-card {
  --c: var(--manage);
  position: relative; min-width: 0;
  display: flex; flex-direction: column; align-items: center; text-align: center;
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--c) 4%, transparent), transparent 68%),
    color-mix(in srgb, var(--bg) 84%, transparent);
  border: 1px solid color-mix(in srgb, var(--c) 12%, var(--border));
  border-radius: 20px;
  padding: clamp(34px, 3vw, 46px) clamp(18px, 1.8vw, 28px) clamp(30px, 2.6vw, 40px);
  box-shadow: 0 30px 70px -52px color-mix(in srgb, var(--c) 42%, rgba(16,24,40,.45));
  transition: transform .3s cubic-bezier(.22,1,.36,1), box-shadow .35s ease, border-color .3s ease, background .3s ease;
  overflow: hidden;
}
.price-card::before {
  content: "";
  position: absolute;
  left: 50%;
  top: -90px;
  width: 210px;
  height: 160px;
  transform: translateX(-50%);
  border-radius: 50%;
  background: radial-gradient(closest-side, color-mix(in srgb, var(--c) 18%, transparent), transparent 72%);
  filter: blur(22px);
  opacity: .75;
  pointer-events: none;
}
.price-card[data-brand="create"]  { --c: var(--create); }
.price-card[data-brand="manage"]  { --c: var(--manage); }
.price-card[data-brand="connect"] { --c: var(--connect); }
.price-card[data-brand="learn"]   { --c: var(--learn); }
.price-card:hover {
  transform: translateY(-5px);
  border-color: color-mix(in srgb, var(--c) 26%, var(--border));
  box-shadow: 0 42px 84px -52px color-mix(in srgb, var(--c) 54%, rgba(16,24,40,.45));
}

.price-card__icon {
  display: grid; place-items: center;
  width: 70px; height: 70px; border-radius: 50%;
  color: var(--c);
  background: radial-gradient(closest-side, color-mix(in srgb, var(--c) 17%, var(--bg)), color-mix(in srgb, var(--c) 6%, var(--bg)));
  border: 1px solid color-mix(in srgb, var(--c) 18%, transparent);
  box-shadow: 0 18px 38px -20px color-mix(in srgb, var(--c) 55%, transparent);
  margin-bottom: 24px;
}
.price-card__icon svg { width: 30px; height: 30px; }

.price-card__name {
  font-size: 1.28rem; font-weight: 700; letter-spacing: -.01em;
  color: var(--c);
}
.price-card__rule {
  display: block; width: 34px; height: 2px; border-radius: 3px;
  background: var(--c); opacity: .74; margin: 13px auto 17px;
}
.price-card__from { font-size: .92rem; color: var(--muted); }
.price-card__price {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; font-size: clamp(2.2rem, 3.4vw, 2.7rem); line-height: 1;
  color: var(--ink); margin-top: 2px;
}
.price-card__soon {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; font-size: clamp(1.7rem, 2.8vw, 2.1rem); line-height: 1.05;
  color: var(--ink); margin: 2px 0 4px; max-width: 8ch;
}
.price-card__head {
  margin-top: 16px; font-weight: 700; font-size: 1rem; color: var(--ink-2);
}
.price-card__desc {
  margin-top: 8px; font-size: .95rem; color: var(--muted); max-width: 24ch;
}
.price-card__cta {
  margin-top: auto; padding-top: 22px;
  display: inline-flex; align-items: center; gap: .4em;
  font-weight: 600; font-size: .96rem; color: var(--c);
}
.price-card__cta i { transition: transform .2s ease; }
.price-card:hover .price-card__cta i { transform: translateX(4px); }
.price-card__cta--soon { opacity: .92; }
.price-card:focus-within { outline: none; }
.price-card__cta:focus-visible {
  outline: 3px solid color-mix(in srgb, var(--c) 55%, transparent); outline-offset: 4px; border-radius: 6px;
}

.price-note {
  max-width: 62ch; margin: clamp(30px, 4vw, 46px) auto 0;
  text-align: center; font-size: .92rem; color: var(--muted);
}

/* =====================================================================
   PRICING DETAILS — editorial breakdown per solution
   ===================================================================== */
.price-details {
  position: relative;
  max-width: 1120px; margin: 0 auto;
  padding: clamp(64px, 9vw, 126px) var(--pad) clamp(16px, 4vw, 38px);
}
.price-details::before {
  content: "";
  position: absolute;
  top: clamp(82px, 10vw, 142px);
  bottom: clamp(38px, 7vw, 86px);
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--connect) 24%, var(--border)) 12%, color-mix(in srgb, var(--create) 18%, var(--border)) 52%, transparent);
  opacity: .8;
  pointer-events: none;
}
.pdetail {
  --c: var(--manage);
  position: relative;
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: clamp(44px, 7vw, 104px); align-items: start;
  padding: clamp(58px, 9vw, 108px) 0;
  border-top: 0;
  scroll-margin-top: calc(var(--nav-h) + 24px);
}
.pdetail + .pdetail {
  border-top: 1px solid color-mix(in srgb, var(--c) 18%, var(--border));
}
.pdetail::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 18% -8% 12%;
  background:
    radial-gradient(420px 280px at 78% 48%, color-mix(in srgb, var(--c) 10%, transparent), transparent 72%);
  filter: blur(12px);
  opacity: .9;
  pointer-events: none;
}
.pdetail[data-brand="create"]  { --c: var(--create); }
.pdetail[data-brand="manage"]  { --c: var(--manage); }
.pdetail[data-brand="connect"] { --c: var(--connect); }
.pdetail[data-brand="learn"]   { --c: var(--learn); }

.pdetail__intro { min-width: 0; max-width: 520px; }
.pdetail__eyebrow {
  display: inline-flex; align-items: center; gap: 10px;
  font-size: .78rem; font-weight: 700; letter-spacing: .18em; text-transform: uppercase;
  color: var(--c); margin-bottom: 20px;
}
.pdetail__eyebrow::before { content: ""; width: 28px; height: 2px; border-radius: 999px; background: var(--c); }
.pdetail__price {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; letter-spacing: -.02em; line-height: 1.05;
  font-size: clamp(2.2rem, 4.2vw, 3.55rem); color: var(--ink);
}
.pdetail--soon .pdetail__price { font-size: inherit; line-height: 1.2; }
.pdetail__soon {
  display: inline-block;
  font-size: .92rem; font-weight: 700; letter-spacing: .04em;
  color: var(--c);
  background: color-mix(in srgb, var(--c) 12%, var(--bg));
  border: 1px solid color-mix(in srgb, var(--c) 28%, transparent);
  padding: 9px 18px; border-radius: 999px;
}
.pdetail__lede { margin-top: 20px; max-width: 36ch; color: var(--body); font-size: clamp(1.02rem, 1.35vw, 1.15rem); }
.pdetail__cta {
  display: inline-flex; align-items: center; gap: .45em; margin-top: 28px;
  font-weight: 600; font-size: 1rem; color: var(--c);
}
.pdetail__cta i { transition: transform .2s ease; }
.pdetail__cta:hover i { transform: translateX(4px); }
.pdetail__cta:focus-visible { outline: 3px solid color-mix(in srgb, var(--c) 55%, transparent); outline-offset: 4px; border-radius: 6px; }

.pdetail__includes {
  min-width: 0;
  padding: clamp(22px, 3vw, 34px) 0 clamp(20px, 3vw, 32px) clamp(24px, 3vw, 38px);
  border-left: 2px solid color-mix(in srgb, var(--c) 42%, transparent);
}
.pdetail__label {
  display: inline-block; font-size: .74rem; font-weight: 700;
  letter-spacing: .16em; text-transform: uppercase; color: var(--muted); margin-bottom: 18px;
}
.pdetail__list { display: flex; flex-direction: column; gap: 15px; }
.pdetail__list li {
  position: relative; padding-left: 30px;
  color: var(--ink-2); font-size: clamp(1rem, 1.2vw, 1.08rem); font-weight: 500;
}
.pdetail__list li::before {
  content: ""; position: absolute; left: 0; top: 1px;
  width: 20px; height: 20px; border-radius: 50%;
  background: color-mix(in srgb, var(--c) 14%, transparent);
}
.pdetail__list li::after {
  content: ""; position: absolute; left: 7px; top: 8px;
  width: 6px; height: 6px; border-radius: 50%; background: var(--c);
}

/* =====================================================================
   ECOSYSTEM FLOW
   ===================================================================== */
.price-eco {
  position: relative;
  padding: clamp(82px, 12vw, 150px) 0;
  background:
    radial-gradient(760px 420px at 50% 0%, rgba(138,43,226,.08), transparent 70%),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 78%, transparent), transparent);
  border-block: 1px solid color-mix(in srgb, var(--connect) 12%, var(--border));
  margin-top: clamp(48px, 7vw, 90px);
  overflow: hidden;
}
.price-eco__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.price-eco__head { max-width: 780px; margin: 0 auto clamp(44px, 6vw, 72px); text-align: center; }
.price-eco__head h2 {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; letter-spacing: -.02em; color: var(--ink);
  font-size: clamp(2.25rem, 5vw, 4rem); line-height: 1.04;
}
.price-eco__head p { margin-top: 20px; font-size: clamp(1.02rem, 1.35vw, 1.16rem); color: var(--body); }

.eco-flow {
  display: flex; flex-wrap: wrap; align-items: center; justify-content: center;
  gap: clamp(10px, 1.6vw, 18px);
  max-width: 990px; margin: 0 auto;
}
.eco-flow__step {
  --c: var(--manage);
  flex: 1 1 0; min-width: 132px;
  display: flex; flex-direction: column; align-items: center; text-align: center; gap: 4px;
  padding: 22px 12px 18px;
  background: transparent; border: 0; border-radius: 0;
  box-shadow: none;
  transition: transform .2s ease;
}
.eco-flow__step[data-brand="create"]  { --c: var(--create); }
.eco-flow__step[data-brand="manage"]  { --c: var(--manage); }
.eco-flow__step[data-brand="connect"] { --c: var(--connect); }
.eco-flow__step[data-brand="promote"] { --c: var(--promote); }
.eco-flow__step[data-brand="learn"]   { --c: var(--learn); }
.eco-flow__step:hover {
  transform: translateY(-4px);
}
.eco-flow__icon {
  display: grid; place-items: center;
  width: 58px; height: 58px; border-radius: 50%;
  color: var(--c); background: color-mix(in srgb, var(--c) 13%, var(--bg));
  border: 1px solid color-mix(in srgb, var(--c) 22%, transparent);
  box-shadow: 0 18px 44px -26px color-mix(in srgb, var(--c) 70%, transparent);
  margin-bottom: 14px;
}
.eco-flow__icon svg { width: 24px; height: 24px; }
.eco-flow__name { font-weight: 700; font-size: 1rem; color: var(--ink); }
.eco-flow__verb { font-size: .84rem; color: var(--muted); }

.eco-flow__arrow {
  align-self: center; flex: none;
  color: color-mix(in srgb, var(--connect) 60%, var(--muted));
  font-size: 1.3rem; line-height: 1; font-weight: 600;
}

.price-eco__foot {
  margin: clamp(38px, 5vw, 58px) auto 0; max-width: 60ch; text-align: center;
  font-size: clamp(1.06rem, 1.8vw, 1.24rem); color: var(--ink-2); font-weight: 500;
}
.price-eco__foot strong { color: var(--ink); font-weight: 700; }

/* =====================================================================
   ENQUIRY — dark editorial band
   ===================================================================== */
.price-enquiry { padding: clamp(78px, 11vw, 142px) 0 clamp(58px, 9vw, 108px); }
.price-enquiry__card {
  position: relative; overflow: hidden;
  max-width: var(--maxw); margin-inline: var(--pad);
  display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1.05fr) auto;
  align-items: center; gap: clamp(26px, 4vw, 56px);
  padding: clamp(42px, 6vw, 74px) clamp(30px, 5vw, 72px);
  border-radius: clamp(18px, 2.2vw, 28px);
  background:
    radial-gradient(620px 320px at 88% 120%, rgba(138,43,226,.55), transparent 62%),
    radial-gradient(520px 300px at 100% 0%, rgba(0,123,255,.4), transparent 60%),
    linear-gradient(140deg, #0c0d14, #131526 64%, #1a1330);
  color: #cdd3e3;
  box-shadow: 0 48px 110px -54px rgba(10,8,30,.85);
  border: 1px solid rgba(255,255,255,.08);
}
@media (min-width: 1260px) { .price-enquiry__card { margin-inline: auto; } }
.price-enquiry__card::before {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  background: radial-gradient(500px 260px at 6% -10%, rgba(255,106,0,.16), transparent 60%);
}
.price-enquiry__copy { position: relative; min-width: 0; }
.price-enquiry__copy h2 {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; letter-spacing: -.02em; color: #fff;
  font-size: clamp(2.05rem, 4vw, 3.35rem); line-height: 1.05;
}
.price-enquiry__copy p { margin-top: 16px; color: rgba(226,230,242,.82); font-size: 1.04rem; }
.price-enquiry__copy .price-enquiry__sub { margin-top: 12px; color: rgba(206,212,228,.62); font-size: .96rem; }

.price-enquiry__points {
  position: relative; min-width: 0;
  display: flex; flex-direction: column; gap: 18px;
}
.price-enquiry__points li { display: flex; align-items: flex-start; gap: 14px; }
.price-enquiry__ico {
  flex: none; display: grid; place-items: center;
  width: 40px; height: 40px; border-radius: 11px; color: #fff;
  background: rgba(255,255,255,.08); border: 1px solid rgba(255,255,255,.16);
}
.price-enquiry__ico svg { width: 20px; height: 20px; }
.price-enquiry__pt { display: flex; flex-direction: column; font-size: .9rem; color: rgba(205,211,227,.78); }
.price-enquiry__pt strong { color: #fff; font-size: 1rem; font-weight: 700; margin-bottom: 2px; }

.price-enquiry__action {
  position: relative; display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.price-enquiry__action .btn { white-space: nowrap; }
.price-enquiry__action .btn i { transition: transform .2s ease; }
.price-enquiry__action .btn:hover i { transform: translateX(4px); }
.price-enquiry__meta { font-size: .82rem; color: rgba(205,211,227,.62); }
.price-enquiry__note {
  position: relative; grid-column: 1 / -1; margin-top: 4px;
  text-align: center; color: rgba(205,211,227,.58); font-size: .84rem;
}

/* =====================================================================
   WHAT HAPPENS NEXT
   ===================================================================== */
.price-steps { padding: clamp(46px, 7vw, 86px) 0 clamp(82px, 12vw, 150px); }
.price-steps__inner { max-width: var(--maxw); margin: 0 auto; padding: 0 var(--pad); }
.price-steps__head { margin-bottom: clamp(40px, 5vw, 64px); text-align: center; }
.price-steps__head h2 {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600; letter-spacing: -.02em; color: var(--ink);
  font-size: clamp(2rem, 4.4vw, 3.25rem);
}
.steps {
  display: grid; grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(18px, 2.4vw, 30px);
}
.steps__item {
  position: relative; min-width: 0; text-align: center;
  display: flex; flex-direction: column; align-items: center;
}
/* dotted connector between steps (desktop) */
.steps__item::after {
  content: ""; position: absolute; top: 30px; left: calc(50% + 38px); right: calc(-50% + 38px);
  height: 0; border-top: 2px dashed var(--border-2); z-index: 0;
}
.steps__item:last-child::after { display: none; }
.steps__icon {
  position: relative; z-index: 1;
  display: grid; place-items: center;
  width: 64px; height: 64px; border-radius: 50%;
  color: var(--connect);
  background: color-mix(in srgb, var(--connect) 11%, var(--bg));
  border: 1px solid color-mix(in srgb, var(--connect) 22%, transparent);
  box-shadow: 0 20px 50px -32px color-mix(in srgb, var(--connect) 70%, transparent);
  margin-bottom: 20px;
}
.steps__icon svg { width: 26px; height: 26px; }
.steps__item h3 { font-size: 1.06rem; line-height: 1.3; color: var(--ink); max-width: 18ch; }
.steps__num {
  font-weight: 800;
  background: var(--grad); -webkit-background-clip: text; background-clip: text; color: transparent;
}
.steps__item p { margin-top: 10px; font-size: .92rem; color: var(--muted); max-width: 22ch; }

/* Stagger reveal */
.price-grid .price-card:nth-child(2),
.steps .steps__item:nth-child(2) { transition-delay: .06s; }
.price-grid .price-card:nth-child(3),
.steps .steps__item:nth-child(3) { transition-delay: .12s; }
.price-grid .price-card:nth-child(4),
.steps .steps__item:nth-child(4) { transition-delay: .18s; }

/* =====================================================================
   DEDICATED PRICING DETAIL PAGES — editorial, homepage-aligned
   ===================================================================== */
.pricing-detail-main {
  --c: var(--connect);
  --c-text: #7A1FD0;
  --c-glow: rgba(138,43,226,.18);
}
.pricing-detail-main[data-brand="create"] {
  --c: var(--create);
  --c-text: #E25E00;
  --c-glow: rgba(255,106,0,.20);
}
.pricing-detail-main[data-brand="manage"] {
  --c: var(--manage);
  --c-text: #0067D6;
  --c-glow: rgba(0,123,255,.20);
}
.pricing-detail-main[data-brand="connect"] {
  --c: var(--connect);
  --c-text: #7A1FD0;
  --c-glow: rgba(138,43,226,.22);
}
.pricing-detail-main[data-brand="learn"] {
  --c: var(--learn);
  --c-text: #B8860B;
  --c-glow: rgba(255,196,0,.22);
}

.pricing-detail-main .btn--primary {
  background: linear-gradient(135deg, var(--c), color-mix(in srgb, var(--c) 62%, #8A2BE2));
  box-shadow: 0 16px 34px -16px color-mix(in srgb, var(--c) 72%, transparent);
}
.pricing-detail-main .btn--primary:hover {
  box-shadow: 0 22px 44px -18px color-mix(in srgb, var(--c) 78%, transparent);
}

.price-detail-hero {
  position: relative;
  min-height: min(740px, 76svh);
  display: grid;
  place-items: center;
  padding: calc(var(--nav-h) + clamp(54px, 8vw, 106px)) var(--pad) clamp(70px, 10vw, 130px);
  text-align: center;
  isolation: isolate;
}
.price-detail-hero::after {
  content: "";
  position: absolute;
  left: 50%;
  bottom: clamp(30px, 6vw, 84px);
  z-index: -1;
  width: min(720px, 72vw);
  height: 1px;
  transform: translateX(-50%);
  background: linear-gradient(90deg, transparent, color-mix(in srgb, var(--c) 34%, transparent), transparent);
}
.price-detail-hero__glow {
  position: absolute;
  z-index: -1;
  pointer-events: none;
  top: 16%;
  left: 50%;
  width: min(880px, 92vw);
  height: 430px;
  transform: translateX(-50%);
  background:
    radial-gradient(ellipse at 44% 42%, var(--c-glow), transparent 64%),
    radial-gradient(ellipse at 66% 62%, rgba(138,43,226,.12), transparent 68%);
  filter: blur(42px);
  opacity: .95;
}
.price-detail-hero__inner {
  max-width: 980px;
  margin: 0 auto;
}
.pricing-detail-main .price-eyebrow::before {
  background: var(--c);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--c) 16%, transparent);
}
.price-accent {
  color: var(--c-text);
}

.price-detail-story {
  position: relative;
  max-width: 1120px;
  margin: 0 auto;
  padding: clamp(58px, 9vw, 120px) var(--pad) clamp(86px, 12vw, 150px);
}
.price-detail-story::before {
  content: "";
  position: absolute;
  top: clamp(76px, 10vw, 138px);
  bottom: clamp(120px, 14vw, 178px);
  left: 50%;
  width: 1px;
  transform: translateX(-50%);
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--c) 28%, var(--border)) 14%, color-mix(in srgb, var(--c) 18%, var(--border)) 72%, transparent);
  pointer-events: none;
}
.price-detail-block {
  position: relative;
  display: grid;
  grid-template-columns: minmax(0, .72fr) minmax(0, 1fr);
  gap: clamp(40px, 7vw, 104px);
  align-items: start;
  padding: clamp(54px, 8vw, 96px) 0;
  border-top: 1px solid color-mix(in srgb, var(--c) 16%, var(--border));
}
.price-detail-block:first-child {
  border-top: 0;
  padding-top: 0;
}
.price-detail-block::before {
  content: "";
  position: absolute;
  z-index: -1;
  inset: 16% -8% 12%;
  background: radial-gradient(440px 280px at 78% 48%, color-mix(in srgb, var(--c) 9%, transparent), transparent 72%);
  filter: blur(12px);
  pointer-events: none;
}
.price-detail-block .pdetail__eyebrow {
  grid-column: 1;
  margin-top: .2em;
}
.price-detail-block h2,
.price-detail-block p,
.price-detail-block .pdetail__list {
  grid-column: 2;
}
.price-detail-block h2 {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600;
  letter-spacing: -.02em;
  color: var(--ink);
  font-size: clamp(2.1rem, 4.6vw, 4rem);
  line-height: 1.04;
}
.price-detail-block p {
  margin-top: 18px;
  max-width: 42em;
  color: var(--body);
  font-size: clamp(1.02rem, 1.35vw, 1.16rem);
}
.price-detail-block .pdetail__list {
  padding-left: clamp(22px, 3vw, 34px);
  border-left: 2px solid color-mix(in srgb, var(--c) 42%, transparent);
}

.price-detail-quote {
  position: relative;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: clamp(24px, 5vw, 64px);
  margin-top: clamp(30px, 5vw, 58px);
  padding: clamp(40px, 6vw, 74px) clamp(30px, 5vw, 72px);
  border-radius: clamp(18px, 2.2vw, 28px);
  background:
    radial-gradient(580px 320px at 88% 120%, color-mix(in srgb, var(--c) 46%, transparent), transparent 62%),
    radial-gradient(500px 280px at 8% -10%, rgba(255,106,0,.16), transparent 60%),
    linear-gradient(140deg, #0c0d14, #131526 64%, #171326);
  color: #d6dbea;
  box-shadow: 0 48px 110px -54px color-mix(in srgb, var(--c) 60%, rgba(10,8,30,.85));
  border: 1px solid rgba(255,255,255,.08);
}
.price-detail-quote h2 {
  font-family: "Playfair Display", "Iowan Old Style", Georgia, serif;
  font-weight: 600;
  letter-spacing: -.02em;
  color: #fff;
  font-size: clamp(2rem, 4vw, 3.35rem);
  line-height: 1.05;
}
.price-detail-quote p {
  margin-top: 16px;
  max-width: 45ch;
  color: rgba(226,230,242,.82);
  font-size: 1.04rem;
}
.price-detail-quote .pdetail__eyebrow {
  color: color-mix(in srgb, var(--c) 74%, #fff);
}

/* =====================================================================
   FOOTER — signed-off editorial (matches homepage + solution pages)
   ===================================================================== */
.site-foot {
  position: relative; overflow: hidden; text-align: center;
  padding: clamp(48px, 8vw, 88px) var(--pad) clamp(34px, 5vw, 52px);
  border-top: 1px solid var(--border);
  background:
    radial-gradient(680px 240px at 50% 0%, rgba(138,43,226,.07), transparent 72%),
    var(--bg);
}
.site-foot__inner { display: flex; flex-direction: column; align-items: center; gap: 14px; }
.site-foot__logo-wrap { position: relative; display: inline-flex; isolation: isolate; margin-bottom: 4px; }

/* single soft glow behind the footer logo — one colour at a time, slowly
   cycling orange → purple → blue → gold. Low opacity + soft blur keep the
   wordmark crisp and avoid any multi-colour haze over the artwork. */
@property --foot-glow {
  syntax: "<color>";
  inherits: false;
  initial-value: rgba(255, 106, 0, 0.5);
}
.site-foot__logo-wrap::before {
  content: ""; position: absolute; z-index: -1; pointer-events: none;
  left: 50%; top: 50%; transform: translate(-50%, -50%);
  width: clamp(200px, 23vw, 330px); height: clamp(118px, 13vw, 188px);
  /* light: soft dark spotlight lifts the logo so its artwork stays crisp — no colour haze */
  background: radial-gradient(closest-side, rgba(16,13,38,.30), rgba(16,13,38,.10) 58%, transparent 82%);
  filter: blur(20px); opacity: 1;
}
@keyframes footGlowCycle {
  0%, 100% { --foot-glow: rgba(255, 106, 0, .5); }  /* orange */
  25%      { --foot-glow: rgba(138, 43, 226, .5); } /* purple */
  50%      { --foot-glow: rgba(0, 123, 255, .5); }  /* blue   */
  75%      { --foot-glow: rgba(255, 196, 0, .5); }  /* gold   */
}
.site-foot__logo {
  position: relative; width: clamp(220px, 26vw, 360px); height: auto; object-fit: contain;
  filter: saturate(1.05) contrast(1.04) drop-shadow(0 8px 20px rgba(18,14,45,.20));
}
.site-foot__links { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px 28px; margin-top: 4px; }
.site-foot__links a { color: var(--muted); font-size: .92rem; transition: color .2s ease; }
.site-foot__links a:hover, .site-foot__links a:focus-visible { color: var(--ink); }
.site-foot__links a[aria-current="page"] { color: var(--ink); font-weight: 600; }

html[data-theme="dark"] .site-foot {
  border-top-color: rgba(255,255,255,.10);
  background:
    radial-gradient(680px 240px at 50% 0%, rgba(138,43,226,.14), transparent 72%),
    var(--bg);
}
html[data-theme="dark"] .site-foot__logo {
  filter: saturate(1.12) brightness(1.05) contrast(1.03) drop-shadow(0 10px 26px rgba(0,0,0,.55));
}
html[data-theme="dark"] .site-foot__logo-wrap::before {
  background: radial-gradient(closest-side, rgba(150,134,255,.16), transparent 78%);
}

/* =====================================================================
   DARK MODE — section tweaks (most colours come from tokens)
   ===================================================================== */
html[data-theme="dark"] .price-card { background: var(--bg-soft); }
html[data-theme="dark"] .price-eyebrow {
  background: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.12);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.07), var(--sh-sm);
}
html[data-theme="dark"] .price-card__icon { background: color-mix(in srgb, var(--c) 22%, var(--bg-soft)); }
html[data-theme="dark"] .eco-flow__step { background: transparent; }
html[data-theme="dark"] .eco-flow__icon { background: color-mix(in srgb, var(--c) 24%, var(--bg)); }
html[data-theme="dark"] .steps__icon { background: color-mix(in srgb, var(--connect) 26%, var(--bg)); }
html[data-theme="dark"] .price-hero__glow { opacity: .9; }
html[data-theme="dark"] .pdetail { border-top-color: rgba(255,255,255,.10); }
html[data-theme="dark"] .price-details::before {
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--connect) 30%, rgba(255,255,255,.12)) 12%, color-mix(in srgb, var(--create) 24%, rgba(255,255,255,.10)) 52%, transparent);
}
html[data-theme="dark"] .pdetail::before { opacity: .72; }
html[data-theme="dark"] .pdetail__soon { background: color-mix(in srgb, var(--c) 24%, var(--bg)); }
html[data-theme="dark"] .pdetail__list li::before { background: color-mix(in srgb, var(--c) 26%, transparent); }
html[data-theme="dark"] .price-eco {
  background:
    radial-gradient(760px 420px at 50% 0%, rgba(138,43,226,.15), transparent 70%),
    linear-gradient(180deg, color-mix(in srgb, var(--bg-soft) 84%, transparent), transparent);
}
html[data-theme="dark"] .price-card {
  background:
    linear-gradient(180deg, color-mix(in srgb, var(--c) 10%, transparent), transparent 68%),
    color-mix(in srgb, var(--c) 5%, var(--bg-soft));
  border-color: color-mix(in srgb, var(--c) 16%, transparent);
}
html[data-theme="dark"] .price-card::before { opacity: .95; }
html[data-theme="dark"] .pricing-detail-main[data-brand="create"] {
  --c-text: #ff9a55;
  --c-glow: rgba(255,106,0,.28);
}
html[data-theme="dark"] .pricing-detail-main[data-brand="manage"] {
  --c-text: #63b2ff;
  --c-glow: rgba(0,123,255,.30);
}
html[data-theme="dark"] .pricing-detail-main[data-brand="connect"] {
  --c-text: #ba8cff;
  --c-glow: rgba(138,43,226,.32);
}
html[data-theme="dark"] .pricing-detail-main[data-brand="learn"] {
  --c-text: #ffd95c;
  --c-glow: rgba(255,196,0,.30);
}
html[data-theme="dark"] .price-detail-story::before {
  background: linear-gradient(180deg, transparent, color-mix(in srgb, var(--c) 34%, rgba(255,255,255,.12)) 14%, color-mix(in srgb, var(--c) 22%, rgba(255,255,255,.10)) 72%, transparent);
}
html[data-theme="dark"] .price-detail-block {
  border-top-color: color-mix(in srgb, var(--c) 18%, rgba(255,255,255,.10));
}
html[data-theme="dark"] .price-detail-block::before {
  opacity: .78;
}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 1080px) {
  .price-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .steps { grid-template-columns: repeat(2, minmax(0, 1fr)); row-gap: clamp(30px, 5vw, 44px); }
  .steps__item:nth-child(2)::after { display: none; }
}

@media (max-width: 980px) {
  .price-enquiry__card {
    grid-template-columns: minmax(0, 1fr); text-align: center; justify-items: center;
  }
  .price-enquiry__points { width: 100%; max-width: 460px; }
  .price-enquiry__points li { text-align: left; }
  .price-detail-quote {
    grid-template-columns: minmax(0, 1fr);
    text-align: center;
    justify-items: center;
  }
  .price-detail-quote p {
    margin-inline: auto;
  }
}

@media (max-width: 820px) {
  /* Ecosystem flow stacks vertically; arrows point down */
  .eco-flow { flex-direction: column; align-items: center; gap: 12px; }
  .eco-flow__step { width: 100%; max-width: 420px; flex: none; }
  .eco-flow__arrow { transform: rotate(90deg); }
}

@media (max-width: 760px) {
  .price-details::before { display: none; }
  .pdetail { grid-template-columns: 1fr; gap: 26px; padding: clamp(48px, 12vw, 70px) 0; }
  .pdetail__includes { padding-top: 0; }
  .price-detail-story::before { display: none; }
  .price-detail-block {
    grid-template-columns: minmax(0, 1fr);
    gap: 24px;
    padding: clamp(48px, 12vw, 70px) 0;
  }
  .price-detail-block .pdetail__eyebrow,
  .price-detail-block h2,
  .price-detail-block p,
  .price-detail-block .pdetail__list {
    grid-column: 1;
  }
  .price-detail-block p {
    margin-top: 0;
  }
}

@media (max-width: 680px) {
  .price-grid { grid-template-columns: 1fr; max-width: 460px; margin-inline: auto; }
  .steps { grid-template-columns: 1fr; max-width: 420px; margin-inline: auto; }
  .steps__item::after { display: none; }
}

@media (max-width: 560px) {
  .price-hero {
    min-height: auto;
    padding-top: calc(var(--nav-h) + 46px);
    padding-bottom: 72px;
  }
  .price-detail-hero {
    min-height: auto;
    padding-top: calc(var(--nav-h) + 46px);
    padding-bottom: 76px;
  }
  .price-title { font-size: clamp(2.7rem, 13.5vw, 3.7rem); }
  .price-plans { padding-top: 42px; }
  .price-card { border-radius: 18px; }
  .pdetail__includes {
    padding-left: 20px;
    border-left-width: 1px;
  }
  .price-detail-block .pdetail__list {
    padding-left: 20px;
    border-left-width: 1px;
  }
  .price-detail-quote {
    padding: clamp(30px, 8vw, 42px) clamp(22px, 6vw, 30px);
  }
  .price-detail-quote .btn {
    width: 100%;
  }
  .price-enquiry__card { padding: clamp(28px, 7vw, 40px) clamp(22px, 6vw, 30px); }
  .price-enquiry__action .btn { width: 100%; }
}

/* =====================================================================
   REDUCED MOTION
   ===================================================================== */
@media (prefers-reduced-motion: reduce) {
  .price-card:hover, .eco-flow__step:hover { transform: none; }
  .site-foot__logo-wrap::before { animation: none; }
}

/* =====================================================================
   PRICING DETAIL PAGES v2 — homepage design-system alignment
   ---------------------------------------------------------------------
   The four detail pages (creative/hub/app/academy) now load
   homepage-style.css (the master design system) + homepage-script.js, so
   they share the exact homepage shell: aura, .site-hdr, .rail, .story /
   .journey, .hero, alternating .moment sections, .final and .site-foot.

   Everything below is ADDITIVE. It uses new class names that
   homepage-style.css does not define, all scoped under `.pd` (the detail
   pages set <body class="pd">). The pricing index page keeps
   <body class="pricing"> and is therefore completely unaffected.
   ===================================================================== */

/* The shared .site-foot rule above resolves its border to --border, which
   only exists in the legacy token set the index page loads. Under the
   homepage tokens these pages use, restore the homepage hairline. */
.pd .site-foot { border-top: 1px solid var(--line); }

/* ---- Hero: eyebrow price line ---- */
.pd .hero__price {
  margin: clamp(20px, 2.6vw, 30px) auto 0;
  max-width: 50ch;
  font-size: clamp(1rem, 1.4vw, 1.14rem);
  color: var(--ink-soft);
}
.pd .hero__price b {
  font-weight: 700;
  background: var(--grad);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

/* ---- Hero: Coming-soon badge (App / Academy) ---- */
.pd .soon-badge {
  display: inline-flex; align-items: center; gap: 9px;
  margin-bottom: clamp(20px, 2.6vw, 28px);
  padding: 9px 18px; border-radius: 999px;
  font-size: .72rem; font-weight: 700; letter-spacing: .2em; text-transform: uppercase;
  color: #fff; background: var(--grad);
  box-shadow: 0 16px 34px -16px rgba(138, 43, 226, .55);
}
.pd .soon-badge::before {
  content: ""; width: 8px; height: 8px; border-radius: 50%;
  background: #fff; box-shadow: 0 0 0 4px rgba(255, 255, 255, .3);
}

/* ---- Editorial list — spacious, gradient-dotted, never boxy ---- */
.pd .editorial-list {
  margin-top: clamp(22px, 2.6vw, 30px);
  display: grid; gap: 14px;
  max-width: 46ch;
}
.pd .editorial-list li {
  position: relative; padding-left: 28px;
  color: var(--ink-soft); font-size: 1.05rem; line-height: 1.5; font-weight: 500;
}
.pd .editorial-list li::before {
  content: ""; position: absolute; left: 0; top: .5em;
  width: 9px; height: 9px; border-radius: 50%;
  background: var(--grad);
  box-shadow: 0 0 0 4px color-mix(in srgb, var(--connect) 12%, transparent);
}

/* ---- Spec chips — soft pills for "what affects price" ---- */
.pd .spec-chips {
  margin-top: clamp(22px, 2.6vw, 30px);
  display: flex; flex-wrap: wrap; gap: 10px;
  max-width: 50ch;
}
.pd .spec-chip {
  font-size: .88rem; font-weight: 600; color: var(--ink-soft);
  padding: 9px 16px; border-radius: 999px;
  background: var(--panel); border: 1px solid var(--line);
}
html[data-theme="dark"] .pd .spec-chip { background: rgba(255, 255, 255, .05); }

/* ---- Soft supporting note ---- */
.pd .lead-note {
  margin-top: clamp(20px, 2.2vw, 26px);
  max-width: 48ch; font-size: 1rem; color: var(--muted);
}
.pd .lead-note strong { color: var(--ink-soft); font-weight: 600; }

/* ---- Faux-UI extras (compose with homepage .ui__* atoms) ---- */
.pd .ui__price .from {
  display: block; font-size: .68rem; font-weight: 700; letter-spacing: .18em;
  text-transform: uppercase; color: var(--muted); margin-bottom: 8px;
}
.pd .ui__price .amt {
  font-family: var(--serif); font-weight: 600; letter-spacing: -.02em;
  font-size: clamp(2.4rem, 4vw, 3rem); line-height: 1; color: var(--ink);
}
.pd .ui__price .amt .cur { color: var(--ink-soft); }
.pd .ui__price .tag {
  font-family: var(--serif); font-weight: 600; letter-spacing: -.01em;
  font-size: clamp(1.5rem, 3vw, 1.9rem); line-height: 1.05; color: var(--ink);
}
.pd .ui__check {
  display: flex; align-items: center; gap: 12px;
  font-size: .9rem; font-weight: 600; color: var(--ink-soft);
}
.pd .ui__check .tick {
  display: grid; place-items: center; flex: none;
  width: 22px; height: 22px; border-radius: 50%;
  background: color-mix(in srgb, #22b07a 18%, transparent); color: #18936a;
}
.pd .ui__check .tick svg { width: 13px; height: 13px; }
.pd .ui__num {
  display: grid; place-items: center; flex: none;
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--grad); color: #fff; font-size: .78rem; font-weight: 700;
}
html[data-theme="dark"] .pd .ui__check .tick { color: #4fd6a3; }

/* ---- Dark-mode treatment for the glass panel + #fff-backed atoms ----
   homepage only ships dark styling for .mini and .panel--preview; the plain
   glass .panel and the white faux-UI atoms need a dark counterpart so they
   read as frosted cards on the near-black canvas (mirrors the .mini rule). */
html[data-theme="dark"] .pd .panel {
  background: rgba(255, 255, 255, .06);
  border-color: rgba(255, 255, 255, .1);
}
html[data-theme="dark"] .pd .ui__card,
html[data-theme="dark"] .pd .ui__stat,
html[data-theme="dark"] .pd .ui__field {
  background: rgba(255, 255, 255, .05);
  border-color: rgba(255, 255, 255, .1);
}
html[data-theme="dark"] .pd .ui__media {
  background: color-mix(in srgb, var(--accent-solid) 24%, rgba(255, 255, 255, .04));
}

/* ---- Mobile: centre the editorial copy like the homepage moments ---- */
@media (max-width: 980px) {
  .pd .editorial-list { justify-items: center; margin-inline: auto; }
  .pd .editorial-list li { text-align: left; }
  .pd .spec-chips { justify-content: center; margin-inline: auto; }
  .pd .lead-note { margin-inline: auto; text-align: center; }
  .pd .hero__price { text-align: center; }
}
