:root {
  --site-primary: #173e36;
  --site-primary-strong: #0f312b;
  --site-primary-soft: #e7eeeb;
  --site-secondary: #c8d2c6;
  --site-secondary-soft: #eef2ec;
  --site-accent: #b58b51;
  --site-accent-soft: #f1e8db;
  --site-page-bg: #fbf9f5;
  --site-surface: #fdfcfb;
  --site-surface-alt: #f4f0e8;
  --site-card: #ffffff;
  --site-border: #e8dfd0;
  --site-text: #29312f;
  --site-muted: #746b60;
  --site-on-primary: #ffffff;
  --site-on-accent: #17201e;
  --site-process-bg: #0f312b;
  --site-process-text: #ffffff;
  --site-final-cta-bg: #0f312b;
  --site-final-cta-text: #ffffff;
  --site-footer-bg: #09241f;
  --site-footer-text: #ffffff;
  --site-button-bg: #b58b51;
  --site-button-text: #17201e;
  --site-focus: #b58b51;
  --site-radius-sm: 12px;
  --site-radius-md: 20px;
  --site-radius-lg: 30px;
  --sand-50: var(--site-page-bg);
  --sand-100: var(--site-surface-alt);
  --sand-200: var(--site-border);
  --sand-300: color-mix(in srgb, var(--site-border) 55%, var(--site-accent));
  --stone-500: var(--site-muted);
  --graphite: var(--site-text);
  --green-700: var(--site-primary);
  --green-800: var(--site-primary-strong);
  --green-900: var(--site-footer-bg);
  --gold: var(--site-accent);
  --white: #ffffff;
  --error: #a32929;
  --shadow-sm: 0 10px 30px color-mix(in srgb, var(--site-primary) 10%, transparent);
  --shadow-lg: 0 22px 60px color-mix(in srgb, var(--site-primary) 18%, transparent);
  --radius-sm: var(--site-radius-sm);
  --radius-md: var(--site-radius-md);
  --radius-lg: var(--site-radius-lg);
  --container: 1180px;
  --font-display: Georgia, "Times New Roman", serif;
  --font-body: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--sand-50);
  color: var(--graphite);
  font-family: var(--font-body);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
}
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }

.skip-link {
  position: fixed;
  left: 12px;
  top: -80px;
  z-index: 100;
  padding: 10px 14px;
  border-radius: 8px;
  background: var(--green-900);
  color: var(--white);
  transition: top 0.2s ease;
}
.skip-link:focus { top: 12px; }

.container { width: min(calc(100% - 32px), var(--container)); margin-inline: auto; }
.section { padding: 74px 0; }
.eyebrow {
  margin: 0 0 10px;
  color: var(--gold);
  font-size: 0.72rem;
  font-weight: 800;
  letter-spacing: 0.17em;
  line-height: 1.3;
  text-transform: uppercase;
}
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { color: var(--green-900); line-height: 1.14; }
h1, h2 { font-family: var(--font-display); font-weight: 500; letter-spacing: -0.035em; }
h1 { margin-bottom: 18px; font-size: clamp(2.5rem, 11vw, 4.7rem); }
h2 { margin-bottom: 16px; font-size: clamp(2rem, 8.5vw, 3.5rem); }
h3 { margin-bottom: 8px; font-size: 1.12rem; }
p { color: var(--stone-500); }

.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  border-bottom: 1px solid rgba(181, 139, 81, 0.12);
  background: rgba(251, 249, 245, 0.92);
  backdrop-filter: blur(16px);
}
.header-content { display: flex; align-items: center; justify-content: space-between; gap: 14px; min-height: 76px; }
.brand { display: flex; align-items: center; gap: 10px; min-width: 0; color: var(--green-900); text-decoration: none; }
.brand-mark { display: grid; width: 40px; height: 40px; flex: 0 0 auto; place-items: center; border: 1px solid var(--gold); border-radius: 50%; color: var(--green-700); font-family: var(--font-display); font-size: 0.8rem; }
.brand strong { display: block; overflow: hidden; font-family: var(--font-display); font-size: 1rem; line-height: 1.1; text-overflow: ellipsis; white-space: nowrap; }
.brand small { display: none; }

.button {
  display: inline-flex;
  min-height: 52px;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 13px 18px;
  border: 1px solid var(--green-700);
  border-radius: 999px;
  background: var(--green-700);
  color: var(--white);
  font-size: 0.88rem;
  font-weight: 800;
  letter-spacing: 0.015em;
  line-height: 1.15;
  text-align: center;
  text-decoration: none;
  transition: background 0.2s ease, border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease;
}
.button:hover { border-color: var(--green-800); background: var(--green-800); box-shadow: 0 8px 18px rgba(15, 49, 43, 0.16); transform: translateY(-1px); }
.button:focus-visible, a:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 3px solid rgba(181, 139, 81, 0.72); outline-offset: 3px; }
.button-small { min-height: 42px; padding: 10px 12px; font-size: 0.73rem; }
.button-outline { border-color: rgba(23, 62, 54, 0.34); background: transparent; color: var(--green-700); }
.button-outline:hover { color: var(--white); }
.button-ghost { border-color: transparent; background: transparent; color: var(--green-700); }
.button-ghost:hover { border-color: var(--sand-200); background: var(--sand-100); box-shadow: none; color: var(--green-800); }
.button-light { border-color: var(--white); background: var(--white); color: var(--green-800); }
.button-light:hover { border-color: var(--sand-100); background: var(--sand-100); color: var(--green-900); }

.hero { padding: 38px 0 70px; background: radial-gradient(circle at 85% 10%, rgba(215, 197, 170, 0.27), transparent 36%), var(--sand-50); }
.hero-grid { display: grid; gap: 32px; }
.hero-copy { align-self: center; }
.hero-text { max-width: 640px; margin-bottom: 24px; font-size: 1.05rem; }
.hero-actions { display: flex; flex-direction: column; gap: 8px; }
.trust-pills { display: flex; flex-wrap: wrap; gap: 8px; margin: 24px 0 0; padding: 0; list-style: none; }
.trust-pills li { padding: 7px 10px; border: 1px solid var(--sand-200); border-radius: 999px; background: rgba(255, 255, 255, 0.56); color: var(--green-700); font-size: 0.72rem; font-weight: 750; }
.hero-media { position: relative; overflow: hidden; margin: 0; border-radius: var(--radius-lg); background: var(--sand-200); box-shadow: var(--shadow-lg); }
.hero-media img { width: 100%; aspect-ratio: 1.24 / 1; object-fit: cover; }
.hero-media figcaption { position: absolute; right: 14px; bottom: 14px; left: 14px; padding: 14px; border: 1px solid rgba(255, 255, 255, 0.36); border-radius: 16px; background: rgba(9, 36, 31, 0.8); color: var(--white); backdrop-filter: blur(10px); }
.hero-media figcaption strong { display: block; color: var(--white); font-family: var(--font-display); font-size: 1.25rem; font-weight: 500; line-height: 1.16; }
.media-kicker { display: block; margin-bottom: 4px; color: #ead9b4; font-size: 0.63rem; font-weight: 800; letter-spacing: 0.17em; text-transform: uppercase; }

.section-heading { max-width: 720px; margin-bottom: 30px; }
.section-heading > p:last-child { margin-bottom: 0; }
.section-heading.compact { max-width: 660px; }
.section-services { border-top: 1px solid var(--sand-200); background: var(--white); }
.service-grid { display: grid; gap: 12px; }
.service-card { min-height: 160px; padding: 20px; border: 1px solid rgba(232, 223, 208, 0.92); border-radius: var(--radius-md); background: var(--sand-50); transition: border-color 0.2s ease, box-shadow 0.2s ease, transform 0.2s ease; }
.service-card:hover { border-color: var(--sand-300); box-shadow: var(--shadow-sm); transform: translateY(-2px); }
.service-card p { margin-bottom: 0; font-size: 0.91rem; }
.service-icon { display: grid; width: 38px; height: 38px; margin-bottom: 18px; place-items: center; border-radius: 50%; background: rgba(23, 62, 54, 0.08); color: var(--green-700); font-size: 1rem; }

.section-process { background: var(--green-900); }
.section-process h2, .section-process strong { color: var(--white); }
.steps-grid { display: grid; gap: 0; margin: 30px 0 0; padding: 0; list-style: none; }
.steps-grid li { padding: 22px 0; border-top: 1px solid rgba(255, 255, 255, 0.16); }
.steps-grid span { display: inline-block; margin-bottom: 8px; color: #dcb982; font-size: 0.72rem; font-weight: 800; letter-spacing: 0.18em; }
.steps-grid strong { display: block; margin-bottom: 5px; font-size: 1rem; }
.steps-grid p { margin-bottom: 0; color: rgba(255, 255, 255, 0.62); font-size: 0.91rem; }
.process-note { margin: 22px 0 0; padding: 13px 15px; border: 1px solid rgba(255, 255, 255, 0.13); border-radius: var(--radius-sm); color: rgba(255, 255, 255, 0.72); font-size: 0.89rem; }


.section-before-after { border-top: 1px solid var(--sand-200); background: var(--sand-50); }
.before-after-grid { display: grid; gap: 12px; }
.comparison-card { min-height: 172px; padding: 22px; border: 1px solid var(--sand-200); border-radius: var(--radius-md); background: var(--white); box-shadow: var(--shadow-sm); }
.comparison-card-before { background: linear-gradient(145deg, #f5efe6, #fbf9f5); }
.comparison-card-after { border-color: rgba(181, 139, 81, 0.42); background: linear-gradient(145deg, rgba(23, 62, 54, 0.98), var(--green-900)); }
.comparison-label { margin-bottom: 20px; color: var(--gold); font-size: 0.72rem; font-weight: 800; letter-spacing: 0.16em; text-transform: uppercase; }
.comparison-card blockquote { margin: 0; color: var(--green-900); font-family: var(--font-display); font-size: clamp(1.7rem, 8vw, 2.45rem); line-height: 1.14; }
.comparison-card-after p:last-child { max-width: 620px; margin-bottom: 0; color: rgba(255, 255, 255, 0.82); font-size: 1rem; }

.section-form { background: var(--sand-100); }
.form-layout { display: grid; gap: 24px; }
.form-intro > p:not(.eyebrow) { max-width: 500px; }
.form-assurance { display: flex; gap: 10px; margin-top: 20px; padding: 15px; border: 1px solid var(--sand-200); border-radius: var(--radius-sm); background: rgba(255, 255, 255, 0.48); }
.form-assurance span { color: var(--green-700); font-weight: 900; }
.form-assurance p { margin-bottom: 0; font-size: 0.88rem; }
.form-assurance strong { color: var(--green-800); }
.quote-form { padding: 18px; border: 1px solid rgba(215, 197, 170, 0.8); border-radius: var(--radius-md); background: var(--white); box-shadow: var(--shadow-sm); }
.field-grid { display: grid; gap: 14px; }
.field-group { min-width: 0; }
.field-group label, .fieldset-group legend { display: block; margin-bottom: 7px; color: var(--green-900); font-size: 0.83rem; font-weight: 800; }
.field-group label span, .fieldset-group legend span { color: var(--error); }
input, select, textarea { width: 100%; border: 1px solid #d7d0c5; border-radius: 10px; background: var(--white); color: var(--graphite); }
input, select { min-height: 50px; padding: 10px 12px; }
textarea { min-height: 108px; padding: 12px; resize: vertical; }
input::placeholder, textarea::placeholder { color: #999186; }
.fieldset-group { margin: 0; padding: 0; border: 0; }
.radio-grid { display: grid; grid-template-columns: 1fr; gap: 8px; }
.radio-option { display: flex; min-height: 46px; align-items: center; gap: 8px; padding: 9px 10px; border: 1px solid #d7d0c5; border-radius: 10px; background: var(--white); color: var(--graphite); cursor: pointer; font-size: 0.86rem; }
.radio-option:has(input:checked) { border-color: var(--green-700); background: rgba(23, 62, 54, 0.05); color: var(--green-800); font-weight: 750; }
.radio-option input { width: 17px; min-height: auto; height: 17px; margin: 0; accent-color: var(--green-700); }
.field-error { min-height: 0; margin: 5px 0 0; color: var(--error); font-size: 0.77rem; font-weight: 700; }
.field-hint { margin: 6px 0 0; color: var(--stone-500); font-size: 0.75rem; }
.is-invalid { border-color: var(--error) !important; background: #fffafa !important; }
.radio-grid.is-invalid { padding: 5px; border: 1px solid var(--error); border-radius: 12px; }
.quote-review { display: grid; gap: 12px; margin: 18px 0 0; padding: 16px; border-radius: var(--radius-sm); background: var(--sand-50); }
.quote-review h3 { margin: 0; font-family: var(--font-display); font-size: 1.44rem; font-weight: 500; }
.quote-review dl { display: grid; gap: 0; margin: 0; }
.quote-review dl div { display: flex; justify-content: space-between; gap: 16px; padding: 7px 0; border-top: 1px solid var(--sand-200); font-size: 0.78rem; }
.quote-review dt { color: var(--stone-500); }
.quote-review dd { margin: 0; color: var(--green-900); font-weight: 800; text-align: right; }
.form-status { min-height: 24px; margin-top: 10px; color: var(--error); font-size: 0.82rem; font-weight: 800; }
.button-submit { width: 100%; min-height: 58px; margin-top: 2px; }

.section-benefits { background: var(--white); }
.benefit-grid { display: grid; gap: 12px; }
.benefit-grid article { padding: 22px; border: 1px solid var(--sand-200); border-radius: var(--radius-md); background: var(--sand-50); }
.benefit-grid span { display: block; margin-bottom: 14px; color: var(--gold); font-size: 0.73rem; font-weight: 800; letter-spacing: 0.17em; }
.benefit-grid p { margin-bottom: 0; font-size: 0.92rem; }

.section-gallery { background: var(--sand-100); }
.gallery-copy { margin-bottom: 24px; }
.check-list { display: grid; gap: 9px; margin: 22px 0 0; padding: 0; list-style: none; }
.check-list li { position: relative; padding-left: 23px; color: var(--green-800); font-size: 0.9rem; font-weight: 750; }
.check-list li::before { position: absolute; left: 0; color: var(--gold); content: "✓"; }
.gallery-grid { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); gap: 9px; }
.gallery-grid img { width: 100%; min-width: 0; height: 100%; min-height: 160px; border-radius: var(--radius-sm); object-fit: cover; }
.gallery-grid img:first-child { grid-row: span 2; }

.final-cta { background: var(--sand-50); }
.cta-card { padding: 34px 22px; border-radius: var(--radius-lg); background: var(--green-800); text-align: center; }
.cta-card h2 { color: var(--white); }
.cta-card p:not(.eyebrow) { max-width: 580px; margin-right: auto; margin-bottom: 22px; margin-left: auto; color: rgba(255, 255, 255, 0.7); }

.site-footer { padding-top: 34px; background: var(--green-900); }
.footer-grid { display: grid; gap: 22px; }
.site-footer strong { color: var(--white); font-family: var(--font-display); font-size: 1.2rem; font-weight: 500; }
.site-footer p, .site-footer a { margin-bottom: 5px; color: rgba(255, 255, 255, 0.64); font-size: 0.85rem; }
.footer-contact { display: grid; justify-items: start; }
.footer-contact p:first-child { margin-bottom: 6px; color: rgba(255, 255, 255, 0.86); }
.footer-bottom { margin-top: 28px; padding: 14px 0 16px; border-top: 1px solid rgba(255, 255, 255, 0.12); }
.footer-bottom p { margin: 0; font-size: 0.76rem; }

@media (min-width: 520px) {
  .container { width: min(calc(100% - 48px), var(--container)); }
  .brand small { display: block; overflow: hidden; max-width: 320px; margin-top: 3px; color: var(--stone-500); font-size: 0.64rem; text-overflow: ellipsis; white-space: nowrap; }
  .button-small { padding-inline: 16px; font-size: 0.78rem; }
  .hero-actions { flex-direction: row; flex-wrap: wrap; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .before-after-grid { grid-template-columns: 0.8fr 1.2fr; }
  .radio-grid { grid-template-columns: repeat(3, 1fr); }
}

@media (min-width: 760px) {
  .section { padding: 94px 0; }
  .hero { padding: 62px 0 88px; }
  .steps-grid { grid-template-columns: repeat(2, 1fr); gap: 0 28px; }
  .field-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .field-wide, .fieldset-group { grid-column: 1 / -1; }
  .benefit-grid { grid-template-columns: repeat(3, 1fr); }
  .section-gallery .container { display: grid; grid-template-columns: 0.9fr 1.1fr; align-items: center; gap: 42px; }
  .gallery-copy { margin-bottom: 0; }
  .footer-grid { grid-template-columns: 1fr auto; }
}

@media (min-width: 980px) {
  .hero-grid { grid-template-columns: 1.04fr 0.96fr; align-items: center; gap: 46px; }
  .hero-media img { min-height: 590px; }
  .service-grid { grid-template-columns: repeat(4, 1fr); }
  .service-card:last-child { grid-column: span 2; }
  .steps-grid { grid-template-columns: repeat(4, 1fr); gap: 18px; }
  .steps-grid li { min-height: 176px; padding: 20px; border: 1px solid rgba(255, 255, 255, 0.16); border-radius: var(--radius-sm); }
  .form-layout { grid-template-columns: minmax(0, 0.7fr) minmax(600px, 1.3fr); align-items: start; gap: 48px; }
  .form-intro { position: sticky; top: 112px; }
  .quote-form { padding: 24px; }
  .quote-review { grid-template-columns: 0.65fr 1.35fr; align-items: start; padding: 18px; }
  .cta-card { padding: 54px; }
}

.form-status-success { color: var(--green-700); }
.footer-bottom { display: flex; flex-wrap: wrap; justify-content: space-between; gap: 8px 18px; }
.footer-admin-link { color: rgba(255, 255, 255, 0.76) !important; font-size: 0.76rem !important; text-decoration-thickness: 1px; text-underline-offset: 3px; }
.footer-admin-link:hover { color: var(--white) !important; }
.honeypot-field { position: absolute !important; left: -10000px !important; width: 1px !important; height: 1px !important; overflow: hidden !important; }
.consent-wrap { padding: 12px; border: 1px solid var(--sand-200); border-radius: 10px; background: var(--sand-50); }
.consent-label { display: flex !important; align-items: flex-start; gap: 9px; margin: 0 !important; color: var(--graphite) !important; font-size: .78rem !important; line-height: 1.45; cursor: pointer; }
.consent-label input { width: 18px; min-height: 18px; height: 18px; flex: 0 0 auto; margin-top: 1px; accent-color: var(--green-700); }
.consent-wrap.is-invalid { border-color: var(--error) !important; }
.turnstile-wrap { padding-top: 4px; }
.turnstile-config-note { margin: 0; padding: 10px 12px; border: 1px solid var(--sand-200); border-radius: 10px; background: var(--sand-50); color: var(--stone-500); font-size: .78rem; }
.button-fallback { width: 100%; margin-top: 8px; }
.footer-links { display: flex; flex-wrap: wrap; gap: 8px 16px; }
.privacy-page { min-height: 70vh; background: var(--sand-100); }
.privacy-content { max-width: 760px; padding: 28px; border: 1px solid var(--sand-200); border-radius: var(--radius-md); background: var(--white); box-shadow: var(--shadow-sm); }
.privacy-content h2 { margin-top: 28px; font-size: 1.45rem; }
.privacy-updated { margin-top: 28px; color: var(--stone-500); font-size: .82rem; }
[hidden] { display: none !important; }


/* v0.6.3 — sistema de tokens semânticos. A paleta legada acima permanece somente como alias compatível. */
body.site-template { background: var(--site-page-bg); color: var(--site-text); }
.site-template h1, .site-template h2, .site-template h3 { color: var(--site-primary-strong); }
.site-template p { color: var(--site-muted); }
.site-template .site-header { border-color: color-mix(in srgb, var(--site-accent) 25%, transparent); background: color-mix(in srgb, var(--site-page-bg) 92%, transparent); }
.site-template .brand { color: var(--site-primary-strong); }
.site-template .brand small { color: var(--site-muted); }
.site-template .brand-mark { border-color: var(--site-accent); color: var(--site-primary); background: var(--site-surface); }
.site-template .eyebrow, .site-template .comparison-label, .site-template .benefit-grid span, .site-template .media-kicker { color: var(--site-accent); }
.site-template .button:not(.button-light):not(.button-ghost):not(.button-outline):not(.button-fallback) { border-color: var(--site-button-bg); background: var(--site-button-bg); color: var(--site-button-text); }
.site-template .button:not(.button-light):not(.button-ghost):not(.button-outline):not(.button-fallback):hover { border-color: color-mix(in srgb, var(--site-button-bg) 76%, #000); background: color-mix(in srgb, var(--site-button-bg) 82%, #000); color: var(--site-button-text); box-shadow: 0 8px 18px color-mix(in srgb, var(--site-button-bg) 26%, transparent); }
.site-template .button-outline { border-color: color-mix(in srgb, var(--site-primary) 44%, transparent); background: transparent; color: var(--site-primary); }
.site-template .button-outline:hover { border-color: var(--site-primary); background: var(--site-primary); color: var(--site-on-primary); }
.site-template .button-ghost { border-color: transparent; background: transparent; color: var(--site-primary); }
.site-template .button-ghost:hover { border-color: var(--site-border); background: var(--site-surface-alt); color: var(--site-primary-strong); }
.site-template .button-light { border-color: var(--site-card); background: var(--site-card); color: var(--site-primary-strong); }
.site-template .button-light:hover { border-color: var(--site-surface-alt); background: var(--site-surface-alt); color: var(--site-primary-strong); }
.site-template .button:focus-visible, .site-template a:focus-visible, .site-template input:focus-visible, .site-template select:focus-visible, .site-template textarea:focus-visible { outline-color: color-mix(in srgb, var(--site-focus) 76%, transparent); }
.site-template .hero { background: radial-gradient(circle at 85% 10%, color-mix(in srgb, var(--site-accent-soft) 78%, transparent), transparent 38%), var(--site-page-bg); }
.site-template .trust-pills li { border-color: var(--site-border); background: color-mix(in srgb, var(--site-card) 72%, transparent); color: var(--site-primary); }
.site-template .hero-media { background: var(--site-surface-alt); }
.site-template .hero-media figcaption { border-color: color-mix(in srgb, var(--site-card) 34%, transparent); background: color-mix(in srgb, var(--site-primary-strong) 88%, transparent); color: var(--site-on-primary); }
.site-template .hero-media figcaption strong { color: var(--site-on-primary); }
.site-template .section-services { border-color: var(--site-border); background: var(--site-surface); }
.site-template .service-card { border-color: var(--site-border); background: var(--site-card); }
.site-template .service-card:hover { border-color: color-mix(in srgb, var(--site-accent) 55%, var(--site-border)); }
.site-template .service-icon { background: var(--site-primary-soft); color: var(--site-primary); }
.site-template .section-process { background: var(--site-process-bg); }
.site-template .section-process h2, .site-template .section-process strong { color: var(--site-process-text); }
.site-template .steps-grid li { border-color: color-mix(in srgb, var(--site-process-text) 18%, transparent); }
.site-template .steps-grid span { color: var(--site-accent); }
.site-template .steps-grid p, .site-template .process-note { color: color-mix(in srgb, var(--site-process-text) 74%, transparent); }
.site-template .process-note { border-color: color-mix(in srgb, var(--site-process-text) 17%, transparent); }
.site-template .section-before-after { border-color: var(--site-border); background: var(--site-page-bg); }
.site-template .comparison-card { border-color: var(--site-border); background: var(--site-card); }
.site-template .comparison-card-before { background: linear-gradient(145deg, var(--site-surface-alt), var(--site-card)); }
.site-template .comparison-card-after { border-color: color-mix(in srgb, var(--site-accent) 56%, transparent); background: linear-gradient(145deg, var(--site-process-bg), var(--site-footer-bg)); }
.site-template .comparison-card blockquote { color: var(--site-primary-strong); }
.site-template .comparison-card-after p:last-child { color: color-mix(in srgb, var(--site-process-text) 85%, transparent); }
.site-template .section-form { background: var(--site-surface-alt); }
.site-template .form-assurance { border-color: var(--site-border); background: color-mix(in srgb, var(--site-card) 66%, transparent); }
.site-template .form-assurance span { color: var(--site-accent); }
.site-template .form-assurance strong { color: var(--site-primary-strong); }
.site-template .quote-form { border-color: color-mix(in srgb, var(--site-border) 78%, var(--site-accent)); background: var(--site-card); }
.site-template .field-group label, .site-template .fieldset-group legend { color: var(--site-primary-strong); }
.site-template input, .site-template select, .site-template textarea, .site-template .radio-option { border-color: var(--site-border); background: var(--site-card); color: var(--site-text); }
.site-template .radio-option:has(input:checked) { border-color: var(--site-primary); background: var(--site-primary-soft); color: var(--site-primary-strong); }
.site-template .radio-option input, .site-template .consent-label input { accent-color: var(--site-primary); }
.site-template .field-hint { color: var(--site-muted); }
.site-template .quote-review, .site-template .consent-wrap, .site-template .turnstile-config-note { border-color: var(--site-border); background: var(--site-surface-alt); }
.site-template .quote-review dl div { border-color: var(--site-border); }
.site-template .quote-review dt { color: var(--site-muted); }
.site-template .quote-review dd { color: var(--site-primary-strong); }
.site-template .section-benefits { background: var(--site-surface); }
.site-template .benefit-grid article { border-color: var(--site-border); background: var(--site-card); }
.site-template .section-gallery { background: var(--site-surface-alt); }
.site-template .check-list li { color: var(--site-primary-strong); }
.site-template .check-list li::before { color: var(--site-accent); }
.site-template .final-cta { background: var(--site-page-bg); }
.site-template .cta-card { background: var(--site-final-cta-bg); }
.site-template .cta-card h2 { color: var(--site-final-cta-text); }
.site-template .cta-card p:not(.eyebrow) { color: color-mix(in srgb, var(--site-final-cta-text) 76%, transparent); }
.site-template .site-footer { background: var(--site-footer-bg); }
.site-template .site-footer strong { color: var(--site-footer-text); }
.site-template .site-footer p, .site-template .site-footer a { color: color-mix(in srgb, var(--site-footer-text) 68%, transparent); }
.site-template .footer-contact p:first-child { color: color-mix(in srgb, var(--site-footer-text) 88%, transparent); }
.site-template .footer-bottom { border-color: color-mix(in srgb, var(--site-footer-text) 16%, transparent); }
.site-template .footer-admin-link { color: color-mix(in srgb, var(--site-footer-text) 78%, transparent) !important; }
.site-template .footer-admin-link:hover { color: var(--site-footer-text) !important; }
.site-template.intensity-soft .hero, .site-template.intensity-soft .section-before-after, .site-template.intensity-soft .final-cta { background-color: var(--site-page-bg); }
.site-template.intensity-balanced .section-gallery, .site-template.intensity-balanced .section-form { background: var(--site-surface-alt); }
.site-template.intensity-bold .hero { background: linear-gradient(145deg, var(--site-primary-soft), var(--site-page-bg) 62%); }
.site-template.intensity-bold .section-services { background: var(--site-secondary-soft); }
.site-template.intensity-bold .service-card, .site-template.intensity-bold .benefit-grid article { border-color: color-mix(in srgb, var(--site-accent) 32%, var(--site-border)); }
.site-template.buttons-outline .button:not(.button-light):not(.button-ghost):not(.button-fallback) { border-width: 2px; border-color: var(--site-button-bg); background: transparent; color: var(--site-button-bg); box-shadow: none; }
.site-template.buttons-outline .button:not(.button-light):not(.button-ghost):not(.button-fallback):hover { background: var(--site-button-bg); color: var(--site-button-text); }
.site-template.buttons-elegant .button:not(.button-light):not(.button-ghost):not(.button-outline):not(.button-fallback) { background: linear-gradient(135deg, var(--site-button-bg), color-mix(in srgb, var(--site-button-bg) 80%, #fff)); box-shadow: 0 8px 22px color-mix(in srgb, var(--site-button-bg) 23%, transparent); }

/* v0.8.4: shell público neutro em billing restricted ou falha RPC online. */
.public-unavailable-page { min-height: 100vh; margin: 0; background: #f5f5f2; color: #263238; }
.public-unavailable-shell { display: grid; min-height: 100vh; place-items: center; padding: 24px; }
.public-unavailable-card { width: min(100%, 620px); padding: clamp(28px, 6vw, 52px); border: 1px solid #d7dcda; border-radius: 22px; background: #fff; box-shadow: 0 18px 45px rgba(38, 50, 56, 0.1); text-align: center; }
.public-unavailable-mark { display: grid; width: 54px; height: 54px; margin: 0 auto 18px; place-items: center; border-radius: 50%; background: #263238; color: #fff; font-family: var(--font-display); font-size: 0.94rem; letter-spacing: 0.08em; }
.public-unavailable-company { margin-bottom: 10px; color: #65726f; font-size: 0.82rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; }
.public-unavailable-card h1 { margin-bottom: 14px; color: #263238; font-size: clamp(2rem, 7vw, 3.4rem); }
.public-unavailable-card p { margin: 0 auto 7px; max-width: 480px; color: #65726f; }

.public-unavailable-actions { margin-top: 22px !important; }
.public-unavailable-actions .button { display: inline-flex; }

#public-site-root[hidden] { display: none !important; }
