:root {
  font-size: 16px;
  color-scheme: light;
}
html,body {
  height: 100%;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
body {
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, "Helvetica Neue", Arial;
  background-color: #f8fafc;
  color: #0f172a;
  line-height: 1.6;
  font-size: 1rem;
}
.container { max-width: 1200px; }
img { max-width: 100%; height: auto; display: block; object-fit: cover; }
.iconify { display: inline-block; vertical-align: middle; height: 1em; width: 1em; }
a { color: inherit; text-decoration: none; }
:focus { outline: none; }
:focus-visible { box-shadow: 0 0 0 4px rgba(59,130,246,0.15); border-radius: 8px; }
button:focus-visible, a:focus-visible { box-shadow: 0 0 0 4px rgba(59,130,246,0.15); }
.cookie-hidden { display: none !important; }
.no-scroll { height: 100vh; overflow: hidden; }
#mobileMenu { transition: opacity .28s ease, transform .32s ease; }
#mobileMenu[aria-hidden="false"] { display: block; }
#mobileOverlay { transition: opacity .28s ease; }
.lazy { opacity: 0; transform: translateY(8px); transition: opacity .6s ease, transform .6s ease; }
.lazy.loaded { opacity: 1; transform: translateY(0); }
.rounded-2xl { border-radius: 1rem; }
.shadow-md { box-shadow: 0 6px 18px rgba(15, 23, 42, 0.06); }
.shadow-lg { box-shadow: 0 20px 40px rgba(2,6,23,0.08); }
.btn-focus { transition: transform .18s ease, box-shadow .18s ease; }
.btn-focus:active { transform: translateY(1px); }
.card-hover { transition: transform .25s cubic-bezier(.2,.8,.2,1), box-shadow .25s ease; }
.card-hover:hover, .card-hover:focus-within { transform: translateY(-6px); }
@media (prefers-reduced-motion: reduce) {
  .lazy, #mobileMenu, #mobileOverlay, .card-hover, .btn-focus { transition: none !important; animation: none !important; }
}
@media (max-width: 768px) {
  .cookie-fixed { right: 1rem; left: auto; bottom: 1rem; width: calc(100% - 2rem); }
}
