.site-srOnly { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }
.site-header { position: sticky; top: 0; left: 0; right: 0; width: 100%; z-index: 60; background: #ffffff; color: #172033; border-bottom: 1px solid #e5e7eb; }
.site-header__inner { max-width: 1200px; margin: 0 auto; padding: 16px 24px; display: flex; align-items: center; justify-content: space-between; gap: 24px; }
.site-brand { display: inline-flex; align-items: center; gap: 12px; text-decoration: none; color: #172033; font-weight: 800; font-size: 1.125rem; text-transform: uppercase; letter-spacing: 0.02em; }
.site-brand svg { width: 32px; height: 32px; display: block; color: #059669; }
.site-nav { display: flex; align-items: center; gap: 32px; flex: 1; justify-content: center; }
.site-nav__link { text-decoration: none; color: #172033; font-weight: 600; font-size: 0.9375rem; transition: color 0.2s; }
.site-nav__link:hover { color: #059669; }
.site-header__actions { display: flex; align-items: center; gap: 16px; min-width: max-content; }
.site-header__cta { display: inline-flex; align-items: center; justify-content: center; padding: 10px 20px; border-radius: 4px; background: #059669; color: #ffffff; text-decoration: none; font-size: 0.875rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; transition: background 0.2s; }
.site-header__cta:hover { background: #047857; }
.site-burger { display: none; flex-direction: column; justify-content: space-between; width: 32px; height: 24px; background: transparent; border: none; color: #172033; cursor: pointer; padding: 0; }
.site-burger__line { display: block; width: 100%; height: 2px; background: currentColor; border-radius: 2px; transition: transform 0.2s, opacity 0.2s; }

.site-mobileNav { position: fixed; inset: 0; z-index: 70; background: rgba(23, 32, 51, 0.4); backdrop-filter: blur(4px); }
.site-mobileNav[hidden], .site-mobileNav.hidden { display: none; }
.site-mobileNav[data-mobile-open="1"] { display: block; }
.site-mobileNav__panel { position: absolute; top: 0; right: 0; bottom: 0; width: min(400px, 85vw); background: #ffffff; color: #172033; padding: 24px; display: flex; flex-direction: column; gap: 32px; box-shadow: -10px 0 30px rgba(0,0,0,0.1); overflow-y: auto; }
.site-mobileNav__top { display: flex; align-items: center; justify-content: space-between; border-bottom: 1px solid #e5e7eb; padding-bottom: 16px; }
.site-mobileNav__brand { font-weight: 800; font-size: 1.125rem; text-transform: uppercase; color: #172033; }
.site-mobileNav__close { width: 32px; height: 32px; display: flex; align-items: center; justify-content: center; background: transparent; border: none; font-size: 28px; color: #172033; cursor: pointer; }
.site-mobileNav__links { display: flex; flex-direction: column; gap: 20px; }
.site-mobileNav__link { color: #172033; text-decoration: none; font-weight: 700; font-size: 1.25rem; transition: color 0.2s; }
.site-mobileNav__link:hover { color: #059669; }
.site-mobileNav__cta { display: inline-flex; align-items: center; justify-content: center; padding: 14px 24px; border-radius: 4px; background: #059669; color: #ffffff; text-decoration: none; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; text-align: center; margin-top: auto; }

.site-footer { background: #172033; color: #f5efe5; padding: 64px 24px 32px; font-family: system-ui, sans-serif; }
.site-footer__editorial { max-width: 1200px; margin: 0 auto 48px; text-align: center; }
.site-footer__closingLine { font-size: clamp(1.5rem, 4vw, 2.5rem); font-weight: 800; margin: 0; color: #ffffff; line-height: 1.2; }
.site-footer__inner { max-width: 1200px; margin: 0 auto; display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 48px; padding-bottom: 48px; border-bottom: 1px solid rgba(245,239,229,0.1); }
.site-footer__heading { font-size: 1rem; font-weight: 700; text-transform: uppercase; letter-spacing: 0.05em; margin: 0 0 20px; color: #059669; }
.site-footer__links, .site-footer__contact { display: flex; flex-direction: column; gap: 12px; }
.site-footer__link, .site-footer__contactLink, .site-footer__social { color: #f5efe5; text-decoration: none; font-size: 0.9375rem; opacity: 0.8; transition: opacity 0.2s, color 0.2s; }
.site-footer__link:hover, .site-footer__contactLink:hover, .site-footer__social:hover { opacity: 1; color: #ffffff; }
.site-footer__socials { display: flex; gap: 16px; margin-top: 20px; }
.site-footer__form { display: flex; gap: 8px; margin-top: 16px; }
.site-footer__input { flex: 1; padding: 12px 16px; border: 1px solid rgba(245,239,229,0.2); background: rgba(255,255,255,0.05); color: #ffffff; border-radius: 4px; font-size: 0.9375rem; }
.site-footer__input:focus { outline: none; border-color: #059669; }
.site-footer__submit { padding: 12px 20px; background: #059669; color: #ffffff; border: none; border-radius: 4px; font-weight: 700; cursor: pointer; transition: background 0.2s; }
.site-footer__submit:hover { background: #047857; }
.site-footer__bottom { max-width: 1200px; margin: 32px auto 0; display: flex; flex-wrap: wrap; align-items: center; justify-content: space-between; gap: 16px; }
.site-footer__legal { display: flex; gap: 24px; }
.site-footer__legalLink { color: #f5efe5; text-decoration: none; font-size: 0.875rem; opacity: 0.6; transition: opacity 0.2s; }
.site-footer__legalLink:hover { opacity: 1; }
.site-footer__copyright { font-size: 0.875rem; opacity: 0.6; }

@media (max-width: 900px) {
  .site-nav--desktop { display: none; }
  .site-header__cta { display: none; }
  .site-burger { display: flex; }
  .site-footer__inner { grid-template-columns: 1fr; gap: 32px; }
  .site-footer__bottom { flex-direction: column; align-items: flex-start; }
}
[data-mobile-nav][hidden],[data-mobile-nav].hidden{display:none}
[data-mobile-nav][data-mobile-open="1"]{display:block}
