/* ============================================================
   IMPAVID HOLDING — Core Stylesheet
   Identity: Sovereign navy · gold precision · electric signal
   ============================================================ */

:root{
  /* Brand palette (from IMPAVID brand guidelines) */
  --navy:#1B3163;
  --navy-deep:#0E1B3A;
  --navy-900:#091128;
  --navy-800:#10204a;
  --gold:#D4B483;
  --gold-bright:#E7CFA3;
  --cyan:#00BEF1;
  --blue:#006CFF;
  --mist:#D9E2EB;
  --ink:#0B1226;
  --paper:#F6F4EF;
  --paper-2:#EFEBE2;
  --line:rgba(212,180,131,.28);
  --line-soft:rgba(11,18,38,.10);

  /* Typography */
  --display:"Playfair Display", Georgia, "Times New Roman", serif;
  --body:"Inter", "Helvetica Neue", Arial, sans-serif;
  --mono:"Archivo", "Inter", sans-serif;          /* uppercase labels */
  --data:"JetBrains Mono", ui-monospace, "SFMono-Regular", monospace; /* figures / ledger */

  /* Rhythm */
  --maxw:1240px;
  --gut:clamp(20px,5vw,64px);
  --r:4px;
  --ease:cubic-bezier(.22,.61,.36,1);

  /* Elevation — soft, layered, print-grade */
  --sh-1:0 1px 2px rgba(11,18,38,.06), 0 8px 24px -16px rgba(11,18,38,.30);
  --sh-2:0 2px 4px rgba(11,18,38,.05), 0 30px 60px -32px rgba(11,18,38,.45);
  --sh-dark:0 30px 70px -34px rgba(0,0,0,.7), inset 0 1px 0 rgba(255,255,255,.05);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--body);
  color:var(--ink);
  background:var(--paper);
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
  overflow-x:hidden;
}
/* film grain — adds print-grade texture, sits above backgrounds, below content */
body::before{content:"";position:fixed;inset:0;z-index:1;pointer-events:none;opacity:.04;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E")}
.nav,main,.foot{position:relative;z-index:2}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
.data{font-family:var(--data);font-feature-settings:"tnum" 1;letter-spacing:-.02em}
h1,h2,h3,h4{font-family:var(--display);font-weight:500;line-height:1.08;margin:0;letter-spacing:.004em}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--gut)}
.section{padding:clamp(72px,11vw,150px) 0}
.eyebrow{
  font-family:var(--mono);
  font-size:.72rem;letter-spacing:.34em;text-transform:uppercase;
  font-weight:600;color:var(--gold);
  display:inline-flex;align-items:center;gap:.7em;margin:0 0 1.2rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--gold);opacity:.7}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}

.lead{font-size:clamp(1.05rem,1.7vw,1.32rem);line-height:1.7;color:#33405e;max-width:64ch}
.muted{color:#5a667e}
.gold{color:var(--gold)}

/* Diamond divider (brand motif) */
.diamond-rule{display:flex;align-items:center;justify-content:center;gap:14px;margin:0 auto}
.diamond-rule .ln{height:1px;width:min(120px,18vw);background:linear-gradient(90deg,transparent,var(--gold))}
.diamond-rule .ln.r{background:linear-gradient(90deg,var(--gold),transparent)}
.diamond-rule .dot{width:9px;height:9px;background:var(--gold);transform:rotate(45deg)}
.diamond-rule .dot.lg{width:13px;height:13px}

/* ---------- Buttons ---------- */
.btn{
  --bg:var(--gold);--fg:var(--navy-deep);
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--mono);font-weight:600;font-size:.76rem;letter-spacing:.14em;text-transform:uppercase;
  padding:1.05em 1.8em;border:1px solid var(--bg);background:var(--bg);color:var(--fg);
  border-radius:var(--r);cursor:pointer;position:relative;overflow:hidden;
  transition:transform .4s var(--ease), background .4s var(--ease), color .4s var(--ease), border-color .4s var(--ease);
}
.btn .arw{transition:transform .4s var(--ease)}
.btn:hover{transform:translateY(-2px)}
.btn:hover .arw{transform:translateX(5px)}
.btn.ghost{--bg:transparent;--fg:var(--paper);border-color:rgba(212,180,131,.5)}
.btn.ghost:hover{background:var(--gold);color:var(--navy-deep);border-color:var(--gold)}
.btn.ink{--bg:var(--navy-deep);--fg:#fff}
.btn.outline-ink{--bg:transparent;--fg:var(--navy-deep);border-color:rgba(11,18,38,.25)}
.btn.outline-ink:hover{background:var(--navy-deep);color:#fff;border-color:var(--navy-deep)}

/* ============================================================
   NAVBAR
   ============================================================ */
.scrollbar{position:fixed;top:0;left:0;height:2px;width:0;z-index:70;background:var(--gold);opacity:.85;transition:width .1s linear}
.nav{
  position:fixed;top:0;left:0;right:0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:18px var(--gut);
  transition:background .5s var(--ease), padding .5s var(--ease), box-shadow .5s var(--ease), border-color .5s;
  border-bottom:1px solid transparent;
}
.nav.solid{background:rgba(9,17,40,.86);backdrop-filter:blur(14px);padding:12px var(--gut);border-bottom-color:rgba(212,180,131,.16)}
.nav__logo img{height:30px;width:auto}
.nav__links{display:flex;align-items:center;gap:34px;list-style:none;margin:0;padding:0}
.nav__links a{
  font-family:var(--mono);font-size:.82rem;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.82);position:relative;padding:6px 0;transition:color .3s;
}
.nav__links a::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:0;background:var(--gold);transition:width .35s var(--ease)}
.nav__links a:hover,.nav__links a.active{color:#fff}
.nav__links a:hover::after,.nav__links a.active::after{width:100%}
.nav__menu>.btn{display:none}
.nav__cta{display:flex;align-items:center;gap:18px}
.nav .btn{padding:.78em 1.3em;font-size:.74rem}
.nav__burger{display:none;background:none;border:0;cursor:pointer;width:30px;height:22px;position:relative}
.nav__burger span{position:absolute;left:0;height:2px;width:100%;background:#fff;transition:.35s var(--ease)}
.nav__burger span:nth-child(1){top:0}
.nav__burger span:nth-child(2){top:10px}
.nav__burger span:nth-child(3){top:20px}
.nav.open .nav__burger span:nth-child(1){top:10px;transform:rotate(45deg)}
.nav.open .nav__burger span:nth-child(2){opacity:0}
.nav.open .nav__burger span:nth-child(3){top:10px;transform:rotate(-45deg)}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;min-height:100svh;display:flex;align-items:center;
  background:var(--navy-deep);color:#fff;overflow:hidden;
}
.hero__bg{position:absolute;inset:0;z-index:0}
.hero__bg img{width:100%;height:100%;object-fit:cover;opacity:.16;filter:saturate(.92) contrast(1.02)}
.hero__bg::after{content:"";position:absolute;inset:0;
  background:
    radial-gradient(120% 90% at 78% 12%, rgba(27,49,99,.35), transparent 60%),
    linear-gradient(180deg, rgba(9,17,40,.62), rgba(9,17,40,.95));
}
.hero__grid{position:absolute;inset:0;z-index:1;opacity:.35;
  background-image:linear-gradient(rgba(212,180,131,.04) 1px,transparent 1px),linear-gradient(90deg,rgba(212,180,131,.04) 1px,transparent 1px);
  background-size:80px 80px;mask-image:radial-gradient(120% 100% at 50% 0%,#000,transparent 72%)}
.hero .wrap{position:relative;z-index:3;width:100%;padding-top:120px;padding-bottom:60px}
.hero__kicker{font-family:var(--mono);letter-spacing:.36em;text-transform:uppercase;font-size:.72rem;color:rgba(212,180,131,.9);margin-bottom:34px;display:flex;gap:1em;align-items:center}
.hero__kicker .pulse{width:6px;height:6px;background:var(--gold);border-radius:50%;opacity:.9}
.hero h1{font-size:clamp(2.7rem,7.6vw,6.2rem);line-height:1.02;font-weight:500;letter-spacing:-.012em}
.hero h1 .it{font-style:italic;font-weight:500;color:var(--gold)}
.hero__sub{margin:34px 0 0;max-width:52ch;font-size:clamp(1.04rem,1.5vw,1.22rem);color:rgba(232,238,250,.74);line-height:1.75;font-weight:400}
.hero__cta{display:flex;gap:14px;flex-wrap:wrap;margin-top:46px}
.hero__scroll{position:absolute;left:var(--gut);bottom:30px;z-index:3;display:flex;align-items:center;gap:12px;font-family:var(--mono);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.hero__scroll .bar{width:1px;height:42px;background:linear-gradient(var(--gold),transparent);position:relative;overflow:hidden}
.hero__scroll .bar::after{content:"";position:absolute;top:-50%;left:0;width:100%;height:50%;background:var(--gold);animation:drop 2.2s var(--ease) infinite}
@keyframes drop{0%{top:-50%}60%,100%{top:100%}}

/* marquee strip of sectors under hero */
.hero__ticker{position:relative;z-index:3;border-top:1px solid rgba(212,180,131,.16);border-bottom:1px solid rgba(212,180,131,.16);
  background:rgba(8,15,34,.5);overflow:hidden;white-space:nowrap}
.hero__ticker .track{display:inline-flex;gap:54px;padding:16px 0;animation:scrollx 28s linear infinite;will-change:transform}
.hero__ticker .track span{font-family:var(--mono);text-transform:uppercase;letter-spacing:.22em;font-size:.78rem;color:rgba(255,255,255,.55);display:inline-flex;align-items:center;gap:54px}
.hero__ticker .track span::after{content:"◆";color:var(--gold);font-size:.6rem}
@keyframes scrollx{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ============================================================
   STAT STRIP
   ============================================================ */
.stats{background:var(--navy-deep);color:#fff;border-top:1px solid rgba(212,180,131,.14)}
.stats .grid{display:grid;grid-template-columns:repeat(4,1fr)}
.stat{padding:clamp(34px,5vw,64px) clamp(18px,3vw,40px);border-right:1px solid rgba(212,180,131,.14);position:relative}
.stat:last-child{border-right:0}
.stat .num{font-family:var(--data);font-feature-settings:"tnum" 1;font-weight:500;font-size:clamp(2.4rem,5vw,3.8rem);line-height:1;color:#fff;display:flex;align-items:baseline;gap:.04em;letter-spacing:-.03em}
.stat .num .suf{color:var(--gold);font-size:.5em;letter-spacing:0}
.stat .lbl{font-family:var(--mono);text-transform:uppercase;letter-spacing:.16em;font-size:.72rem;color:rgba(255,255,255,.6);margin-top:16px}
.stat::after{content:"";position:absolute;left:clamp(18px,3vw,40px);bottom:clamp(22px,3vw,40px);width:0;height:2px;background:var(--gold);transition:width 1s var(--ease) .2s}
.stat.in::after{width:34px}

/* ============================================================
   TRUST / BRAND STRIP
   ============================================================ */
.trust{background:var(--paper);border-bottom:1px solid var(--line-soft);padding:clamp(34px,5vw,54px) 0}
.trust__lbl{text-align:center;font-family:var(--mono);font-size:.72rem;letter-spacing:.22em;text-transform:uppercase;color:#8a93a7;margin-bottom:26px}
.trust__row{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:18px 46px}
.trust__row b{font-family:var(--display);font-weight:600;font-size:clamp(1.1rem,2.2vw,1.55rem);color:#33415e;letter-spacing:.01em;opacity:.78;transition:opacity .3s,color .3s,transform .3s}
.trust__row b:hover{opacity:1;color:var(--navy);transform:translateY(-2px)}
.trust__row .sep{width:5px;height:5px;background:var(--gold);transform:rotate(45deg);opacity:.6}
@media(max-width:600px){.trust__row .sep{display:none}.trust__row{gap:14px 26px}}

/* ============================================================
   GENERIC SECTION HEADERS
   ============================================================ */
.shead{display:grid;grid-template-columns:1.1fr 1fr;gap:40px;align-items:end;margin-bottom:64px}
.shead h2{font-size:clamp(2rem,4.6vw,3.6rem)}
.shead .lead{justify-self:start}
@media(max-width:820px){.shead{grid-template-columns:1fr;gap:20px}}

/* ============================================================
   WHO WE ARE / split
   ============================================================ */
.split{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,6vw,90px);align-items:center}
.split.rev{direction:rtl}.split.rev>*{direction:ltr}
@media(max-width:880px){.split{grid-template-columns:1fr}}
.media{position:relative}
.media img{width:100%;border-radius:var(--r);box-shadow:0 30px 70px -30px rgba(11,18,38,.5)}
.media .frame{position:absolute;inset:-14px;border:1px solid var(--line);border-radius:var(--r);pointer-events:none}
.media .badge{position:absolute;background:var(--navy-deep);color:#fff;padding:18px 22px;border-radius:var(--r);box-shadow:0 20px 40px -18px rgba(11,18,38,.6)}
.media .badge .n{font-family:var(--display);font-size:1.9rem;color:var(--gold);line-height:1}
.media .badge .t{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-top:6px}

/* ============================================================
   ECOSYSTEM (signature)
   ============================================================ */
.eco{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden}
.eco__halo{position:absolute;inset:0;background:radial-gradient(55% 55% at 50% 42%,rgba(0,108,255,.10),transparent 62%);pointer-events:none}
.eco .wrap{position:relative;z-index:2}
.eco__head{text-align:center;max-width:720px;margin:0 auto 18px}
.eco__head h2{font-size:clamp(2rem,4.6vw,3.5rem)}
.eco__head .lead{margin:18px auto 0;color:rgba(232,238,250,.78)}
.eco__stage{position:relative;width:100%;max-width:920px;margin:10px auto 0;aspect-ratio:16/11}
.eco__stage svg{position:absolute;inset:0;width:100%;height:100%;overflow:visible}
.eco-line{stroke:rgba(212,180,131,.32);stroke-width:1.2;fill:none;transition:stroke .35s,stroke-width .35s;stroke-dasharray:120;stroke-dashoffset:120}
.eco__stage.drawn .eco-line{animation:draw 1.1s var(--ease) forwards}
.eco__stage.drawn .eco-line:nth-of-type(2){animation-delay:.15s}
.eco__stage.drawn .eco-line:nth-of-type(3){animation-delay:.3s}
.eco__stage.drawn .eco-line:nth-of-type(4){animation-delay:.45s}
@keyframes draw{to{stroke-dashoffset:0}}
.eco-line.lit{stroke:var(--gold);stroke-width:2}
.node{position:absolute;transform:translate(-50%,-50%);text-align:center;cursor:pointer}
.node .chip{display:inline-flex;flex-direction:column;align-items:center;gap:7px;padding:13px 17px;border:1px solid rgba(212,180,131,.3);background:rgba(13,24,53,.72);backdrop-filter:blur(6px);border-radius:var(--r);transition:.4s var(--ease);min-width:120px}
.node .chip:hover,.node.on .chip{border-color:var(--gold);transform:translateY(-3px);box-shadow:0 18px 40px -20px rgba(0,0,0,.7)}
.node .sect{font-family:var(--mono);font-size:.58rem;letter-spacing:.18em;text-transform:uppercase;color:var(--cyan)}
.node .nm{font-family:var(--display);font-size:1.04rem;color:#fff;line-height:1.1}
.node .chip img.blogo{height:18px;width:auto;margin-top:3px;opacity:.95}
.node--core{z-index:5}
.node--core .core{width:clamp(120px,17vw,168px);height:clamp(120px,17vw,168px);display:grid;place-items:center;position:relative}
.node--core .core .dia{position:absolute;inset:0;border:1px solid var(--gold);transform:rotate(45deg);animation:spin 26s linear infinite}
.node--core .core .dia.b{inset:14px;border-color:rgba(0,190,241,.4);animation-duration:34s;animation-direction:reverse}
.node--core .core img{width:62%;position:relative;z-index:2}
@keyframes spin{to{transform:rotate(405deg)}}
.eco__readout{max-width:640px;margin:26px auto 0;text-align:center;min-height:60px;transition:opacity .35s}
@media(max-width:680px){
  .eco__stage{position:static;aspect-ratio:auto;display:grid;grid-template-columns:1fr 1fr;gap:14px;max-width:440px;margin-top:28px}
  .eco__stage svg{display:none}
  .eco__stage .node{position:static !important;transform:none !important;left:auto !important;top:auto !important}
  .eco__stage .node .chip{width:100%;min-width:0}
  .node--core{grid-column:1/3;order:-1;display:flex;justify-content:center;margin-bottom:6px}
  .node--core .core{width:120px;height:120px}
}
.eco__readout .r-nm{font-family:var(--display);font-size:1.5rem;color:var(--gold)}
.eco__readout .r-tx{color:rgba(232,238,250,.8);margin-top:6px}

/* ============================================================
   PORTFOLIO — editorial index / ledger
   ============================================================ */
/* slim facts row */
.facts{display:flex;flex-wrap:wrap;gap:0;border-top:1px solid rgba(11,18,38,.14);border-bottom:1px solid rgba(11,18,38,.14)}
.facts .f{flex:1 1 0;min-width:140px;padding:clamp(26px,3vw,40px) clamp(8px,2vw,26px);border-right:1px solid rgba(11,18,38,.1)}
.facts .f:last-child{border-right:0}
.facts .f .v{font-family:var(--data);font-feature-settings:"tnum" 1;letter-spacing:-.02em;font-size:clamp(1.5rem,2.6vw,2rem);color:var(--navy);line-height:1}
.facts .f .k{font-family:var(--mono);font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;color:#8a8472;margin-top:12px}
@media(max-width:620px){.facts .f{flex:1 1 50%;border-bottom:1px solid rgba(11,18,38,.1)}.facts .f:nth-child(2){border-right:0}}

.folio{border-top:1px solid rgba(11,18,38,.14)}
.folio__row{--accent:var(--gold);--cobg:var(--navy-deep);
  position:relative;display:grid;grid-template-columns:1fr auto;gap:clamp(20px,4vw,60px);
  align-items:center;padding:clamp(30px,4vw,52px) clamp(16px,2.5vw,28px);border-bottom:1px solid rgba(11,18,38,.12);
  transition:transform .5s var(--ease)}
/* brand rooms revealed on hover */
.folio__row--meraki{--accent:#38B5E6;--cobg:#0a1628}
.folio__row--mena{--accent:#E9AA23;--cobg:#211e1e}
.folio__row--rozhvolt{--accent:#D0FF00;--cobg:#06213f}
.folio__row--1001{--accent:#C9A24B;--cobg:#240b0b}
.folio__row::before{content:"";position:absolute;left:calc(-1 * var(--gut));right:calc(-1 * var(--gut));top:-1px;bottom:-1px;
  background:var(--cobg);opacity:0;transition:opacity .5s var(--ease);z-index:-1;box-shadow:inset 5px 0 0 var(--accent)}
.folio__row:hover::before,.folio__row:focus-within::before{opacity:1}
.folio__main{display:grid;grid-template-columns:clamp(150px,20vw,230px) 1fr;gap:clamp(20px,4vw,56px);align-items:center}
@media(max-width:680px){.folio__main{grid-template-columns:1fr;gap:16px}}
.folio__logobox{position:relative;display:inline-flex;align-items:center;min-height:50px}
.folio__logo{width:auto;max-width:100%;transition:opacity .45s var(--ease)}
.folio__logo--hover{position:absolute;left:0;top:50%;transform:translateY(-50%);opacity:0}
.folio__row:hover .folio__logo--rest,.folio__row:focus-within .folio__logo--rest{opacity:0}
.folio__row:hover .folio__logo--hover,.folio__row:focus-within .folio__logo--hover{opacity:1}
.folio__sector{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:#8a8472;margin-bottom:10px;display:block;transition:color .4s}
.folio__desc{color:#46526e;font-size:1.02rem;line-height:1.6;max-width:46ch;transition:color .4s}
.folio__row:hover .folio__sector,.folio__row:focus-within .folio__sector{color:var(--accent)}
.folio__row:hover .folio__desc,.folio__row:focus-within .folio__desc{color:rgba(255,255,255,.84)}
.folio__cta{align-self:center;text-align:right;white-space:nowrap}
.folio__link{font-family:var(--mono);font-size:.74rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);display:inline-flex;align-items:center;gap:.6em;transition:gap .35s,color .35s}
.folio__row:hover .folio__link,.folio__row:focus-within .folio__link{color:var(--accent)}
.folio__link:hover{gap:1.1em}
.folio__link .ar{width:26px;height:1px;background:currentColor;position:relative;transition:width .35s var(--ease)}
.folio__link .ar::after{content:"";position:absolute;right:0;top:-2px;width:5px;height:5px;border-top:1px solid currentColor;border-right:1px solid currentColor;transform:rotate(45deg)}
.folio__link:hover .ar{width:38px}
.folio__soon{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#a9a293;transition:color .4s}
.folio__row:hover .folio__soon,.folio__row:focus-within .folio__soon{color:rgba(255,255,255,.55)}
@media(max-width:820px){
  .folio__row{grid-template-columns:1fr;gap:14px 18px}
  .folio__cta{text-align:left;margin-top:6px}
}

/* ============================================================
   COMPANY DETAIL BLOCKS (companies page)
   ============================================================ */
.co{padding:clamp(60px,8vw,110px) 0;border-bottom:1px solid var(--line-soft);scroll-margin-top:90px}
.co:nth-child(even){background:var(--paper-2)}
.co__grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px);align-items:center}
.co:nth-child(even) .co__media{order:-1}
@media(max-width:880px){.co__grid{grid-template-columns:1fr}.co:nth-child(even) .co__media{order:0}}
.co__index{font-family:var(--data);font-size:.8rem;letter-spacing:.04em;color:var(--gold);display:flex;align-items:center;gap:.9em;margin-bottom:22px}
.co__index .sct{font-family:var(--mono);letter-spacing:.16em;color:#6b6557;padding:5px 11px;border:1px solid rgba(11,18,38,.14);border-radius:100px;font-size:.64rem;text-transform:uppercase}
.co__logo{height:clamp(30px,3.6vw,42px);width:auto;margin-bottom:18px}
.co h2{font-size:clamp(2rem,4.4vw,3.2rem);color:var(--navy);margin-bottom:8px}
.co__metrics .m .v{font-family:var(--data);font-feature-settings:"tnum" 1;letter-spacing:-.02em}
.co__tag{font-family:var(--display);font-style:italic;color:var(--gold);font-size:1.15rem;margin-bottom:18px}
.co__desc{color:#46526e;line-height:1.7;max-width:56ch}
.co__metrics{display:flex;flex-wrap:wrap;gap:30px;margin:28px 0}
.co__metrics .m .v{font-family:var(--display);font-size:clamp(1.7rem,3.2vw,2.4rem);color:var(--navy);line-height:1}
.co__metrics .m .k{font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;color:#7a8499;margin-top:7px}
.co__svc{display:flex;flex-wrap:wrap;gap:9px;margin:22px 0 30px}
.co__svc span{font-family:var(--mono);font-size:.72rem;letter-spacing:.05em;color:var(--navy);background:#fff;border:1px solid var(--line-soft);padding:9px 13px;border-radius:100px}
.co:nth-child(even) .co__svc span{background:var(--paper)}
.co__media{position:relative}
.co__media img{width:100%;border-radius:var(--r);box-shadow:0 30px 70px -34px rgba(11,18,38,.5)}
.co__media .stack{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.co__media .stack img:first-child{grid-column:1/3}
.co__media .pill{position:absolute;top:16px;left:16px;background:rgba(9,17,40,.9);color:#fff;font-family:var(--mono);font-size:.66rem;letter-spacing:.14em;text-transform:uppercase;padding:8px 13px;border-radius:100px}
.brandrow{display:flex;flex-wrap:wrap;gap:10px 22px;align-items:center;margin-top:6px}
.brandrow span{font-family:var(--display);color:#9aa3b5;font-size:1.05rem}

/* ---- Themed brand "rooms" (each company owns its colour) ---- */
.co--meraki{--accent:#38B5E6;--cobg:#0a1628}
.co--mena{--accent:#E9AA23;--cobg:#211e1e}
.co--rozhvolt{--accent:#D0FF00;--cobg:#06213f}
.co--1001{--accent:#C9A24B;--cobg:#240b0b}
.co.themed{background:var(--cobg);color:#fff;border-bottom:1px solid rgba(255,255,255,.08);position:relative;overflow:hidden}
.co.themed::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(80% 60% at 85% 0%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 60%)}
.co.themed .wrap{position:relative;z-index:1}
.co.themed .co__index{color:var(--accent)}
.co.themed .co__index .sct{color:rgba(255,255,255,.72);border-color:rgba(255,255,255,.2)}
.co.themed .co__tag{color:var(--accent)}
.co.themed .co__desc{color:rgba(255,255,255,.8)}
.co.themed .co__metrics .v{color:#fff}
.co.themed .co__metrics .k{color:rgba(255,255,255,.55)}
.co.themed .co__svc span{background:rgba(255,255,255,.05);border-color:rgba(255,255,255,.16);color:rgba(255,255,255,.86)}
.co.themed .pill{background:var(--accent);color:#0a0f14}
.co.themed .co__media img{box-shadow:0 30px 70px -34px rgba(0,0,0,.7)}
.co.themed .btn{--bg:var(--accent);--fg:#0a0f14;border-color:var(--accent)}
.co.themed .btn:hover{filter:brightness(1.08)}
.co.themed .btn.outline-ink{--bg:transparent;--fg:#fff;border-color:rgba(255,255,255,.3)}
.co.themed .btn.outline-ink:hover{background:var(--accent);color:#0a0f14;border-color:var(--accent)}
.co.themed .co__logo{filter:drop-shadow(0 2px 10px rgba(0,0,0,.35))}

/* ============================================================
   GROW — audience entry points (light, un-boxed)
   ============================================================ */
.grow{background:var(--paper)}
.grow__head{max-width:680px;margin-bottom:clamp(40px,5vw,68px)}
.grow__list{display:grid;grid-template-columns:1fr 1fr;gap:0 clamp(40px,6vw,88px)}
@media(max-width:760px){.grow__list{grid-template-columns:1fr}}
.gitem{display:block;padding:clamp(28px,3.4vw,42px) 0;border-top:1px solid rgba(11,18,38,.12);transition:padding .45s var(--ease)}
.gitem:hover{padding-left:10px}
.gicon{width:30px;height:30px;color:var(--gold);margin-bottom:20px;stroke-width:1.4}
.gitem .pk{font-family:var(--mono);font-size:.64rem;letter-spacing:.2em;text-transform:uppercase;color:#8a8472;display:block;margin-bottom:12px}
.gitem h3{font-family:var(--display);font-weight:500;font-size:clamp(1.4rem,2.4vw,1.85rem);color:var(--navy);margin-bottom:12px}
.gitem p{color:#52607a;font-size:.97rem;line-height:1.65;max-width:42ch;margin-bottom:18px}
.gitem .glink{font-family:var(--mono);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);display:inline-flex;align-items:center;gap:.6em;transition:gap .35s,color .35s}
.gitem:hover .glink{gap:1em;color:var(--gold)}

/* ============================================================
   QUOTE / FOUNDER
   ============================================================ */
.quote{background:var(--paper-2);position:relative;overflow:hidden}
.quote .wrap{position:relative;z-index:2;display:grid;grid-template-columns:.85fr 1.15fr;gap:clamp(34px,6vw,80px);align-items:center}
@media(max-width:880px){.quote .wrap{grid-template-columns:1fr}}
.quote__mark{font-family:var(--display);font-size:9rem;line-height:.6;color:var(--gold);opacity:.5;height:60px}
.quote blockquote{margin:0;font-family:var(--display);font-size:clamp(1.5rem,3.2vw,2.4rem);line-height:1.32;color:var(--navy);font-weight:500}
.quote .who{margin-top:30px;display:flex;align-items:center;gap:16px}
.quote .who .l{width:34px;height:1px;background:var(--gold)}
.quote .who b{font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;font-size:.8rem;color:var(--navy)}
.quote .who span{font-family:var(--mono);font-size:.72rem;letter-spacing:.08em;color:#6b7895;text-transform:uppercase}
.portrait{position:relative}
.portrait img{border-radius:var(--r);width:100%}
.portrait .tag{position:absolute;bottom:18px;left:18px;background:rgba(9,17,40,.9);color:#fff;padding:12px 18px;border-radius:var(--r)}
.portrait .tag b{font-family:var(--display);font-size:1.05rem;display:block;color:var(--gold)}
.portrait .tag span{font-family:var(--mono);font-size:.64rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.7)}

/* ============================================================
   SECTORS / capabilities list
   ============================================================ */
.cap{border-top:1px solid var(--line-soft)}
.cap__row{display:grid;grid-template-columns:80px 1fr auto;gap:30px;align-items:center;padding:30px 0;border-bottom:1px solid var(--line-soft);transition:padding .4s var(--ease),background .4s}
.cap__row:hover{padding-left:18px;padding-right:18px;background:#fff}
.cap__no{font-family:var(--mono);color:var(--gold);font-size:.9rem;letter-spacing:.1em}
.cap__name{font-family:var(--display);font-size:clamp(1.3rem,2.6vw,1.9rem);color:var(--navy)}
.cap__desc{max-width:46ch;color:#5d6a86;font-size:.95rem}
@media(max-width:760px){.cap__row{grid-template-columns:50px 1fr}.cap__desc{display:none}}

/* ============================================================
   CTA BAND
   ============================================================ */
.cta-band{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden;text-align:center}
.cta-band__glow{position:absolute;inset:0;background:radial-gradient(60% 120% at 50% 0%,rgba(27,49,99,.5),transparent 58%)}
.cta-band .wrap{position:relative;z-index:2}
.cta-band h2{font-size:clamp(2.1rem,5.4vw,4rem);max-width:18ch;margin:0 auto}
.cta-band p{color:rgba(232,238,250,.78);max-width:52ch;margin:22px auto 0;font-size:1.1rem}
.cta-band .hero__cta{justify-content:center}

/* lean CTA — interior pages (light, editorial, left-aligned) */
.cta-edge{background:var(--paper);border-top:1px solid rgba(11,18,38,.12)}
.cta-edge .wrap{display:grid;grid-template-columns:1.4fr auto;gap:40px;align-items:center}
@media(max-width:760px){.cta-edge .wrap{grid-template-columns:1fr;gap:26px}}
.cta-edge h2{font-size:clamp(1.8rem,3.6vw,2.8rem);color:var(--navy);max-width:20ch}
.cta-edge p{color:#52607a;margin-top:14px;max-width:46ch}
.cta-edge__act{display:flex;gap:14px;flex-wrap:wrap}

/* ============================================================
   FOOTER
   ============================================================ */
.foot{background:var(--navy-900);color:#fff;padding-top:clamp(60px,8vw,100px)}
.foot__top{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:60px;border-bottom:1px solid rgba(212,180,131,.14)}
@media(max-width:880px){.foot__top{grid-template-columns:1fr 1fr}}
@media(max-width:540px){.foot__top{grid-template-columns:1fr}}
.foot__brand img{height:34px;margin-bottom:20px}
.foot__brand p{color:rgba(232,238,250,.6);max-width:32ch;font-size:.95rem}
.foot h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:600}
.foot ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.foot ul a,.foot address{color:rgba(232,238,250,.7);font-style:normal;font-size:.92rem;transition:color .3s}
.foot ul a:hover{color:var(--gold)}
.foot address{line-height:1.8}
.foot__bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;padding:26px 0;flex-wrap:wrap}
.foot__bottom small{color:rgba(232,238,250,.5);font-size:.8rem;letter-spacing:.02em}
.foot__bottom .tagline{font-family:var(--display);font-style:italic;color:var(--gold);font-size:1.05rem}

/* ============================================================
   PAGE HEADER (interior pages)
   ============================================================ */
.phead{background:var(--navy-deep);color:#fff;position:relative;overflow:hidden;padding:160px 0 clamp(60px,9vw,110px)}
.phead__bg{position:absolute;inset:0;opacity:.16}
.phead__bg img{width:100%;height:100%;object-fit:cover}
.phead::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(9,17,40,.7),rgba(9,17,40,.94))}
.phead .wrap{position:relative;z-index:2}
.phead h1{font-size:clamp(2.6rem,7vw,5.4rem);max-width:16ch}
.phead .lead{color:rgba(232,238,250,.8);margin-top:24px}
.crumbs{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:rgba(212,180,131,.8);margin-bottom:26px;display:flex;gap:.7em;align-items:center}
.crumbs a{color:rgba(255,255,255,.6)}
.crumbs a:hover{color:#fff}

/* ============================================================
   VISION / MISSION diamonds
   ============================================================ */
.vm{display:grid;grid-template-columns:1fr 1fr;gap:clamp(20px,4vw,50px)}
@media(max-width:760px){.vm{grid-template-columns:1fr}}
.vm__card{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:clamp(30px,4vw,52px);position:relative;overflow:hidden}
.vm__card::before{content:"";position:absolute;top:-40px;right:-40px;width:140px;height:140px;border:1px solid var(--line);transform:rotate(45deg)}
.vm__card .k{font-family:var(--mono);letter-spacing:.2em;text-transform:uppercase;font-size:.72rem;color:var(--gold);margin-bottom:18px;display:block}
.vm__card h3{font-size:clamp(1.6rem,3vw,2.3rem);color:var(--navy);margin-bottom:16px}
.vm__card p{color:#46526e;line-height:1.7}

/* values */
.values{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(16px,2vw,24px)}
@media(max-width:820px){.values{grid-template-columns:1fr}}
.val{padding:30px 0 4px;border-top:1px solid rgba(11,18,38,.14);transition:padding .4s var(--ease)}
.val:hover{padding-left:8px}
.val .vno{font-family:var(--data);font-size:.9rem;letter-spacing:-.02em;color:var(--gold)}
.val h4{font-family:var(--display);font-weight:500;font-size:1.3rem;color:var(--navy);margin:14px 0 10px}
.val p{color:#5d6a86;font-size:.94rem;line-height:1.6;max-width:38ch}

/* ============================================================
   CONTACT
   ============================================================ */
.contact{display:grid;grid-template-columns:1fr 1fr;gap:clamp(34px,6vw,80px)}
@media(max-width:880px){.contact{grid-template-columns:1fr}}
.cinfo .ci{display:flex;gap:18px;padding:24px 0;border-bottom:1px solid var(--line-soft)}
.cinfo .ci .ic{width:46px;height:46px;flex:none;display:grid;place-items:center;border:1px solid var(--line);border-radius:var(--r);color:var(--gold)}
.cinfo .ci .ic svg{width:20px;height:20px}
.cinfo .ci h4{font-family:var(--mono);font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;color:#8a93a7;margin:0 0 6px}
.cinfo .ci p,.cinfo .ci a{color:var(--navy);font-size:1.05rem;font-weight:500}
.cinfo .ci a:hover{color:var(--blue)}
.form{background:#fff;border:1px solid var(--line-soft);border-radius:var(--r);padding:clamp(26px,4vw,44px)}
.form .fg{margin-bottom:20px}
.form label{display:block;font-family:var(--mono);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:#6b7895;margin-bottom:9px}
.form input,.form textarea,.form select{width:100%;padding:14px 16px;border:1px solid var(--line-soft);border-radius:var(--r);font-family:var(--body);font-size:1rem;background:var(--paper);color:var(--ink);transition:border-color .3s,box-shadow .3s}
.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--gold);box-shadow:0 0 0 3px rgba(212,180,131,.18)}
.form textarea{min-height:130px;resize:vertical}
.form .note{font-size:.8rem;color:#8a93a7;margin-top:8px}

/* ============================================================
   REVEAL ANIMATIONS
   ============================================================ */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.08s}.reveal.d2{transition-delay:.16s}.reveal.d3{transition-delay:.24s}.reveal.d4{transition-delay:.32s}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:980px){
  .nav__links,.nav__cta .btn{display:none}
  .nav__burger{display:block}
  .nav__menu{position:fixed;inset:0 0 0 auto;width:min(82vw,360px);background:var(--navy-900);transform:translateX(100%);transition:transform .5s var(--ease);
    display:flex;flex-direction:column;justify-content:center;gap:30px;padding:40px;z-index:55;box-shadow:-30px 0 60px -30px rgba(0,0,0,.6)}
  .nav.open .nav__menu{transform:translateX(0)}
  .nav__menu .nav__links{display:flex;flex-direction:column;gap:26px;align-items:flex-start}
  .nav__menu .nav__links a{font-size:1.1rem}
  .nav__menu .btn{display:inline-flex !important;margin-top:10px}
}
@media(max-width:760px){
  .stats .grid{grid-template-columns:1fr 1fr}
  .stat:nth-child(2){border-right:0}
  .stat:nth-child(1),.stat:nth-child(2){border-bottom:1px solid rgba(212,180,131,.14)}
}
@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}
}
:focus-visible{outline:2px solid var(--gold);outline-offset:3px;border-radius:2px}
.skip{position:fixed;top:-60px;left:14px;z-index:100;background:var(--gold);color:var(--navy-deep);padding:12px 18px;border-radius:var(--r);font-family:var(--mono);font-size:.8rem;letter-spacing:.06em;text-transform:uppercase;transition:top .3s var(--ease)}
.skip:focus{top:14px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
