:root {
  --color-bg: #fafaff;
  --color-muted-bg: rgba(228,217,255,0.35);
  --color-surface: #ffffff;
  --color-text: #30343F;
  --color-muted: #5f6371;
  --color-border: #e4d9ff;
  --color-primary: #273469;
  --color-secondary: #1E2749;
  --color-accent: #30343F;
  --color-primary-contrast: #fafaff;
  
  --max-width: 1100px;
  --space-xxs: 0.25rem;
  --space-xs: 0.5rem;
  --space-sm: 1rem;
  --space-md: 1.5rem;
  --space-lg: 2.5rem;
  --radius: 8px;
  --shadow-sm: 0 6px 18px rgba(15,23,42,0.06);
  --header-offset: 93px;
}

.skip-link {position: absolute; left: -999px; top: auto; width: 1px; height: 1px; overflow: hidden}
.skip-link:focus {left: 1rem; top: 1rem; width: auto; height: auto; padding: .5rem .75rem; background: var(--color-primary); color: var(--color-primary-contrast); border-radius: 6px; z-index: 9999}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: var(--header-offset); }
body {
  margin: 0;
  background: var(--color-bg);
  color: var(--color-text);
  font-family: Inter, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  line-height: 1.6;
  font-size: 18px;
  -webkit-font-smoothing:antialiased;
}

.container {
  width: min(var(--max-width), calc(100% - 2rem));
  margin: 0 auto;
}

h1, h2, h3 { margin: 0 0 var(--space-sm) 0; }
h1 { font-family: Georgia, 'Times New Roman', serif; font-size: clamp(2.2rem, 5vw, 3.6rem); line-height: 1.06; }

.merriweather-loaded h1 { font-family: Merriweather, Georgia, serif; }

.hero h1 {
  min-height: calc(2 * clamp(2.2rem, 5vw, 3.6rem) * 1.06);
  overflow-wrap: break-word;
}
h2 { font-size: 1.6rem; color: var(--color-accent); }
h3 { font-size: 1.05rem; font-weight: 600; }
p { margin-top: 0.75rem; color: var(--color-muted); }
.eyebrow { display: inline-block; font-size: .85rem; text-transform: uppercase; letter-spacing: .06em; color: var(--color-muted); }
.lead { font-size: 1.15rem; color: var(--color-muted); }

#site-header { display: block; min-height: var(--header-offset); position: sticky; top: 0; left: 0; right: 0; z-index: 1000; background: var(--color-surface); }
#site-header.loading { position: relative; overflow: hidden; background: linear-gradient(180deg, #f7f5f1, #f7f5f1); }
#site-header.loading::before { content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, rgba(255,255,255,0), rgba(255,255,255,0.65), rgba(255,255,255,0));
  transform: translateX(-100%);
  animation: shimmer 1.6s infinite;
}
#site-footer { display: block; }
.site-footer { background: var(--color-secondary); padding: 2rem 0; border-top: 1px solid rgba(255,255,255,0.12); }
.site-footer .footer-inner { display: flex; flex-wrap: wrap; justify-content: space-between; align-items: flex-start; gap: 1.25rem; }
.site-footer .footer-info { display: flex; flex-direction: column; gap: .35rem; color: rgba(255,255,255,0.88); font-size: 0.98rem; max-width: 38rem; }
.site-footer .footer-info .legal { color: #fafaff; font-weight: 600; }
.site-footer .footer-info .company-meta { color: rgba(255,255,255,0.72); font-size: 0.92rem; }
.site-footer .footer-nav { display: flex; flex-wrap: wrap; gap: 1rem; align-items: center; font-size: 0.95rem; }
.site-footer .footer-nav a { color: #fafaff; text-decoration: none; font-weight: 500; padding: .15rem 0; transition: color .2s ease; white-space: nowrap; }
.site-footer .footer-nav a:hover { color: #e4d9ff; }
header { border-bottom: 1px solid var(--color-border); padding: var(--space-md) 0; position: relative; width: 100%; background: transparent; box-shadow: 0 6px 18px rgba(15,23,42,0.06); transition: box-shadow .18s ease; }

@media (max-width: 700px) {
  .site-footer .footer-inner { flex-direction: column; align-items: stretch; }
  .site-footer .footer-nav { width: 100%; justify-content: flex-start; }
}

@keyframes shimmer {
  to { transform: translateX(100%); }
}
.brand { font-weight: 700; letter-spacing: .04em; text-transform: uppercase; color: var(--color-primary); line-height: 1; }

.header-inner { display: flex; align-items: center; justify-content: space-between; gap: 1rem; min-height: 42px; }
.nav-list { display: flex; gap: .75rem; list-style: none; margin: 0; padding: 0; align-items: center; }
.nav-list li { display: flex; }
.nav-list a { color: var(--color-text); text-decoration: none; padding: .7rem .95rem; border-radius: 6px; font-weight: 600; line-height: 1; display: inline-flex; align-items: center; transition: background .2s ease, transform .2s ease, color .2s ease; }
.nav-list a:hover, .nav-list a:focus { background: var(--color-muted-bg); outline: none; transform: translateY(-1px); }

.menu-toggle { display: none; appearance: none; background: transparent; border: 1px solid transparent; width: 56px; height: 56px; border-radius: 18px; cursor: pointer; align-items: center; justify-content: center; padding: 0; margin-left: auto; transition: background .2s ease; }
.menu-toggle svg { width: 28px; height: 28px; color: var(--color-text); }
.menu-toggle:hover, .menu-toggle:focus { background: rgba(11,114,133,.08); outline: none; }

.mobile-menu { position: fixed; inset: 0; z-index: 2000; display: flex; align-items: center; justify-content: center; padding: 2rem 1.25rem; background: rgba(15,23,42,0.95); color: #fff; opacity: 0; visibility: hidden; pointer-events: none; transition: opacity .25s ease, visibility .25s ease; }
.mobile-menu.mobile-menu-open { opacity: 1; visibility: visible; pointer-events: auto; }
.mobile-menu-panel { position: relative; width: min(100%, 520px); max-width: 100%; text-align: center; padding-top: 3rem; }
.mobile-menu-close { position: absolute; top: 1.25rem; right: 1.25rem; width: 44px; height: 44px; border: none; background: rgba(255,255,255,.12); color: #fff; border-radius: 50%; display: grid; place-items: center; cursor: pointer; transition: transform .2s ease, background .2s ease; }
.mobile-menu-close svg { width: 20px; height: 20px; }
.mobile-menu-close:hover, .mobile-menu-close:focus { background: rgba(255,255,255,.2); outline: none; }

body.mobile-menu-active { overflow: hidden; }

.mobile-nav-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 1.5rem; }
.mobile-nav-list a { display: inline-block; color: #fff; text-decoration: none; font-size: clamp(1.35rem, 4vw, 1.75rem); font-weight: 700; padding: .35rem .5rem; transition: color .2s ease; }
.mobile-nav-list a:hover, .mobile-nav-list a:focus { color: var(--color-primary); }

@media (max-width: 900px) {
  :root {
    --header-offset: 105px;
  }
  .nav-list { display: none; }
  .menu-toggle { display: inline-flex; }
}

@media (max-width: 500px) {
  .mobile-menu { padding: 1.5rem 1rem; }
  .mobile-menu-close { top: .75rem; right: .75rem; }
  .mobile-nav-list { gap: 1.25rem; }
}

.hero { padding: clamp(2rem, 6vw, 5rem) 0; background: linear-gradient(180deg, var(--color-surface) 0%, rgba(228,217,255,0.25) 100%); }
.hero p { max-width: 70ch; }

.button, .btn { display: inline-block; padding: .75rem 1.15rem; text-decoration: none; font-weight: 600; border-radius: 6px; transition: transform .08s ease, box-shadow .12s ease, background .2s ease, color .2s ease; }
.button.primary, .btn--primary, .button.primary:link, .button.primary:visited { background: var(--color-primary); color: var(--color-primary-contrast); border: 1px solid transparent; }
.button.secondary, .btn--outline { background: #fafaff; color: var(--color-accent); border: 1px solid rgba(39,52,105,0.16); box-shadow: 0 4px 12px rgba(39,52,105,0.06); }
.button.secondary:hover, .btn--outline:hover { background: rgba(228,217,255,0.35); }
.button:focus-visible, .btn:focus-visible { outline: 3px solid color-mix(in srgb, var(--color-primary) 20%, transparent); outline-offset: 2px; }
.button:hover, .btn:hover { transform: translateY(-1px); }

section { padding: var(--space-lg) 0; background: var(--color-surface); }
section + section { border-top: 1px solid var(--color-border); }

.grid { display: grid; gap: 1.5rem; margin-top: 1.5rem; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.grid-three { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.grid-two { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.card { background: var(--color-surface); border: 1px solid var(--color-border); padding: 1.15rem; border-radius: var(--radius); box-shadow: var(--shadow-sm); }
.card p { color: var(--color-muted); margin: .5rem 0 0 0; }

.highlight { background: var(--color-muted-bg); border: 1px solid rgba(228,217,255,0.7); }
.two-column { display: grid; gap: 2rem; grid-template-columns: 1fr 1fr; }

.contact-box { max-width: 700px; }
.image-responsive { width: 100%; height: auto; border-radius: 6px; }
.muted { color: var(--color-muted); }
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

a { color: var(--color-primary); text-decoration: none; }

:focus { outline: none; }

@media (max-width: 800px) {
  .two-column { grid-template-columns: 1fr; }
  body { font-size: 17px; }
}

.button.primary { background: var(--color-primary); color: var(--color-primary-contrast); }
.button.secondary { background: #fafaff; color: var(--color-accent); border: 1px solid rgba(39,52,105,0.16); }

.divider { height: 1px; background: var(--color-border); width: 100%; }

