@import url("https://fonts.googleapis.com/css2?family=Marcellus&family=Playfair+Display:wght@500;600;700&display=swap");

:root {
  --bg: #fbf4e8;
  --paper: rgba(255, 251, 246, 0.74);
  --card: #fffaf3;
  --text: #1f1a16;
  --muted: #62574d;
  --line: rgba(76, 31, 121, 0.11);
  --brand: #6f349e;
  --brand-deep: #4c1f79;
  --accent: #e0aa2c;
  --accent-soft: #f4d779;
  --lavender: #b98adf;
  --shadow: 0 10px 24px rgba(76, 31, 121, 0.07);
  --radius: 18px;
  --max: 1040px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Marcellus", Georgia, serif;
  color: var(--text);
  background:
    linear-gradient(180deg, rgba(251, 244, 232, 0) 0 5.8rem, rgba(251, 244, 232, 0.96) 8rem, var(--bg) 10rem calc(100% - 18rem), rgba(251, 244, 232, 0) calc(100% - 8rem) 100%),
    url("watercolor-background.png") top center / 100% auto no-repeat,
    url("watercolor-background.png") bottom center / 100% auto no-repeat,
    var(--bg);
  background-attachment: scroll;
  position: relative;
}
body::before {
  content: none;
}
body::after {
  content: none;
}
a { color: inherit; text-decoration: none; }
.container { width: min(calc(100% - 2rem), var(--max)); margin: 0 auto; }
.site-header {
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(18px);
  background: rgba(255, 253, 248, 0.16);
  border-bottom: 1px solid rgba(224, 170, 44, 0.24);
}
.header-inner {
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem; padding: .55rem 0;
}
.brand { display: flex; align-items: center; gap: .8rem; font-weight: 700; }
.site-header .brand span {
  display: none;
}
.site-header .brand {
  padding: .18rem .34rem;
  border-radius: 12px;
  background: rgba(255, 253, 248, 0.68);
  box-shadow: 0 10px 28px rgba(31, 26, 22, 0.08);
  backdrop-filter: blur(8px);
}
.brand-mark {
  width: 112px;
  height: 68px;
  display: block;
  object-fit: contain;
}
.nav, .button-row, .footer-links, .stat-grid, .card-grid, .price-grid, .news-grid, .footer-grid, .hero-pills {
  display: flex; gap: 1rem;
}
.nav { align-items: center; }
.nav a { color: var(--muted); }
.nav a.active, .nav a:hover { color: var(--text); }
.nav-group {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.nav-links {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.mobile-page-menu {
  display: none;
}
.nav-login {
  white-space: nowrap;
  padding: .8rem 1.1rem;
}
.page-select {
  min-width: 170px;
  padding: .8rem 2.4rem .8rem .95rem;
  font: inherit;
  color: var(--text);
  background: rgba(255, 251, 246, 0.9);
  border: 1px solid var(--line);
  border-radius: 999px;
  appearance: none;
  cursor: pointer;
}
.button-row { flex-wrap: wrap; }
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  padding: .72rem 1rem; border-radius: 999px; font-size: .9rem;
  border: 1px solid transparent; transition: transform .18s ease;
}
.btn:hover { transform: translateY(-1px); }
.btn-primary {
  background: linear-gradient(135deg, var(--brand), var(--brand-deep));
  color: #fffaf4;
  box-shadow: 0 14px 28px rgba(76, 31, 121, 0.22);
}
.btn-secondary {
  background: linear-gradient(135deg, rgba(255, 249, 233, 0.96), rgba(246, 225, 166, 0.96));
  border-color: rgba(224, 170, 44, 0.25);
  color: var(--brand-deep);
}
.eyebrow {
  display: inline-block; padding: .34rem .72rem; border-radius: 999px;
  font-size: .68rem; text-transform: uppercase; letter-spacing: .08em;
  color: var(--brand-deep); background: rgba(255, 250, 243, 0.9); border: 1px solid rgba(111, 52, 158, 0.12);
}
.hero, .page-hero { padding: clamp(1.25rem, 3vw, 2.25rem) 0 clamp(.55rem, 1.6vw, 1rem); }
.hero {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.hero::before {
  content: none;
}
.hero::after {
  content: none;
}
.hero-grid, .two-col, .contact-grid {
  display: grid; grid-template-columns: 1.1fr .9fr; gap: 1.4rem; align-items: center;
}
.hero-grid {
  grid-template-columns: minmax(0, 720px);
}
.hero-grid > div:first-child {
  max-width: 680px;
}
.home-hero-logo {
  display: none;
}
.home-hero-logo::before {
  content: "";
  position: absolute;
  inset: 7% 2% 5% 4%;
  z-index: -1;
  border-radius: 48% 52% 46% 54% / 58% 44% 56% 42%;
  background:
    radial-gradient(ellipse at 74% 28%, rgba(24, 88, 66, 0.36), transparent 25%),
    radial-gradient(ellipse at 52% 42%, rgba(62, 119, 91, 0.26), transparent 26%),
    radial-gradient(ellipse at 38% 60%, rgba(208, 164, 54, 0.22), transparent 28%),
    linear-gradient(126deg, transparent 36%, rgba(208, 164, 54, 0.3) 36.4%, transparent 36.9%),
    linear-gradient(154deg, transparent 54%, rgba(208, 164, 54, 0.24) 54.35%, transparent 54.85%);
  filter: blur(14px) saturate(1.18);
  transform: rotate(-6deg);
}
.home-hero-logo::after {
  content: "";
  position: absolute;
  inset: 14% 7% 10% 10%;
  border-radius: 52% 48% 55% 45% / 42% 58% 44% 56%;
  background:
    radial-gradient(ellipse at 60% 34%, rgba(255, 253, 248, 0.66), transparent 20%),
    radial-gradient(ellipse at 42% 56%, rgba(21, 78, 59, 0.18), transparent 24%),
    radial-gradient(ellipse at 54% 66%, rgba(208, 164, 54, 0.18), transparent 24%);
  filter: blur(9px);
  transform: rotate(8deg);
}
.home-hero-logo img {
  display: none;
  width: 100%;
  height: auto;
  filter: drop-shadow(0 24px 32px rgba(76, 31, 121, 0.16));
}
.contact-grid.single-card {
  grid-template-columns: 1fr;
  justify-items: center;
}
.contact-grid.single-card .contact-card {
  width: min(100%, 760px);
}
h1, h2, h3, h4 {
  font-family: "Playfair Display", Georgia, serif;
  color: var(--text);
}
h1 { font-size: clamp(1.85rem, 3vw, 2.7rem); line-height: 1.04; letter-spacing: 0; margin: .55rem 0; font-weight: 700; }
h2 { font-size: clamp(1.4rem, 2.35vw, 2.05rem); line-height: 1.08; letter-spacing: 0; margin: .5rem 0; font-weight: 700; }
h3, h4 { margin: 0 0 .45rem; font-size: 1.05rem; font-weight: 700; letter-spacing: 0; }
h4 { color: var(--text); }
p, li { color: #453b34; line-height: 1.5; font-size: .95rem; }
.section { padding: clamp(.65rem, 1.6vw, 1.25rem) 0 clamp(1.2rem, 3vw, 2.2rem); }
.panel, .card, .price-card, .news-card, .faq, .contact-card, .hero-visual, .table-wrap {
  background:
    linear-gradient(135deg, rgba(255, 255, 255, 0.76), rgba(255, 251, 246, 0.7)),
    var(--paper);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  backdrop-filter: blur(10px);
  border-radius: var(--radius);
}
.hero-visual, .panel, .table-wrap { padding: clamp(1rem, 2.2vw, 1.55rem); }
.card, .price-card, .news-card, .faq, .contact-card { padding: clamp(.85rem, 1.8vw, 1.2rem); }
.hero-pills, .stat-grid, .card-grid, .price-grid, .news-grid, .footer-grid { flex-wrap: wrap; }
.pill { padding: .45rem .8rem; border-radius: 999px; background: rgba(111, 52, 158, 0.1); color: var(--brand-deep); font-size: .8rem; }
.planner-ui {
  min-height: 360px; border-radius: 20px; padding: 1rem;
  background:
    linear-gradient(135deg, rgba(42,111,99,.08), rgba(199,134,87,.05)),
    repeating-linear-gradient(0deg, transparent, transparent 24px, rgba(53,41,28,.05) 24px, rgba(53,41,28,.05) 25px),
    repeating-linear-gradient(90deg, transparent, transparent 24px, rgba(53,41,28,.05) 24px, rgba(53,41,28,.05) 25px);
}
.planner-ui .split { display: grid; grid-template-columns: 1.2fr .8fr; gap: 1rem; margin-top: 1rem; }
.sketch {
  min-height: 250px; border-radius: 18px; position: relative;
  background: rgba(255,255,255,.35); border: 1px solid rgba(53,41,28,.06);
}
.sketch::before, .sketch::after {
  content: ""; position: absolute; border-radius: 999px;
}
.sketch::before {
  width: 120px; height: 120px; top: 16%; left: 15%;
  border: 3px solid rgba(42,111,99,.5);
}
.sketch::after {
  width: 180px; height: 60px; right: 10%; bottom: 20%;
  border: 3px solid rgba(199,134,87,.55); transform: rotate(-14deg);
}
.mini { background: rgba(255,255,255,.5); border: 1px solid rgba(53,41,28,.06); border-radius: 18px; padding: 1rem; }
.stat, .card, .price-card, .news-card { flex: 1 1 240px; }
.news-feature {
  flex: 1 1 100%;
}
.news-feature h2 {
  max-width: 760px;
  margin-bottom: .75rem;
}
.news-feature p {
  max-width: 860px;
}
.news-feature .button-row {
  margin-top: 1rem;
}
.home-details {
  padding-top: .25rem;
}
.home-details .two-col {
  align-items: start;
  gap: clamp(1rem, 2.2vw, 1.6rem);
}
.home-details .feature-summary {
  background: linear-gradient(90deg, rgba(255, 253, 248, 0.54), rgba(255, 253, 248, 0.18));
  border: 0;
  border-left: 1px solid rgba(224, 170, 44, 0.48);
  border-radius: 0;
  box-shadow: none;
  backdrop-filter: none;
  padding: .45rem 0 .45rem 1.2rem;
}
.home-details ul.clean {
  margin-top: .7rem;
}
.about-next {
  padding-top: .25rem;
}
.about-next .panel {
  display: grid;
  grid-template-columns: minmax(0, .9fr) minmax(280px, 1.1fr);
  gap: clamp(1rem, 2.4vw, 1.8rem);
  align-items: start;
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.82), rgba(255, 251, 246, 0.58)),
    var(--paper);
  border-color: rgba(224, 170, 44, 0.26);
}
.about-next h2 {
  max-width: 620px;
}
.about-next p {
  margin-bottom: 0;
}
.next-step-list {
  display: grid;
  gap: .65rem;
}
.next-step-list a {
  display: grid;
  gap: .14rem;
  padding: .75rem .9rem;
  border-left: 2px solid rgba(224, 170, 44, 0.55);
  background: rgba(255, 253, 248, 0.45);
}
.next-step-list strong {
  color: var(--brand-deep);
}
.next-step-list span {
  color: #453b34;
  font-size: .9rem;
  line-height: 1.35;
}
.panel.feature-summary {
  position: relative;
  min-height: 0;
  padding-bottom: clamp(1rem, 2.2vw, 1.55rem);
}
.panel.feature-summary .button-row {
  position: static;
  margin-top: 1rem;
}
.price-card.has-corner-button {
  position: relative;
  padding-top: 4.4rem;
}
.price-card.has-bottom-preview {
  display: flex;
  flex-direction: column;
}
.price-card.has-bottom-preview > .clean {
  margin-bottom: 1.25rem;
}
.price-card.has-bottom-preview .preview-action {
  margin-top: auto;
  padding-top: 1.25rem;
  position: static;
  right: auto;
  top: auto;
}
.price-card.has-bottom-preview .preview-action .btn {
  width: 100%;
}
.price-card.has-corner-button .button-row {
  position: absolute;
  top: 1.2rem;
  right: 1.2rem;
}
.price-card.has-corner-button.has-bottom-preview .button-row.preview-action {
  position: static;
  inset: auto;
  margin-top: auto;
  padding-top: 1.25rem;
}
.price-card.has-corner-button.has-bottom-preview .button-row.preview-action .btn {
  width: 100%;
}
.plans-overview {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: clamp(.9rem, 2vw, 1.4rem);
  align-items: start;
}
.plans-overview .price-card,
.plans-grid .price-card {
  background:
    linear-gradient(135deg, rgba(255, 253, 248, 0.9), rgba(255, 251, 246, 0.8)),
    var(--paper);
}
.plan-feature-card.wide-card {
  grid-column: 1 / -1;
}
.plan-title-row {
  display: flex;
  align-items: start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: .7rem;
}
.preview-link {
  display: grid;
  gap: .2rem;
  width: 76px;
  padding: .28rem;
  border: 1px solid rgba(224, 170, 44, 0.34);
  border-radius: 14px;
  background: rgba(255, 253, 248, 0.7);
  color: var(--brand-deep);
  font: inherit;
  font-size: .78rem;
  cursor: pointer;
  box-shadow: 0 8px 18px rgba(76, 31, 121, 0.06);
  transition: transform .18s ease, border-color .18s ease, box-shadow .18s ease;
}
.preview-link img {
  width: 100%;
  aspect-ratio: 4 / 3;
  object-fit: cover;
  border-radius: 10px;
}
.preview-link:hover,
.preview-link:focus-visible {
  transform: translateY(-2px);
  border-color: rgba(111, 52, 158, 0.34);
  box-shadow: 0 12px 24px rgba(76, 31, 121, 0.12);
  outline: none;
}
.section-heading {
  max-width: 640px;
  margin-bottom: 1rem;
}
.faq-list {
  display: grid;
  gap: .65rem;
}
.faq {
  overflow: hidden;
}
.faq summary {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  cursor: pointer;
  color: var(--text);
  font-family: "Playfair Display", Georgia, serif;
  font-size: clamp(1.02rem, 1.7vw, 1.18rem);
  font-weight: 700;
  list-style: none;
}
.faq summary::-webkit-details-marker {
  display: none;
}
.faq summary::after {
  content: "+";
  display: grid;
  place-items: center;
  flex: 0 0 1.6rem;
  width: 1.6rem;
  height: 1.6rem;
  border: 1px solid rgba(224, 170, 44, 0.42);
  border-radius: 999px;
  background: rgba(255, 248, 222, 0.8);
  color: var(--brand-deep);
  font-family: "Marcellus", Georgia, serif;
  font-size: 1.05rem;
  line-height: 1;
}
.faq[open] summary::after {
  content: "-";
}
.faq summary:focus-visible {
  outline: 2px solid rgba(111, 52, 158, 0.35);
  outline-offset: 4px;
  border-radius: 8px;
}
.faq p {
  margin: .55rem 2.5rem 0 0;
}
.plans-grid {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: clamp(.75rem, 1.6vw, 1rem);
  align-items: stretch;
}
.plans-grid .price-card {
  display: flex;
  flex-direction: column;
  flex: 1 1 300px;
  max-width: 420px;
}
.plans-grid > .price-card:first-child {
  flex: 1 1 100%;
  max-width: none;
  position: relative;
}
.plans-grid > .price-card:first-child .plan-title-row {
  display: block;
  margin-bottom: .25rem;
  padding-right: 5.25rem;
}
.plans-grid > .price-card:first-child .preview-link {
  position: absolute;
  top: clamp(.85rem, 1.8vw, 1.2rem);
  right: clamp(.85rem, 1.8vw, 1.2rem);
}
.plans-grid > .price-card:first-child .clean {
  columns: 2;
  column-gap: clamp(1.5rem, 4vw, 3rem);
  margin-top: .85rem;
}
.plans-grid > .price-card:first-child .clean li {
  break-inside: avoid;
}
.plans-grid .subscription-card {
  flex: 1 1 100%;
  max-width: none;
  position: relative;
}
.plans-grid .subscription-card .plan-title-row {
  display: block;
  margin-bottom: .65rem;
  padding-right: 5.25rem;
}
.plans-grid .subscription-card .preview-link {
  position: absolute;
  top: clamp(.85rem, 1.8vw, 1.2rem);
  right: clamp(.85rem, 1.8vw, 1.2rem);
}
.subscription-features {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
  margin: .65rem 0 .75rem;
}
.subscription-features div {
  padding: .62rem .75rem;
  border-left: 2px solid rgba(224, 170, 44, 0.55);
  background: rgba(255, 253, 248, 0.48);
}
.subscription-features strong {
  color: var(--brand-deep);
}
.subscription-features p {
  margin: .16rem 0 0;
  font-size: .86rem;
  line-height: 1.28;
}
.subscription-split {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .65rem;
  margin-top: auto;
  align-items: stretch;
}
.subscription-tier {
  display: flex;
  flex-direction: column;
  padding: .72rem .82rem;
  border: 1px solid rgba(224, 170, 44, 0.24);
  border-radius: 14px;
  background: rgba(255, 253, 248, 0.5);
}
.subscription-tier.highlight {
  outline: 1px solid rgba(111, 52, 158, 0.2);
}
.stacked-pricing {
  flex-direction: column;
  align-items: center;
}
.stacked-pricing .price-card {
  width: min(100%, 760px);
  flex: 0 1 auto;
}
.pricing-matrix {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}
.pricing-matrix .price-card {
  width: 100%;
  flex: none;
}
.pricing-slider {
  max-width: 820px;
}
.pricing-track {
  position: relative;
  min-height: 430px;
}
.pricing-slide {
  display: none;
  min-height: 430px;
}
.pricing-slide.is-active {
  display: block;
  animation: slideIn .28s ease both;
}
.pricing-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  margin-bottom: 1.25rem;
  color: var(--muted);
}
@keyframes slideIn {
  from { opacity: 0; transform: translateY(10px) scale(.99); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}
.feature-matrix {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  align-items: stretch;
}
.feature-matrix .price-card {
  width: 100%;
  flex: none;
}
.feature-matrix .wide-card {
  grid-column: 1 / -1;
}
.combined-feature-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.4fr) minmax(280px, .8fr);
  gap: clamp(1rem, 3vw, 2rem);
  align-items: start;
}
.combined-feature-grid h3 {
  margin-top: 0;
}
.wide-card.has-corner-button {
  padding-top: 2.1rem;
}
.wide-card.has-corner-button .button-row {
  top: 1.5rem;
  right: 1.5rem;
}
.price-amount {
  margin: .12rem 0 0;
  font-size: clamp(1.45rem, 2.6vw, 1.9rem);
  font-weight: 700;
  line-height: 1;
  color: var(--text);
}
.price-amount span {
  font-size: .95rem;
  font-weight: 400;
}
.price-subtext {
  margin: .22rem 0 0;
  font-size: .9rem;
}
.price-offer {
  margin-top: .65rem;
  padding-top: .6rem;
  border-top: 1px solid var(--line);
}
.price-offer strong {
  display: block;
  margin-bottom: .35rem;
  color: var(--brand-deep);
}
.preview-action {
  margin-top: 1.25rem;
}
.price-card > .preview-action .btn {
  width: 100%;
}
.preview-modal {
  position: fixed;
  inset: 0;
  z-index: 50;
  display: none;
  align-items: center;
  justify-content: center;
  padding: 1rem;
}
.preview-modal.is-open {
  display: flex;
}
.preview-backdrop {
  position: absolute;
  inset: 0;
  background: rgba(31, 26, 22, 0.58);
  backdrop-filter: blur(8px);
}
.preview-dialog {
  position: relative;
  width: min(100%, 980px);
  max-height: min(90vh, 760px);
  padding: clamp(1rem, 3vw, 1.5rem);
  border-radius: var(--radius);
  background: rgba(255, 251, 246, 0.92);
  border: 1px solid rgba(111, 52, 158, 0.18);
  box-shadow: 0 30px 70px rgba(31, 26, 22, 0.28);
}
.preview-dialog img {
  display: block;
  width: 100%;
  max-height: 72vh;
  object-fit: contain;
  border-radius: 18px;
}
.preview-gallery {
  display: grid;
  gap: 1rem;
}
.preview-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1rem;
  flex-wrap: wrap;
  color: var(--muted);
  font-size: .95rem;
}
.preview-nav {
  border: 0;
  border-radius: 999px;
  padding: .75rem 1.2rem;
  font: inherit;
  font-weight: 700;
  color: #fffaf4;
  background: linear-gradient(135deg, var(--brand), var(--brand-deep));
  box-shadow: 0 12px 24px rgba(111, 52, 158, 0.2);
  cursor: pointer;
}
.preview-close {
  position: absolute;
  right: 1rem;
  top: 1rem;
  border: 0;
  border-radius: 999px;
  padding: .55rem .8rem;
  font: inherit;
  color: #fffaf4;
  background: linear-gradient(135deg, var(--brand), var(--brand-deep));
  cursor: pointer;
}
.stat strong { display: block; font-size: 1.9rem; margin-bottom: .35rem; }
ul.clean { padding: 0; margin: .7rem 0 0; }
ul.clean li { list-style: none; position: relative; padding-left: 1rem; margin-bottom: .42rem; }
ul.clean li::before { content: "•"; position: absolute; left: 0; color: var(--accent); }
.highlight { outline: 2px solid rgba(111, 52, 158, .18); }
table { width: 100%; border-collapse: collapse; }
th, td { text-align: left; padding: 1rem; border-bottom: 1px solid var(--line); }
th { font-size: .82rem; text-transform: uppercase; letter-spacing: .08em; color: var(--muted); }
.cta {
  margin: 0 0 4rem; padding: 2rem; border-radius: var(--radius);
  background: linear-gradient(135deg, var(--brand), var(--brand-deep)); color: #fffaf4;
  box-shadow: var(--shadow);
}
.cta p { color: rgba(255,250,244,.85); }
.site-footer {
  border-top: 1px solid rgba(224, 170, 44, 0.55);
  padding: .85rem 0 1rem;
  background: linear-gradient(180deg, transparent, rgba(255, 251, 246, 0.54));
}
.site-footer .footer-grid {
  align-items: flex-start;
  justify-content: space-between;
  gap: .55rem 1.4rem;
}
.footer-grid > * { flex: 0 1 auto; }
.site-footer .brand-mark {
  width: 54px;
  height: 32px;
}
.site-footer p {
  display: none;
}
.site-footer strong {
  font-size: .86rem;
}
.footer-links {
  flex-direction: column;
  gap: .12rem;
  font-size: .84rem;
}
.contact-form { display: grid; gap: .9rem; }
.contact-form label { display: grid; gap: .45rem; font-size: .92rem; color: var(--muted); }
.hidden-field { display: none; }
.contact-form input, .contact-form textarea, .contact-form select {
  width: 100%; padding: .9rem 1rem; font: inherit; color: var(--text);
  background: rgba(255, 251, 246, 0.72); border: 1px solid var(--line); border-radius: 16px;
  transition: border-color .18s ease, box-shadow .18s ease, background .18s ease;
}
.contact-form input:focus,
.contact-form textarea:focus,
.contact-form select:focus {
  outline: none;
  background: rgba(255, 251, 246, 0.98);
  border-color: rgba(111, 52, 158, 0.32);
  box-shadow: 0 0 0 4px rgba(111, 52, 158, 0.08);
}
.contact-form textarea { min-height: 150px; resize: vertical; }
[data-reveal] { opacity: 0; transform: translateY(18px); transition: opacity .5s ease, transform .5s ease; }
[data-reveal].visible { opacity: 1; transform: translateY(0); }

@media (max-width: 900px) {
  .nav {
    flex-wrap: wrap;
  }
  .nav-links {
    display: none;
  }
  .mobile-page-menu {
    display: inline-block;
  }
}

@media (max-width: 760px) {
  body::before {
    inset: 15rem -48vw auto auto;
    width: 132vw;
    height: 92vw;
    opacity: 0.42;
  }
  .header-inner, .hero-grid, .two-col, .contact-grid, .planner-ui .split { grid-template-columns: 1fr; display: grid; }
  .pricing-matrix {
    grid-template-columns: 1fr;
  }
  .plans-grid .price-card {
    max-width: none;
  }
  .plans-grid > .price-card:first-child {
    padding-right: clamp(.85rem, 1.8vw, 1.2rem);
  }
  .plans-grid > .price-card:first-child .plan-title-row {
    display: flex;
    margin-bottom: .7rem;
    padding-right: 0;
  }
  .plans-grid > .price-card:first-child .preview-link {
    position: static;
  }
  .plans-grid > .price-card:first-child .clean {
    columns: 1;
  }
  .plans-grid .subscription-card {
    padding-right: clamp(.85rem, 1.8vw, 1.2rem);
  }
  .plans-grid .subscription-card .plan-title-row {
    display: flex;
    margin-bottom: .7rem;
    padding-right: 0;
  }
  .plans-grid .subscription-card .preview-link {
    position: static;
  }
  .subscription-features,
  .subscription-split {
    grid-template-columns: 1fr;
  }
  .plan-feature-card.wide-card {
    grid-column: auto;
  }
  .plan-title-row {
    align-items: stretch;
  }
  .preview-link {
    width: 92px;
  }
  .feature-matrix {
    grid-template-columns: 1fr;
  }
  .combined-feature-grid {
    grid-template-columns: 1fr;
  }
  .about-next .panel {
    grid-template-columns: 1fr;
  }
  .panel.feature-summary .button-row {
    position: static;
    margin-top: 1.5rem;
  }
  .price-card.has-corner-button .button-row {
    position: static;
    margin-bottom: 1rem;
  }
  .btn { width: 100%; }
}
