*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; font-size: 16px; }

body {
  font-family: var(--font-body);
  background: var(--navy);
  color: var(--text);
  min-height: 100vh;
  overflow-x: hidden;
  line-height: 1.6;
}

body::before {
  content: '';
  position: fixed; inset: 0; z-index: 0;
  background:
    radial-gradient(ellipse 80% 60% at 10% 0%,   rgba(239,132,63,0.12) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 90% 100%,  rgba(239,132,63,0.08) 0%, transparent 55%),
    radial-gradient(ellipse 100% 50% at 50% 50%,  rgba(28,30,82,0.6)   0%, transparent 100%);
  pointer-events: none;
}

.container {
  max-width: var(--container);
  margin: 0 auto;
  padding: 0 clamp(1.25rem, 4vw, 2.5rem);
  position: relative;
  z-index: 1;
}

img  { max-width: 100%; height: auto; display: block; }
a    { text-decoration: none; color: inherit; }
ul   { list-style: none; }

::selection { background: rgba(239,132,63,0.3); color: #fff; }

::-webkit-scrollbar        { width: 6px; }
::-webkit-scrollbar-track  { background: var(--navy3); }
::-webkit-scrollbar-thumb  { background: var(--navy2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: rgba(239,132,63,0.5); }

/* Animations */
@keyframes fadeUp   { from { opacity:0; transform:translateY(32px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn   { from { opacity:0; } to { opacity:1; } }
@keyframes float    { 0%,100% { transform:translateY(0); } 50% { transform:translateY(-14px); } }
@keyframes pulse    { 0%,100% { opacity:1; } 50% { opacity:0.4; } }
@keyframes spin     { to { transform:rotate(360deg); } }
@keyframes pulse-ring { 0% { transform:scale(1); opacity:0.8; } 100% { transform:scale(1.6); opacity:0; } }
@keyframes shimmer  { 0% { transform:translateX(-100%); } 100% { transform:translateX(200%); } }
@keyframes slide-r  { from { opacity:0; transform:translateX(24px); } to { opacity:1; transform:translateX(0); } }

/* Scroll reveal */
.reveal {
  opacity: 0;
  transform: translateY(40px);
  transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal.visible { opacity: 1; transform: translateY(0); }
.reveal-d1 { transition-delay: 0.1s; }
.reveal-d2 { transition-delay: 0.2s; }
.reveal-d3 { transition-delay: 0.3s; }
.reveal-d4 { transition-delay: 0.4s; }
.reveal-d5 { transition-delay: 0.5s; }
.reveal-d6 { transition-delay: 0.6s; }
