/* SERVICES PAGE */

/* Balanced vertical rhythm — slightly tighter than global .section defaults */
.page-services .section {
  padding: clamp(56px, 8vw, 132px) 0;
}
.page-services .section-head {
  margin-bottom: clamp(28px, 4vw, 56px);
}
.page-services .services-hero {
  padding: clamp(140px, 18vh, 200px) 0 clamp(32px, 5vw, 64px);
}
.page-services .svc-intro {
  padding-top: 0;
  padding-bottom: clamp(40px, 6vw, 72px);
}
.page-services .svc-overview {
  padding-top: clamp(40px, 5vw, 64px);
}
.page-services .svc-setup {
  padding-top: clamp(40px, 5vw, 64px);
}
.page-services .svc-custom,
.page-services .svc-process,
.page-services .svc-why {
  padding-top: clamp(48px, 6vw, 88px);
  padding-bottom: clamp(48px, 6vw, 88px);
}
.page-services .svc-pricing {
  padding-top: clamp(32px, 4vw, 56px);
}
.page-services .svc-faq {
  padding-top: clamp(48px, 6vw, 88px);
}
.page-services .cta-strip.section {
  padding: clamp(56px, 8vw, 120px) 0;
}

.services-hero {
  padding: clamp(160px, 22vh, 240px) 0 clamp(40px, 6vw, 80px);
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.aurora--svc {
  width: 70vw; height: 70vw;
  right: -20vw; top: -10vw;
  background: radial-gradient(closest-side, rgba(255,106,0,0.32), transparent 70%);
  z-index: -1;
}
.services-hero__title {
  margin: 24px 0;
  max-width: 18ch;
}
.services-hero__sub {
  max-width: 60ch;
  font-size: 18px;
  line-height: 1.6;
}
.services-hero__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 32px;
}
@media (max-width: 720px) {
  .services-hero__actions .btn { flex: 1 1 auto; min-width: 0; }
}

/* Intro */
.svc-intro { padding-top: 0; }
.svc-intro__head { margin-bottom: 0; }
.svc-intro__desc {
  margin-top: 18px;
  max-width: 62ch;
  font-size: 16px;
  line-height: 1.65;
}

/* Philosophy-style blocks (shared with About) */
.philosophy__grid {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(40px, 6vw, 100px);
  align-items: start;
}
.philosophy__head h2 { margin-top: 24px; max-width: 16ch; }
.philosophy__lines { display: flex; flex-direction: column; }
.philo-line {
  padding: clamp(18px, 2.2vw, 28px) 0;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: baseline;
  gap: 24px;
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(22px, 2.6vw, 40px);
  line-height: 1.1;
  letter-spacing: -0.025em;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.philo-line:last-child { border-bottom: 1px solid var(--border); }
.philo-line::before {
  content: counter(philo, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  color: var(--accent);
  opacity: 0.8;
  flex: 0 0 auto;
}
.philosophy__lines { counter-reset: philo; }
.philo-line { counter-increment: philo; }
.philo-line span { transition: transform .8s var(--ease-out), color .4s ease; display: inline-block; }
.philo-line:hover span { transform: translateX(20px); color: var(--accent); }
.svc-custom__desc {
  margin-top: 16px;
  max-width: 48ch;
  font-size: 15px;
  line-height: 1.6;
}
@media (max-width: 880px) {
  .philosophy__grid { grid-template-columns: 1fr; }
}

/* Process */
.process__list { display: grid; gap: 0; }
.process__item {
  display: grid;
  grid-template-columns: 100px 1fr 220px;
  gap: 40px;
  padding: clamp(28px, 4vw, 50px) 0;
  border-top: 1px solid var(--border);
  align-items: baseline;
  position: relative;
  isolation: isolate;
  overflow: hidden;
}
.process__item:last-child { border-bottom: 1px solid var(--border); }
.process__item::before {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, var(--accent-soft), transparent);
  transform: translateX(-100%);
  transition: transform .8s var(--ease-out);
  z-index: 0;
}
.process__item:hover::before { transform: translateX(0); }
.process__step {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--accent);
  position: relative;
  z-index: 1;
}
.process__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(28px, 4vw, 56px);
  line-height: 1;
  letter-spacing: -0.03em;
  position: relative;
  z-index: 1;
  transition: transform .8s var(--ease-out);
}
.process__item:hover .process__title { transform: translateX(20px); }
.process__desc {
  color: var(--text-muted);
  font-size: 14px;
  line-height: 1.6;
  position: relative;
  z-index: 1;
}
@media (max-width: 880px) {
  .process__item { grid-template-columns: 1fr; gap: 14px; }
  .process__title { font-size: clamp(26px, 8vw, 44px); }
}

/* Quote-only pricing */
.svc-pricing { padding-top: 0; }
.svc-pricing__panel {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
  padding: clamp(40px, 5vw, 64px);
  max-width: 720px;
}
.svc-pricing__title { margin: 0; max-width: 18ch; }
.svc-pricing__desc,
.svc-pricing__note {
  margin: 0;
  max-width: 56ch;
  font-size: 16px;
  line-height: 1.6;
}
.svc-pricing__note { color: var(--text); }

/* FAQ */
.svc-faq__list { display: flex; flex-direction: column; }
.svc-faq__item {
  padding: clamp(22px, 2.8vw, 32px) 0;
  border-top: 1px solid var(--border);
}
.svc-faq__item:last-child { border-bottom: 1px solid var(--border); }
.svc-faq__q {
  margin: 0 0 10px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(20px, 2.2vw, 28px);
  letter-spacing: -0.02em;
  line-height: 1.15;
}
.svc-faq__a {
  margin: 0;
  max-width: 62ch;
  font-size: 15px;
  line-height: 1.6;
}

/* Final CTA */
.svc-final__desc {
  margin: 16px 0 0;
  max-width: 42ch;
  font-size: 16px;
  line-height: 1.6;
}
.cta-strip__actions {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  flex-shrink: 0;
}
@media (max-width: 880px) {
  .cta-strip__actions { width: 100%; }
  .cta-strip__actions .btn { flex: 1 1 auto; }
}

/* ---------- Service overview — category cards (no pricing) ---------- */
.svc-overview__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.svc-cat {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: clamp(28px, 3.2vw, 44px);
  background: var(--bg-deep);
  position: relative;
  isolation: isolate;
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  transition: background 0.5s ease;
}
.svc-cat::before {
  content: "";
  position: absolute;
  inset: -1px;
  background: radial-gradient(55% 55% at var(--mx, 50%) var(--my, 50%), var(--accent-soft), transparent 70%);
  opacity: 0;
  transition: opacity 0.5s ease;
  z-index: 0;
}
article.svc-cat {
  cursor: default;
}
.svc-cat:hover {
  background: #0d0d10;
}
.svc-cat:hover::before {
  opacity: 1;
}
.svc-cat__num {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.22em;
  color: var(--accent);
  position: relative;
  z-index: 1;
}
.svc-cat__title {
  margin: 0;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(26px, 3.2vw, 44px);
  line-height: 1.05;
  letter-spacing: -0.03em;
  position: relative;
  z-index: 1;
  transition: transform 0.75s var(--ease-out);
}
.svc-cat:hover .svc-cat__title {
  transform: translateX(6px);
}
.svc-cat__title em {
  font-style: italic;
  background: linear-gradient(135deg, var(--accent-bright), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}
.svc-cat__desc {
  margin: 0;
  font-size: 15px;
  line-height: 1.6;
  color: var(--text-muted);
  max-width: 52ch;
  position: relative;
  z-index: 1;
}
.svc-cat__price {
  margin: 0;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  position: relative;
  z-index: 1;
}
.svc-cat__tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  position: relative;
  z-index: 1;
}
.svc-cat__tag {
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.svc-cat__go {
  margin-top: auto;
  padding-top: 8px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  position: relative;
  z-index: 1;
}
.svc-cat__go svg {
  width: 14px;
  height: 14px;
  transition: transform 0.4s var(--ease-out);
}
.svc-cat:hover .svc-cat__go svg {
  transform: translateX(4px);
}
@media (max-width: 720px) {
  .svc-overview__grid {
    grid-template-columns: 1fr;
  }
}

/* Additional setup & customization — 3-card grid */
.svc-setup__head .svc-setup__desc {
  margin-top: 18px;
  max-width: 62ch;
  font-size: 16px;
  line-height: 1.65;
}
.svc-setup__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  align-items: stretch;
}
.svc-setup-card {
  height: 100%;
  min-height: 100%;
}
.svc-setup-card .svc-cat__price {
  margin-top: 4px;
}
.svc-setup-card .svc-cat__desc {
  flex: 1 1 auto;
}
.svc-cat__note {
  margin: 0;
  margin-top: auto;
  padding-top: 16px;
  font-size: 13px;
  line-height: 1.55;
  max-width: none;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
@media (max-width: 960px) {
  .svc-setup__grid {
    grid-template-columns: 1fr;
  }
}

/* Legacy service stack rows (unused; kept for reference) */
.svc-stack__list { display: grid; gap: 0; }
.svc-row {
  display: grid;
  grid-template-columns: 80px 1fr 1.4fr;
  gap: clamp(20px, 3vw, 60px);
  padding: clamp(40px, 5vw, 80px) 0;
  border-top: 1px solid var(--border);
  align-items: start;
  position: relative;
  isolation: isolate;
  overflow: hidden;
  transition: background .5s ease;
}
.svc-row:last-child { border-bottom: 1px solid var(--border); }
.svc-row::before {
  content:"";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, var(--accent-soft), transparent);
  transform: translateY(110%);
  transition: transform .8s var(--ease-out);
  z-index: -1;
}
.svc-row:hover::before { transform: translateY(0); }

.svc-row__num {
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0.2em;
  color: var(--accent);
}
.svc-row__title {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 5vw, 80px);
  line-height: 1;
  letter-spacing: -0.035em;
  transition: transform .8s var(--ease-out), color .4s ease;
}
.svc-row:hover .svc-row__title {
  transform: translateX(20px);
}
.svc-row__title em {
  font-style: italic;
  background: linear-gradient(135deg, var(--accent-bright), var(--accent));
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.svc-row__right {
  display: flex;
  flex-direction: column;
  gap: 24px;
}
.svc-row__desc {
  font-size: 16px;
  color: var(--text-muted);
  line-height: 1.65;
  max-width: 60ch;
}
.svc-row__tags { display: flex; flex-wrap: wrap; gap: 6px; }
.svc-row__tag {
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.svc-row__cta {
  margin-top: 8px;
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--accent);
  width: fit-content;
}
.svc-row__cta svg { width: 14px; height: 14px; transition: transform .4s var(--ease-out); }
.svc-row__cta:hover svg { transform: translateX(4px); }

@media (max-width: 880px) {
  .svc-row { grid-template-columns: 60px 1fr; gap: 16px 20px; }
  .svc-row__right { grid-column: 1 / -1; }
}

/* =====================================================================
   PRICING LAB — luxury cinematic 6-card pricing experience
   ===================================================================== */
.pricing-lab {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(80px, 11vw, 160px) 0 clamp(80px, 9vw, 140px);
}

/* Layered background */
.pricing-lab__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.pricing-lab__aurora {
  position: absolute;
  border-radius: 50%;
  filter: blur(120px);
  opacity: 0.55;
  animation: pricingAurora 18s ease-in-out infinite alternate;
}
.pricing-lab__aurora--a {
  width: 60vw; height: 60vw;
  top: -10vw; left: -15vw;
  background: radial-gradient(closest-side, rgba(255,106,0,0.45), transparent 70%);
}
.pricing-lab__aurora--b {
  width: 55vw; height: 55vw;
  bottom: -10vw; right: -12vw;
  background: radial-gradient(closest-side, rgba(255,138,42,0.35), transparent 70%);
  animation-delay: -7s;
}
@keyframes pricingAurora {
  0%   { transform: translate3d(0,0,0) scale(1); opacity: 0.5; }
  50%  { transform: translate3d(2vw, -2vw, 0) scale(1.08); opacity: 0.65; }
  100% { transform: translate3d(-2vw, 2vw, 0) scale(0.95); opacity: 0.45; }
}
.pricing-lab__grid-bg {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size: 64px 64px;
  mask-image: radial-gradient(circle at 50% 40%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(circle at 50% 40%, black 30%, transparent 75%);
  opacity: 0.5;
}
.pricing-lab__particles {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.65;
  mix-blend-mode: screen;
}

/* Section header */
.pricing-lab__head {
  text-align: center;
  max-width: 920px;
  margin: 0 auto clamp(50px, 6vw, 90px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 18px;
}
.pricing-lab__head .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,106,0,0.35);
  background: linear-gradient(180deg, rgba(255,106,0,0.08), rgba(255,106,0,0.02));
  box-shadow: 0 0 28px -8px rgba(255,106,0,0.5);
}
.pricing-lab__title {
  margin: 0;
  max-width: 18ch;
  text-wrap: balance;
}
.pricing-lab__title .pricing-line {
  display: block;
}
.pricing-lab__title .accent-grad {
  font-style: normal;
  background: linear-gradient(120deg, #ffd9b5 0%, var(--accent-bright) 50%, var(--accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 30px rgba(255, 138, 42, 0.45));
}
.pricing-lab__sub {
  max-width: 60ch;
  font-size: 17px;
  line-height: 1.6;
  margin: 0;
}

/* Grid */
.pricing-lab__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(20px, 1.6vw, 28px);
  align-items: stretch;
}

/* Card */
.plan {
  --plan-x: 50%;
  --plan-y: 50%;
  --plan-glow: rgba(255,106,0,0.0);
  position: relative;
  border-radius: 26px;
  padding: 1px;
  display: flex;
  isolation: isolate;
  transform: translateZ(0);
  transition: transform .8s var(--ease-out), filter .6s ease;
  will-change: transform;
}
.plan::before {
  /* outer animated/gradient border */
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    radial-gradient(180px 180px at var(--plan-x) var(--plan-y), rgba(255,138,42,0.55), transparent 60%),
    linear-gradient(160deg, rgba(255,255,255,0.18), rgba(255,255,255,0.02) 38%, rgba(255,255,255,0.02) 62%, rgba(255,106,0,0.18));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  transition: opacity .5s ease;
  pointer-events: none;
  z-index: 1;
}
.plan::after {
  /* outer ambient glow on hover */
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: radial-gradient(60% 70% at var(--plan-x) var(--plan-y), var(--plan-glow), transparent 70%);
  filter: blur(28px);
  opacity: 0;
  transition: opacity .6s ease;
  z-index: -1;
  pointer-events: none;
}
.plan:hover {
  transform: translateY(-10px);
}
.plan:hover::after {
  opacity: 0.9;
}
.plan:hover {
  --plan-glow: rgba(255,106,0,0.55);
}

.plan__inner {
  position: relative;
  width: 100%;
  border-radius: inherit;
  padding: clamp(28px, 2.6vw, 40px);
  background:
    linear-gradient(180deg, rgba(20,20,24,0.78) 0%, rgba(8,8,10,0.86) 100%);
  backdrop-filter: blur(18px) saturate(120%);
  -webkit-backdrop-filter: blur(18px) saturate(120%);
  border-radius: 25px;
  display: flex;
  flex-direction: column;
  gap: 18px;
  overflow: hidden;
  z-index: 0;
}
/* Spotlight following cursor */
.plan__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(420px 420px at var(--plan-x) var(--plan-y), rgba(255,138,42,0.16), transparent 55%);
  opacity: 0;
  transition: opacity .5s ease;
  pointer-events: none;
}
.plan:hover .plan__inner::before { opacity: 1; }

/* Inner subtle starfield */
.plan__inner::after {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 18% 22%, rgba(255,255,255,0.22), transparent 60%),
    radial-gradient(1px 1px at 72% 38%, rgba(255,138,42,0.35), transparent 60%),
    radial-gradient(1px 1px at 35% 70%, rgba(255,255,255,0.18), transparent 60%),
    radial-gradient(1px 1px at 84% 82%, rgba(255,106,0,0.4), transparent 60%),
    radial-gradient(1px 1px at 12% 88%, rgba(255,255,255,0.18), transparent 60%);
  opacity: 0.5;
  pointer-events: none;
  mask-image: linear-gradient(180deg, black, transparent 90%);
  -webkit-mask-image: linear-gradient(180deg, black, transparent 90%);
}

/* Header row */
.plan__head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  position: relative;
}
.plan__index {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.24em;
  color: var(--text-muted);
  text-transform: uppercase;
}
.plan__tag {
  font-family: var(--font-mono);
  font-size: 9.5px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--accent);
  padding: 6px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,106,0,0.35);
  background: rgba(255,106,0,0.06);
}

/* Plan name */
.plan__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(28px, 2.6vw, 38px);
  letter-spacing: -0.025em;
  line-height: 1;
  margin: 4px 0 0;
}

/* Tagline */
.plan__tagline {
  color: var(--text-muted);
  font-size: 14px;
  line-height: 1.55;
  margin: 0;
  max-width: 32ch;
}

/* Price block */
.plan__price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin: 8px 0 6px;
  position: relative;
}
.plan__currency {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(22px, 2vw, 28px);
  color: var(--accent);
  letter-spacing: -0.02em;
  line-height: 1;
  transform: translateY(-6px);
}
.plan__amount {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(44px, 4.4vw, 64px);
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(180deg, #ffffff 0%, #c9c9d1 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.plan--featured .plan__amount {
  background: linear-gradient(180deg, #ffffff 0%, var(--accent-bright) 90%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}

.plan__divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.12), transparent);
  margin: 4px 0 6px;
}

/* Features list */
.plan__features {
  display: flex;
  flex-direction: column;
  gap: 11px;
  margin: 0;
  list-style: none;
  padding: 0;
  position: relative;
}
.plan__features li {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  font-size: 14px;
  line-height: 1.45;
  color: rgba(245,245,247,0.86);
}
.plan__check {
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,106,0,0.12);
  border: 1px solid rgba(255,106,0,0.35);
  color: var(--accent);
  margin-top: 2px;
  box-shadow: 0 0 0 0 rgba(255,106,0,0);
  transition: box-shadow .5s ease, background .4s ease;
}
.plan:hover .plan__check {
  box-shadow: 0 0 14px rgba(255,106,0,0.45);
  background: rgba(255,106,0,0.2);
}
.plan__check svg { width: 10px; height: 10px; }

/* CTA */
.plan__cta {
  margin-top: auto;
  width: 100%;
  justify-content: center;
  position: relative;
  letter-spacing: 0.12em;
  font-size: 12px;
  text-transform: uppercase;
  padding: 16px 22px;
}

/* Featured card — Most Popular */
.plan--featured {
  transform: translateY(-6px);
}
.plan--featured::before {
  background:
    radial-gradient(220px 220px at var(--plan-x) var(--plan-y), rgba(255,138,42,0.85), transparent 60%),
    conic-gradient(from var(--plan-angle, 0deg), rgba(255,106,0,0.6), rgba(255,138,42,0.15) 30%, rgba(255,106,0,0.6) 60%, rgba(255,138,42,0.15) 90%, rgba(255,106,0,0.6));
  animation: planSpin 8s linear infinite;
}
.plan--featured::after {
  opacity: 0.55;
}
.plan--featured:hover { transform: translateY(-14px); }
.plan--featured .plan__inner {
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(255,106,0,0.12), transparent 60%),
    linear-gradient(180deg, rgba(24,18,14,0.85) 0%, rgba(8,8,10,0.92) 100%);
}
@property --plan-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
@keyframes planSpin {
  to { --plan-angle: 360deg; }
}

/* Badge */
.plan__badge {
  position: absolute;
  top: -14px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 3;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #1a1004;
  background: linear-gradient(135deg, #ffb872 0%, var(--accent-bright) 50%, var(--accent) 100%);
  box-shadow: 0 10px 30px -10px rgba(255,106,0,0.7), 0 0 0 1px rgba(255,255,255,0.18) inset;
}
.plan__badge::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #1a1004;
  box-shadow: 0 0 0 3px rgba(26,16,4,0.2);
  animation: planPulse 1.6s ease-in-out infinite;
}
@keyframes planPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(0.6); opacity: 0.6; }
}

/* Tier accent variation — Legend gets a richer tone */
.plan[data-plan-name="legend"] .plan__amount {
  background: linear-gradient(180deg, #ffffff 0%, #ffd9b5 60%, var(--accent-bright) 100%);
  -webkit-background-clip: text; background-clip: text; color: transparent;
}
.plan[data-plan-name="legend"] .plan__tag {
  color: #ffd9b5;
  border-color: rgba(255,217,181,0.4);
  background: rgba(255,138,42,0.08);
}

/* Footer note */
.pricing-lab__foot {
  margin-top: clamp(40px, 5vw, 64px);
  display: flex;
  justify-content: center;
}
.pricing-lab__note {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  padding: 12px 22px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(16,16,18,0.6);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  font-size: 13px;
  color: var(--text-muted);
}
.pricing-lab__note a {
  color: var(--accent);
  font-weight: 500;
  margin-left: 4px;
}
.pricing-lab__dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 12px var(--accent-glow);
  animation: planPulse 1.8s ease-in-out infinite;
}

/* Responsive */
@media (max-width: 1100px) {
  .pricing-lab__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .plan--featured { transform: none; }
}
@media (max-width: 680px) {
  .pricing-lab__grid { grid-template-columns: 1fr; gap: 18px; }
  .plan__inner { padding: 28px 24px; }
  .plan__name { font-size: 28px; }
  .plan__amount { font-size: 44px; }
  .plan--featured { transform: none; }
  .pricing-lab__particles { display: none; }
}

@media (prefers-reduced-motion: reduce) {
  .pricing-lab__aurora,
  .plan--featured::before,
  .plan__badge::before,
  .pricing-lab__dot { animation: none !important; }
  .plan { transition: none; }
}

/* =====================================================================
   EXTRAS — luxury add-on tiles + Monthly Care plan
   ===================================================================== */
.extras {
  position: relative;
  isolation: isolate;
  overflow: hidden;
  padding: clamp(80px, 10vw, 140px) 0 clamp(80px, 9vw, 140px);
}
.extras__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  overflow: hidden;
}
.extras__aurora {
  position: absolute;
  border-radius: 50%;
  filter: blur(140px);
  opacity: 0.45;
  animation: extrasFloat 22s ease-in-out infinite alternate;
}
.extras__aurora--a {
  width: 50vw; height: 50vw;
  top: 10vw; left: -15vw;
  background: radial-gradient(closest-side, rgba(255,138,42,0.42), transparent 70%);
}
.extras__aurora--b {
  width: 45vw; height: 45vw;
  bottom: -8vw; right: -10vw;
  background: radial-gradient(closest-side, rgba(255,106,0,0.32), transparent 70%);
  animation-delay: -10s;
}
@keyframes extrasFloat {
  0%, 100% { transform: translate3d(0, 0, 0) scale(1); }
  50%      { transform: translate3d(2vw, -2vw, 0) scale(1.06); }
}
.extras__particles {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  opacity: 0.55;
  mix-blend-mode: screen;
}

/* Header */
.extras__head {
  text-align: center;
  max-width: 780px;
  margin: 0 auto clamp(46px, 5vw, 80px);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.extras__head .eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,106,0,0.32);
  background: linear-gradient(180deg, rgba(255,106,0,0.06), rgba(255,106,0,0.015));
  box-shadow: 0 0 24px -10px rgba(255,106,0,0.45);
}
.extras__title {
  margin: 0;
  max-width: 18ch;
  text-wrap: balance;
}
.extras__title .extras-line { display: block; }
.extras__title .accent-grad {
  font-style: normal;
  background: linear-gradient(120deg, #ffd9b5 0%, var(--accent-bright) 50%, var(--accent) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  filter: drop-shadow(0 0 28px rgba(255, 138, 42, 0.4));
}
.extras__sub {
  max-width: 60ch;
  font-size: 16px;
  line-height: 1.6;
  margin: 0;
}

/* Tile grid */
.extras__grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: clamp(14px, 1.4vw, 22px);
}

/* Tile */
.extra {
  --extra-x: 50%;
  --extra-y: 50%;
  position: relative;
  border-radius: 22px;
  padding: 1px;
  isolation: isolate;
  display: flex;
  transform: translateZ(0);
  transition: transform .7s var(--ease-out);
  will-change: transform;
}
.extra::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    radial-gradient(160px 160px at var(--extra-x) var(--extra-y), rgba(255,138,42,0.6), transparent 60%),
    linear-gradient(160deg, rgba(255,255,255,0.12), rgba(255,255,255,0.02) 38%, rgba(255,255,255,0.02) 62%, rgba(255,106,0,0.12));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  transition: opacity .5s ease;
}
.extra::after {
  content: "";
  position: absolute;
  inset: -2px;
  border-radius: inherit;
  background: radial-gradient(60% 70% at var(--extra-x) var(--extra-y), rgba(255,106,0,0.45), transparent 70%);
  filter: blur(26px);
  opacity: 0;
  transition: opacity .55s ease;
  z-index: -1;
  pointer-events: none;
}
.extra:hover { transform: translateY(-8px); }
.extra:hover::after { opacity: 1; }

.extra__inner {
  position: relative;
  width: 100%;
  border-radius: 21px;
  padding: clamp(20px, 1.7vw, 26px);
  background: linear-gradient(180deg, rgba(20,20,24,0.78) 0%, rgba(8,8,10,0.88) 100%);
  backdrop-filter: blur(16px) saturate(120%);
  -webkit-backdrop-filter: blur(16px) saturate(120%);
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  z-index: 0;
}
.extra__inner::before {
  content: "";
  position: absolute;
  inset: 0;
  background: radial-gradient(280px 280px at var(--extra-x) var(--extra-y), rgba(255,138,42,0.13), transparent 60%);
  opacity: 0;
  transition: opacity .55s ease;
  pointer-events: none;
}
.extra:hover .extra__inner::before { opacity: 1; }

/* Icon */
.extra__icon {
  width: 46px;
  height: 46px;
  border-radius: 14px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(120% 120% at 30% 20%, rgba(255,138,42,0.18), transparent 60%),
    rgba(255,255,255,0.03);
  border: 1px solid rgba(255,106,0,0.22);
  color: var(--accent);
  box-shadow: 0 0 0 0 rgba(255,106,0,0);
  transition: box-shadow .5s ease, border-color .4s ease, transform .6s var(--ease-out);
  flex: 0 0 auto;
}
.extra__icon svg { width: 22px; height: 22px; }
.extra:hover .extra__icon {
  box-shadow: 0 0 22px rgba(255,106,0,0.4);
  border-color: rgba(255,138,42,0.5);
  transform: translateY(-2px);
}

.extra__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 18px;
  line-height: 1.2;
  letter-spacing: -0.018em;
  margin: 4px 0 0;
}
.extra__desc {
  color: var(--text-muted);
  font-size: 13.5px;
  line-height: 1.55;
  margin: 0;
}

.extra__foot {
  margin-top: auto;
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding-top: 14px;
  border-top: 1px solid rgba(255,255,255,0.06);
  gap: 12px;
}
.extra__price {
  display: inline-flex;
  align-items: baseline;
  gap: 2px;
  font-family: var(--font-display);
  letter-spacing: -0.02em;
}
.extra__currency {
  color: var(--accent);
  font-weight: 500;
  font-size: 14px;
  transform: translateY(-2px);
}
.extra__amount {
  color: #fff;
  font-weight: 600;
  font-size: 22px;
}
.extra__suffix {
  color: var(--accent);
  font-weight: 500;
  font-size: 14px;
  margin-left: 2px;
}

/* ---------- Monthly Care Plan ---------- */
.extras__care {
  margin-top: clamp(36px, 4vw, 56px);
  --care-x: 70%;
  --care-y: 30%;
  position: relative;
  border-radius: 28px;
  padding: 1px;
  isolation: isolate;
  overflow: hidden;
}
.extras__care::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  padding: 1px;
  background:
    radial-gradient(280px 280px at var(--care-x) var(--care-y), rgba(255,138,42,0.7), transparent 60%),
    conic-gradient(from var(--care-angle, 0deg), rgba(255,106,0,0.55), rgba(255,138,42,0.1) 30%, rgba(255,106,0,0.55) 60%, rgba(255,138,42,0.1) 90%, rgba(255,106,0,0.55));
  -webkit-mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
          mask: linear-gradient(#000 0 0) content-box, linear-gradient(#000 0 0);
  -webkit-mask-composite: xor;
          mask-composite: exclude;
  pointer-events: none;
  z-index: 1;
  animation: careSpin 14s linear infinite;
}
.extras__care::after {
  content: "";
  position: absolute;
  inset: -3px;
  border-radius: inherit;
  background: radial-gradient(60% 80% at 50% 50%, rgba(255,106,0,0.32), transparent 70%);
  filter: blur(40px);
  opacity: 0.55;
  z-index: -1;
  pointer-events: none;
}
@property --care-angle {
  syntax: "<angle>";
  initial-value: 0deg;
  inherits: false;
}
@keyframes careSpin {
  to { --care-angle: 360deg; }
}

.care__inner {
  position: relative;
  border-radius: 27px;
  padding: clamp(32px, 3.5vw, 56px);
  background:
    radial-gradient(140% 80% at 0% 0%, rgba(255,106,0,0.10), transparent 55%),
    linear-gradient(180deg, rgba(22,18,14,0.92) 0%, rgba(8,8,10,0.95) 100%);
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: clamp(28px, 4vw, 56px);
  align-items: start;
  overflow: hidden;
  z-index: 0;
}
.care__inner::before {
  /* Inner starfield */
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(1px 1px at 12% 18%, rgba(255,255,255,0.22), transparent 60%),
    radial-gradient(1px 1px at 78% 38%, rgba(255,138,42,0.45), transparent 60%),
    radial-gradient(1px 1px at 35% 80%, rgba(255,255,255,0.18), transparent 60%),
    radial-gradient(1px 1px at 88% 86%, rgba(255,106,0,0.45), transparent 60%);
  opacity: 0.45;
  pointer-events: none;
}

.care__left {
  display: flex;
  flex-direction: column;
  gap: 18px;
  align-items: flex-start;
}
.care__tag {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 7px 14px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: #1a1004;
  background: linear-gradient(135deg, #ffb872 0%, var(--accent-bright) 50%, var(--accent) 100%);
  box-shadow: 0 10px 24px -10px rgba(255,106,0,0.7), 0 0 0 1px rgba(255,255,255,0.18) inset;
}
.care__tag::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 50%;
  background: #1a1004;
  animation: planPulse 1.6s ease-in-out infinite;
}
.care__name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(34px, 3.6vw, 52px);
  letter-spacing: -0.03em;
  line-height: 1;
  margin: 0;
}
.care__desc {
  color: var(--text-muted);
  font-size: 15.5px;
  line-height: 1.6;
  max-width: 44ch;
  margin: 0;
}
.care__price {
  display: flex;
  align-items: baseline;
  gap: 4px;
  margin: 6px 0 4px;
}
.care__currency {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(22px, 1.8vw, 28px);
  color: var(--accent);
  transform: translateY(-8px);
  letter-spacing: -0.02em;
}
.care__amount {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(46px, 4.6vw, 68px);
  letter-spacing: -0.04em;
  line-height: 1;
  background: linear-gradient(180deg, #ffffff 0%, var(--accent-bright) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
}
.care__unit {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--text-muted);
  margin-left: 6px;
  letter-spacing: 0.06em;
}
.care__cta {
  width: auto;
  white-space: nowrap;
  align-self: flex-start;
  margin-top: 6px;
}

/* Right: features */
.care__right { display: flex; flex-direction: column; gap: 18px; }
.care__features-label {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.24em;
  text-transform: uppercase;
  color: var(--text-muted);
}
.care__features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px 22px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.care__features li {
  display: flex;
  align-items: flex-start;
  gap: 11px;
  font-size: 14px;
  line-height: 1.4;
  color: rgba(245,245,247,0.88);
}
.care__check {
  flex: 0 0 auto;
  width: 18px; height: 18px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,106,0,0.12);
  border: 1px solid rgba(255,106,0,0.4);
  color: var(--accent);
  margin-top: 1px;
}
.care__check svg { width: 10px; height: 10px; }
.care__note {
  margin-top: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(255,106,0,0.22);
  background:
    linear-gradient(180deg, rgba(255,106,0,0.05), rgba(255,106,0,0.02));
  font-size: 12.5px;
  line-height: 1.5;
  color: var(--text-muted);
  display: flex;
  gap: 10px;
  align-items: flex-start;
}
.care__note-icon {
  flex: 0 0 auto;
  color: var(--accent);
  margin-top: 1px;
}

/* Responsive */
@media (max-width: 1180px) {
  .extras__grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 980px) {
  .care__inner { grid-template-columns: 1fr; gap: 28px; }
  .care__features { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .extras__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
  .extra__inner { padding: 18px; }
  .extra__name { font-size: 16px; }
  .extra__amount { font-size: 20px; }
  .care__features { grid-template-columns: 1fr; }
  .extras__particles { display: none; }
}
@media (max-width: 460px) {
  .extras__grid { grid-template-columns: 1fr; }
}

@media (prefers-reduced-motion: reduce) {
  .extras__aurora,
  .extras__care::before,
  .care__tag::before { animation: none !important; }
  .extra { transition: none; }
}
