/* ============================================================
   SEREGH — reconstructed styles.css
   The reference site shipped an external styles.css that was not
   captured (live site is password-protected). This file is a
   faithful reconstruction from: the per-page inline <style> blocks,
   the class/variable names used throughout the captured HTML, the
   full-page reference screenshots, and the Seregh brand design
   system (royal blue #161D46 + red-card orange #EA5A27 + penalty
   yellow #F0B31D). Font: Mulish (the reference's chosen web font).
   ============================================================ */

:root{
  --navy:#161D46;          /* royal blue — the workhorse */
  --navy2:#20296A;         /* lighter navy / borders on dark */
  --navy3:#0E1330;         /* deepest navy — bold panels, video bg */
  --orange:#EA5A27;        /* red-card orange — primary accent / CTA */
  --gold:#F0B31D;          /* penalty yellow — secondary accent */
  --white:#FFFFFF;
  --ink:#1b1f33;           /* body text on light */
  --mut:#4a4f63;           /* muted text on light */
  --mutblue:#aeb6d6;       /* muted text on dark (navy) */
  --mist:#F1F1F1;          /* jersey gray section bg */
  --line:#e4e4ea;          /* hairline on light */
  --maxw:1180px;
  --maxw-narrow:820px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:"Mulish","Helvetica Neue",Arial,sans-serif;
  font-weight:500;
  color:var(--ink);
  background:var(--white);
  font-size:17px;
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem)}
.wrap-narrow{max-width:var(--maxw-narrow);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem)}
section{padding:clamp(3.5rem,7vw,5.5rem) 0}
.center{text-align:center}
.mt-2{margin-top:1.2rem}
.mt-3{margin-top:2rem}

/* ---------- section themes ---------- */
.mist{background:var(--mist)}
.dark{background:var(--navy);color:var(--white)}
.dark h1,.dark h2,.dark h3,.dark h4{color:var(--white)}
.darker{background:var(--navy3);color:var(--white)}
.darker h1,.darker h2,.darker h3{color:var(--white)}

/* ---------- typography ---------- */
.eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  font-size:.74rem;font-weight:900;letter-spacing:.22em;text-transform:uppercase;
  color:var(--orange);margin-bottom:1.1rem;
}
.eyebrow.center{justify-content:center}
.eyebrow::before{content:"";width:26px;height:3px;background:var(--orange);display:inline-block}
.eyebrow.center::before{display:none}

h1,.display{
  font-family:"Mulish",sans-serif;font-weight:900;line-height:1.04;
  letter-spacing:-.01em;margin:0 0 1rem;color:var(--navy);
  font-size:clamp(2.6rem,6.4vw,5rem);text-transform:none;
}
.display-md{font-size:clamp(2rem,4.6vw,3.2rem);font-weight:900;line-height:1.08;letter-spacing:-.01em;margin:0 0 .6rem;color:var(--navy)}
.display-sm{font-size:clamp(1.7rem,3.4vw,2.4rem);font-weight:900;line-height:1.12;letter-spacing:-.01em;margin:0 0 .6rem;color:var(--navy)}
.dark .display-md,.dark .display-sm,.darker .display{color:var(--white)}
h2{font-family:"Mulish",sans-serif;font-weight:900;line-height:1.12;color:var(--navy);margin:0 0 .6rem;font-size:clamp(1.6rem,3vw,2.2rem)}
h3{font-family:"Mulish",sans-serif;font-weight:900;font-size:1.25rem;line-height:1.2;color:var(--navy);margin:0 0 .5rem}
h4,h5{font-family:"Mulish",sans-serif;color:var(--navy)}
p{margin:0 0 1rem;color:inherit}
.lede{font-size:clamp(1.05rem,1.6vw,1.3rem);font-weight:500;line-height:1.7;color:var(--mut)}
.dark .lede,.darker .lede{color:var(--mutblue)}
.micro{font-size:.78rem;color:var(--mut);line-height:1.6}
.big-pull{font-size:clamp(1.3rem,2.6vw,1.9rem);font-weight:900;line-height:1.4;color:var(--navy);margin:1.6rem 0}
.big-pull em{font-style:normal;color:var(--orange)}

/* accent colored words inside headings */
.o{color:var(--orange)}
.g{color:var(--gold)}

a{color:var(--orange);text-decoration:none}
a:hover{color:var(--navy)}

/* ---------- nav ---------- */
.nav{position:absolute;top:0;left:0;right:0;z-index:50;background:transparent;transition:background .3s}
.nav.scrolled,.nav.solid,.nav.always-solid{position:fixed;background:var(--navy);box-shadow:0 2px 18px rgba(14,19,48,.3)}
.nav-inner{max-width:var(--maxw);margin:0 auto;padding:1.1rem clamp(1.2rem,4vw,2.5rem);display:flex;align-items:center;justify-content:space-between}
.nav-logo img{height:30px;width:auto}
.nav .links{display:flex;align-items:center;gap:1.6rem}
.nav .links a{
  color:var(--white);font-size:.82rem;font-weight:800;letter-spacing:.08em;
  text-transform:uppercase;text-decoration:none;opacity:.9;transition:.2s;
}
.nav .links a:hover,.nav .links a.active{opacity:1;color:var(--gold)}
.nav .links a.cta{
  background:var(--orange);color:#fff;padding:.55rem 1.1rem;border-radius:2px;opacity:1;
}
.nav .links a.cta:hover{background:#fff;color:var(--navy)}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:0;cursor:pointer;padding:6px}
.burger span{width:26px;height:2px;background:#fff;display:block}

/* spacer so fixed nav doesn't cover content on solid pages */
.nav.always-solid + *{margin-top:0}

/* ---------- ticker ---------- */
.ticker{background:var(--orange);color:var(--white);overflow:hidden;padding:.85rem 0;border-top:2px solid var(--navy);border-bottom:2px solid var(--navy)}
.ticker .track{display:flex;gap:3.5rem;white-space:nowrap;animation:tick 36s linear infinite;width:max-content}
.ticker span{font-size:.74rem;font-weight:900;letter-spacing:.24em;text-transform:uppercase}
.ticker span::before{content:"\25C6";margin-right:3.5rem;color:var(--gold)}
@keyframes tick{to{transform:translateX(-50%)}}

/* ---------- page hero (interior pages) ---------- */
.page-hero{
  position:relative;background:var(--navy);color:var(--white);
  padding:clamp(8rem,16vw,12rem) 0 clamp(4rem,8vw,7rem);overflow:hidden;
}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .display,.page-hero h1{color:var(--white)}
.page-hero .lede{color:var(--mutblue)}
.page-hero .skyline{
  position:absolute;right:-4%;bottom:-8%;width:min(620px,60%);opacity:.18;
  pointer-events:none;z-index:1;
}
.scroll-cue{
  position:absolute;bottom:1.6rem;left:50%;transform:translateX(-50%);z-index:4;color:#fff;
  font-size:.62rem;font-weight:800;letter-spacing:.3em;text-transform:uppercase;opacity:.75;text-align:center;
}
.scroll-cue::after{content:"";display:block;width:2px;height:30px;background:var(--gold);margin:.5rem auto 0;animation:cue 1.8s infinite}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top}45%{transform:scaleY(1);transform-origin:top}55%{transform:scaleY(1);transform-origin:bottom}100%{transform:scaleY(0);transform-origin:bottom}}

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

/* ---------- cards ---------- */
.card{
  background:var(--white);border:1px solid var(--line);border-top:3px solid var(--orange);
  border-radius:4px;padding:2rem 1.8rem;box-shadow:0 6px 30px rgba(22,29,70,.06);
}
.card h3{color:var(--navy)}
.card p{color:var(--mut);margin:0}
.dark .card{background:var(--navy2);border-color:rgba(255,255,255,.08);border-top-color:var(--orange)}
.dark .card h3{color:var(--white)}
.dark .card p{color:var(--mutblue)}
.card .num{font-size:.95rem;font-weight:900;color:var(--orange);letter-spacing:.18em;margin-bottom:.7rem}

/* ---------- buttons ---------- */
.btn{
  display:inline-block;font-family:inherit;font-weight:900;font-size:.78rem;letter-spacing:.1em;
  text-transform:uppercase;padding:.85rem 1.6rem;border-radius:2px;cursor:pointer;
  text-decoration:none;border:2px solid transparent;transition:.2s;
}
.btn-orange{background:var(--orange);color:#fff;border-color:var(--orange)}
.btn-orange:hover{background:#fff;color:var(--navy);border-color:#fff}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--orange);border-color:var(--orange);color:#fff}
.btn-ghost{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-ghost:hover{background:#fff;color:var(--navy);border-color:#fff}
.dark .btn-ghost,.band .btn-ghost{color:#fff}
section:not(.dark):not(.darker) .btn-ghost{color:var(--navy);border-color:var(--navy)}
section:not(.dark):not(.darker) .btn-ghost:hover{background:var(--navy);color:#fff}

/* ---------- photo band (full-bleed statement) ---------- */
.band{
  position:relative;background:var(--navy3) center/cover no-repeat;color:#fff;
  padding:clamp(5rem,10vw,8rem) 0;text-align:center;
}
.band::before{content:"";position:absolute;inset:0;background:linear-gradient(rgba(14,19,48,.72),rgba(22,29,70,.82))}
.band .wrap{position:relative;z-index:2}
.band h2,.band .display,.band .display-md{color:#fff}
.band .lede{color:#dfe2ef}

/* ---------- footer ---------- */
footer{background:var(--navy3);color:var(--mutblue);padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.foot-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr .8fr;gap:2.4rem}
@media(max-width:900px){.foot-grid{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.foot-grid{grid-template-columns:1fr}}
.f-logo img{height:30px;margin-bottom:1rem}
.f-tag{font-size:.9rem;line-height:1.7;color:var(--mutblue);max-width:34ch}
footer h5{color:#fff;font-size:.74rem;font-weight:900;letter-spacing:.18em;text-transform:uppercase;margin:0 0 1rem}
footer ul{list-style:none;margin:0;padding:0}
footer ul li{margin-bottom:.5rem}
footer ul li a,footer .addr a{color:var(--mutblue);text-decoration:none;font-size:.9rem}
footer ul li a:hover,footer .addr a:hover{color:var(--gold)}
.addr{font-size:.9rem;line-height:1.7;color:var(--mutblue)}
.foot-legal{border-top:1px solid rgba(255,255,255,.08);margin-top:2.6rem;padding-top:1.6rem}
.foot-legal p{font-size:.72rem;line-height:1.7;color:#7e87a8}
.foot-legal .copy{margin-top:1rem;font-size:.74rem;color:#9aa2c4}
.foot-legal a{color:#9aa2c4}

/* ---------- doors (home: who we work with) ---------- */
.door{position:relative;display:block;overflow:hidden;border-radius:4px;min-height:330px;text-decoration:none;background:var(--navy)}
.door .bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;transition:.4s}
.door:hover .bg{opacity:.4;transform:scale(1.04)}
.door-body{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:1.8rem;background:linear-gradient(rgba(14,19,48,.1),rgba(14,19,48,.85))}
.door-body h3{color:#fff;font-size:1.4rem}
.door-body p{color:#dfe2ef;font-size:.92rem;margin:.4rem 0 .8rem}
.door-body .go{color:var(--gold);font-weight:900;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase}

/* ---------- ladder (philosophy III) ---------- */
.ladder{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin:2rem 0}
@media(max-width:860px){.ladder{grid-template-columns:1fr 1fr}}
.ladder>div{background:var(--mist);border-top:3px solid var(--orange);padding:1.4rem;border-radius:4px}
.ladder small{display:block;font-size:.7rem;font-weight:900;letter-spacing:.12em;text-transform:uppercase;color:var(--orange);margin-bottom:.5rem}
.ladder strong{display:block;font-size:1.3rem;font-weight:900;color:var(--navy);margin-bottom:.3rem}
.ladder span{font-size:.85rem;color:var(--mut)}

/* ---------- misc ---------- */
.divider-dash{display:flex;gap:.5rem;justify-content:center;margin:2rem 0}
.divider-dash i{width:26px;height:3px;background:var(--orange);display:block}
.forces-close{max-width:760px;margin:2.5rem auto 0;text-align:center}
.forces-close .punch{font-size:1.2rem;font-weight:900;color:var(--gold)}
.logo-wall{display:grid;grid-template-columns:repeat(6,1fr);gap:1px;background:var(--line);border:1px solid var(--line)}
@media(max-width:860px){.logo-wall{grid-template-columns:repeat(3,1fr)}}
.logo-wall .cell{background:#fff;aspect-ratio:3/2;display:flex;align-items:center;justify-content:center;padding:1rem}
.logo-wall .cell img{max-height:38px;width:auto;opacity:.6;filter:grayscale(1)}
.logo-wall .cell.tm{font-size:.7rem;font-weight:900;text-transform:uppercase;color:var(--mut);text-align:center;letter-spacing:.08em}
.gold-band{background:var(--gold);padding:2.4rem 0}
.gold-band .wrap{display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}
.gold-band p{color:var(--navy);font-weight:700;margin:0;font-size:1.05rem}
.num{font-weight:900;color:var(--orange)}

/* dotnav (right-side section dots) — hidden on the WP replica for simplicity */
.dotnav{display:none}

/* reveal helper — content visible by default (no JS dependency for parity) */
.rv{opacity:1}

@media(max-width:860px){
  .nav .links{display:none}
  .burger{display:flex}
  .nav .links.open{display:flex;position:absolute;top:100%;left:0;right:0;flex-direction:column;background:var(--navy);padding:1rem 1.5rem;gap:1rem}
}

/* ============================================================
   WP-replica overrides — the reference home hero is a fullscreen
   autoplay film (assets/hero-slow.mp4) that was not in the capture.
   Force the hero end-card visible over a navy panel so the home
   hero ("From Futurism to Tomorrowism") shows statically. Hide the
   video-only controls.
   ============================================================ */
.hero-video{background:var(--navy3)}
.hero-video video{display:none}
.hero-end{opacity:1 !important;pointer-events:auto !important}
.hero-end img.script{width:min(320px,52vw);margin-bottom:1.6rem}
.hero-end h1.display{color:#fff;font-size:clamp(2.6rem,6vw,4.6rem)}
.hero-end h1 .o{color:var(--orange)}
.hero-end p.sub{color:var(--mutblue);font-size:1rem;font-weight:800;letter-spacing:.18em;text-transform:uppercase;margin-top:1.2rem}
.hero-ctas{display:flex;gap:1rem;margin-top:2.2rem;flex-wrap:wrap;justify-content:center}
.replay,.soundbtn{display:none !important}

/* logo-wall cells show the partner name as a wordmark (the bitmap logos
   were not part of the capture) — keeps the "Company We Keep" wall legible */
.logo-wall .cell .name{font-size:.72rem;font-weight:900;text-transform:uppercase;color:var(--mut);letter-spacing:.06em;text-align:center}

