    html, body { background:transparent; color:#fff;  scroll-behavior:smooth;}
    body { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; background:transparent; }
    #app, nav, main, header, .hero { position: relative; z-index: 10; }
    #flow-bg{ position:fixed; inset:0; width:100vw; height:100vh; z-index:0; pointer-events:none; background:#070b14; }
    .glass{
      background:linear-gradient(180deg,rgba(255,255,255,.06),rgba(255,255,255,.02));
      border:1px solid rgba(255,255,255,.08);
      backdrop-filter:blur(8px);
    }
    /* Loader */
    .loader{position:fixed; inset:0; background:#070b14; color:#fff; z-index:9999;
      --loader-letter-duration:1400ms;
      --loader-letter-stagger:320ms;
      --loader-letter-count:4;
      --loader-progress-duration:3200ms;}
    .loader .glow{position:absolute; inset:-80px;
      background:
        radial-gradient(60% 60% at 20% 20%, rgba(0,51,160,.35), transparent 60%),
        radial-gradient(60% 60% at 80% 80%, rgba(214,40,40,.35), transparent 60%);
      filter:blur(42px)}
    .loader .center{position:absolute; inset:0; display:grid; place-items:center}
    .loader .letters{display:flex;}
    .loader .letter{font:800 clamp(42px,8vw,96px)/1 "Inter",system-ui; letter-spacing:.06em;
      opacity:0; transform:translateY(24px) scale(.92); filter:blur(12px); display:inline-block; margin:0 .08em;}
    .loader .letter.is-active{
      animation:loader-letter var(--loader-letter-duration) cubic-bezier(.22,.7,.18,1) forwards;
      animation-play-state:paused;
    }
    .loader.play .letter.is-active{animation-play-state:running;}
    .loader .sub{position:absolute; top:58%; opacity:.8; margin:0}
    .loader .bar{position:absolute; bottom:42px; width:min(520px,60vw); height:3px; background:#ffffff1a; border-radius:2px; overflow:hidden}
    .loader .fill{height:100%; width:0; background:linear-gradient(90deg,#0033A0,#D62828); transition:width .28s cubic-bezier(.33,.99,.48,1); will-change:width;}
    .loader .fill.is-active{opacity:1;}
    .loader.play .fill.is-active{transition:width .28s cubic-bezier(.33,.99,.48,1);}
    .loader #skip{position:absolute; bottom:14px; font-size:12px; color:#ffffffa0; background:none; border:0}


    /* Geometric hero frame */
    #geom-wrap{ position:relative; }
    #geom-wrap::after{
      content:""; position:absolute; inset:-28px; z-index:-1; border-radius:28px;
      background:
        radial-gradient(1000px 600px at 12% 8%, rgba(0,51,160,.22), transparent 60%),
        radial-gradient(1000px 600px at 88% 92%, rgba(214,40,40,.18), transparent 60%);
      filter: blur(28px);
    }
    #geom{ will-change: transform; }
    .sat path.main { stroke-dasharray: 24 12; }
    .sat path.glow { opacity:.45; }

    @media (prefers-reduced-motion: reduce){
      #geom { transition:none !important }
      .loader .letter{animation:none !important; opacity:1; transform:none; filter:none; text-shadow:none}
      .loader .fill{width:100%}
    }
	
	#flow-bg{
  position: fixed;
  inset: 0;
  z-index: 0;
  display: block;
}
/* Smooth loader fade-out */
.loader{transition:opacity .5s ease;}
.loader.hide{opacity:0;pointer-events:none;}

@keyframes loader-letter{
  0%{opacity:0; transform:translateY(24px) scale(.92); filter:blur(12px); text-shadow:none;}
  55%{opacity:1; transform:translateY(0) scale(1.14); filter:blur(0); text-shadow:0 0 12px rgba(255,255,255,.75),0 0 24px rgba(0,51,160,.62),0 0 38px rgba(214,40,40,.48);}
  72%{transform:translateY(0) scale(1.05); text-shadow:0 0 12px rgba(255,255,255,.58),0 0 24px rgba(0,51,160,.42);}
  100%{opacity:1; transform:translateY(0) scale(1); filter:blur(0); text-shadow:0 0 8px rgba(255,255,255,.25);}
}

/* === Background + hero shapes layers === */
#bg-fluid { pointer-events: none; }
.hero-shapes .hs-spin-slower { animation: hs-spin-slow 28s linear infinite; }
.hero-shapes .hs-spin       { animation: hs-spin 16s linear infinite; }
.hero-shapes .hs-orbit-slow { animation: hs-orbit-slow 42s linear infinite; }
.hero-shapes .hs-orbit-mid  { animation: hs-orbit 32s linear infinite reverse; }
.hero-shapes .hs-drift      { animation: hs-drift 10s ease-in-out infinite; }
@keyframes hs-spin-slow { to { transform: rotate(360deg); } }
@keyframes hs-spin      { to { transform: rotate(360deg); } }
@keyframes hs-orbit {
  0% { transform: translate(0,0) rotate(0deg); }
  50%{ transform: translate(8px,-6px) rotate(180deg); }
  100%{ transform: translate(0,0) rotate(360deg); }
}
@keyframes hs-orbit-slow {
  0% { transform: translate(0,0) rotate(0deg); }
  50%{ transform: translate(-10px,8px) rotate(180deg); }
  100%{ transform: translate(0,0) rotate(360deg); }
}
@keyframes hs-drift {
  0% { transform: translate(0,0); opacity: .8; }
  50%{ transform: translate(-6px,4px); opacity: .95; }
  100%{ transform: translate(0,0); opacity: .8; }
}
@media (prefers-reduced-motion: reduce) {
  #bg-fluid animate { display: none !important; }
  .hero-shapes * { animation: none !important; }
}


/* === Background + hero shapes layers === */
#bg-fluid { pointer-events: none; }
#app, header, main, footer, .hero, nav { position: relative; z-index: 10; }
#fnhp-loader { position: fixed; inset: 0; z-index: 50; }
.loader { opacity: 1; transition: opacity .5s ease; }
.loader.hide { opacity: 0; pointer-events: none; }

.hero-shapes .hs-spin-slower { animation: hs-spin-slow 28s linear infinite; }
.hero-shapes .hs-spin       { animation: hs-spin 16s linear infinite; }
.hero-shapes .hs-orbit-slow { animation: hs-orbit-slow 42s linear infinite; }
.hero-shapes .hs-orbit-mid  { animation: hs-orbit 32s linear infinite reverse; }
.hero-shapes .hs-drift      { animation: hs-drift 10s ease-in-out infinite; }

@keyframes hs-spin-slow { to { transform: rotate(360deg); } }
@keyframes hs-spin      { to { transform: rotate(360deg); } }
@keyframes hs-orbit {
  0% { transform: translate(0,0) rotate(0deg); }
  50%{ transform: translate(8px,-6px) rotate(180deg); }
  100%{ transform: translate(0,0) rotate(360deg); }
}
@keyframes hs-orbit-slow {
  0% { transform: translate(0,0) rotate(0deg); }
  50%{ transform: translate(-10px,8px) rotate(180deg); }
  100%{ transform: translate(0,0) rotate(360deg); }
}
@keyframes hs-drift {
  0% { transform: translate(0,0); opacity: .8; }
  50%{ transform: translate(-6px,4px); opacity: .95; }
  100%{ transform: translate(0,0); opacity: .8; }
}

@media (prefers-reduced-motion: reduce) {
  #bg-fluid animate { display: none !important; }
  .hero-shapes * { animation: none !important; }
}

.site-header {
  position: sticky;
  top: 0;
  left: 0;
  right: 0;
  width: 100%;
  z-index: 30;
  background: rgba(7, 11, 20, 0.55);
  backdrop-filter: blur(12px);
  box-shadow: 0 14px 40px rgba(7, 11, 20, 0.28);
  transition: background-color .3s ease, box-shadow .3s ease, backdrop-filter .3s ease;
}

.site-header.is-scrolled {
  background: rgba(0, 0, 0, 0.88);
  box-shadow: 0 18px 48px rgba(0, 0, 0, 0.45);
}

.site-nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1.5rem;
  transition: padding .3s ease;
}

/* Project detail progress bar */
.project-progress {
  position: relative;
  width: 100%;
  height: 14px;
  border-radius: 9999px;
  background: rgba(255, 255, 255, 0.08);
  overflow: hidden;
}

.project-progress .progress-fill {
  position: absolute;
  inset: 0;
  width: 0;
  background: linear-gradient(90deg, rgba(0, 51, 160, 0.95), rgba(14, 165, 233, 0.95));
  border-radius: inherit;
  animation: project-progress-fill 1.6s cubic-bezier(0.33, 1, 0.68, 1) forwards;
}

@keyframes project-progress-fill {
  from {
    width: 0%;
  }
  to {
    width: var(--progress, 100%);
  }
}

@media (prefers-reduced-motion: reduce) {
  .project-progress .progress-fill {
    animation: none !important;
    width: var(--progress, 100%);
  }
}

.site-header.is-scrolled .site-nav {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.site-nav .brand {
  display: inline-flex;
  align-items: center;
  gap: .75rem;
  color: inherit;
  text-decoration: none;
  font-size: 1.125rem;
  font-weight: 600;
  letter-spacing: .08em;
}

.site-nav .brand-mark {
  width: 2.25rem;
  height: 2.25rem;
  border-radius: .9rem;
  overflow: hidden;
  background: rgba(255,255,255,.08);
  box-shadow: 0 12px 32px rgba(0,0,0,.4);
}

.site-nav .brand-mark img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.site-nav .brand-label {
  display: inline-block;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
}

.nav-toggle {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: .35rem;
  width: 2.75rem;
  height: 2.75rem;
  border-radius: .9rem;
  background: rgba(255,255,255,.08);
  border: 1px solid rgba(255,255,255,.12);
  cursor: pointer;
  transition: background .2s ease, border-color .2s ease;
}

.nav-toggle:hover,
.nav-toggle:focus-visible {
  outline: none;
  background: rgba(255,255,255,.14);
  border-color: rgba(255,255,255,.24);
}

.nav-toggle-bar {
  display: block;
  height: 2px;
  width: 1.25rem;
  margin: 0 auto;
  border-radius: 999px;
  background: #fff;
}

.nav-menu {
  position: absolute;
  top: 100%;
  left: 1.5rem;
  right: 1.5rem;
  margin-top: 1rem;
  padding: 1.25rem;
  border-radius: 1.25rem;
  backdrop-filter: blur(18px);
  background: rgba(7,11,20,.92);
  border: 1px solid rgba(255,255,255,.08);
  box-shadow: 0 24px 64px rgba(0,0,0,.45);
  display: none;
  flex-direction: column;
  gap: 1rem;
  z-index: 30;
}

.nav-menu.is-open {
  display: flex;
}

.nav-links {
  display: flex;
  flex-direction: column;
  gap: .75rem;
}

.nav-links a {
  color: rgba(255,255,255,.82);
  text-decoration: none;
  font-weight: 500;
  transition: color .2s ease;
}

.nav-links a:hover,
.nav-links a:focus-visible {
  color: #fff;
  outline: none;
}

.nav-divider {
  width: 100%;
  height: 1px;
  background: rgba(255,255,255,.08);
}

.nav-languages {
  display: flex;
  gap: .5rem;
}

.nav-languages .lang {
  padding: .35rem .75rem;
  border-radius: .75rem;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.1);
  color: rgba(255,255,255,.86);
  font-size: .85rem;
  cursor: pointer;
  transition: background .2s ease, color .2s ease, border-color .2s ease;
}

.nav-languages .lang:hover,
.nav-languages .lang:focus-visible {
  background: rgba(255,255,255,.16);
  border-color: rgba(255,255,255,.22);
  color: #fff;
  outline: none;
}

.lang[aria-pressed="true"],
.lang.is-active {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
}

body.nav-open {
  overflow: hidden;
}

@media (min-width: 768px) {
  .nav-toggle {
    display: none;
  }

  .nav-menu {
    position: static;
    display: flex !important;
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
    padding: 0;
    margin-top: 0;
    background: transparent;
    border: 0;
    box-shadow: none;
    backdrop-filter: none;
  }

  .nav-links {
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
  }

  .nav-divider {
    width: 1px;
    height: 1.5rem;
    background: rgba(255,255,255,.18);
  }

  .nav-languages {
    align-items: center;
  }
}

/* === Responsive adjustments across breakpoints === */
:root {
  --layout-radius-lg: 1.35rem;
  --layout-radius-md: 1rem;
  --layout-radius-sm: 0.875rem;
}

@media (max-width: 1023px) {
  .site-nav {
    gap: 1rem;
  }

  .site-nav .brand-label {
    font-size: clamp(1rem, 2.4vw, 1.125rem);
  }

  .glass.p-12,
  .glass.p-10 {
    padding: 2rem;
  }

  .glass.p-8,
  .glass.p-6 {
    padding: 1.75rem;
  }
}

@media (max-width: 767px) {
  .site-nav {
    padding-inline: 1.5rem;
  }

  .nav-menu {
    left: 1rem;
    right: 1rem;
  }

  .nav-menu .nav-links {
    gap: 0.65rem;
  }

  .nav-menu .nav-languages {
    flex-wrap: wrap;
  }

  .rounded-3xl {
    border-radius: var(--layout-radius-lg);
  }

  .rounded-2xl {
    border-radius: var(--layout-radius-md);
  }

  .rounded-xl {
    border-radius: var(--layout-radius-sm);
  }

  .pb-24 {
    padding-bottom: 4.5rem;
  }

  .pb-20 {
    padding-bottom: 4rem;
  }

  .pt-16,
  .pt-14 {
    padding-top: 3.5rem;
  }

  .py-24 {
    padding-top: 4.5rem;
    padding-bottom: 4.5rem;
  }
}

@media (max-width: 639px) {
  .site-nav {
    padding-inline: 1.25rem;
    padding-top: 1.25rem;
    padding-bottom: 1.25rem;
    flex-wrap: wrap;
  }

  .site-nav .brand {
    font-size: 1rem;
    gap: 0.6rem;
  }

  .site-nav .brand-mark {
    width: 2rem;
    height: 2rem;
    border-radius: 0.75rem;
  }

  .nav-toggle {
    width: 2.5rem;
    height: 2.5rem;
  }

  .nav-menu {
    padding: 1rem 1rem 1.25rem;
    align-items: stretch;
    gap: 0.85rem;
  }

  .nav-divider {
    display: none;
  }

  #contact .flex-wrap {
    flex-direction: column;
    align-items: stretch;
  }

  #contact .flex-wrap > a {
    width: 100%;
    justify-content: center;
  }

  footer > div.flex {
    flex-direction: column;
    align-items: flex-start;
    gap: 1.25rem;
  }

  footer > div.flex > div.flex {
    width: 100%;
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 0.75rem;
  }

  h1 {
    font-size: clamp(2.25rem, 9vw, 3.25rem);
    line-height: 1.15;
  }

  h2 {
    font-size: clamp(1.5rem, 5.8vw, 2.25rem);
  }

  h3 {
    font-size: clamp(1.25rem, 4.8vw, 1.75rem);
  }

  .glass.p-12,
  .glass.p-10 {
    padding: 1.75rem;
  }

  .glass.p-8,
  .glass.p-6 {
    padding: 1.5rem;
  }

  .min-h-\[260px\] {
    min-height: 220px;
  }

  .min-h-\[180px\] {
    min-height: 150px;
  }

  #overview .grid,
  #features .grid,
  #story .grid,
  #progress .grid,
  #contact .grid,
  #about .grid,
  #projects .grid,
  #philosophy .grid {
    gap: 1.75rem;
  }
}

[data-carousel] .carousel-indicator {
  width: 0.65rem;
  height: 0.65rem;
  border-radius: 9999px;
  background: rgba(255, 255, 255, 0.35);
  border: 1px solid rgba(255, 255, 255, 0.45);
  opacity: 0.6;
  transition: opacity 0.2s ease, transform 0.2s ease, background-color 0.2s ease, border-color 0.2s ease;
}

[data-carousel] .carousel-indicator.is-active {
  opacity: 1;
  background: rgba(255, 255, 255, 0.95);
  border-color: rgba(255, 255, 255, 0.95);
  transform: scale(1.1);
}

[data-carousel] .carousel-indicator:focus-visible {
  outline: 2px solid rgba(255, 255, 255, 0.8);
  outline-offset: 2px;
}
