﻿:root {
  --site-ink: #122235;
  --site-muted: #607084;
  --site-paper: #f5f9fc;
  --site-card: rgba(255, 255, 255, .95);
  --site-line: rgba(57, 101, 148, .16);
  --site-blue: #2c6fa8;
  --site-cyan: #2c938e;
  --site-mint: #8fd8c8;
  --site-deep: #173d63;
  --site-shadow: 0 18px 44px rgba(25, 75, 120, .11);
  --site-shadow-lift: 0 28px 70px rgba(25, 75, 120, .17);
}

body {
  color: var(--site-ink) !important;
  background:
    radial-gradient(circle at 10% 10%, rgba(44, 147, 142, .14), transparent 24rem),
    radial-gradient(circle at 86% 8%, rgba(44, 111, 168, .15), transparent 26rem),
    linear-gradient(180deg, #f8fbfd 0%, #ffffff 46%, #f1f7f8 100%) !important;
  font-family: Inter, "Nunito Sans", Arial, sans-serif !important;
}

body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: .3;
  background-image:
    linear-gradient(90deg, rgba(44, 111, 168, .08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(44, 147, 142, .06) 1px, transparent 1px);
  background-size: 52px 52px;
  mask-image: linear-gradient(180deg, #000, transparent 84%);
}

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

.site-header {
  border-bottom: 1px solid var(--site-line) !important;
  background: rgba(247, 251, 255, .86) !important;
  backdrop-filter: blur(16px);
  box-shadow: 0 10px 32px rgba(25, 75, 120, .06) !important;
}

.brand-mark {
  color: transparent !important;
  background: var(--site-metal) !important;
  background-size: 180% 180% !important;
  background-position: 0% 50% !important;
  box-shadow: 0 12px 26px rgba(44, 111, 168, .22) !important;
}

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

h1,
h2 {
  font-family: "Source Serif 4", Georgia, serif !important;
}

.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-blue) !important;
}

.nav-links a {
  position: relative;
  transition: color .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-blue), var(--site-cyan));
  opacity: 0;
  transform: scaleX(.72);
  transition: opacity .2s ease, transform .2s ease;
}

.nav-links a:hover {
  color: var(--site-deep) !important;
}

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

.button.primary {
  color: #fff !important;
  background: linear-gradient(135deg, var(--site-blue), var(--site-cyan)) !important;
  box-shadow: 0 18px 38px rgba(44, 111, 168, .22) !important;
}

.button.secondary {
  color: var(--site-deep) !important;
  border-color: var(--site-line) !important;
  background: rgba(255, 255, 255, .86) !important;
}

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

.button:hover,
.asset-modal__close:hover,
button:hover {
  transform: translateY(-2px);
}

.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 {
  border-color: var(--site-line) !important;
  border-radius: 18px !important;
  background:
    linear-gradient(180deg, rgba(255, 255, 255, .96), rgba(246, 251, 253, .92)) !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;
}

.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(-7px) !important;
  border-color: rgba(44, 111, 168, .3) !important;
  background: linear-gradient(180deg, #fff, #eff8ff) !important;
  box-shadow: var(--site-shadow-lift) !important;
}

.hero,
.page-hero {
  position: relative;
  overflow: hidden;
  background:
    radial-gradient(circle at 82% 16%, rgba(143, 216, 200, .18), transparent 24rem),
    radial-gradient(circle at 16% 18%, rgba(44, 111, 168, .15), transparent 26rem),
    linear-gradient(135deg, rgba(255, 255, 255, .9), rgba(235, 247, 255, .9)) !important;
  border-bottom-color: rgba(57, 101, 148, .12) !important;
}

.hero::after,
.page-hero::after {
  content: "";
  position: absolute;
  right: clamp(18px, 7vw, 90px);
  top: clamp(28px, 8vw, 90px);
  width: min(34vw, 340px);
  aspect-ratio: 1;
  border-radius: 44% 56% 50% 48%;
  background:
    radial-gradient(circle at 32% 28%, rgba(255, 255, 255, .72), transparent 20%),
    linear-gradient(135deg, rgba(44, 111, 168, .14), rgba(44, 147, 142, .12));
  pointer-events: none;
  z-index: 0;
  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, .74), rgba(244, 250, 255, .74)),
    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-blue), var(--site-cyan), var(--site-mint)) !important;
}

.portrait,
.services-hero-art,
.specialty-hero-art,
.resource-hero-art,
.portrait-glass {
  border-color: rgba(44, 111, 168, .18) !important;
  background: #e8f4ff !important;
  box-shadow: 0 24px 60px rgba(25, 75, 120, .14) !important;
}

.layered-section,
.viewer-note-banner {
  background:
    radial-gradient(circle at 90% 12%, rgba(143, 216, 200, .28), transparent 18rem),
    linear-gradient(135deg, #11253c, #194b78 58%, #1e6c6a) !important;
}

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

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

.layered-section .mini-proof h3,
.layered-section .mini-proof p,
.layered-section .mini-proof .link-more,
.layered-section .systems-grid article h3,
.layered-section .systems-grid article p,
.viewer-note-banner .button {
  color: var(--site-ink) !important;
}

.layered-section .mini-proof p,
.layered-section .systems-grid article p {
  color: var(--site-muted) !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 {
  border-color: rgba(57, 101, 148, .2) !important;
  background: rgba(255, 255, 255, .92) !important;
  transition: border-color .18s ease, box-shadow .18s ease !important;
}

input:focus,
select:focus,
textarea:focus {
  outline: none !important;
  border-color: rgba(44, 111, 168, .55) !important;
  box-shadow: 0 0 0 4px rgba(44, 111, 168, .11) !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(0deg);
  }

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

@media (max-width: 820px) {
  .hero,
  .page-hero {
    background:
      radial-gradient(circle at 88% 0%, rgba(143, 216, 200, .18), transparent 18rem),
      linear-gradient(180deg, #f3f9ff, #ffffff) !important;
  }

  .page-hero h1,
  .page-hero h2,
  .page-hero p:not(.eyebrow) {
    color: var(--site-ink) !important;
  }
}

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

/* Gold metallic master theme override. Keep this last. */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600;700&family=Manrope:wght@400;500;600;700;800&display=swap");

@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:wght@600;700&family=Manrope:wght@400;500;600;700;800&display=swap");

:root {
  --site-ink: #f7f2e8;
  --site-muted: #c9bdac;
  --site-paper: #070707;
  --site-card: rgba(20, 18, 15, .9);
  --site-line: rgba(220, 184, 94, .26);
  --site-gold: #d7b15f;
  --site-gold-bright: #ffe3a1;
  --site-gold-deep: #8b6422;
  --site-onyx: #090908;
  --site-shadow: 0 22px 60px rgba(0, 0, 0, .32);
  --site-shadow-lift: 0 34px 90px rgba(0, 0, 0, .46);
  --site-metal: linear-gradient(135deg, #7a5117 0%, #d7b15f 31%, #fff0b9 49%, #a7792d 67%, #f4d27d 100%);
}

html,
body {
  color: var(--site-ink) !important;
  background:
    radial-gradient(circle at 12% 6%, rgba(255, 227, 161, .13), transparent 26rem),
    radial-gradient(circle at 82% 14%, rgba(183, 132, 42, .16), transparent 28rem),
    linear-gradient(145deg, #050505 0%, #11100e 47%, #050505 100%) !important;
  font-family: Manrope, Inter, "Nunito Sans", Arial, sans-serif !important;
}

body::before {
  opacity: .38 !important;
  background-image:
    linear-gradient(90deg, rgba(255, 227, 161, .08) 1px, transparent 1px),
    linear-gradient(0deg, rgba(255, 227, 161, .045) 1px, transparent 1px),
    linear-gradient(135deg, transparent 0 47%, rgba(255, 227, 161, .08) 49%, transparent 51% 100%) !important;
  background-size: 72px 72px, 72px 72px, 180px 180px !important;
}

.site-header {
  border-bottom-color: rgba(220, 184, 94, .22) !important;
  background: rgba(8, 8, 7, .86) !important;
  box-shadow: 0 14px 42px rgba(0, 0, 0, .28) !important;
}

.brand-mark {
  color: transparent !important;
  border: 1px solid rgba(255, 227, 161, .42) !important;
  background: var(--site-metal) !important;
  background-size: 180% 180% !important;
  background-position: 0% 50% !important;
  box-shadow: 0 16px 34px rgba(215, 177, 95, .22), inset 0 1px 0 rgba(255, 255, 255, .42) !important;
}

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

h1,
h2 {
  font-family: "Cormorant Garamond", "Source Serif 4", Georgia, serif !important;
  font-weight: 700 !important;
}

.brand small,
p,
li,
dd,
label,
.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,
main a:not(.button):not(.card):not(.card-link) {
  color: var(--site-gold-bright) !important;
}

.nav-links a {
  color: #d9cdbb !important;
}

.nav-links a::after,
.service-list h3::before,
.systems-grid h3::before,
.support-grid h3::before,
.workflow-track article span,
.billing-snapshot span,
.lane-icon {
  background: var(--site-metal) !important;
}

.nav-links a:hover {
  color: #fff2c2 !important;
}

.button.primary,
button[type="submit"],
.lead-form .button,
.quote-form .button {
  color: #100c05 !important;
  border: 1px solid rgba(255, 227, 161, .54) !important;
  background: var(--site-metal) !important;
  background-size: 180% 180% !important;
  box-shadow: 0 18px 42px rgba(215, 177, 95, .24), inset 0 1px 0 rgba(255, 255, 255, .48) !important;
}

.button.secondary,
.asset-modal__close {
  color: #ffe9ad !important;
  border-color: rgba(220, 184, 94, .32) !important;
  background: rgba(12, 11, 9, .78) !important;
}

.hero,
.page-hero,
body.resources-polish .page-hero,
body.specialty-polish .page-hero,
body.services-polish .page-hero,
body.about-polish .page-hero,
body.contact-polish .page-hero {
  background:
    radial-gradient(circle at 78% 16%, rgba(255, 227, 161, .18), transparent 24rem),
    radial-gradient(circle at 15% 18%, rgba(145, 94, 20, .22), transparent 26rem),
    linear-gradient(135deg, rgba(13, 12, 10, .96), rgba(25, 22, 17, .94) 52%, rgba(6, 6, 6, .98)) !important;
  border-bottom-color: rgba(220, 184, 94, .22) !important;
}

.services-section,
.systems-section,
.trust-section,
.practice-support-section,
.process-section,
.contact-section,
.about-section,
.resources-section,
.testimonials-section,
.faq-section,
.specialties-section,
.detail-section,
.asset-section,
.section,
section {
  background:
    linear-gradient(180deg, rgba(10, 10, 9, .84), rgba(18, 16, 13, .84)),
    var(--site-paper) !important;
  color: var(--site-ink) !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,
.polish-visual,
.polish-copy,
.polish-points b,
.mini-proof,
.asset-card,
.asset-modal__panel,
.resource-list article,
.content-card,
.panel,
aside,
body.about-polish .card,
body.about-polish .panel,
body.about-polish aside,
body.contact-polish form,
body.contact-polish .form,
body.contact-polish .contact-form,
body.contact-polish [class*="form"] {
  border-color: var(--site-line) !important;
  border-radius: 8px !important;
  background:
    linear-gradient(145deg, rgba(255, 237, 184, .09), transparent 34%),
    linear-gradient(180deg, rgba(24, 22, 18, .96), rgba(9, 9, 8, .94)) !important;
  box-shadow: var(--site-shadow) !important;
  color: var(--site-ink) !important;
}

.summary-card:hover,
.portrait-card:hover,
.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,
.polish-visual:hover,
.polish-copy:hover,
.asset-card:hover,
article:hover {
  border-color: rgba(255, 227, 161, .46) !important;
  box-shadow: var(--site-shadow-lift) !important;
}

.label,
.tag,
.pill,
.polish-copy span,
[class*="tag"],
[class*="pill"],
a[class*="card"]:not(.card-link)::after {
  color: #120d05 !important;
  border: 1px solid rgba(255, 227, 161, .42) !important;
  background: var(--site-metal) !important;
}

.portrait,
.services-hero-art,
.resource-hero-art,
.specialty-hero-art,
.portrait-glass,
.polish-visual {
  border-color: rgba(255, 227, 161, .28) !important;
  background: #14110b !important;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .36), 0 0 0 1px rgba(255, 227, 161, .08) !important;
}

.layered-section,
.viewer-note-banner {
  background:
    radial-gradient(circle at 88% 12%, rgba(255, 227, 161, .2), transparent 18rem),
    linear-gradient(135deg, #070707, #191510 58%, #5d4219) !important;
}

input,
select,
textarea {
  color: var(--site-ink) !important;
  border-color: rgba(220, 184, 94, .28) !important;
  background: rgba(11, 11, 10, .92) !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: rgba(255, 227, 161, .66) !important;
  box-shadow: 0 0 0 4px rgba(215, 177, 95, .14) !important;
}

.site-footer {
  border-top-color: var(--site-line) !important;
  background: rgba(6, 6, 5, .96) !important;
}

.process-section .section-heading h2,
.process-section .section-heading p,
.steps strong,
.steps span,
.process-card h3,
.process-card p,
.workflow-track article h3,
.workflow-track article p {
  text-shadow: 0 1px 2px rgba(0, 0, 0, .72) !important;
}

.steps li,
.process-card,
.workflow-track article {
  border-color: rgba(255, 227, 161, .36) !important;
  background:
    linear-gradient(145deg, rgba(255, 237, 184, .13), transparent 34%),
    linear-gradient(180deg, rgba(31, 28, 22, .98), rgba(9, 9, 8, .96)) !important;
}

.steps strong,
.process-card h3,
.workflow-track article h3 {
  color: #fff2c2 !important;
  font-weight: 800 !important;
}

.steps span,
.process-card p,
.workflow-track article p {
  color: #eadcc5 !important;
}

.steps li::marker {
  color: var(--site-gold-bright) !important;
}

@media (max-width: 820px) {
  .hero,
  .page-hero,
  body.resources-polish .page-hero,
  body.specialty-polish .page-hero {
    background:
      radial-gradient(circle at 88% 0%, rgba(255, 227, 161, .16), transparent 18rem),
      linear-gradient(180deg, #11100e, #050505) !important;
  }
}

/* Metallic Luxe hover readability: keep cards dark and legible. */
html body .card:hover,
html body .service-card:hover,
html body .specialty-card:hover,
html body .resource-card:hover,
html body .testimonial-card:hover,
html body .fit-card:hover,
html body .process-card:hover,
html body .detail-card:hover,
html body .summary-card:hover,
html body .portrait-card:hover,
html body article[class*="card"]:hover,
html body a[class*="card"]:hover {
  background:
    linear-gradient(135deg, rgba(255, 227, 161, .14), transparent 48%),
    linear-gradient(180deg, rgba(30, 26, 18, .98), rgba(12, 11, 9, .96)) !important;
  color: #fff4cf !important;
  border-color: rgba(255, 227, 161, .52) !important;
}

html body .card:hover *,
html body .service-card:hover *,
html body .specialty-card:hover *,
html body .resource-card:hover *,
html body .testimonial-card:hover *,
html body .fit-card:hover *,
html body .process-card:hover *,
html body .detail-card:hover *,
html body .summary-card:hover *,
html body .portrait-card:hover *,
html body article[class*="card"]:hover *,
html body a[class*="card"]:hover * {
  color: #fff4cf !important;
}

