@import url("https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,600;9..144,700&family=Plus+Jakarta+Sans:wght@400;500;600;700;800&display=swap");

:root {
  --site-ink: #142129;
  --site-muted: #5d6a70;
  --site-paper: #f6faf6;
  --site-mist: #edf5ef;
  --site-white: #ffffff;
  --site-sage: #2f6f63;
  --site-sage-dark: #18473f;
  --site-coral: #d96f57;
  --site-lavender: #c9c3f4;
  --site-sky: #d8edf2;
  --site-amber: #f2bd66;
  --site-line: rgba(47, 111, 99, .2);
  --site-shadow: 0 18px 44px rgba(16, 44, 39, .11);
  --site-shadow-lift: 0 26px 70px rgba(16, 44, 39, .17);
  --site-wash: linear-gradient(135deg, rgba(216, 237, 242, .82), rgba(246, 250, 246, .94) 46%, rgba(250, 239, 232, .78));
}

* {
  letter-spacing: 0 !important;
}

html {
  background: var(--site-paper);
  scroll-behavior: smooth;
}

body {
  color: var(--site-ink) !important;
  background:
    radial-gradient(circle at 10% 8%, rgba(201, 195, 244, .34), transparent 23rem),
    radial-gradient(circle at 92% 20%, rgba(217, 111, 87, .18), transparent 24rem),
    radial-gradient(circle at 52% 100%, rgba(47, 111, 99, .18), transparent 30rem),
    linear-gradient(180deg, #f9fcf8 0%, #eef7f1 52%, #f8fbf7 100%) !important;
  font-family: "Plus Jakarta Sans", Inter, Arial, sans-serif !important;
  line-height: 1.6 !important;
  overflow-x: hidden;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .5;
  background-image:
    linear-gradient(90deg, rgba(47, 111, 99, .09) 1px, transparent 1px),
    linear-gradient(0deg, rgba(47, 111, 99, .07) 1px, transparent 1px),
    radial-gradient(circle at center, rgba(217, 111, 87, .14) 0 2px, transparent 2px);
  background-size: 54px 54px, 54px 54px, 108px 108px;
  mask-image: linear-gradient(180deg, #000, transparent 88%);
  animation: siteGridDrift 22s linear infinite;
}

body::after {
  content: "";
  position: fixed;
  inset: auto -10% 0 -10%;
  z-index: -1;
  height: 34vh;
  pointer-events: none;
  background:
    linear-gradient(90deg, rgba(47, 111, 99, .08), rgba(201, 195, 244, .18), rgba(217, 111, 87, .1));
  filter: blur(44px);
  transform: translateY(34%);
}

main {
  animation: sitePageIn .5s ease both;
}

.site-header {
  border-bottom: 1px solid rgba(47, 111, 99, .16) !important;
  background: rgba(250, 253, 249, .82) !important;
  backdrop-filter: blur(18px) saturate(1.14);
  box-shadow: 0 12px 38px rgba(16, 44, 39, .08) !important;
}

.brand {
  color: var(--site-ink) !important;
}

.brand-mark {
  color: transparent !important;
  border: 1px solid rgba(255, 255, 255, .68) !important;
  background:
    radial-gradient(circle at 28% 26%, #ffffff 0 13%, transparent 14%),
    conic-gradient(from 140deg, var(--site-sage), var(--site-coral), var(--site-lavender), var(--site-sage)) !important;
  box-shadow: 0 14px 30px rgba(47, 111, 99, .2), inset 0 1px 0 rgba(255, 255, 255, .7) !important;
  transition: transform .24s ease, box-shadow .24s ease !important;
}

.brand:hover .brand-mark {
  transform: rotate(-6deg) scale(1.05);
  box-shadow: 0 18px 40px rgba(47, 111, 99, .26), inset 0 1px 0 rgba(255, 255, 255, .72) !important;
}

.brand strong,
h1,
h2,
h3 {
  color: var(--site-ink) !important;
}

h1,
h2 {
  font-family: "Fraunces", "Source Serif 4", Georgia, serif !important;
  font-weight: 700 !important;
  text-wrap: balance;
}

.brand small,
p,
li,
dd,
.hero-lede,
.section-heading p:not(.eyebrow),
.about-copy,
.portrait-card p,
.service-list p,
.systems-grid p,
.trust-grid p,
.contact-copy p,
.site-footer {
  color: var(--site-muted) !important;
}

.eyebrow,
.summary-card dt,
.link-more,
.open,
.site-footer a {
  color: var(--site-sage-dark) !important;
  font-weight: 800 !important;
}

.eyebrow {
  width: fit-content;
  padding: 6px 9px;
  border: 1px solid rgba(47, 111, 99, .14);
  border-radius: 999px;
  background: rgba(255, 255, 255, .64);
  box-shadow: 0 8px 22px rgba(16, 44, 39, .06);
  letter-spacing: .08em !important;
}

.nav-links a {
  position: relative;
  color: #53626a !important;
  transition: color .2s ease, transform .2s ease;
}

.nav-links a::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: -7px;
  height: 2px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--site-coral), var(--site-sage), var(--site-lavender));
  opacity: 0;
  transform: scaleX(.55);
  transition: opacity .2s ease, transform .2s ease;
}

.nav-links a:hover {
  color: var(--site-sage-dark) !important;
  transform: translateY(-1px);
}

.nav-links a:hover::after {
  opacity: 1;
  transform: scaleX(1);
}

.button.primary {
  color: #ffffff !important;
  border: 1px solid rgba(24, 71, 63, .18) !important;
  background:
    linear-gradient(110deg, transparent 0 34%, rgba(255, 255, 255, .28) 44%, transparent 54% 100%),
    linear-gradient(135deg, var(--site-sage-dark), var(--site-sage) 58%, #3a7a9a) !important;
  background-size: 220% 100%, 100% 100% !important;
  box-shadow: 0 16px 34px rgba(47, 111, 99, .22) !important;
}

.button.secondary {
  color: var(--site-sage-dark) !important;
  border-color: rgba(47, 111, 99, .22) !important;
  background: rgba(255, 255, 255, .78) !important;
  box-shadow: 0 12px 26px rgba(16, 44, 39, .08) !important;
}

.button,
.asset-modal__close,
button {
  border-radius: 999px !important;
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background-position .42s ease !important;
}

.button:hover,
.asset-modal__close:hover,
button:hover {
  transform: translateY(-3px);
  background-position: 100% 50%, 50% 50% !important;
}

.summary-card,
.portrait-card,
.service-list article,
.support-grid article,
.systems-grid article,
.steps li,
.trust-grid p,
.lead-form,
.quote-form,
.scheduler-box,
.resource-grid article,
.testimonial-grid article,
.faq-list article,
.article-body,
.card,
.service-card,
.specialty-card,
.resource-card,
.testimonial-card,
.fit-card,
.process-card,
.detail-card {
  position: relative;
  overflow: hidden;
  border-color: var(--site-line) !important;
  border-radius: 8px !important;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, .9), rgba(255, 255, 255, .72)),
    linear-gradient(180deg, rgba(237, 245, 239, .92), rgba(255, 255, 255, .94)) !important;
  box-shadow: var(--site-shadow) !important;
  backdrop-filter: blur(10px);
  transition: transform .24s ease, box-shadow .24s ease, border-color .24s ease, background .24s ease !important;
}

.summary-card::after,
.portrait-card::after,
.service-list article::after,
.support-grid article::after,
.systems-grid article::after,
.steps li::after,
.resource-grid article::after,
.testimonial-grid article::after,
.faq-list article::after,
.article-body::after,
.card::after,
.service-card::after,
.specialty-card::after,
.resource-card::after,
.testimonial-card::after,
.fit-card::after,
.process-card::after,
.detail-card::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  border-radius: inherit;
  background:
    linear-gradient(110deg, transparent 0 36%, rgba(255, 255, 255, .72) 46%, transparent 58% 100%);
  transform: translateX(-120%);
  transition: transform .64s ease;
}

.service-list article:hover,
.support-grid article:hover,
.systems-grid article:hover,
.steps li:hover,
.resource-grid article:hover,
.testimonial-grid article:hover,
.faq-list article:hover,
.article-body:hover,
.card:hover,
.service-card:hover,
.specialty-card:hover,
.resource-card:hover,
.testimonial-card:hover,
.fit-card:hover,
.process-card:hover,
.detail-card:hover,
article[class*="card"]:hover,
a[class*="card"]:hover {
  transform: translateY(-6px) scale(1.01) !important;
  border-color: rgba(217, 111, 87, .32) !important;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, .96), rgba(255, 255, 255, .78)),
    linear-gradient(180deg, rgba(246, 250, 246, .98), rgba(255, 250, 247, .94)) !important;
  box-shadow: var(--site-shadow-lift), 0 0 0 1px rgba(217, 111, 87, .08) !important;
}

.summary-card:hover::after,
.portrait-card:hover::after,
.service-list article:hover::after,
.support-grid article:hover::after,
.systems-grid article:hover::after,
.steps li:hover::after,
.resource-grid article:hover::after,
.testimonial-grid article:hover::after,
.faq-list article:hover::after,
.article-body:hover::after,
.card:hover::after,
.service-card:hover::after,
.specialty-card:hover::after,
.resource-card:hover::after,
.testimonial-card:hover::after,
.fit-card:hover::after,
.process-card:hover::after,
.detail-card:hover::after {
  transform: translateX(120%);
}

.hero,
.page-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 82% 16%, rgba(201, 195, 244, .45), transparent 22rem),
    radial-gradient(circle at 12% 12%, rgba(216, 237, 242, .7), transparent 23rem),
    linear-gradient(135deg, rgba(248, 252, 247, .96), rgba(234, 245, 239, .9) 55%, rgba(255, 243, 238, .84)) !important;
  border-bottom-color: rgba(47, 111, 99, .16) !important;
}

.hero::after,
.page-hero::after {
  content: "";
  position: absolute;
  right: clamp(18px, 7vw, 92px);
  top: clamp(26px, 8vw, 86px);
  width: min(30vw, 300px);
  aspect-ratio: 1;
  border: 1px solid rgba(47, 111, 99, .14);
  border-radius: 8px;
  background:
    linear-gradient(135deg, rgba(255, 255, 255, .36), rgba(255, 255, 255, 0)),
    conic-gradient(from 20deg, rgba(47, 111, 99, .14), rgba(217, 111, 87, .13), rgba(201, 195, 244, .22), rgba(47, 111, 99, .14));
  pointer-events: none;
  z-index: 0;
  transform: rotate(10deg);
  animation: siteFloat 8s ease-in-out infinite;
}

.hero > *,
.page-hero > * {
  position: relative;
  z-index: 1;
}

.services-section,
.systems-section,
.trust-section,
.practice-support-section,
.process-section,
.contact-section {
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .5), rgba(237, 245, 239, .58)),
    var(--site-paper) !important;
}

.service-list h3::before,
.systems-grid h3::before,
.support-grid h3::before,
.services-polish .article-body h2::before,
.specialty-polish .service-list article h3::before,
.workflow-track article span,
.billing-snapshot span,
.lane-icon {
  background: linear-gradient(90deg, var(--site-coral), var(--site-sage), #4f8faa) !important;
}

.portrait,
.services-hero-art,
.specialty-hero-art,
.resource-hero-art,
.portrait-glass {
  border-color: rgba(255, 255, 255, .72) !important;
  background: var(--site-mist) !important;
  box-shadow: 0 24px 60px rgba(16, 44, 39, .16), 0 0 0 1px rgba(47, 111, 99, .08) !important;
}

.portrait img,
.services-hero-art img,
.specialty-hero-art img,
.resource-hero-art img,
.polish-visual img {
  transition: transform .5s ease, filter .5s ease;
}

.portrait:hover img,
.services-hero-art:hover img,
.specialty-hero-art:hover img,
.resource-hero-art:hover img,
.polish-visual:hover img {
  filter: saturate(1.08) contrast(1.03);
  transform: scale(1.045);
}

.layered-section,
.viewer-note-banner {
  background:
    radial-gradient(circle at 90% 10%, rgba(242, 189, 102, .34), transparent 17rem),
    linear-gradient(135deg, #173c37, #2f6f63 58%, #746ed2) !important;
  box-shadow: 0 24px 62px rgba(24, 71, 63, .22) !important;
}

.layered-section h2,
.layered-section .eyebrow,
.viewer-note-banner h2,
.viewer-note-banner .eyebrow {
  color: #ffffff !important;
}

.layered-section p,
.viewer-note-banner p {
  color: rgba(255, 255, 255, .78) !important;
}

.link-more {
  color: var(--site-sage-dark) !important;
}

.link-more::after {
  content: "->";
  transition: transform .2s ease;
}

article:hover .link-more::after,
.card-link:hover .link-more::after {
  transform: translateX(5px);
}

input,
select,
textarea {
  color: var(--site-ink) !important;
  border-color: rgba(47, 111, 99, .22) !important;
  background: rgba(255, 255, 255, .88) !important;
  transition: border-color .18s ease, box-shadow .18s ease, transform .18s ease !important;
}

input:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: rgba(217, 111, 87, .58) !important;
  box-shadow: 0 0 0 4px rgba(217, 111, 87, .12) !important;
}

@keyframes sitePageIn {
  from {
    opacity: 0;
    transform: translateY(10px);
  }

  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes siteFloat {
  0%,
  100% {
    transform: translate3d(0, 0, 0) rotate(10deg);
  }

  50% {
    transform: translate3d(8px, 12px, 0) rotate(14deg);
  }
}

@keyframes siteGridDrift {
  from {
    background-position: 0 0, 0 0, 0 0;
  }

  to {
    background-position: 54px 54px, -54px 54px, 108px 108px;
  }
}

@media (max-width: 820px) {
  .hero,
  .page-hero {
    background:
      radial-gradient(circle at 92% 4%, rgba(201, 195, 244, .44), transparent 16rem),
      linear-gradient(180deg, #fbfdf9, #eef7f1) !important;
  }

  .hero::after,
  .page-hero::after {
    opacity: .34;
  }
}

@media (prefers-reduced-motion: reduce) {
  *,
  *::before,
  *::after {
    animation-duration: .01ms !important;
    animation-iteration-count: 1 !important;
    scroll-behavior: auto !important;
    transition-duration: .01ms !important;
  }
}

/* Final package-wide theme lock: keeps legacy page-local styles on the redesign palette. */
:root,
body {
  --ink: var(--site-ink) !important;
  --muted: var(--site-muted) !important;
  --paper: var(--site-paper) !important;
  --white: var(--site-white) !important;
  --line: var(--site-line) !important;
  --soft: var(--site-mist) !important;
  --blue: var(--site-sage) !important;
  --blue-dark: var(--site-sage-dark) !important;
  --teal: var(--site-coral) !important;
  --teal-dark: var(--site-sage-dark) !important;
  --sky: var(--site-sky) !important;
  --gold: var(--site-lavender) !important;
  --card: rgba(255, 255, 255, .86) !important;
  --shadow: var(--site-shadow) !important;
  --shadow-lift: var(--site-shadow-lift) !important;
}

.section,
.about-section,
.proof-preview-section,
.resources-section,
.specialties-section,
.testimonials-section,
.article-section,
.launch-assets-section {
  background:
    radial-gradient(circle at 92% 8%, rgba(201, 195, 244, .2), transparent 18rem),
    linear-gradient(180deg, rgba(255, 255, 255, .62), rgba(237, 245, 239, .64)),
    var(--site-paper) !important;
}

.page-hero,
.hero,
.contact-hero,
.resource-hero,
.services-hero,
.specialty-hero {
  color: var(--site-ink) !important;
}

.page-hero p:not(.eyebrow),
.hero p:not(.eyebrow),
.section p,
.section li,
.article-body p,
.article-body li,
.resource-grid p,
.testimonial-grid p,
.faq-list p {
  color: var(--site-muted) !important;
}

.card-link,
.card-link h3,
.card-link p,
.card-link span {
  position: relative;
  z-index: 1;
}

.resource-grid article,
.testimonial-grid article,
.faq-list article,
.scheduler-box,
.asset-modal__panel,
.polish-visual,
.polish-copy,
.polish-points b,
form,
.form,
[class*="form"],
.mini-proof,
.billing-snapshot,
.workflow-track article {
  border-color: var(--site-line) !important;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, .94), rgba(255, 255, 255, .76)),
    linear-gradient(180deg, rgba(237, 245, 239, .94), rgba(255, 255, 255, .95)) !important;
  box-shadow: var(--site-shadow) !important;
}

.resource-grid article:hover,
.testimonial-grid article:hover,
.faq-list article:hover,
.polish-points b:hover {
  border-color: rgba(217, 111, 87, .32) !important;
  box-shadow: var(--site-shadow-lift) !important;
}

.polish-copy span,
a[class*="card"]:not(.card-link)::after,
.resources-polish .resource-grid .eyebrow,
[class*="tag"],
[class*="pill"],
.mini-list span {
  color: var(--site-sage-dark) !important;
  border-color: rgba(47, 111, 99, .16) !important;
  background: rgba(255, 255, 255, .66) !important;
}

.service-list article h3,
.systems-grid article h3,
.support-grid article h3,
.resource-grid article h3,
.testimonial-grid strong,
.steps strong,
.article-body h2,
.article-body h3,
label,
.lead-form span,
.quote-form span {
  color: var(--site-ink) !important;
}

.site-footer {
  border-top-color: var(--site-line) !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .88), rgba(237, 245, 239, .86)),
    var(--site-paper) !important;
}

.asset-modal__backdrop {
  background: rgba(20, 33, 41, .56) !important;
}

.asset-modal__close {
  color: var(--site-sage-dark) !important;
  background: rgba(255, 255, 255, .94) !important;
}

.viewer-note-banner .button,
.layered-section .button {
  color: var(--site-sage-dark) !important;
  background: #ffffff !important;
}

.portrait,
.portrait-card,
.services-hero-art,
.specialty-hero-art,
.resource-hero-art,
.polish-visual {
  border-radius: 8px !important;
}

.contact-polish form,
.contact-polish .form,
.contact-polish .contact-form,
.contact-polish .lead-form,
.contact-polish .quote-form,
.contact-polish [class*="form"],
.about-polish .card,
.about-polish .panel,
.about-polish aside,
.about-polish [class*="highlight"],
.about-polish [class*="experience"],
.about-polish [class*="process"] {
  border-color: var(--site-line) !important;
  background:
    linear-gradient(140deg, rgba(255, 255, 255, .94), rgba(255, 255, 255, .76)),
    linear-gradient(180deg, rgba(237, 245, 239, .94), rgba(255, 255, 255, .95)) !important;
  box-shadow: var(--site-shadow) !important;
}

.contact-polish input,
.contact-polish textarea,
.contact-polish select {
  border-color: rgba(47, 111, 99, .22) !important;
  background: rgba(255, 255, 255, .9) !important;
}

.contact-polish input:focus,
.contact-polish textarea:focus,
.contact-polish select:focus {
  border-color: rgba(217, 111, 87, .58) !important;
  box-shadow: 0 0 0 4px rgba(217, 111, 87, .12) !important;
}
