/* styles.css */
:root{
  --accent:#062649;
  --bg:#f5f7fb;
  --ink:#0b0f17;
  --muted:rgba(11,15,23,.62);
  --line:rgba(10,18,32,.10);
  --glass:rgba(255,255,255,.72);
  --ease:cubic-bezier(.2,.8,.2,1);
  --max:1200px;

  --shadow: 0 30px 80px rgba(10,18,32,.08);
  --shadow2: 0 18px 55px rgba(10,18,32,.10);
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Inter, Arial;
  color:var(--ink);
  background:var(--bg);
  overflow-x:hidden;
}

a{ color:inherit; text-decoration:none; }
img{ display:block; max-width:100%; }

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

.muted{ color:var(--muted); }
.link{
  color:var(--accent);
  background-image: linear-gradient(transparent, transparent), linear-gradient(var(--accent), var(--accent));
  background-size: 0% 1px, 100% 1px;
  background-position: 0 100%, 0 100%;
  background-repeat: no-repeat;
  transition: background-size .5s var(--ease);
}
.link:hover{ background-size:100% 1px, 100% 1px; }

/* -----------------------
   Global luxury background
------------------------ */
.bg{
  position:fixed;
  inset:0;
  z-index:-2;
  pointer-events:none;
}

.bg__base{
  position:absolute;
  inset:0;
  background: radial-gradient(circle at 30% 10%, rgba(6,38,73,.06), transparent 55%),
              radial-gradient(circle at 80% 25%, rgba(6,38,73,.05), transparent 55%),
              linear-gradient(to bottom, rgba(10,18,32,.03), transparent 40%);
}

.bg__grid{
  position:absolute;
  inset:-20%;
  background-image:
    linear-gradient(rgba(10,18,32,.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(10,18,32,.06) 1px, transparent 1px);
  background-size: 140px 140px;
  opacity:.06;
  transform: translate3d(0,0,0);
}

.bg__noise{
  position:absolute;
  inset:0;
  opacity:.06;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='400' height='400'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.7' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='400' height='400' filter='url(%23n)' opacity='.45'/%3E%3C/svg%3E");
  background-size: 260px 260px;
}

.bg__spot{
  position:absolute;
  inset: 0;
  background: radial-gradient(
    circle 260px at var(--cx, 50%) var(--cy, 20%),
    rgba(6,38,73,.10),
    transparent 100%
  );
  opacity: .6;
  pointer-events:none;
}

/* beams (JS moves the spans; ::before animates internal shimmer) */
.beams{ position:absolute; inset:-20%; }
.beam{
  position:absolute;
  width: 160%;
  height: 140%;
  filter: blur(52px);
  opacity:.50;
  will-change: transform;
}
.beam::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(6,38,73,.06) 42%,
    rgba(6,38,73,.14) 50%,
    rgba(6,38,73,.06) 58%,
    transparent 100%);
  animation: beamShine 28s linear infinite;
}
@keyframes beamShine{
  0%{ transform: translateX(-28%); }
  100%{ transform: translateX(28%); }
}
.beam--1{ top:-40%; left:-40%; opacity:.55; }
.beam--2{ top:-15%; left:-55%; opacity:.40; }
.beam--3{ top:10%;  left:-50%; opacity:.35; }
.beam--4{ top:35%;  left:-45%; opacity:.25; }
.beam--1::before{ animation-duration: 42s; }
.beam--2::before{ animation-duration: 58s; }
.beam--3::before{ animation-duration: 70s; }
.beam--4::before{ animation-duration: 88s; }

/* -----------------------
   Header / Nav
------------------------ */
.header{
  position:sticky;
  top:0;
  z-index:50;
  background: rgba(245,247,251,.70);
  backdrop-filter: blur(6px);
  border-bottom: 1px solid rgba(10,18,32,.08);
}
.header__inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 18px 0;
}
.logo{
  height: 46px;
  width:auto;
  max-width:none;
}

.nav{
  position:relative;
  display:flex;
  align-items:center;
  gap: 22px;
}
.nav__link{
  font-size: 14px;
  color: rgba(11,15,23,.70);
  padding: 8px 10px;
  border-radius: 999px;
  transition: background .35s var(--ease), color .35s var(--ease);
}
.nav__link:hover{
  background: rgba(10,18,32,.05);
  color: rgba(11,15,23,.92);
}
.nav__indicator{
  position:absolute;
  bottom:-6px;
  left:0;
  width: 18px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent);
  opacity:.9;
  transform: translateX(0);
  transition: transform .55s var(--ease), width .55s var(--ease), opacity .25s var(--ease);
  pointer-events:none;
}

.menu{
  display:none;
  width:42px;
  height:42px;
  border-radius: 12px;
  border:1px solid rgba(10,18,32,.10);
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(6px);
}
.menu__bar{
  display:block;
  width:18px;
  height:2px;
  background: rgba(11,15,23,.85);
  margin: 6px auto;
  border-radius:999px;
}

.drawer{
  display:none;
  border-top: 1px solid rgba(10,18,32,.08);
  background: rgba(245,247,251,.78);
  backdrop-filter: blur(6px);
}
.drawer[data-open="true"]{ display:block; }
.drawer__inner{
  padding: 16px 0 22px 0;
  display:flex;
  flex-direction:column;
  gap:10px;
}
.drawer__link{
  padding: 12px 12px;
  border-radius: 14px;
  border:1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.55);
}

/* -----------------------
   Buttons
------------------------ */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 12px 16px;
  border-radius: 999px;
  border:1px solid var(--line);
  font-weight: 560;
  letter-spacing: -0.01em;
  transition: transform .35s var(--ease), box-shadow .35s var(--ease), background .35s var(--ease), border-color .35s var(--ease);
  will-change: transform;
}
.btn:active{ transform: translateY(1px) scale(.99); }
.btn--primary{
  background: var(--ink);
  color:#fff;
  border-color: rgba(0,0,0,.10);
  box-shadow: 0 16px 40px rgba(0,0,0,.16);
}
.btn--primary:hover{ transform: translateY(-1px); box-shadow: 0 22px 55px rgba(0,0,0,.18); }
.btn--ghost{
  background: rgba(255,255,255,.65);
  backdrop-filter: blur(6px);
}
.btn--ghost:hover{
  transform: translateY(-1px);
  box-shadow: 0 18px 50px rgba(10,18,32,.10);
  border-color: rgba(10,18,32,.18);
}

/* -----------------------
   Typography / layout blocks
------------------------ */
.h1{
  margin: 14px 0 0 0;
  font-size: clamp(46px, 5.2vw, 72px);
  line-height: 1.02;
  letter-spacing: -0.045em;
}
.h2{
  margin:0;
  font-size: 30px;
  letter-spacing: -0.03em;
}
.lead{
  margin: 18px 0 0 0;
  font-size: 18px;
  line-height: 1.7;
  color: rgba(11,15,23,.68);
  max-width: 62ch;
}
.sub{
  margin:0;
  color: rgba(11,15,23,.62);
  max-width: 70ch;
  line-height: 1.7;
}

.eyebrow{
  display:flex;
  align-items:center;
  gap:10px;
  font-size: 12px;
  color: rgba(11,15,23,.60);
  letter-spacing: .10em;
  text-transform: uppercase;
}
.dot{
  width:8px; height:8px; border-radius:999px;
  background: var(--accent);
  box-shadow: 0 0 0 6px rgba(6,38,73,.10);
}

/* -----------------------
   Hero
------------------------ */
.hero{
  padding: 90px 0 0 0;
}
.hero__inner{
  padding: 72px 0 44px 0;
  display:grid;
  grid-template-columns: 1.15fr .85fr;
  gap: 42px;
  align-items:start;
}
.hero__meta{
  margin-top: 28px;
  display:grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 14px;
}
.meta{
  padding: 14px 14px;
  border-radius: 18px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.55);
  backdrop-filter: blur(6px);
}
.meta__k{
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(11,15,23,.52);
}
.meta__v{
  margin-top: 6px;
  font-weight: 620;
  color: rgba(11,15,23,.82);
}

.panel{
  border-radius: 28px;
  border: 1px solid rgba(10,18,32,.10);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  box-shadow: var(--shadow);
  overflow:hidden;
}
.panel__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 16px 18px;
  border-bottom: 1px solid rgba(10,18,32,.08);
}
.pill{
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  background: rgba(10,18,32,.04);
  border: 1px solid rgba(10,18,32,.08);
  color: rgba(11,15,23,.70);
}
.badge{
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(6,38,73,.18);
  color: var(--accent);
  background: rgba(6,38,73,.05);
}
.panel__body{
  padding: 18px 18px 16px 18px;
}
.row{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
  padding: 10px 2px;
}
.row__k{ font-size: 12px; color: rgba(11,15,23,.55); letter-spacing:.06em; text-transform: uppercase; }
.row__v{ font-weight: 720; letter-spacing: -0.02em; }

.divider{
  height: 1px;
  background: rgba(10,18,32,.08);
  margin: 12px 0;
}
.microgrid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.micro{
  padding: 12px 12px;
  border-radius: 18px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.55);
}
.micro__k{
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(11,15,23,.52);
}
.micro__v{
  margin-top: 6px;
  font-weight: 650;
}

.panel__bottom{
  padding: 14px 18px 18px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-top: 1px solid rgba(10,18,32,.08);
}
.accentline{
  width: 44px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent);
  opacity: .9;
}

/* rail */
.hero__rail{
  padding: 14px 0 0 0;
}
.rail{
  display:flex;
  align-items:center;
  justify-content:center;
  gap: 16px;
  padding: 14px 16px;
  border-radius: 999px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.52);
  backdrop-filter: blur(6px);
}
.rail__item{ font-size: 13px; color: rgba(11,15,23,.72); }
.rail__sep{ width: 1px; height: 14px; background: rgba(10,18,32,.14); }

/* -----------------------
   Sections
------------------------ */
.section{ padding: 180px 0; }
.section--soft{
  background: none;
  border: none;
}
.head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap: 28px;
  margin-bottom: 28px;
}

/* Overview */
.overview{
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  gap: 18px;
  align-items:start;
}
.statement{
  padding: 22px;
  border-radius: 28px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.62);
  backdrop-filter: blur(6px);
  box-shadow: 0 10px 34px rgba(10,18,32,.06);
}
.quote{
  margin:0;
  font-size: 22px;
  line-height: 1.45;
  letter-spacing: -0.02em;
  color: rgba(11,15,23,.86);
}
.small{
  margin: 14px 0 0 0;
  color: rgba(11,15,23,.66);
  line-height: 1.75;
}

/* Cards */
.cards{
  display:grid;
  grid-template-columns: 1fr;
  gap: 14px;
}
.card{
  padding: 20px;
  border-radius: 28px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  box-shadow: 0 10px 34px rgba(10,18,32,.06);
  transition: transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.card:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow2);
  border-color: rgba(10,18,32,.14);
}
.card__cap{
  font-size: 11px;
  letter-spacing: .10em;
  text-transform: uppercase;
  color: rgba(11,15,23,.55);
}
.card__title{
  margin-top: 8px;
  font-weight: 760;
  letter-spacing: -0.02em;
}
.card__text{
  margin-top: 10px;
  color: rgba(11,15,23,.66);
  line-height: 1.7;
}
.tags{
  margin-top: 14px;
  display:flex;
  gap: 8px;
  flex-wrap:wrap;
}
.tag{
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.55);
  color: rgba(11,15,23,.70);
}

/* Platform */
.platform{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 18px;
  align-items:start;
}
.steps{
  display:flex;
  flex-direction:column;
  gap: 14px;
}
.step{
  display:flex;
  gap: 14px;
  padding: 18px;
  border-radius: 28px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.66);
  backdrop-filter: blur(6px);
}
.step__n{
  width: 44px;
  height: 44px;
  border-radius: 16px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(6,38,73,.06);
  border: 1px solid rgba(6,38,73,.14);
  color: var(--accent);
  font-weight: 800;
}
.step__t{ font-weight: 760; letter-spacing: -0.02em; }
.step__d{ margin-top: 6px; color: rgba(11,15,23,.66); line-height: 1.7; }

.vault{
  padding: 22px;
  border-radius: 28px;
  border: 1px solid rgba(10,18,32,.10);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  box-shadow: var(--shadow);
}
.vault__top{
  display:flex;
  align-items:baseline;
  justify-content:space-between;
}
.vault__k{ font-size: 11px; letter-spacing:.10em; text-transform: uppercase; color: rgba(11,15,23,.55); }
.vault__v{ font-weight: 820; letter-spacing: -0.02em; }
.vault__mid{
  margin: 18px 0;
  display:flex;
  flex-direction:column;
  gap: 10px;
}
.vault__line{
  height: 10px;
  border-radius: 999px;
  background: rgba(10,18,32,.06);
  border: 1px solid rgba(10,18,32,.06);
}
.vault__bot{
  display:flex;
  gap: 8px;
  flex-wrap:wrap;
}
.vault__pill{
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.55);
}
.note{
  margin-top: 12px;
  padding: 18px;
  border-radius: 22px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.60);
  backdrop-filter: blur(6px);
}
.note__t{ font-size: 11px; letter-spacing:.10em; text-transform: uppercase; color: rgba(11,15,23,.55); }
.note__d{ margin-top: 8px; color: rgba(11,15,23,.66); line-height: 1.7; }

/* Focus grid */
.focusgrid{
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.focuscard{
  padding: 18px;
  border-radius: 24px;
  border: 1px solid rgba(10,18,32,.08);
  background: rgba(255,255,255,.68);
  backdrop-filter: blur(6px);
  transition: transform .45s var(--ease), box-shadow .45s var(--ease), border-color .45s var(--ease);
}
.focuscard:hover{
  transform: translateY(-4px);
  box-shadow: var(--shadow2);
  border-color: rgba(10,18,32,.14);
}
.focuscard__k{
  font-size: 11px;
  letter-spacing:.10em;
  text-transform: uppercase;
  color: rgba(11,15,23,.55);
}
.focuscard__t{
  margin-top: 10px;
  font-weight: 760;
  letter-spacing: -0.02em;
}
.focuscard__d{
  margin-top: 10px;
  color: rgba(11,15,23,.66);
  line-height: 1.7;
}

/* Contact */
.contact{ margin-top: 14px; }
.contact__card{
  padding: 22px;
  border-radius: 28px;
  border: 1px solid rgba(10,18,32,.10);
  background: rgba(255,255,255,.72);
  backdrop-filter: blur(6px);
  box-shadow: var(--shadow);
}
.contact__top{
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.contact__k{
  font-size: 11px;
  letter-spacing:.10em;
  text-transform: uppercase;
  color: rgba(11,15,23,.55);
}
.contact__badge{
  font-size: 12px;
  padding: 7px 10px;
  border-radius: 999px;
  border: 1px solid rgba(6,38,73,.18);
  color: var(--accent);
  background: rgba(6,38,73,.05);
}
.contact__big{
  margin-top: 14px;
  font-size: 26px;
  font-weight: 760;
  letter-spacing: -0.03em;
}
.contact__foot{
  margin-top: 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
}

/* Footer */
.footer{
  margin-top: 34px;
  padding: 22px 0 10px 0;
  display:flex;
  align-items:center;
  gap: 12px;
  border-top: 1px solid rgba(10,18,32,.06);
}
.footer__logo{
  width: 46px;
  height: 46px;
  object-fit: contain;
}

/* No section fades: ensure everything is visible */
.reveal{ opacity: 1 !important; transform: none !important; transition: none !important; }

/* Responsive */
@media (max-width: 980px){
  .hero__inner{ grid-template-columns: 1fr; }
  .hero__meta{ grid-template-columns: 1fr; }
  .overview{ grid-template-columns: 1fr; }
  .platform{ grid-template-columns: 1fr; }
  .focusgrid{ grid-template-columns: 1fr 1fr; }
  .nav{ display:none; }
  .menu{ display:inline-flex; align-items:center; justify-content:center; }
  .container{ width:min(var(--max), calc(100% - 36px)); }
}
@media (max-width: 520px){
  .focusgrid{ grid-template-columns: 1fr; }
  .contact__big{ font-size: 22px; }
  .rail{ flex-wrap: wrap; border-radius: 22px; }
}

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  .beam::before{ animation: none; }
  .bg__spot{ display:none; }
}

/* Responsive */
@media (max-width: 980px){
  .hero__grid{ grid-template-columns: 1fr; }
  .hero__right{ order:-1; }
  .section__head{ grid-template-columns: 1fr; gap: 10px; }
  .cards{ grid-template-columns: 1fr; }
  .split{ grid-template-columns: 1fr; }
  .principles{ grid-template-columns: 1fr 1fr; }
  .contact{ grid-template-columns: 1fr; }
  .nav{ display:none; }
  .menu{ display:inline-flex; align-items:center; justify-content:center; }
}
@media (max-width: 520px){
  .hero{ padding-top: 56px; }
  .hero__meta{ grid-template-columns: 1fr; }
  .trusted{ flex-direction: column; align-items:flex-start; }
  .principles{ grid-template-columns: 1fr; }
}
/* ===== NOVENDAL FINAL PATCH ===== */

/* 1) Correct header logo sizing for .logo (your HTML uses .logo, not .brand__logo) */
.logo{
  height: 46px;
  width: auto;
  max-width: none;
}

/* 2) More "luxury spacing" (your current .section is a bit tight) */
.section{ padding: 120px 0; }
.hero{ padding: 110px 0 40px 0; }

/* 3) Nav indicator (keynote feel) */
.nav{
  position: relative;
}
.nav__indicator{
  position: absolute;
  bottom: -6px;
  left: 0;
  width: 20px;
  height: 2px;
  border-radius: 999px;
  background: var(--accent);
  opacity: .9;
  transform: translateX(0);
  transition: transform .55s var(--ease), width .55s var(--ease), opacity .35s var(--ease);
  pointer-events: none;
}

/* 4) Beam system: move gradient into ::before so JS can transform the beam wrapper safely */
.beam{
  background: transparent;
  filter: blur(44px);
  will-change: transform;
}
.beam::before{
  content:"";
  position:absolute;
  inset:0;
  background: linear-gradient(
    90deg,
    transparent 0%,
    rgba(6,38,73,0.08) 45%,
    rgba(6,38,73,0.14) 50%,
    rgba(6,38,73,0.08) 55%,
    transparent 100%
  );
  transform-origin: center;
  animation: beamMove 40s linear infinite;
}

/* Preserve your durations + opacity */
.beam--1::before{ animation-duration: 55s; }
.beam--2::before{ animation-duration: 70s; }
.beam--3::before{ animation-duration: 90s; }

/* 5) Make reveal feel expensive (faster in, less obvious motion) */
.reveal{
  transform: translateY(10px);
  transition: opacity .8s var(--ease), transform .8s var(--ease);
}

/* 6) Make footer logo match your new HTML */
.footer__logo{
  width: 46px;
  height: 46px;
  object-fit: contain;
}

/* 7) On very large screens: widen layout slightly */
@media (min-width: 1400px){
  :root{ --max: 1240px; }
}
/* Premium cursor spotlight (works with main.js vars --cx/--cy) */
body::before{
  content:"";
  position: fixed;
  inset: -20%;
  pointer-events:none;
  z-index:-1;
  background:
    radial-gradient(circle at var(--cx, 50%) var(--cy, 30%),
      rgba(6,38,73,0.10),
      transparent 55%);
  opacity: .9;
  transition: opacity .2s linear;
}
