:root {
  --ink: #1f1d1e;
  --cyan: #51a8b1;
  --clay: #ed2f59;
  --forest: #5c8d3f;
  --brass: #d9a436;
  --paper: #f7fcfd;
  --white: #fff;
  --muted: #657579;
  --line: #cbe9ec;
  --brand-font: "Arial Narrow", "HelveticaNeue-CondensedBold", "Roboto Condensed", Arial, sans-serif;
}
* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; background: var(--paper); color: var(--ink); font-family: Arial, sans-serif; line-height: 1.68; }
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
.site-header { position: sticky; top: 0; z-index: 20; border-bottom: 1px solid var(--line); background: rgba(255,255,255,.96); }
.nav-shell { display: flex; align-items: center; gap: 18px; width: min(1180px, calc(100% - 32px)); margin: auto; padding: 9px 0; }
.brand-logo { width: 105px; height: 82px; object-fit: contain; }
.nav-links { display: flex; align-items: center; gap: 5px; margin-left: auto; }
.nav-links a { border-radius: 6px; padding: 9px 10px; font-family: var(--brand-font); font-size: .84rem; font-weight: 800; text-transform: uppercase; }
.nav-links a:hover { background: rgba(81,168,177,.12); color: var(--forest); }
.header-quote, .button { display: inline-flex; min-height: 42px; align-items: center; justify-content: center; border-radius: 6px; font-family: var(--brand-font); font-weight: 800; text-transform: uppercase; }
.header-quote { background: var(--clay); color: var(--white); padding: 0 13px; font-size: .78rem; white-space: nowrap; }
.mobile-toggle { display: none; width: 44px; height: 44px; border: 1px solid var(--line); border-radius: 6px; background: rgba(81,168,177,.08); }
.mobile-toggle svg { width: 20px; fill: none; stroke: currentColor; stroke-width: 2; }
.hero { position: relative; min-height: 480px; display: grid; align-items: end; overflow: hidden; color: var(--white); }
.hero-image { position: absolute; inset: 0; z-index: 0; width: 100%; height: 100%; object-fit: cover; object-position: center; }
.hero::before { content: ""; position: absolute; inset: 0; z-index: 1; background: linear-gradient(90deg, rgba(31,29,30,.9), rgba(31,29,30,.45)); }
.hero-inner { position: relative; z-index: 2; width: min(920px, calc(100% - 32px)); margin: 0 auto; padding: 90px 0 62px; }
.eyebrow { margin: 0 0 12px; color: var(--brass); font-family: var(--brand-font); font-weight: 800; text-transform: uppercase; }
h1, h2, h3 { font-family: var(--brand-font); line-height: 1.08; text-transform: uppercase; }
h1 { max-width: 900px; margin: 0 0 18px; font-size: clamp(2.3rem, 5.8vw, 4.8rem); }
.hero-copy { max-width: 760px; color: rgba(255,255,255,.88); font-size: 1.12rem; }
.article { width: min(820px, calc(100% - 32px)); margin: auto; padding: 68px 0; }
.article h2 { margin: 46px 0 14px; font-size: clamp(1.7rem, 3.5vw, 2.55rem); }
.article h3 { margin: 28px 0 10px; font-size: 1.35rem; }
.article p, .article li { color: #4f5f62; font-size: 1.04rem; }
.article ul, .article ol { padding-left: 22px; }
.article strong { color: var(--ink); }
.price-table { width: 100%; border-collapse: collapse; margin: 22px 0; background: var(--white); }
.price-table th, .price-table td { border: 1px solid var(--line); padding: 12px; text-align: left; }
.price-table th { background: rgba(81,168,177,.1); }
.note { border-left: 4px solid var(--brass); background: var(--white); padding: 18px 20px; }
.cta { border-radius: 8px; margin-top: 48px; background: var(--ink); color: var(--white); padding: 28px; }
.cta p { color: rgba(255,255,255,.74); }
.button { background: var(--clay); color: var(--white); padding: 0 18px; }
.footer { background: var(--ink); color: var(--white); }
.footer-inner { display: flex; align-items: center; justify-content: space-between; gap: 30px; width: min(1180px, calc(100% - 32px)); margin: auto; padding: 28px 0; }
.footer-brand { display: grid; gap: 8px; max-width: 680px; }
.footer-meta { display: flex; align-items: center; flex-wrap: wrap; gap: 7px 16px; }
.footer-summary, .footer-address { display: inline-flex; align-items: center; width: auto; gap: 6px; margin: 0; font-size: .86rem; line-height: 1.35; }
.footer-links { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 12px; }
.footer-links a { display: inline-flex; align-items: center; justify-content: center; gap: 8px; min-width: 42px; min-height: 42px; border: 1px solid rgba(255,255,255,.2); border-radius: 6px; padding: 0 12px; }
.footer-links svg, .contact-icon { width: 19px; height: 19px; flex: 0 0 auto; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.footer-links .icon-fill { fill: currentColor; stroke: none; }
.footer .contact-icon { width: 16px; height: 16px; }
.whatsapp-logo { width: 21px; height: 21px; flex: 0 0 auto; }
.footer-legal { margin: 0; color: rgba(255,255,255,.54); font-size: .82rem; }
.footer-policy { color: rgba(255,255,255,.82); font-size: .82rem; font-weight: 800; text-decoration: underline; text-underline-offset: 3px; }
.footer-phone-label { font-size: .86rem; line-height: 1; white-space: nowrap; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; }
.footer a { color: var(--brass); }
@media (max-width: 980px) {
  .nav-shell { position: relative; }
  .mobile-toggle { display: grid; place-items: center; }
  .nav-links { position: absolute; inset: calc(100% + 8px) 0 auto; display: none; flex-direction: column; align-items: stretch; border: 1px solid var(--line); border-radius: 8px; background: var(--white); padding: 10px; }
  .nav-links.is-open { display: flex; }
  .brand-logo { width: 80px; height: 65px; }
  .header-quote { margin-left: auto; padding: 0 10px; font-size: .72rem; }
}
@media (max-width: 540px) {
  h1 { font-size: 2.3rem; }
  .hero { min-height: 520px; }
  .hero-image { object-position: center; }
  .article { padding: 52px 0; }
  .article p, .article li { font-size: 1rem; }
  .footer-inner { display: grid; }
  .footer-brand, .footer-links { width: 100%; }
  .footer-meta { align-items: flex-start; flex-direction: column; gap: 9px; }
  .footer-links { justify-content: flex-start; }
  .footer-links a.social-phone { flex: 1 1 auto; }
  .footer-address { align-items: flex-start; }
}
