/* ── EOW Global Styles ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{--bg:#0b0b0b;--bgw:#111110;--sf:#181817;--bd:#2a2a28;--tx:#ececea;--ts:#9a9a96;--td:#666662;--ac:#c8a96e;--acs:rgba(200,169,110,0.1);--se:'DM Serif Display',Georgia,serif;--sa:'Inter',-apple-system,sans-serif;--mw:1200px;--g:clamp(1.5rem,4vw,4rem)}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased}
body{font-family:var(--sa);background:var(--bg);color:var(--tx);line-height:1.6;overflow-x:hidden}
a{color:inherit;text-decoration:none}img{max-width:100%;display:block}
.c{max-width:var(--mw);margin:0 auto;padding:0 var(--g)}

/* ── Header ── */
.hd{position:fixed;top:0;left:0;right:0;z-index:100;padding:1.5rem 0}
.hd .c{display:flex;justify-content:space-between;align-items:center}
.lo{font-size:1.1rem;font-weight:600;letter-spacing:.15em;text-transform:uppercase;display:flex;align-items:center;gap:.75rem}
.lo img{height:36px;width:auto;filter:invert(1) brightness(2)}
.lo span{color:var(--td);font-weight:300;margin-left:.5rem;letter-spacing:.05em;font-size:.75rem}
.hdr{display:flex;align-items:center;gap:1.2rem}
.lb{font-size:.78rem;letter-spacing:.1em;padding:.35rem .8rem;border:1px solid var(--bd);background:transparent;color:var(--ts);cursor:pointer;border-radius:2px;transition:color .2s,border-color .2s;font-family:var(--sa)}
.lb:hover{color:var(--tx);border-color:var(--ts)}
.hb{width:32px;height:24px;cursor:pointer;display:flex;flex-direction:column;justify-content:space-between;background:none;border:none;padding:0;z-index:200}
.hb span{display:block;width:100%;height:2px;background:var(--tx);transition:transform .3s,opacity .3s}
.hb.open span:nth-child(1){transform:translateY(11px) rotate(45deg)}
.hb.open span:nth-child(2){opacity:0}
.hb.open span:nth-child(3){transform:translateY(-11px) rotate(-45deg)}

/* ── Menu Overlay ── */
.menu-ov{position:fixed;inset:0;background:rgba(11,11,11,.96);z-index:150;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2.5rem;opacity:0;pointer-events:none;transition:opacity .35s ease;backdrop-filter:blur(20px)}
.menu-ov.open{opacity:1;pointer-events:auto}
.menu-ov a{font-family:var(--se);font-size:clamp(2rem,5vw,3.5rem);color:var(--tx);transition:color .2s}
.menu-ov a:hover{color:var(--ac)}
.menu-ov .menu-sep{width:60px;height:1px;background:var(--bd)}
.menu-ov .menu-ext{font-family:var(--sa);font-size:1rem;color:var(--td);letter-spacing:.05em}
.menu-ov .menu-ext:hover{color:var(--ac)}

/* ── Hero (Landing Only) ── */
.hero{min-height:100vh;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.trail-container{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;overflow:hidden;z-index:1}
.trail-img{position:absolute;width:clamp(160px,16vw,260px);height:auto;opacity:0;pointer-events:none;border-radius:3px;box-shadow:0 8px 40px rgba(0,0,0,.4);transition:opacity .6s ease-out,transform .6s ease-out}
.hero-bottom{position:relative;width:100%;padding:0 var(--g) 4vh;display:flex;justify-content:space-between;align-items:flex-end;gap:2rem;z-index:5}
.hero-text{max-width:640px}
.hero-text h1{font-family:var(--se);font-size:clamp(2.2rem,5.5vw,4.2rem);line-height:1.15;font-weight:400;margin-bottom:1rem}
.hero-text h1 em{font-style:italic;color:var(--ac)}
.hero-text p{font-size:clamp(.88rem,1.3vw,1.05rem);color:var(--ts);line-height:1.7;font-weight:300;margin-top:.4rem}
.hero-links{display:flex;flex-direction:column;align-items:flex-end;gap:.8rem;flex-shrink:0}
.hero-links a{font-size:.82rem;color:var(--ac);letter-spacing:.06em;transition:opacity .2s;white-space:nowrap}
.hero-links a:hover{opacity:.7}

/* ── Page Header (inner pages) ── */
.page-hero{padding:clamp(8rem,15vh,12rem) 0 clamp(4rem,8vh,6rem);background:var(--bg)}

/* ── Shared Section Styles ── */
.s{padding:clamp(5rem,10vh,8rem) 0}
.sl{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ac);margin-bottom:1.5rem;font-weight:500}
.sh{font-family:var(--se);font-size:clamp(2rem,4vw,3.2rem);line-height:1.2;max-width:700px;margin-bottom:1.5rem}
.sd{color:var(--ts);max-width:520px;line-height:1.75;font-weight:300;font-size:.95rem}

/* ── About ── */
.ab{background:var(--bgw)}
.abg{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:start}
.abr{padding-top:3rem}
.abq{font-family:var(--se);font-size:1.5rem;line-height:1.6;font-style:italic;border-left:2px solid var(--ac);padding-left:1.5rem;margin-bottom:2rem}
.abp{color:var(--ts);font-size:.9rem;line-height:1.8;font-weight:300}
.abn{display:flex;gap:3rem;margin-top:3rem;padding-top:2rem;border-top:1px solid var(--bd)}
.abnv{font-family:var(--se);font-size:1.8rem;color:var(--ac)}
.abnl{font-size:.72rem;color:var(--td);text-transform:uppercase;letter-spacing:.08em;margin-top:.2rem}

/* ── TaaS Banner ── */
.ta{background:var(--acs);border-top:1px solid rgba(200,169,110,.2);border-bottom:1px solid rgba(200,169,110,.2)}
.tai{display:grid;grid-template-columns:auto 1fr;gap:3rem;align-items:center}
.tab{font-family:var(--se);font-size:clamp(1.3rem,2.5vw,2rem);color:var(--ac);white-space:nowrap}
.tac{color:var(--ts);font-size:.92rem;line-height:1.7;font-weight:300}
.tac strong{color:var(--tx);font-weight:500}

/* ── Services Grid ── */
.svg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bd);margin-top:3rem}
.sv{background:var(--bg);padding:2.5rem;transition:background .3s;position:relative}
.sv:hover{background:var(--sf)}
.svn{font-family:var(--se);font-size:3rem;color:var(--bd);margin-bottom:1.5rem;line-height:1}
.svt{font-size:1.05rem;font-weight:500;margin-bottom:.75rem}
.svd{font-size:.85rem;color:var(--ts);line-height:1.7;font-weight:300}
.svtg{position:absolute;top:1.5rem;right:1.5rem;font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ac);border:1px solid rgba(200,169,110,.3);padding:.2rem .5rem;border-radius:2px}

/* ── Portfolio Grid ── */
.pf{background:var(--bgw)}
.pft{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:3rem;flex-wrap:wrap;gap:1rem}
.pfl{font-size:.82rem;color:var(--ac);display:inline-flex;align-items:center;gap:.5rem;transition:gap .3s}
.pfl:hover{gap:.9rem}
.pfg{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1px;background:var(--bd)}
.pfc{background:var(--bg);padding:2rem 2rem 1.75rem;transition:background .3s}
.pfc:hover{background:var(--sf)}
.pfct{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.5rem}
.pfcy{font-family:var(--se);font-size:1rem;color:var(--td)}
.pfcp{font-size:.65rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ac);border:1px solid rgba(200,169,110,.25);padding:.15rem .5rem;border-radius:2px}
.pfcn{font-size:1.15rem;font-weight:500;margin-bottom:.5rem}
.pfcs{font-size:.78rem;color:var(--td)}

/* ── Team Grid ── */
.tmg{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--bd);margin-top:3rem}
.tmc{background:var(--bg);padding:2.5rem}
.tmd{font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--ac);margin-bottom:1.5rem}
.tmn{font-family:var(--se);font-size:1.4rem;margin-bottom:.25rem}
.tmk{font-size:.85rem;color:var(--ts);margin-bottom:1rem}
.tmr{font-size:.8rem;color:var(--td);text-transform:uppercase;letter-spacing:.08em;margin-bottom:1.5rem}
.tmct{font-size:.82rem;color:var(--ts);line-height:2}
.tmct a{transition:color .2s}
.tmct a:hover{color:var(--ac)}

/* ── Partners ── */
.ptr-hero{display:grid;grid-template-columns:1fr 1fr;gap:4rem;align-items:center;margin-top:3rem}
.ptr-logo{max-width:280px}
.ptr-logo img{width:100%;filter:invert(1)}
.ptr-desc{color:var(--ts);font-size:.95rem;line-height:1.8;font-weight:300}
.ptr-desc h3{font-family:var(--se);font-size:1.6rem;color:var(--tx);margin-bottom:1rem}
.ptr-desc a{color:var(--ac);transition:opacity .2s}
.ptr-desc a:hover{opacity:.7}
.ptr-clients{margin-top:4rem;padding-top:3rem;border-top:1px solid var(--bd)}
.ptr-cat{margin-bottom:2rem}
.ptr-cat h4{font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;color:var(--ac);margin-bottom:.75rem}
.ptr-cat p{color:var(--ts);font-size:.9rem;line-height:1.8;font-weight:300}

/* ── Contact ── */
.ct{background:var(--sf);text-align:center;padding:clamp(6rem,12vh,10rem) 0}
.cth{font-family:var(--se);font-size:clamp(2rem,4vw,3rem);margin-bottom:1rem}
.cts{color:var(--ts);font-size:.95rem;max-width:480px;margin:0 auto 3rem;line-height:1.7;font-weight:300}
.cte{display:inline-block;font-size:1.1rem;color:var(--ac);border-bottom:1px solid var(--ac);padding-bottom:.15rem;transition:opacity .2s}
.cte:hover{opacity:.7}

/* ── CTA Strip ── */
.cta-strip{padding:3rem 0;border-top:1px solid var(--bd);display:flex;justify-content:center;gap:3rem;flex-wrap:wrap}
.cta-strip a{font-size:.85rem;color:var(--ac);letter-spacing:.06em;transition:opacity .2s}
.cta-strip a:hover{opacity:.7}

/* ── Footer ── */
.ft{border-top:1px solid var(--bd);padding:2rem 0}
.ft .c{display:flex;justify-content:space-between;align-items:center}
.ftc{font-size:.75rem;color:var(--td)}
.ft-logos{display:flex;align-items:center;gap:1rem}
.ft-logos img{height:56px;width:auto;filter:invert(1);opacity:.6;transition:opacity .2s}
.ft-logos img:hover{opacity:.9}

/* ── Scroll Reveal ── */
.rv{opacity:0;transform:translateY(30px);transition:opacity .8s,transform .8s}
.rv.vi{opacity:1;transform:translateY(0)}

/* ── Responsive ── */
@media(max-width:900px){
  .abg{grid-template-columns:1fr;gap:2rem}.abr{padding-top:0}
  .svg{grid-template-columns:1fr}.tmg{grid-template-columns:1fr}
  .pfg{grid-template-columns:1fr}.tai{grid-template-columns:1fr;gap:1rem}
  .hero-bottom{flex-direction:column;align-items:flex-start}
  .hero-links{align-items:flex-start}
  .ptr-hero{grid-template-columns:1fr;gap:2rem}
  .ft .c{flex-direction:column;gap:1rem;text-align:center}
  .cta-strip{flex-direction:column;align-items:center;gap:1.5rem}
}
