﻿:root {
  --bg: #f3f3f3;
  --surface: #ffffff;
  --surface-soft: #f7f7f5;
  --surface-alt: #eef3f5;
  --ink: #222222;
  --muted: #5d6670;
  --line: rgba(15, 91, 120, 0.12);
  --brand: #e3a126;
  --brand-deep: #b17c12;
  --accent: #0f5b78;
  --accent-deep: #0b4258;
  --success: #1f7f55;
  --shadow: 0 20px 55px rgba(12, 35, 48, 0.08);
  --radius-lg: 28px;
  --radius-md: 18px;
  --radius-sm: 12px;
  --container: 1180px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: "Manrope", sans-serif;
  color: var(--ink);
  background: linear-gradient(180deg, rgba(15, 91, 120, 0.04), transparent 28%), linear-gradient(180deg, #faf9f6 0%, #f3f3f3 100%);
}
img { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
p, li, label, input, textarea, button { font-size: 1rem; line-height: 1.7; }
h1, h2, h3, blockquote { margin: 0; font-family: "Cormorant Garamond", serif; line-height: 1.04; }
.container { width: min(calc(100% - 2rem), var(--container)); margin: 0 auto; }
.section-pad { padding: 5.5rem 0; }
.eyebrow { margin: 0 0 1rem; color: var(--brand-deep); font-size: 0.82rem; font-weight: 800; letter-spacing: 0.18em; text-transform: uppercase; }
.site-header { position: sticky; top: 0; z-index: 30; background: rgba(255,255,255,0.94); backdrop-filter: blur(16px); border-bottom: 3px solid #f99f25; }
.nav-wrap { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 94px; position: relative; }
.brand { display: inline-flex; align-items: center; flex-shrink: 0; }
.brand img { width: 230px; height: auto; }
.main-nav { display: flex; align-items: center; gap: 1.5rem; }
.main-nav a { position: relative; color: var(--muted); font-weight: 700; padding: 0.45rem 0.8rem; border-radius: 999px; transition: color 180ms ease, background-color 180ms ease, transform 180ms ease; }
.main-nav a::after { content: none; }
.main-nav a:hover, .main-nav a.is-active { color: var(--accent); background: #f99f25; transform: translateY(-1px); }
.nav-actions { display: flex; align-items: center; gap: 0.75rem; }
.nav-link-call, .nav-cta, .button {
  display: inline-flex; align-items: center; justify-content: center; min-height: 48px;
  padding: 0.85rem 1.2rem; border-radius: 999px; font-weight: 800;
  transition: transform 180ms ease, background-color 180ms ease, color 180ms ease, border-color 180ms ease;
}
.nav-link-call { border: 1px solid #f99f25; background: var(--surface); color: var(--accent); }
.nav-cta, .button-primary { background: var(--accent); color: #fff; border: 1px solid #f99f25; }
.button-secondary { background: rgba(255,255,255,0.12); color: #fff; border: 1px solid #f99f25; }
.button-secondary-dark { background: var(--surface); color: var(--accent); border: 1px solid #f99f25; }
.button-whatsapp, .button-whatsapp-solid { background: var(--success); color: #fff; border: 1px solid #f99f25; }
.button-block { width: 100%; }
.button:hover, .nav-cta:hover, .nav-link-call:hover { transform: translateY(-1px); }
.menu-toggle { display: none; width: 48px; height: 48px; padding: 0; border: 1px solid rgba(15,91,120,0.14); border-radius: 12px; background: #fff; cursor: pointer; }
.menu-toggle span { display: block; width: 22px; height: 2px; margin: 5px auto; background: var(--accent); }
.hero-home {
  position: relative; overflow: hidden; padding: 4.5rem 0 5rem;
  background: url("images/hero_back_v1.webp?v=2") center/cover no-repeat;
}
.hero-grid, .intro-grid, .section-head, .feature-grid, .principal-grid, .whatsapp-grid, .contact-grid, .footer-grid, .content-grid, .contact-info-grid { display: grid; gap: 1.5rem; }
.hero-grid { grid-template-columns: minmax(0,1.35fr) minmax(300px,0.78fr); align-items: center; }
.hero-panel, .hero-card, .service-card, .feature-card, .principal-card, .cta-panel, .info-card, .contact-form, .map-placeholder, .qr-placeholder { box-shadow: var(--shadow); }
.hero-copy { color: #fff; }
.hero-copy h1 { max-width: 11ch; font-size: clamp(3.4rem, 7vw, 6rem); margin-bottom: 1rem; }
.hero-text { max-width: 62ch; color: rgba(255,255,255,0.9); }
.hero-actions { display: flex; flex-wrap: wrap; gap: 0.85rem; margin: 2rem 0; }
.hero-points { display: flex; flex-wrap: wrap; gap: 0.75rem; margin: 0; padding: 0; list-style: none; }
.hero-points li { padding: 0.6rem 0.95rem; border-radius: 999px; background: rgba(255,255,255,0.1); border: 1px solid #f99f25; }
.hero-card, .principal-card, .info-card, .contact-form {
  padding: 2rem; border-radius: var(--radius-lg); background: rgba(255,255,255,0.94); border: 1px solid rgba(15,91,120,0.1);
}
.hero-card h2, .section-head h2, .principal-copy h2, .contact-copy h2, .content-grid h2, .cta-panel h2, .whatsapp-grid h2, .page-hero h1 { font-size: clamp(2.7rem, 5vw, 4.2rem); }
.contact-mini-list, .footer-grid ul, .contact-list, .info-card ul { margin: 1rem 0 0; padding: 0; list-style: none; }
.contact-mini-list li, .contact-list li, .info-card li, .footer-grid li { margin-bottom: 0.5rem; }
.intro-section, .whatsapp-section, .alt-section { background: var(--surface-soft); }
.intro-grid, .content-grid, .principal-grid, .contact-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.section-head { grid-template-columns: minmax(0,1fr) minmax(320px,0.78fr); align-items: end; margin-bottom: 2rem; }
.section-note, .footer-bottom p, .form-note, .page-hero p, .cta-panel p, .intro-grid p, .principal-copy p, .contact-copy p, .service-card p, .feature-card p, .info-card p, .site-footer p { color: var(--muted); }
.service-grid-home, .feature-grid, .service-grid-large { display: grid; gap: 1.25rem; grid-template-columns: repeat(3, minmax(0, 1fr)); }
.service-card, .feature-card { padding: 1.6rem; border-radius: var(--radius-md); background: var(--surface); border: 1px solid rgba(15,91,120,0.08); }
.service-card span { display: inline-block; margin-bottom: 1rem; color: var(--brand-deep); font-weight: 800; }
.service-card h3, .feature-card h3, .principal-card h3, .info-card h3, .contact-form h3, .footer-grid h3 { font-size: 2rem; margin-bottom: 0.8rem; }
.why-section { background: linear-gradient(180deg, rgba(15,91,120,0.03), transparent 100%); }
.principal-card { background: linear-gradient(180deg, #fff 0%, #f4f7f8 100%); }
.principal-copy .text-link { color: var(--accent); font-weight: 800; }
.portrait {
  display: grid; place-items: center; width: 92px; height: 92px; margin-bottom: 1rem; border-radius: 24px;
  background: linear-gradient(135deg, var(--accent), var(--brand)); color: #fff; font-size: 1.45rem; font-weight: 800;
}
.role { margin: 0 0 0.8rem; color: var(--brand-deep); font-size: 0.82rem; font-weight: 800; letter-spacing: 0.12em; text-transform: uppercase; }
.whatsapp-grid { grid-template-columns: minmax(0,1.1fr) minmax(260px,0.7fr); align-items: center; }
.qr-placeholder, .map-placeholder {
  display: grid; place-items: center; min-height: 280px; border-radius: var(--radius-lg); border: 1px dashed rgba(15,91,120,0.25);
  background: repeating-linear-gradient(45deg, rgba(15,91,120,0.04), rgba(15,91,120,0.04) 12px, rgba(227,161,38,0.05) 12px, rgba(227,161,38,0.05) 24px);
  color: var(--accent); text-align: center; padding: 1.5rem;
}
.map-embed {
  overflow: hidden;
  min-height: 360px;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(15,91,120,0.12);
  box-shadow: var(--shadow);
}
.map-embed iframe {
  display: block;
  width: 100%;
  min-height: 360px;
  border: 0;
}
.cta-section { padding-top: 0; }
.cta-panel {
  display: grid; grid-template-columns: minmax(0,1fr) auto; align-items: center; gap: 1.5rem; padding: 2rem;
  border-radius: var(--radius-lg); background: linear-gradient(135deg, var(--accent-deep), var(--accent)); color: #fff;
}
.cta-panel p { color: rgba(255,255,255,0.82); }
.cta-actions { display: flex; flex-wrap: wrap; gap: 0.8rem; justify-content: flex-end; }
.page-hero { padding: 4.5rem 0 4rem; background: linear-gradient(135deg, rgba(15,91,120,0.98), rgba(227,161,38,0.88)); color: #fff; }
.page-hero-inner { max-width: 860px; }
.page-hero p { max-width: 62ch; color: rgba(255,255,255,0.88); }
.contact-info-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); margin-top: 1.5rem; }
.contact-form { align-content: start; }
.contact-form label { display: grid; gap: 0.45rem; font-weight: 700; }
input, textarea {
  width: 100%; padding: 0.95rem 1rem; border: 2px solid rgba(15,91,120,0.14); border-radius: var(--radius-sm);
  background: #fff; color: var(--ink); font: inherit;
}
input:focus, textarea:focus, button:focus, a:focus, .menu-toggle:focus { outline: 2px solid rgba(227,161,38,0.8); outline-offset: 2px; }
textarea { resize: vertical; }
button { border: 0; cursor: pointer; }
.map-section { padding-top: 0; }
.site-footer { padding: 2.5rem 0 1.5rem; background: #10252f; color: #edf4f7; }
.footer-grid { grid-template-columns: minmax(0,1.3fr) repeat(2, minmax(180px,0.7fr)); align-items: start; }
.footer-brand { margin-bottom: 1rem; }
.footer-brand {
  display: inline-flex;
  padding: 0.85rem 1rem;
  border-radius: 3px;
  background: #f4f1ea;
}
.footer-brand img { width: 240px; height: auto; }
.footer-tagline { color: #f0c76e; font-weight: 700; }
.site-footer p, .site-footer li, .site-footer a { color: rgba(237,244,247,0.82); }
.site-footer a:hover { color: #f99f25; }
.footer-bottom { margin-top: 1.75rem; padding-top: 1rem; border-top: 1px solid rgba(255,255,255,0.1); }

@media (max-width: 1040px) {
  .main-nav { position: absolute; top: calc(100% + 1px); left: 0; right: 0; display: none; flex-direction: column; align-items: flex-start; gap: 1rem; padding: 1.25rem 1rem 1.5rem; background: #fff; border-bottom: 1px solid rgba(15,91,120,0.08); box-shadow: 0 18px 40px rgba(12,35,48,0.08); }
  .site-header.nav-open .main-nav { display: flex; }
  .menu-toggle { display: inline-block; order: 3; }
  .nav-actions { margin-left: auto; }
  .hero-grid, .intro-grid, .content-grid, .principal-grid, .contact-grid, .contact-info-grid, .whatsapp-grid, .footer-grid, .section-head, .cta-panel, .service-grid-home, .service-grid-large, .feature-grid { grid-template-columns: 1fr; }
  .hero-home { background: linear-gradient(180deg, var(--accent) 0%, var(--accent) 74%, var(--brand) 74%, #f3efe6 100%); }
  .hero-home {
    background: url("images/hero_back_v1.webp?v=2") center/cover no-repeat;
  }
  .hero-copy h1 { max-width: none; }
  .cta-actions { justify-content: flex-start; }
}

@media (max-width: 760px) {
  .nav-wrap { min-height: 82px; flex-wrap: wrap; padding: 0.85rem 0; }
  .brand img, .footer-brand img { width: 180px; }
  .nav-actions { width: 100%; justify-content: stretch; }
  .nav-link-call, .nav-cta { flex: 1; }
  .section-pad { padding: 4rem 0; }
  .hero-home { padding: 3rem 0 4rem; }
  .hero-card, .principal-card, .info-card, .contact-form, .cta-panel { padding: 1.5rem; }
  .hero-actions, .cta-actions { flex-direction: column; }
  .button, .button-primary, .button-secondary, .button-whatsapp, .button-secondary-dark, .button-whatsapp-solid { width: 100%; }
}
