html {font-size:16px;box-sizing:border-box;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
*,*::before,*::after {box-sizing:inherit}
body {min-height:100vh;margin:0;font-family:Inter, ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial;line-height:1.45;background-color:#ffffff;color:#0f172a}
img {max-width:100%;height:auto;display:block;object-fit:cover}
.container.mx-auto.max-w-screen-xl.px-4 {max-width:1280px}
:focus {outline: none}
:focus-visible {outline:2px solid rgba(19, 111, 97, 0.16);outline-offset:3px;border-radius:0.5rem}
button, a, input, textarea {transition:all 180ms ease-in-out}
button:disabled, [aria-disabled="true"] {opacity:0.6;cursor:not-allowed;transform:none}
header.sticky {backdrop-filter:blur(6px)}
#mobileMenu {transition:opacity 240ms ease, transform 260ms ease}
#mobileMenu.show {display:block}
#mobileMenu.hidden {display:none}
#mobileOverlay {transition:opacity 240ms ease}
.menu-slide {transform:translateY(6px);opacity:0}
.menu-slide.show {transform:translateY(0);opacity:1}
.iconify {display:inline-flex;vertical-align:middle}
footer a {text-decoration:none}
.address-link {color:inherit}
.cookie-consent {max-width:320px}
@media (max-width:640px) {
  .cookie-consent {right:1rem;left:1rem;width:auto;bottom:1rem}
  .container.mx-auto.max-w-screen-xl.px-4 {padding-left:1rem;padding-right:1rem}
}
@media (prefers-reduced-motion:reduce) {
  * {animation-duration:1ms !important;transition-duration:1ms !important}
}
body.noscroll {overflow:hidden}
a:focus,button:focus,input:focus,textarea:focus {box-shadow:0 0 0 4px rgba(16,185,129,0.07)}
.rounded-2xl {border-radius:1rem}
.rounded-xl {border-radius:0.75rem}
.shadow-lg {box-shadow:0 10px 30px rgba(2,6,23,0.08)}
.shadow-md {box-shadow:0 6px 18px rgba(2,6,23,0.06)}
.text-deepblue-500 {color:#0a4f7d}
.text-deepblue-700 {color:#06385a}
.bg-brand-50 {background-color:#f0f9f7}
.bg-brand-100 {background-color:#e6f4f1}
.bg-brand-200 {background-color:#bfe6dd}
.bg-brand-600 {background:linear-gradient(90deg,#138f6f,#0f7a5d)}
.btn-gradient {background:linear-gradient(90deg,#138f6f,#0a4f7d);color:#ffffff}
@keyframes fadeInUp {from {opacity:0;transform:translateY(6px)} to {opacity:1;transform:none}}
.animate-fadeInUp {animation:fadeInUp 560ms ease both}
.header-logo {display:flex;align-items:center;gap:0.6rem}
.kpi-badge {display:inline-flex;align-items:center;gap:0.5rem;padding:0.35rem 0.6rem;border-radius:9999px;background:rgba(5,48,39,0.04);font-weight:600}
.card-hover {transition:transform 260ms cubic-bezier(.2,.9,.3,1),box-shadow 260ms}
.card-hover:hover {transform:translateY(-6px);box-shadow:0 18px 40px rgba(2,6,23,0.08)}
.tablet-grid {display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media (max-width:1024px) {.tablet-grid {grid-template-columns:1fr}}
.hero-media img {border-radius:12px}
.porfolio-thumb {width:100%;height:72px;object-fit:cover;border-radius:0.6rem}
.focus-ring {box-shadow:0 0 0 4px rgba(19,111,97,0.08);border-radius:0.6rem}
.contact-form input, .contact-form textarea {width:100%;padding:0.75rem;border-radius:0.6rem;border:1px solid #e6eef0}
.contact-form input:focus, .contact-form textarea:focus {border-color:#0a4f7d;box-shadow:0 6px 18px rgba(10,79,125,0.06)}
.modal-backdrop {position:fixed;inset:0;background:rgba(2,6,23,0.45);backdrop-filter:blur(4px)}
.nav-link {font-weight:600}
.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}
