@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:wght@400;500;600;700&display=swap');

:root {
  --ez-red: #C0392B;
  --ez-red-dark: #96281B;
  --ez-red-soft: #fef2f2;
  --ez-red-border: #fde8e8;
  --ez-navy: #0f1c2e;
  --ez-navy-2: #16263a;
  --ez-ink: #172033;
  --ez-muted: #5f6878;
  --ez-soft: #F9F8F6;
  --ez-cream: #F4F1EC;
  --ez-white: #ffffff;
  --ez-border: #E8E4DC;
  --ez-border-light: #F1EEE9;
  --ez-green: #059669;
  --ez-shadow-sm: 0 1px 3px rgba(15, 28, 46, 0.06), 0 1px 2px rgba(15, 28, 46, 0.04);
  --ez-shadow-md: 0 8px 24px rgba(15, 28, 46, 0.08), 0 2px 8px rgba(15, 28, 46, 0.05);
  --ez-shadow-lg: 0 18px 48px rgba(15, 28, 46, 0.12), 0 6px 18px rgba(15, 28, 46, 0.06);
  --ez-radius-sm: 8px;
  --ez-radius-md: 12px;
  --ez-radius-lg: 16px;
  --ez-radius-xl: 20px;
  --ez-container: 1120px;
  --ez-section-y: 76px;
  --ez-section-x: 56px;
}

html {
  scroll-padding-top: 92px;
}

body {
  font-family: 'DM Sans', system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif !important;
  color: var(--ez-ink) !important;
  background-color: var(--ez-soft) !important;
  text-rendering: optimizeLegibility;
}

h1,
h2,
.section-title,
.page-header h1,
.page-hero h1,
.hero h1,
.cta-final h2,
.partner-hero h1,
.stat-num,
.price-tag,
.rating-num {
  font-family: 'Playfair Display', 'DM Serif Display', Georgia, serif !important;
  letter-spacing: 0 !important;
}

h3,
h4,
p,
a,
button,
input,
select,
textarea,
label {
  letter-spacing: 0 !important;
}

.container,
.page-header-inner,
.booking-layout,
.services-section,
.footer-grid,
.trust-bar-inner,
.pricing-strip-inner,
.partner-hero-inner,
.partner-contact-inner,
.contact-grid,
.form-inner,
.options-grid {
  max-width: var(--ez-container) !important;
}

section,
.page-header,
.page-hero,
.hero,
.services-section,
.form-section,
.contact-section,
.partner-hero,
.partner-contact,
.booking-section {
  padding-left: var(--ez-section-x) !important;
  padding-right: var(--ez-section-x) !important;
}

section {
  padding-top: var(--ez-section-y) !important;
  padding-bottom: var(--ez-section-y) !important;
}

nav {
  height: 72px !important;
  padding-left: 44px !important;
  padding-right: 44px !important;
  background: rgba(255, 255, 255, 0.9) !important;
  border-bottom: 1px solid rgba(232, 228, 220, 0.9) !important;
  box-shadow: 0 1px 0 rgba(15, 28, 46, 0.04) !important;
  backdrop-filter: blur(18px);
}

nav.scrolled {
  box-shadow: var(--ez-shadow-md) !important;
}

.nav-logo-text,
.footer-logo {
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
}

.nav-links {
  gap: 8px !important;
}

.nav-links a {
  min-height: 40px !important;
  display: inline-flex !important;
  align-items: center !important;
  padding: 9px 13px !important;
  border-radius: var(--ez-radius-sm) !important;
  color: var(--ez-muted) !important;
  font-size: 0.88rem !important;
  font-weight: 600 !important;
  text-decoration: none !important;
}

.nav-links a:hover,
.nav-links a.active {
  color: var(--ez-navy) !important;
  background: rgba(15, 28, 46, 0.055) !important;
}

.nav-links a.es,
.nav-links a[style*="C0392B"],
.nav-links a[style*="--red"] {
  color: var(--ez-red) !important;
}

.btn-primary,
.btn-book-nav,
.btn-white,
.btn-submit,
.mobile-book,
.mob-book,
.sticky-btn-book,
.quick-link,
.svc-link,
.btn-option,
.partner-cta,
.contact-way,
a[class*="btn"] {
  border-radius: var(--ez-radius-md) !important;
  min-height: 44px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-weight: 700 !important;
  text-decoration: none !important;
  transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, border-color 180ms ease !important;
}

.btn-primary,
.btn-book-nav,
.btn-submit,
.mobile-book,
.mob-book,
.sticky-btn-book,
.btn-red {
  background: var(--ez-red) !important;
  color: var(--ez-white) !important;
  border: 1px solid var(--ez-red) !important;
  box-shadow: 0 8px 18px rgba(192, 57, 43, 0.22) !important;
}

.btn-primary:hover,
.btn-book-nav:hover,
.btn-submit:hover,
.mobile-book:hover,
.mob-book:hover,
.sticky-btn-book:hover,
.btn-red:hover {
  background: var(--ez-red-dark) !important;
  border-color: var(--ez-red-dark) !important;
  transform: translateY(-1px) !important;
  box-shadow: 0 12px 26px rgba(192, 57, 43, 0.3) !important;
}

.btn-secondary,
.btn-call,
.btn-call-nav,
.mobile-call,
.mob-call,
.btn-option:not(.btn-red) {
  border-radius: var(--ez-radius-md) !important;
  border: 1px solid rgba(232, 228, 220, 0.95) !important;
  background: rgba(255, 255, 255, 0.72) !important;
  color: var(--ez-navy) !important;
  box-shadow: 0 1px 0 rgba(15, 28, 46, 0.04) !important;
}

.btn-white {
  color: var(--ez-red) !important;
  background: var(--ez-white) !important;
  box-shadow: 0 12px 28px rgba(15, 28, 46, 0.14) !important;
}

.service-card,
.value-card,
.why-item,
.serve-card,
.step,
.review-card,
.price-card,
.contact-card,
.quick-card,
.faq-item,
.prepare-item,
.sidebar-card,
.stat-card,
.cred-card,
.partner-card,
.solution-card,
.benefit-card,
.option-card,
.team-card,
.areas-cloud a,
.area-tag {
  border-radius: var(--ez-radius-lg) !important;
  border-color: var(--ez-border) !important;
  box-shadow: var(--ez-shadow-sm) !important;
}

.service-card:hover,
.value-card:hover,
.review-card:hover,
.price-card:hover,
.contact-card:hover,
.quick-card:hover,
.partner-card:hover,
.solution-card:hover,
.benefit-card:hover,
.option-card:hover {
  box-shadow: var(--ez-shadow-md) !important;
  transform: translateY(-2px);
}

.section-tag,
.section-eyebrow,
.page-badge,
.hero-badge {
  border-radius: 999px !important;
  letter-spacing: 0.08em !important;
  font-family: 'DM Sans', system-ui, sans-serif !important;
  font-weight: 800 !important;
}

.announce-bar {
  background: var(--ez-navy) !important;
  color: rgba(255, 255, 255, 0.86) !important;
}

.trust-bar {
  background: rgba(255, 255, 255, 0.96) !important;
  border-top: 1px solid rgba(232, 228, 220, 0.65) !important;
  border-bottom: 1px solid rgba(232, 228, 220, 0.85) !important;
}

.trust-bar-inner {
  gap: 4px 0 !important;
  padding-top: 12px !important;
  padding-bottom: 12px !important;
}

.trust-item {
  color: var(--ez-muted) !important;
  border-radius: 999px !important;
}

.trust-item strong,
.trust-item.hi {
  color: var(--ez-navy) !important;
}

.mobile-menu {
  top: 72px !important;
  padding: 18px 22px 24px !important;
  background: rgba(255, 255, 255, 0.98) !important;
  box-shadow: var(--ez-shadow-lg) !important;
  border-bottom: 1px solid var(--ez-border) !important;
}

.mobile-menu a {
  min-height: 46px !important;
  border-radius: var(--ez-radius-sm) !important;
  padding-left: 8px !important;
  padding-right: 8px !important;
  color: var(--ez-navy) !important;
}

.hamburger {
  min-width: 44px !important;
  min-height: 44px !important;
  border-radius: var(--ez-radius-sm) !important;
}

.hamburger:focus-visible,
a:focus-visible,
button:focus-visible,
input:focus-visible,
select:focus-visible,
textarea:focus-visible {
  outline: 3px solid rgba(192, 57, 43, 0.26) !important;
  outline-offset: 3px !important;
}

footer {
  background: #07101C !important;
  color: rgba(255, 255, 255, 0.54) !important;
}

.footer-grid {
  gap: 42px !important;
}

.footer-col h4 {
  color: rgba(255, 255, 255, 0.72) !important;
}

.footer-col a,
.footer-contact a,
.footer-contact-item a {
  color: rgba(255, 255, 255, 0.58) !important;
}

.footer-col a:hover,
.footer-contact a:hover,
.footer-contact-item a:hover {
  color: var(--ez-white) !important;
}

.footer-badge {
  border-radius: var(--ez-radius-sm) !important;
  background: rgba(255, 255, 255, 0.07) !important;
  border: 1px solid rgba(255, 255, 255, 0.09) !important;
  color: rgba(255, 255, 255, 0.62) !important;
}

.wa-float {
  border-radius: 999px !important;
  box-shadow: 0 12px 28px rgba(37, 211, 102, 0.28), 0 4px 12px rgba(15, 28, 46, 0.16) !important;
}

input,
select,
textarea {
  border-radius: var(--ez-radius-md) !important;
  border-color: var(--ez-border) !important;
  font-family: 'DM Sans', system-ui, sans-serif !important;
}

input:focus,
select:focus,
textarea:focus {
  border-color: var(--ez-red) !important;
  box-shadow: 0 0 0 4px rgba(192, 57, 43, 0.12) !important;
}

@media (max-width: 1100px) {
  :root {
    --ez-section-x: 36px;
    --ez-section-y: 68px;
  }

  nav {
    padding-left: 28px !important;
    padding-right: 28px !important;
  }
}

@media (max-width: 900px) {
  :root {
    --ez-section-x: 22px;
    --ez-section-y: 58px;
  }

  nav {
    width: 100% !important;
    max-width: 100% !important;
  }

  nav .nav-links,
  nav .btn-call,
  nav .btn-call-nav,
  nav .btn-book-nav {
    display: none !important;
  }

  nav .nav-right {
    min-width: 0 !important;
  }

  nav {
    height: 68px !important;
    padding-left: 20px !important;
    padding-right: 20px !important;
  }

  .mobile-menu {
    top: 68px !important;
  }

  .page-header,
  .page-hero,
  .hero {
    padding-top: 56px !important;
    padding-bottom: 56px !important;
  }

  .trust-bar {
    overflow: visible !important;
  }

  .trust-bar-inner {
    width: 100% !important;
    max-width: 100% !important;
    justify-content: center !important;
    overflow: visible !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .trust-divider {
    display: none !important;
  }

  .trust-item {
    min-height: 34px !important;
    white-space: normal !important;
    text-align: center !important;
    justify-content: center !important;
    border: 1px solid rgba(232, 228, 220, 0.9) !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, 0.72) !important;
    padding: 7px 12px !important;
  }

  .footer-grid {
    grid-template-columns: 1fr 1fr !important;
  }
}

@media (max-width: 580px) {
  :root {
    --ez-section-x: 18px;
    --ez-section-y: 48px;
  }

  body {
    font-size: 16px;
  }

  h1,
  .hero h1,
  .page-header h1,
  .page-hero h1 {
    font-size: clamp(2.05rem, 11vw, 2.8rem) !important;
    line-height: 1.08 !important;
  }

  .section-title,
  h2 {
    font-size: clamp(1.72rem, 8vw, 2.2rem) !important;
    line-height: 1.13 !important;
  }

  .hero-btns,
  .cta-buttons,
  .btn-row,
  .reviews-footer {
    gap: 12px !important;
  }

  .hero-btns a,
  .cta-buttons a,
  .btn-primary,
  .btn-secondary,
  .btn-white,
  .btn-submit,
  .btn-option {
    width: 100%;
    min-height: 48px !important;
  }

  .footer-grid {
    grid-template-columns: 1fr !important;
    gap: 28px !important;
  }

  footer {
    padding-bottom: 64px !important;
  }

  .wa-float {
    display: none !important;
    right: 14px !important;
    bottom: calc(14px + env(safe-area-inset-bottom, 0px)) !important;
    width: 54px !important;
    height: 54px !important;
    min-height: 54px !important;
    padding: 0 !important;
    justify-content: center !important;
    border-radius: 999px !important;
  }

  .wa-float .wa-label {
    display: none !important;
  }

  .wa-float .wa-icon {
    width: 25px !important;
    height: 25px !important;
  }
}
