/* ==========================================================================
   Noctua Science Ventures — Design System
   Nocturnal deep-sky theme. Brand: owl-in-cocoon; Noctua = the night owl.
   Palette + type derived from the Noctua brand guidelines.
   ========================================================================== */

:root{
  /* Night / surfaces */
  --night:    #07111c;
  --night-2:  #0b1a29;
  --night-3:  #102438;
  --night-4:  #16314a;
  /* Brand */
  --navy:     #003f5c;
  --blue:     #0077b6;
  --blue-br:  #2ba4e0;   /* brighter blue for text/links on dark */
  --orange:   #f05524;
  --orange-2: #ff7a4d;
  /* Ink / paper (light sections) */
  --ink:      #0c0c0c;
  --paper:    #f4f7fa;
  --paper-2:  #e8eef4;
  /* Text on dark */
  --text:     #e7eef5;
  --muted:    #9db1c4;
  --muted-2:  #6f879c;
  --line:     rgba(255,255,255,.10);
  --line-2:   rgba(255,255,255,.06);

  --maxw: 1200px;
  --gap: clamp(1rem, 2.5vw, 2rem);
  --radius: 16px;
  --radius-sm: 10px;
  --ease: cubic-bezier(.22,.61,.36,1);

  --font-display: "Montserrat", system-ui, sans-serif;
  --font-body: "Roboto", system-ui, -apple-system, sans-serif;
}

/* ---------- Reset ---------- */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-body);
  background:var(--night);
  color:var(--text);
  line-height:1.6;
  font-size:clamp(1rem,.97rem + .2vw,1.075rem);
  letter-spacing:.005em;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
:focus-visible{outline:2px solid var(--blue-br);outline-offset:3px;border-radius:4px}

/* ---------- Type ---------- */
h1,h2,h3,h4{font-family:var(--font-display);font-weight:800;line-height:1.06;letter-spacing:-.02em}
h1{font-size:clamp(2.4rem,1.6rem + 3.6vw,4.6rem);font-weight:900}
h2{font-size:clamp(1.9rem,1.3rem + 2.4vw,3.1rem)}
h3{font-size:clamp(1.3rem,1.1rem + .8vw,1.7rem)}
p{color:var(--muted)}
strong{color:var(--text);font-weight:600}

.eyebrow{
  font-family:var(--font-display);
  font-weight:700;
  font-size:.72rem;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--blue-br);
  display:inline-flex;align-items:center;gap:.6rem;
}
.eyebrow::before{
  content:"";width:26px;height:1px;background:linear-gradient(90deg,var(--orange),transparent);
}
.eyebrow.is-orange{color:var(--orange-2)}

/* ---------- Layout ---------- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:clamp(1.2rem,4vw,2.5rem)}
.section{padding-block:clamp(4rem,3rem + 6vw,7.5rem)}
.section--tight{padding-block:clamp(3rem,2.5rem + 3vw,5rem)}
.section-head{max-width:48rem;margin-bottom:clamp(2rem,1.5rem + 2vw,3.5rem)}
.section-head p{margin-top:1rem;font-size:1.12rem}
.lead{font-size:clamp(1.1rem,1.02rem + .4vw,1.3rem);color:var(--text);line-height:1.6}

/* Light section */
.section--paper{background:var(--paper);color:var(--ink)}
.section--paper h1,.section--paper h2,.section--paper h3{color:var(--ink)}
.section--paper p{color:#41566a}
.section--paper .eyebrow{color:var(--blue)}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.55rem;
  font-family:var(--font-display);font-weight:700;font-size:.95rem;
  letter-spacing:.01em;
  padding:.92em 1.5em;border-radius:999px;
  transition:transform .25s var(--ease),background .25s var(--ease),box-shadow .25s var(--ease),color .25s var(--ease);
  will-change:transform;
}
.btn svg{width:1.05em;height:1.05em;transition:transform .25s var(--ease)}
.btn--primary{background:var(--orange);color:#fff;box-shadow:0 10px 30px -12px rgba(240,85,36,.7)}
.btn--primary:hover{transform:translateY(-2px);box-shadow:0 16px 40px -12px rgba(240,85,36,.85)}
.btn--primary:hover svg{transform:translateX(3px)}
.btn--ghost{background:transparent;color:var(--text);box-shadow:inset 0 0 0 1.5px var(--line)}
.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--blue-br);color:#fff;transform:translateY(-2px)}
.btn--blue{background:var(--blue);color:#fff}
.btn--blue:hover{background:var(--blue-br);transform:translateY(-2px)}
.btn--lg{padding:1.05em 1.9em;font-size:1.02rem}
.btn--on-paper.btn--ghost{box-shadow:inset 0 0 0 1.5px rgba(0,63,92,.25);color:var(--ink)}
.btn--on-paper.btn--ghost:hover{box-shadow:inset 0 0 0 1.5px var(--blue)}

/* ==========================================================================
   Header / Nav
   ========================================================================== */
.site-header{
  position:sticky;top:0;z-index:60;
  backdrop-filter:blur(12px);
  background:rgba(7,17,28,.55);
  border-bottom:1px solid transparent;
  transition:background .3s var(--ease),border-color .3s var(--ease);
}
.site-header.is-scrolled{background:rgba(7,17,28,.92);border-bottom-color:var(--line-2)}
.nav{display:flex;align-items:center;justify-content:space-between;height:74px;gap:1rem}
.nav__logo img{height:40px;width:auto}
.nav__menu{margin-left:auto}
.nav__actions{display:flex;align-items:center;gap:.7rem}
.nav__cta-btn{padding:.7em 1.25em;font-size:.9rem}
.nav__links{display:flex;align-items:center;gap:.3rem}
.nav__links a{
  font-family:var(--font-display);font-weight:600;font-size:.93rem;
  color:var(--muted);padding:.5rem .85rem;border-radius:8px;
  transition:color .2s var(--ease),background .2s var(--ease);
}
.nav__links a:hover{color:#fff}
.nav__links a.is-active{color:#fff}
.nav__links a.is-active::after{
  content:"";display:block;height:2px;margin-top:3px;border-radius:2px;
  background:linear-gradient(90deg,var(--blue-br),var(--orange));
}
.nav__cta{margin-left:.4rem}
.nav__toggle{display:none;width:44px;height:44px;border-radius:10px;align-items:center;justify-content:center;flex-direction:column;gap:5px}
.nav__toggle span{width:22px;height:2px;background:#fff;border-radius:2px;transition:transform .3s var(--ease),opacity .2s var(--ease)}
.nav__toggle[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle[aria-expanded="true"] span:nth-child(2){opacity:0}
.nav__toggle[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

@media (max-width:920px){
  .nav__toggle{display:flex}
  .nav__menu{margin-left:0;
    position:fixed;inset:74px 0 auto 0;
    background:rgba(7,17,28,.98);border-bottom:1px solid var(--line);
    flex-direction:column;align-items:stretch;gap:.2rem;
    padding:1rem clamp(1.2rem,4vw,2.5rem) 1.6rem;
    transform:translateY(-12px);opacity:0;pointer-events:none;
    transition:opacity .25s var(--ease),transform .25s var(--ease);
  }
  .nav__menu.is-open{opacity:1;transform:none;pointer-events:auto}
  .nav__links{flex-direction:column;align-items:stretch;gap:.1rem}
  .nav__links a{padding:.85rem .4rem;font-size:1.05rem;border-bottom:1px solid var(--line-2);border-radius:0}
  .nav__links a.is-active::after{display:none}
}
@media (max-width:480px){
  .nav__cta-btn{padding:.6em 1em;font-size:.84rem}
  .nav__logo img{height:34px}
}

/* ==========================================================================
   Hero — the night sky (signature)
   ========================================================================== */
.hero{position:relative;overflow:hidden;isolation:isolate}
.hero__sky{position:absolute;inset:0;z-index:-2;width:100%;height:100%}
.hero::before{ /* deep glow */
  content:"";position:absolute;inset:0;z-index:-1;
  background:
    radial-gradient(120% 80% at 80% -10%, rgba(0,119,182,.28), transparent 60%),
    radial-gradient(90% 70% at 8% 110%, rgba(240,85,36,.14), transparent 55%),
    linear-gradient(180deg, #060e18 0%, #07111c 55%, #081421 100%);
}
.hero__inner{
  display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,4vw,4rem);align-items:center;
  padding-block:clamp(4.5rem,4rem + 8vw,9rem) clamp(3.5rem,3rem + 5vw,6rem);
}
.hero__kicker{margin-bottom:1.4rem}
.hero h1{margin-bottom:1.5rem}
.hero h1 .accent{
  background:linear-gradient(100deg,var(--blue-br),#7fd0f5);
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero h1 .accent-o{color:var(--orange)}
.hero__sub{font-size:clamp(1.05rem,1rem + .4vw,1.3rem);color:var(--muted);max-width:34rem;margin-bottom:2.2rem}
.hero__actions{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:2.6rem}
.hero__facts{display:flex;flex-wrap:wrap;gap:2.2rem;border-top:1px solid var(--line);padding-top:1.6rem}
.hero__fact .n{font-family:var(--font-display);font-weight:900;font-size:1.9rem;color:#fff;line-height:1}
.hero__fact .l{font-size:.82rem;color:var(--muted-2);margin-top:.3rem;letter-spacing:.02em}

.hero__owl{position:relative;display:grid;place-items:center}
.hero__owl-disc{
  position:relative;width:min(420px,80%);aspect-ratio:1;border-radius:50%;
  display:grid;place-items:center;
  background:radial-gradient(circle at 50% 40%, rgba(0,119,182,.22), rgba(7,17,28,0) 70%);
}
.hero__owl-disc::before{
  content:"";position:absolute;inset:0;border-radius:50%;
  box-shadow:inset 0 0 0 1px var(--line);
  background:conic-gradient(from 200deg, transparent, rgba(0,119,182,.10), transparent 60%);
  animation:spin 40s linear infinite;
}
.hero__owl img{width:62%;filter:drop-shadow(0 20px 50px rgba(0,119,182,.35));position:relative;z-index:2}
@keyframes spin{to{transform:rotate(360deg)}}

@media (max-width:920px){
  .hero__inner{grid-template-columns:1fr;text-align:left}
  .hero__owl{order:-1;margin-bottom:.5rem}
  .hero__owl-disc{width:min(260px,62%)}
}

/* ==========================================================================
   Marquee / partner strips
   ========================================================================== */
.trust{background:var(--paper);color:var(--ink);padding-block:clamp(2.2rem,2rem + 2vw,3.4rem)}
.trust__label{text-align:center;font-family:var(--font-display);font-weight:700;font-size:.74rem;letter-spacing:.26em;text-transform:uppercase;color:#5b6f82;margin-bottom:1.8rem}
.logo-row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(1.6rem,4vw,3.4rem)}
.logo-row img{height:clamp(30px,2.4vw,42px);width:auto;object-fit:contain;opacity:.78;filter:grayscale(.3);transition:opacity .25s var(--ease),filter .25s var(--ease)}
.logo-row img:hover{opacity:1;filter:none}
.logo-row .logo-row__tall{height:clamp(40px,3.4vw,58px)}

/* ==========================================================================
   Cards / grids
   ========================================================================== */
.grid{display:grid;gap:1.4rem}
.grid--2{grid-template-columns:repeat(2,1fr)}
.grid--3{grid-template-columns:repeat(3,1fr)}
.grid--4{grid-template-columns:repeat(4,1fr)}
@media (max-width:900px){.grid--3,.grid--4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:620px){.grid--2,.grid--3,.grid--4{grid-template-columns:1fr}}

.card{
  background:linear-gradient(180deg,var(--night-3),var(--night-2));
  border:1px solid var(--line);border-radius:var(--radius);
  padding:1.7rem;position:relative;overflow:hidden;
  transition:transform .3s var(--ease),border-color .3s var(--ease),box-shadow .3s var(--ease);
}
.card:hover{transform:translateY(-4px);border-color:rgba(43,164,224,.4);box-shadow:0 24px 50px -30px rgba(0,119,182,.6)}
.card__num{font-family:var(--font-display);font-weight:800;font-size:.8rem;color:var(--muted-2);letter-spacing:.1em}
.card h3{margin:.7rem 0 .6rem}
.card p{font-size:.97rem}
.card__icon{
  width:46px;height:46px;border-radius:12px;display:grid;place-items:center;margin-bottom:1.1rem;
  background:rgba(0,119,182,.14);color:var(--blue-br);
}
.card__icon svg{width:24px;height:24px}

/* Vertical/focus cards with top accent */
.focus-card{padding-top:1.9rem}
.focus-card::before{content:"";position:absolute;top:0;left:0;height:3px;width:100%;
  background:linear-gradient(90deg,var(--blue),var(--orange));opacity:.0;transition:opacity .3s var(--ease)}
.focus-card:hover::before{opacity:1}
.focus-card ul{margin-top:1rem;display:grid;gap:.5rem}
.focus-card li{font-size:.9rem;color:var(--muted);padding-left:1.1rem;position:relative}
.focus-card li::before{content:"";position:absolute;left:0;top:.62em;width:6px;height:6px;border-radius:50%;background:var(--blue-br)}
.focus-card--head{display:flex;flex-direction:column;justify-content:center;align-items:flex-start;min-height:132px}
.focus-card--head h3{margin:0;font-size:clamp(1.3rem,1.1rem + .7vw,1.65rem)}
.focus-card--cta{gap:.3rem}
.focus-card--cta .pcard__link{margin-top:.7rem}

/* ==========================================================================
   Stat band
   ========================================================================== */
.statband{background:linear-gradient(120deg,var(--navy),#012a3e);border-block:1px solid var(--line)}
.statband .grid--4{gap:0}
.stat{padding:clamp(1.6rem,3vw,2.6rem) 1.4rem;border-left:1px solid var(--line)}
.stat:first-child{border-left:none}
.stat .n{font-family:var(--font-display);font-weight:900;font-size:clamp(2.2rem,1.6rem + 2vw,3.2rem);line-height:1;
  background:linear-gradient(120deg,#fff,#9fd9f5);-webkit-background-clip:text;background-clip:text;color:transparent}
.stat .l{margin-top:.7rem;font-size:.92rem;color:var(--muted)}
@media (max-width:900px){.statband .grid--4{grid-template-columns:repeat(2,1fr)}
  .stat:nth-child(odd){border-left:none}.stat:nth-child(n+3){border-top:1px solid var(--line)}}
@media (max-width:620px){.statband .grid--4{grid-template-columns:1fr}.stat{border-left:none;border-top:1px solid var(--line)}.stat:first-child{border-top:none}}

/* ==========================================================================
   Process steps
   ========================================================================== */
.steps{display:grid;gap:1.2rem;grid-template-columns:repeat(4,1fr);counter-reset:step}
@media (max-width:900px){.steps{grid-template-columns:repeat(2,1fr)}}
@media (max-width:540px){.steps{grid-template-columns:1fr}}
.step{position:relative;padding:1.6rem 1.4rem;border:1px solid var(--line);border-radius:var(--radius);background:var(--night-2)}
.step__n{font-family:var(--font-display);font-weight:900;font-size:1rem;color:var(--night);
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;background:var(--blue-br);margin-bottom:1rem}
.step h3{font-size:1.15rem;margin-bottom:.5rem}
.step p{font-size:.92rem}

/* ==========================================================================
   Split / feature
   ========================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,4vw,4.5rem);align-items:center}
@media (max-width:860px){.split{grid-template-columns:1fr}}
.checklist{display:grid;gap:1rem;margin-top:1.6rem}
.checklist li{display:flex;gap:.85rem;align-items:flex-start;font-size:1rem;color:var(--text)}
.checklist svg{flex:0 0 auto;width:22px;height:22px;color:var(--blue-br);margin-top:.15rem}
.checklist span small{display:block;color:var(--muted);font-size:.9rem;margin-top:.15rem}

/* ==========================================================================
   Featured portfolio teaser
   ========================================================================== */
.feature{
  display:grid;grid-template-columns:1.1fr 1fr;gap:0;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--line);background:linear-gradient(180deg,var(--night-3),var(--night-2));
}
@media (max-width:820px){.feature{grid-template-columns:1fr}}
.feature__body{padding:clamp(1.8rem,3vw,3rem)}
.feature__tag{display:inline-block;font-size:.74rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--orange-2);font-family:var(--font-display);font-weight:700;margin-bottom:1rem}
.feature__visual{
  position:relative;min-height:280px;display:grid;place-items:center;padding:2rem;
  background:radial-gradient(circle at 50% 40%,rgba(0,119,182,.22),transparent 70%),#081421;
  border-left:1px solid var(--line);
}
@media (max-width:820px){.feature__visual{border-left:none;border-top:1px solid var(--line);min-height:200px}}
.feature__visual .chip{font-family:var(--font-display);font-weight:900;font-size:clamp(2rem,5vw,3.4rem);color:#fff;letter-spacing:-.02em;text-align:center}
.feature__visual .chip span{color:var(--blue-br)}

/* ==========================================================================
   Team
   ========================================================================== */
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media (max-width:860px){.team-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.team-grid{grid-template-columns:1fr}}
.member{background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:border-color .3s var(--ease),transform .3s var(--ease)}
.member:hover{transform:translateY(-4px);border-color:rgba(43,164,224,.4)}
.member__photo{aspect-ratio:1/1;display:grid;place-items:center;
  background:radial-gradient(circle at 50% 35%,rgba(0,119,182,.25),transparent 70%),var(--night-3);position:relative;overflow:hidden}
.member__photo img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.member__initials{font-family:var(--font-display);font-weight:900;font-size:3.2rem;color:#fff;opacity:.92}
.member__photo::after{content:"";position:absolute;inset:auto 0 0 0;height:1px;background:linear-gradient(90deg,transparent,var(--blue-br),transparent)}
.member__body{padding:1.4rem 1.5rem 1.6rem}
.member__body h3{font-size:1.25rem}
.member__role{color:var(--blue-br);font-family:var(--font-display);font-weight:600;font-size:.9rem;margin:.25rem 0 .9rem}
.member__body p{font-size:.93rem}
.member__links{display:flex;gap:.6rem;margin-top:1.1rem}
.member__links a{width:34px;height:34px;border-radius:8px;display:grid;place-items:center;background:rgba(255,255,255,.05);color:var(--muted);transition:background .2s,color .2s}
.member__links a:hover{background:var(--blue);color:#fff}
.member__links svg{width:17px;height:17px}

/* ==========================================================================
   Portfolio
   ========================================================================== */
.filterbar{display:flex;flex-wrap:wrap;gap:.6rem;margin-bottom:2.2rem}
.filterbar button{font-family:var(--font-display);font-weight:600;font-size:.86rem;padding:.5rem 1rem;border-radius:999px;
  color:var(--muted);box-shadow:inset 0 0 0 1px var(--line);transition:.2s var(--ease)}
.filterbar button:hover{color:#fff}
.filterbar button.is-active{background:var(--blue);color:#fff;box-shadow:none}

.portfolio-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.4rem}
@media (max-width:880px){.portfolio-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:560px){.portfolio-grid{grid-template-columns:1fr}}
.pcard{display:flex;flex-direction:column;background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s var(--ease),border-color .3s var(--ease)}
.pcard:hover{transform:translateY(-4px);border-color:rgba(43,164,224,.4)}
.pcard__top{padding:1.5rem 1.6rem 0;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}
.pcard__logo{font-family:var(--font-display);font-weight:900;font-size:1.5rem;color:#fff;letter-spacing:-.02em}
.pcard__sector{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--blue-br);font-family:var(--font-display);font-weight:700;
  padding:.3rem .6rem;border-radius:999px;background:rgba(0,119,182,.14);white-space:nowrap}
.pcard__body{padding:1rem 1.6rem 1.6rem;flex:1;display:flex;flex-direction:column}
.pcard__body p{font-size:.95rem;flex:1}
.pcard__meta{display:flex;gap:1.2rem;margin-top:1.2rem;padding-top:1.1rem;border-top:1px solid var(--line-2);font-size:.82rem;color:var(--muted-2)}
.pcard__meta b{color:var(--text);font-weight:600;display:block;font-family:var(--font-display)}
.pcard__link{margin-top:1.1rem;font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--blue-br);display:inline-flex;gap:.4rem;align-items:center}
.pcard__link svg{width:1em;height:1em;transition:transform .2s var(--ease)}
.pcard:hover .pcard__link svg{transform:translateX(3px)}

.coming-card{display:grid;place-items:center;text-align:center;border:1px dashed var(--line);background:transparent;border-radius:var(--radius);padding:2rem}
.coming-card .o{font-size:2rem;margin-bottom:.6rem;opacity:.6}

/* ==========================================================================
   Form
   ========================================================================== */
.form-shell{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,4vw,4rem);align-items:start}
@media (max-width:860px){.form-shell{grid-template-columns:1fr}}
.form-aside .checklist{margin-top:1.4rem}
.form-card{background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);padding:clamp(1.6rem,3vw,2.4rem)}
.field{margin-bottom:1.2rem}
.field label{display:block;font-family:var(--font-display);font-weight:600;font-size:.9rem;margin-bottom:.5rem;color:var(--text)}
.field .req{color:var(--orange-2)}
.field input,.field select,.field textarea{
  width:100%;background:var(--night);border:1px solid var(--line);border-radius:var(--radius-sm);
  color:var(--text);padding:.85rem 1rem;font:inherit;transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.field input::placeholder,.field textarea::placeholder{color:var(--muted-2)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--blue-br);box-shadow:0 0 0 3px rgba(43,164,224,.18)}
.field textarea{min-height:130px;resize:vertical}
.field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239db1c4' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}
.field-2{display:grid;grid-template-columns:1fr 1fr;gap:1.2rem}
@media (max-width:520px){.field-2{grid-template-columns:1fr}}
.field-hint{font-size:.82rem;color:var(--muted-2);margin-top:.4rem}
.filedrop{border:1px dashed var(--line);border-radius:var(--radius-sm);padding:1.3rem;text-align:center;cursor:pointer;transition:border-color .2s,background .2s}
.filedrop:hover,.filedrop.is-drag{border-color:var(--blue-br);background:rgba(43,164,224,.06)}
.filedrop input{display:none}
.filedrop__txt{color:var(--muted);font-size:.92rem}
.filedrop__name{color:var(--blue-br);font-weight:600;margin-top:.4rem;font-size:.9rem}
.consent{display:flex;gap:.7rem;align-items:flex-start;font-size:.86rem;color:var(--muted)}
.consent input{width:18px;height:18px;margin-top:.2rem;accent-color:var(--blue)}
.form-status{margin-top:1rem;padding:.9rem 1.1rem;border-radius:var(--radius-sm);font-size:.92rem;display:none}
.form-status.is-error{display:block;background:rgba(240,85,36,.12);color:#ffb59c;border:1px solid rgba(240,85,36,.3)}
.form-status.is-success{display:block;background:rgba(0,119,182,.14);color:#bfe6fb;border:1px solid rgba(43,164,224,.35)}

/* ==========================================================================
   Article / blog
   ========================================================================== */
.article-hero{padding-block:clamp(3.5rem,3rem + 4vw,6rem) 2rem}
.article-hero .eyebrow{margin-bottom:1.2rem}
.article-hero h1{font-size:clamp(2.1rem,1.5rem + 3vw,3.6rem);max-width:20ch}
.article-meta{display:flex;flex-wrap:wrap;gap:1.2rem;margin-top:1.6rem;color:var(--muted);font-size:.92rem;align-items:center}
.article-meta .dot{width:4px;height:4px;border-radius:50%;background:var(--muted-2)}
.article{max-width:46rem;margin-inline:auto}
.article p{color:#c6d4e1;font-size:1.1rem;line-height:1.78;margin-bottom:1.5rem}
.article h2{font-size:clamp(1.5rem,1.2rem + 1.2vw,2rem);margin:2.6rem 0 1rem}
.article h3{margin:2rem 0 .8rem}
.article strong{color:#fff}
.article ul.bullets{margin:0 0 1.5rem;display:grid;gap:.7rem}
.article ul.bullets li{color:#c6d4e1;font-size:1.05rem;padding-left:1.4rem;position:relative;line-height:1.7}
.article ul.bullets li::before{content:"";position:absolute;left:0;top:.65em;width:7px;height:7px;border-radius:50%;background:var(--orange)}
.pullquote{border-left:3px solid var(--blue-br);padding:.4rem 0 .4rem 1.6rem;margin:2.4rem 0;
  font-family:var(--font-display);font-weight:600;font-size:1.4rem;line-height:1.4;color:#fff}
.faq-item{border-top:1px solid var(--line);padding:1.4rem 0}
.faq-item h3{font-size:1.15rem;margin:0 0 .5rem}
.faq-item p{font-size:1rem;margin:0}
.byline{margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--line);color:var(--muted);font-size:.95rem}

.post-list{display:grid;grid-template-columns:repeat(2,1fr);gap:1.4rem}
@media (max-width:760px){.post-list{grid-template-columns:1fr}}
.post{display:flex;flex-direction:column;background:var(--night-2);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;transition:transform .3s var(--ease),border-color .3s var(--ease)}
.post:hover{transform:translateY(-4px);border-color:rgba(43,164,224,.4)}
.post__cover{aspect-ratio:16/8;background:radial-gradient(circle at 70% 20%,rgba(0,119,182,.3),transparent 65%),#081421;display:grid;place-items:center;padding:1.5rem}
.post__cover .chip{font-family:var(--font-display);font-weight:900;font-size:1.8rem;color:#fff;text-align:center}
.post__cover .chip span{color:var(--blue-br)}
.post__body{padding:1.5rem 1.6rem 1.7rem;flex:1;display:flex;flex-direction:column}
.post__tag{font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-2);font-family:var(--font-display);font-weight:700;margin-bottom:.7rem}
.post__body h3{font-size:1.25rem;margin-bottom:.6rem}
.post__body p{font-size:.95rem;flex:1}
.post__more{margin-top:1.1rem;font-family:var(--font-display);font-weight:600;font-size:.9rem;color:var(--blue-br)}

/* ==========================================================================
   CTA band
   ========================================================================== */
.cta{position:relative;overflow:hidden;background:linear-gradient(120deg,#012a3e,var(--navy));border-radius:24px;
  padding:clamp(2.5rem,3vw + 1rem,4.5rem);text-align:center;border:1px solid var(--line)}
.cta::before{content:"";position:absolute;inset:0;
  background:radial-gradient(60% 100% at 80% 0%,rgba(0,119,182,.4),transparent 60%),
            radial-gradient(50% 100% at 10% 100%,rgba(240,85,36,.2),transparent 60%)}
.cta>*{position:relative}
.cta h2{margin-bottom:1rem}
.cta p{color:#bcd2e3;max-width:40rem;margin:0 auto 2rem;font-size:1.1rem}
.cta__actions{display:flex;gap:.9rem;justify-content:center;flex-wrap:wrap}

/* ==========================================================================
   Footer
   ========================================================================== */
.site-footer{background:#050d16;border-top:1px solid var(--line);padding-block:clamp(3rem,2.5rem + 2vw,4.5rem) 2rem}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:2rem}
@media (max-width:820px){.footer-grid{grid-template-columns:1fr 1fr}}
@media (max-width:520px){.footer-grid{grid-template-columns:1fr}}
.footer-brand img{height:46px;margin-bottom:1.2rem}
.footer-brand p{font-size:.92rem;max-width:24rem}
.footer-col h4{font-family:var(--font-display);font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;color:var(--muted-2);margin-bottom:1rem;font-weight:700}
.footer-col a,.footer-col p{display:block;color:var(--muted);font-size:.93rem;padding:.28rem 0;transition:color .2s}
.footer-col a:hover{color:#fff}
.footer-bottom{display:flex;flex-wrap:wrap;justify-content:space-between;gap:1rem;align-items:center;
  margin-top:3rem;padding-top:1.6rem;border-top:1px solid var(--line-2);color:var(--muted-2);font-size:.85rem}
.footer-bottom a{color:var(--muted-2)}
.footer-bottom a:hover{color:var(--muted)}

/* ==========================================================================
   Reveal on scroll
   ========================================================================== */
.reveal{opacity:0;transform:translateY(22px);transition:opacity .7s var(--ease),transform .7s var(--ease)}
.reveal.is-in{opacity:1;transform:none}
.reveal[data-d="1"]{transition-delay:.08s}
.reveal[data-d="2"]{transition-delay:.16s}
.reveal[data-d="3"]{transition-delay:.24s}

/* Page hero (interior) */
.page-hero{position:relative;overflow:hidden;padding-block:clamp(4rem,3.5rem + 5vw,7rem) clamp(2rem,2vw,3rem)}
.page-hero::before{content:"";position:absolute;inset:0;z-index:-1;
  background:radial-gradient(80% 120% at 85% -20%,rgba(0,119,182,.22),transparent 60%),linear-gradient(180deg,#060e18,#07111c)}
.page-hero h1{max-width:18ch;margin-top:1.2rem}
.page-hero p{max-width:46rem;margin-top:1.2rem;font-size:1.15rem}

@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;transition-duration:.001ms !important;scroll-behavior:auto !important}
  .reveal{opacity:1;transform:none}
}
