/* ═══════════════════════════════════════════════════════════════
   SiteDXP — ULTRA LUXURY · Cinematic Dark · Premium Agency
   Concept: Obsidian surfaces · liquid gold accents · editorial depth
   Every section breathes. Every hover has ceremony.
═══════════════════════════════════════════════════════════════ */
@import url('https://fonts.googleapis.com/css2?family=Montserrat:ital,wght@0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,300&display=swap');

/* ══ TOKENS ══ */
:root{
  --black:#050809;
  --bg:#080D0D;
  --bg2:#0C1414;
  --bg3:#101818;
  --card:#131D1D;
  --card2:#182424;
  --lift:#1D2B2B;
  --l1:rgba(255,255,255,.05);
  --l2:rgba(255,255,255,.1);
  --l3:rgba(255,255,255,.18);
  --t0:#FFFFFF;
  --t1:#F2EEE6;
  --t2:#C6C2BA;
  --t3:#7C8880;
  --t4:#4A5450;
  --gold:#D4A843;
  --gold2:#E8C068;
  --gold3:#F5D580;
  --gd:rgba(212,168,67,.1);
  --gm:rgba(212,168,67,.22);
  --gb:rgba(212,168,67,.06);
  --teal:#4A8880;
  --teal2:#5CA898;
  --td:rgba(74,136,128,.12);
  --font:'Montserrat',sans-serif;
  --e:cubic-bezier(.16,1,.3,1);
  --snap:cubic-bezier(.25,.46,.45,.94);
  --spring:cubic-bezier(.34,1.56,.64,1);
}

/* ══ BASE ══ */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--bg);
  color:var(--t1);
  font-family:var(--font);
  font-weight:400;
  line-height:1;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
img{display:block;max-width:100%}
button{cursor:pointer;font-family:var(--font)}
::selection{background:rgba(212,168,67,.2);color:var(--gold3)}
::-webkit-scrollbar{width:3px}
::-webkit-scrollbar-track{background:var(--bg)}
::-webkit-scrollbar-thumb{background:var(--t4);border-radius:2px}

/* ══ KEYFRAMES ══ */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.3;transform:scale(1.7)}}
@keyframes float{0%,100%{transform:translateY(0) rotate(.2deg)}50%{transform:translateY(-14px) rotate(-.2deg)}}
@keyframes tick{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes sAnim{0%,100%{opacity:0;transform:scaleY(0) translateY(-8px)}50%{opacity:1;transform:scaleY(1) translateY(0)}}
@keyframes xPop{from{opacity:0;transform:scale(0) rotate(-20deg)}60%{transform:scale(1.3) rotate(8deg)}to{opacity:1;transform:scale(1) rotate(0)}}
@keyframes shimmer{0%{background-position:-200% center}100%{background-position:200% center}}
@keyframes goldLine{from{transform:scaleX(0)}to{transform:scaleX(1)}}
@keyframes scanDown{from{transform:translateY(-100%)}to{transform:translateY(200%)}}

/* ══ LOGO ══ */
.logo{font-family:var(--font);font-weight:900;font-size:20px;letter-spacing:.1em;text-transform:uppercase;color:var(--t1);display:inline-flex;align-items:center;line-height:1;user-select:none}
.logo .l-d,.logo .l-p{color:var(--teal2)}
.logo .l-x{color:var(--gold);display:inline-block;transition:transform .4s var(--spring),color .2s}
.logo:hover .l-x{transform:rotate(14deg) scale(1.2);color:var(--gold3)}
.logo-anim .l-x{animation:xPop .7s var(--spring) .5s both}
.logo-lg{font-size:26px}

/* ══ NAV ══ */
#nav{
  position:fixed;top:0;left:0;right:0;z-index:900;height:64px;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 52px;
  background:rgba(8,13,13,.82);
  backdrop-filter:blur(32px) saturate(1.8);
  -webkit-backdrop-filter:blur(32px) saturate(1.8);
  border-bottom:1px solid var(--l1);
  transition:background .5s,border-color .4s;
}
#nav.scrolled{background:rgba(8,13,13,.96);border-bottom-color:var(--l2)}
/* Animated gold underline on scroll */
#nav.scrolled::after{
  content:'';position:absolute;bottom:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent 0%,var(--gold) 30%,var(--gold2) 50%,var(--gold) 70%,transparent 100%);
  opacity:.25;
  animation:goldLine .6s var(--e) both;
}
.nav-links{display:flex;list-style:none;gap:36px;align-items:center}
.nav-links a{
  font-size:10px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;
  color:var(--t3);
  transition:color .25s;
  position:relative;padding-bottom:2px;
}
.nav-links a::after{
  content:'';position:absolute;bottom:-2px;left:0;width:100%;height:1px;
  background:var(--gold);
  transform:scaleX(0);transform-origin:left;
  transition:transform .32s var(--e);
}
.nav-links a:hover{color:var(--t1)}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1)}
.nav-links a.active{color:var(--gold)}
.nav-cta{
  font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;
  padding:11px 26px;
  background:var(--gold);color:var(--black);
  border:none;outline:none;cursor:pointer;
  position:relative;overflow:hidden;
  transition:background .25s,transform .2s;
}
/* Shimmer sweep */
.nav-cta::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.22) 50%,transparent 60%);
  transform:translateX(-100%);
  transition:transform .55s var(--e);
}
.nav-cta:hover{background:var(--gold2);transform:translateY(-1px)}
.nav-cta:hover::before{transform:translateX(100%)}
.nav-ham{display:none;flex-direction:column;gap:5px;background:none;border:none;padding:6px}
.nav-ham span{display:block;width:22px;height:1.5px;background:var(--t1);transition:all .3s var(--e)}
.nav-ham.open span:nth-child(1){transform:translateY(6.5px) rotate(45deg)}
.nav-ham.open span:nth-child(2){opacity:0;transform:scaleX(0)}
.nav-ham.open span:nth-child(3){transform:translateY(-6.5px) rotate(-45deg)}
.mob-menu{display:none;position:fixed;top:64px;left:0;right:0;z-index:899;background:rgba(8,13,13,.98);border-bottom:1px solid var(--l2);flex-direction:column;padding:0 0 24px}
.mob-menu.open{display:flex}
.mob-menu a{display:block;padding:16px 28px;font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--t3);border-bottom:1px solid var(--l1);transition:color .2s,background .2s,padding-left .2s}
.mob-menu a:hover{color:var(--t1);background:var(--card);padding-left:38px}
.mob-menu .mob-cta{margin:16px 28px 0;background:var(--gold);color:var(--black);text-align:center;border-bottom:none;padding:14px;font-weight:800}

/* ══ BUTTONS ══ */
.btn-primary{
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 36px;
  background:var(--gold);color:var(--black);
  font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  border:none;cursor:pointer;
  position:relative;overflow:hidden;
  transition:background .25s,transform .2s;
}
.btn-primary::before{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(255,255,255,.22) 50%,transparent 60%);transform:translateX(-100%);transition:transform .55s var(--e)}
.btn-primary:hover{background:var(--gold2);transform:translateY(-2px)}
.btn-primary:hover::before{transform:translateX(100%)}
.btn-outline{
  display:inline-flex;align-items:center;gap:9px;
  padding:13px 36px;
  border:1px solid var(--l3);color:var(--t2);
  font-size:10px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;
  background:transparent;
  transition:all .25s;
  position:relative;overflow:hidden;
}
.btn-outline::before{content:'';position:absolute;inset:0;background:var(--gd);opacity:0;transition:opacity .25s}
.btn-outline:hover{border-color:var(--gold);color:var(--gold)}
.btn-outline:hover::before{opacity:1}
.btn-coral{
  display:inline-flex;align-items:center;gap:9px;
  padding:14px 36px;
  background:var(--card2);color:var(--t1);
  font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;
  border:1px solid var(--l2);
  transition:all .25s;
}
.btn-coral:hover{background:var(--lift);border-color:var(--l3);transform:translateY(-2px)}

/* ══ REVEAL ══ */
.rv{opacity:0;transform:translateY(28px);transition:opacity .85s var(--e),transform .85s var(--e)}
.rv.in{opacity:1;transform:translateY(0)}

/* ══ SECTION ANATOMY ══ */
.sec{padding:120px 52px}
.sec-tag{
  font-size:9px;font-weight:700;letter-spacing:.42em;text-transform:uppercase;
  color:var(--gold);display:inline-block;margin-bottom:18px;
  padding:5px 18px;
  border:1px solid var(--gm);
  background:var(--gb);
  position:relative;
}
.sec-tag::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold)}
.sec-h{
  font-size:clamp(40px,6.5vw,96px);
  font-weight:900;line-height:.86;letter-spacing:-.03em;
  margin-bottom:56px;color:var(--t0);
}
.sec-h em{font-style:normal;color:var(--gold)}

/* ══ PAGE HERO ══ */
.page-hero{
  min-height:380px;display:flex;align-items:flex-end;
  padding:100px 52px 68px;
  position:relative;overflow:hidden;
  border-bottom:1px solid var(--l1);
  background:var(--bg);
}
.page-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 80% at 5% 100%,rgba(74,136,128,.08),transparent 60%),radial-gradient(ellipse 40% 60% at 95% 0%,rgba(212,168,67,.04),transparent 55%);pointer-events:none}
.page-hero .grid-bg{position:absolute;inset:0;background-image:linear-gradient(var(--l1) 1px,transparent 1px),linear-gradient(90deg,var(--l1) 1px,transparent 1px);background-size:60px 60px}
.ph-inner{position:relative;z-index:1;max-width:900px}
.ph-tag{font-size:9px;font-weight:700;letter-spacing:.38em;text-transform:uppercase;color:var(--gold);display:inline-block;margin-bottom:22px;padding:5px 16px;border:1px solid var(--gm);background:var(--gb)}
.ph-h{font-size:clamp(48px,8vw,104px);font-weight:900;line-height:.86;letter-spacing:-.03em;color:var(--t0)}
.ph-sub{font-size:16px;color:var(--t3);line-height:1.92;margin-top:24px;font-weight:400;max-width:540px}

/* ══ HERO ══ */
#hero{
  min-height:100vh;display:flex;align-items:center;
  position:relative;overflow:hidden;
  padding:64px 52px 60px;
}
.hero-video-wrap{position:absolute;inset:0;z-index:0}
.hero-video{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.hero-video-overlay{
  position:absolute;inset:0;
  background:linear-gradient(112deg,rgba(8,13,13,.97) 0%,rgba(8,13,13,.88) 44%,rgba(8,13,13,.52) 100%);
}
/* Fine grid */
.hero-grid{position:absolute;inset:0;z-index:1;pointer-events:none;background-image:linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px);background-size:68px 68px}
/* Scanning light effect */
.hero-grid::after{
  content:'';position:absolute;top:0;left:0;right:0;height:40px;
  background:linear-gradient(to bottom,rgba(212,168,67,.03),transparent);
  animation:scanDown 8s linear infinite;
  pointer-events:none;
}
/* Vertical divider */
.hero-divider{position:absolute;left:52%;top:0;bottom:0;width:1px;z-index:2;pointer-events:none;background:linear-gradient(to bottom,transparent,rgba(212,168,67,.16) 28%,rgba(212,168,67,.24) 50%,rgba(212,168,67,.16) 72%,transparent)}
.hero-inner{position:relative;z-index:3;text-align:left;max-width:560px;flex-shrink:0}
.hero-chip{
  display:inline-flex;align-items:center;gap:10px;
  padding:8px 20px;margin-bottom:40px;
  border:1px solid var(--gm);background:var(--gb);
  font-size:9px;font-weight:700;letter-spacing:.34em;text-transform:uppercase;
  color:var(--gold);
  animation:fadeUp .5s .1s both;
  position:relative;overflow:hidden;
}
.hero-chip::after{content:'';position:absolute;inset:0;background:linear-gradient(105deg,transparent 40%,rgba(212,168,67,.08) 50%,transparent 60%);animation:shimmer 4s ease-in-out infinite;background-size:200% auto}
.chip-dot{width:6px;height:6px;border-radius:50%;background:var(--gold);animation:pulse 2.5s infinite}
h1.hero-h{font-size:clamp(60px,8.5vw,140px);font-weight:900;line-height:.85;letter-spacing:-.035em;margin-bottom:28px;animation:fadeUp .6s .2s both}
.hero-h .hw{display:block;color:var(--t0)}
.hero-h .hg{
  display:block;color:transparent;
  -webkit-text-stroke:2px var(--teal2);
  filter:drop-shadow(0 0 18px rgba(92,168,152,.28));
}
.hero-p{font-size:15px;color:var(--t3);max-width:420px;margin:0 0 46px;line-height:2;font-weight:400;animation:fadeUp .6s .35s both}
.hero-acts{display:flex;gap:14px;flex-wrap:wrap;animation:fadeUp .6s .5s both}
.hero-stats{display:flex;margin-top:60px;padding-top:36px;border-top:1px solid var(--l1);animation:fadeUp .6s .65s both}
.h-stat{padding:0 44px 0 0;text-align:left}
.h-stat+.h-stat{padding-left:44px;border-left:1px solid var(--l2)}
.stat-n{font-size:46px;font-weight:900;line-height:1;color:var(--gold)}
.stat-l{font-size:9px;letter-spacing:.24em;text-transform:uppercase;color:var(--t4);margin-top:8px;font-weight:600}
.scroll-cue{position:absolute;bottom:32px;left:52px;display:flex;flex-direction:column;align-items:flex-start;gap:8px;animation:fadeUp .5s .9s both;z-index:4}
.scroll-cue span{font-size:8px;letter-spacing:.38em;text-transform:uppercase;color:var(--t4);font-weight:600}
.scroll-line{width:1px;height:48px;background:linear-gradient(to bottom,var(--gold),transparent);animation:sAnim 2.4s ease-in-out infinite}

/* Hero card */
.hero-centrepiece{position:absolute;right:52px;top:50%;transform:translateY(-50%);z-index:3;pointer-events:none}
.hero-card{
  width:380px;
  background:rgba(16,24,24,.98);
  border:1px solid var(--l2);
  overflow:hidden;
  box-shadow:0 0 0 1px rgba(255,255,255,.03),0 40px 80px rgba(0,0,0,.65),inset 0 1px 0 rgba(255,255,255,.04);
  animation:float 7s ease-in-out infinite;
  position:relative;
}
/* Gold shimmer on card top */
.hero-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--gold) 40%,var(--gold2) 60%,transparent);opacity:.55}
.hcard-top{padding:28px 28px 24px;border-bottom:1px solid var(--l1);background:linear-gradient(135deg,rgba(212,168,67,.04),transparent 60%);position:relative;overflow:hidden}
.hcard-label{font-size:8px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--t4);margin-bottom:10px}
.hcard-title{font-size:18px;font-weight:900;line-height:1.2;letter-spacing:-.02em;color:var(--t0);margin-bottom:7px}
.hcard-sub{font-size:11px;color:var(--t4);line-height:1.7}
.hcard-live{display:inline-flex;align-items:center;gap:7px;margin-top:16px;font-size:8px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--teal2)}
.hcard-live-dot{width:6px;height:6px;border-radius:50%;background:#5CC87A;box-shadow:0 0 8px rgba(92,200,122,.8);animation:pulse 2s infinite}
.hcard-metrics{display:grid;grid-template-columns:1fr 1fr;gap:1px;border-bottom:1px solid var(--l1);background:var(--l1)}
.hcard-metric{background:rgba(12,18,18,.95);padding:18px 20px}
.hm-val{font-size:24px;font-weight:900;color:var(--gold);line-height:1;margin-bottom:4px}
.hm-lbl{font-size:9px;color:var(--t4);font-weight:500;letter-spacing:.08em}
.hcard-bars{padding:22px 28px 28px}
.hbar-row{margin-bottom:14px}
.hbar-row:last-child{margin-bottom:0}
.hbar-top{display:flex;justify-content:space-between;margin-bottom:8px}
.hbar-name{font-size:11px;font-weight:600;color:var(--t2)}
.hbar-pct{font-size:10px;font-weight:800;color:var(--gold)}
.hbar-track{height:2px;background:rgba(255,255,255,.06);border-radius:1px;overflow:hidden}
.hbar-fill{height:100%;border-radius:1px;background:linear-gradient(90deg,var(--teal),var(--gold))}

/* ══ TICKER ══ */
.ticker{overflow:hidden;padding:20px 0;border-top:1px solid var(--l1);border-bottom:1px solid var(--l1);background:var(--bg2);position:relative}
.ticker::before,.ticker::after{content:'';position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}
.ticker::before{left:0;background:linear-gradient(to right,var(--bg2),transparent)}
.ticker::after{right:0;background:linear-gradient(to left,var(--bg2),transparent)}
.ticker-track{display:flex;white-space:nowrap;animation:tick 35s linear infinite}
.ticker-track:hover{animation-play-state:paused}
.ti{font-size:24px;font-weight:900;padding:0 24px;flex-shrink:0;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.06);letter-spacing:.06em}
.ti.l{-webkit-text-stroke-color:rgba(212,168,67,.28)}
.ti.c{-webkit-text-stroke-color:rgba(92,168,152,.22)}
.ti.b{-webkit-text-stroke-color:rgba(255,255,255,.06)}

/* ══ SERVICES ══ */
.svc-hdr{display:flex;justify-content:space-between;align-items:flex-end;flex-wrap:wrap;gap:24px}
.svc-note{font-size:14px;color:var(--t3);max-width:280px;line-height:1.92}
/* gap:1px + bg creates hairline separators — no individual borders needed */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;margin-top:56px;background:var(--l1)}
.svc-item{
  position:relative;overflow:hidden;
  background:var(--card);
  transition:background .35s var(--snap),transform .3s var(--e);
  cursor:default;display:flex;flex-direction:column;min-height:300px;
}
.svc-item:hover{background:var(--card2);transform:translateY(-4px);z-index:2;box-shadow:0 28px 56px rgba(0,0,0,.55)}
.svc-strip{height:2px;transform:scaleX(0);transform-origin:left;transition:transform .5s var(--e)}
.svc-item:nth-child(1) .svc-strip{background:linear-gradient(90deg,var(--gold),var(--gold2))}
.svc-item:nth-child(2) .svc-strip{background:linear-gradient(90deg,var(--gold),var(--teal2))}
.svc-item:nth-child(3) .svc-strip{background:linear-gradient(90deg,var(--teal2),var(--teal))}
.svc-item:nth-child(4) .svc-strip{background:linear-gradient(90deg,var(--gold2),var(--gold))}
.svc-item:nth-child(5) .svc-strip{background:linear-gradient(90deg,var(--teal2),var(--gold2))}
.svc-item:nth-child(6) .svc-strip{background:linear-gradient(90deg,var(--gold3),var(--gold))}
.svc-item:hover .svc-strip{transform:scaleX(1)}
.svc-body{padding:44px 40px;flex:1;display:flex;flex-direction:column;position:relative;z-index:1}
/* Corner accent on hover */
.svc-item::after{content:'';position:absolute;bottom:0;right:0;width:0;height:0;border-style:solid;border-width:0 0 40px 40px;border-color:transparent transparent var(--gd) transparent;transition:opacity .3s;opacity:0}
.svc-item:hover::after{opacity:1}
.svc-ghost{position:absolute;bottom:-14px;right:4px;font-size:110px;font-weight:900;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.03);line-height:1;pointer-events:none;transition:-webkit-text-stroke-color .35s;user-select:none}
.svc-item:hover .svc-ghost{-webkit-text-stroke-color:rgba(255,255,255,.07)}
.svc-num{font-size:9px;font-weight:700;letter-spacing:.24em;color:var(--t4);margin-bottom:26px}
.svc-ico{
  width:48px;height:48px;display:flex;align-items:center;justify-content:center;
  font-size:20px;margin-bottom:20px;
  background:rgba(255,255,255,.03);border:1px solid var(--l1);
  transition:all .35s var(--spring);
}
.svc-item:hover .svc-ico{transform:scale(1.1) rotate(-5deg);background:var(--gd);border-color:var(--gm)}
.svc-t{font-size:15px;font-weight:800;margin-bottom:10px;color:var(--t0);letter-spacing:-.01em}
.svc-d{font-size:13px;color:var(--t3);line-height:1.96;flex:1}
.svc-arrow{
  display:inline-flex;align-items:center;gap:6px;margin-top:20px;
  font-size:9px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;
  color:var(--gold);
  opacity:0;transform:translateX(-10px);
  transition:opacity .3s,transform .3s;
  text-decoration:none;width:fit-content;
}
.svc-item:hover .svc-arrow{opacity:1;transform:translateX(0)}

/* ══ WORK ══ */
.work-sec{padding:120px 0}
.work-hdr{display:flex;justify-content:space-between;align-items:flex-end;padding:0 52px;margin-bottom:60px;flex-wrap:wrap;gap:20px}
.work-sub{font-size:14px;color:var(--t3);max-width:260px;line-height:1.92}
.work-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.wcard{position:relative;overflow:hidden;height:480px;display:block;cursor:pointer;background:var(--card)}
.wcard:nth-child(3){grid-column:1/3;height:360px}
.wcard-svg{position:absolute;inset:0;width:100%;height:100%;display:block;transition:transform 1s var(--snap)}
.wcard-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top;display:none;transition:transform 1s var(--snap)}
.wcard:hover .wcard-svg,.wcard:hover .wcard-img{transform:scale(1.04)}
.wcard-ov{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:44px 48px;z-index:2;background:linear-gradient(to top,rgba(8,13,13,1) 0%,rgba(8,13,13,.72) 28%,rgba(8,13,13,.12) 65%,transparent 100%)}
.wcard-num{position:absolute;top:20px;right:24px;font-size:52px;font-weight:900;color:rgba(255,255,255,.03);z-index:3;pointer-events:none}
.wcard-tag{display:inline-block;font-size:8px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--gold);margin-bottom:10px;padding:4px 12px;border:1px solid var(--gm);background:var(--gb);width:fit-content}
.wcard-name{font-size:24px;font-weight:900;line-height:1.05;margin-bottom:8px;letter-spacing:-.02em;color:var(--t0)}
.wcard:nth-child(3) .wcard-name{font-size:32px}
.wcard-desc{font-size:13px;color:rgba(200,196,188,.5);line-height:1.7;max-height:0;overflow:hidden;transition:max-height .45s var(--e),margin .45s}
.wcard:hover .wcard-desc{max-height:64px;margin-bottom:14px}
.wcard-link{display:inline-flex;align-items:center;gap:7px;font-size:9px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:0;transform:translateY(8px);transition:opacity .3s,transform .3s}
.wcard:hover .wcard-link{opacity:1;transform:translateY(0)}
.wcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:4;background:linear-gradient(90deg,var(--gold),var(--teal2));transform:scaleX(0);transform-origin:left;transition:transform .55s var(--e)}
.wcard:hover::before{transform:scaleX(1)}

/* Duo grid (homepage 2 cards) */
.work-grid-duo{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.wcard-duo{
  position:relative;overflow:hidden;height:520px;
  cursor:pointer;background:var(--black);
  border:1px solid var(--l1);
  transition:border-color .4s;
}
.wcard-duo:hover{border-color:rgba(212,168,67,.18)}
.wcard-duo-inner{position:relative;width:100%;height:100%}
.wcard-name-bg{
  position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);
  font-size:clamp(46px,6vw,84px);font-weight:900;letter-spacing:-.02em;
  color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.05);
  white-space:nowrap;pointer-events:none;user-select:none;
  transition:-webkit-text-stroke-color .5s;
}
.wcard-duo:hover .wcard-name-bg{-webkit-text-stroke-color:rgba(212,168,67,.12)}
.wcard-duo-ov{
  position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;
  padding:48px 52px;z-index:2;
  background:linear-gradient(to top,rgba(5,8,8,1) 0%,rgba(5,8,8,.82) 30%,rgba(5,8,8,.18) 65%,transparent 100%);
}
.wcard-duo-tag{display:inline-block;font-size:8px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:14px;padding:5px 14px;border:1px solid var(--gm);background:var(--gb);width:fit-content}
.wcard-duo-name{font-size:clamp(32px,4vw,52px);font-weight:900;line-height:1;margin-bottom:14px;letter-spacing:-.025em;color:var(--t0)}
.wcard-duo-desc{font-size:14px;color:rgba(200,196,188,.65);line-height:1.78;max-width:440px;margin-bottom:20px;opacity:0;transform:translateY(8px);transition:opacity .35s,transform .35s}
.wcard-duo:hover .wcard-duo-desc{opacity:1;transform:translateY(0)}
.wcard-duo-link{display:inline-flex;align-items:center;gap:8px;font-size:10px;font-weight:800;letter-spacing:.2em;text-transform:uppercase;color:var(--gold);opacity:0;transform:translateY(6px);transition:opacity .28s .06s,transform .28s .06s}
.wcard-duo:hover .wcard-duo-link{opacity:1;transform:translateY(0)}
.wcard-duo::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:4;background:linear-gradient(90deg,var(--gold),var(--teal2));transform:scaleX(0);transform-origin:left;transition:transform .55s var(--e)}
.wcard-duo:hover::before{transform:scaleX(1)}

/* ══ PROCESS ══ */
.process-sec{background:var(--bg2);border-top:1px solid var(--l1);border-bottom:1px solid var(--l1)}
.psteps{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--l1)}
.pstep{padding:52px 40px;background:var(--card);transition:background .3s,transform .25s}
.pstep:hover{background:var(--card2);transform:translateY(-2px)}
/* Numbered left border on hover */
.pstep{position:relative;overflow:hidden}
.pstep::before{content:'';position:absolute;left:0;top:0;bottom:0;width:2px;background:var(--gold);transform:scaleY(0);transform-origin:bottom;transition:transform .4s var(--e)}
.pstep:hover::before{transform:scaleY(1)}
.pdot{width:12px;height:12px;border-radius:50%;margin-bottom:32px}
.pstep:nth-child(1) .pdot{background:var(--gold);box-shadow:0 0 10px rgba(212,168,67,.45)}
.pstep:nth-child(2) .pdot{background:var(--teal2);box-shadow:0 0 10px rgba(92,168,152,.4)}
.pstep:nth-child(3) .pdot{background:var(--gold2);box-shadow:0 0 10px rgba(232,192,104,.38)}
.pstep:nth-child(4) .pdot{background:var(--gold3);box-shadow:0 0 10px rgba(245,213,128,.38)}
.pnum{font-size:60px;font-weight:900;line-height:1;margin-bottom:18px;color:transparent;-webkit-text-stroke:1px rgba(255,255,255,.07)}
.ptitle{font-size:15px;font-weight:800;margin-bottom:12px;color:var(--t0)}
.pdesc{font-size:13px;color:var(--t3);line-height:1.96}

/* ══ PRICING ══ */
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--l1);margin-top:56px}
.prc-card{background:var(--card);padding:52px 40px;position:relative;overflow:hidden;transition:background .3s,transform .3s;display:flex;flex-direction:column}
.prc-card:hover{background:var(--card2);transform:translateY(-4px);box-shadow:0 28px 56px rgba(0,0,0,.55)}
.prc-card.featured{background:var(--card2);border:1px solid var(--gm);transform:scale(1.02)}
.prc-card.featured:hover{transform:scale(1.02) translateY(-4px)}
.prc-card::after{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--teal2));transform:scaleX(0);transform-origin:left;transition:transform .4s var(--e)}
.prc-card.featured::after{transform:scaleX(1)}
.prc-card:hover::after{transform:scaleX(1)}
.prc-tag{font-size:8px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;display:inline-block;margin-bottom:22px;padding:4px 14px;border:1px solid var(--gm);color:var(--gold);background:var(--gb)}
.prc-name{font-size:22px;font-weight:900;margin-bottom:8px;color:var(--t0)}
.prc-subdesc{font-size:13px;color:var(--t3);line-height:1.85;margin-bottom:28px}
.prc-amt{font-size:52px;font-weight:900;line-height:1;color:var(--gold)}
.prc-range{font-size:12px;font-weight:500;color:var(--t4);margin-top:4px}
.prc-div{height:1px;background:var(--l1);margin:26px 0}
.prc-features{list-style:none;display:flex;flex-direction:column;gap:13px;flex:1;margin-bottom:32px}
.prc-features li{display:flex;align-items:flex-start;gap:10px;font-size:13px;color:var(--t2);line-height:1.55}
.prc-features li .chk{font-size:9px;font-weight:900;color:var(--gold);flex-shrink:0;width:18px;height:18px;background:var(--gd);border-radius:50%;display:flex;align-items:center;justify-content:center;margin-top:1px}
.prc-badge{position:absolute;top:18px;right:18px;font-size:8px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:4px 12px;background:var(--gold);color:var(--black)}
.prc-cta{width:100%}

/* ══ TEAM ══ */
.team-sec{background:var(--bg)}
.team-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px}
.tcard{background:var(--card);border:1px solid var(--l1);overflow:hidden;position:relative;transition:border-color .35s,transform .3s}
.tcard:hover{border-color:var(--gm);transform:translateY(-3px);box-shadow:0 28px 56px rgba(0,0,0,.45)}
.tcard::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;z-index:2;background:linear-gradient(90deg,var(--gold),var(--teal2));opacity:.75}
.tcard:nth-child(2)::before{background:linear-gradient(90deg,var(--teal2),var(--gold))}
.tphoto{height:420px;overflow:hidden;position:relative;background:var(--bg2);display:flex;align-items:center;justify-content:center}
.tphoto img{width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .8s var(--snap)}
.tcard:hover .tphoto img{transform:scale(1.04)}
.tphoto-ph{font-size:88px;font-weight:900;color:var(--card2);user-select:none;letter-spacing:.08em}
.tbody{padding:36px 40px 44px}
.trole{font-size:9px;font-weight:700;letter-spacing:.32em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.tname{font-size:28px;font-weight:900;line-height:1;margin-bottom:8px;color:var(--t0);letter-spacing:-.02em}
.tphone{font-size:13px;font-weight:600;color:var(--teal2);margin-bottom:14px;letter-spacing:.04em}
.tbio{font-size:13px;color:var(--t3);line-height:1.92;margin-bottom:22px}
.tresponsibilities{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}
.tresp-tag{font-size:8px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:4px 12px;border:1px solid var(--l2);color:var(--t2);background:var(--card2);transition:all .22s}
.tcard:hover .tresp-tag{border-color:var(--gm);color:var(--gold)}
.tspecialty{padding-top:18px;border-top:1px solid var(--l1)}
.tspec-label{font-size:8px;font-weight:700;letter-spacing:.24em;text-transform:uppercase;color:var(--t4);margin-bottom:10px}
.tspec-skills{display:flex;flex-wrap:wrap;gap:7px}
.tspec-skill{font-size:11px;color:var(--teal2);font-weight:500;padding:4px 12px;border:1px solid var(--td);background:rgba(74,136,128,.05)}
.tsocials{display:flex;gap:10px;margin-top:20px}
.tsocial{width:36px;height:36px;border:1px solid var(--l1);display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--t4);transition:all .22s}
.tsocial:hover{border-color:var(--gold);color:var(--gold);background:var(--gd)}

/* ══ VALUES ══ */
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--l1)}
.vcard{background:var(--card);padding:44px 36px;transition:background .3s}
.vcard:hover{background:var(--card2)}
.vico{font-size:28px;margin-bottom:20px;display:block}
.vtitle{font-size:15px;font-weight:800;margin-bottom:11px;color:var(--t0)}
.vdesc{font-size:13px;color:var(--t3);line-height:1.92}

/* ══ STATS ROW ══ */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--l1);border-bottom:1px solid var(--l1)}
.sstat{padding:48px;text-align:center;border-right:1px solid var(--l1);background:var(--bg2);transition:background .25s}
.sstat:last-child{border-right:none}
.sstat:hover{background:var(--card)}
.sstat-n{font-size:52px;font-weight:900;line-height:1;color:var(--gold);margin-bottom:10px}
.sstat-l{font-size:9px;color:var(--t4);letter-spacing:.26em;text-transform:uppercase;font-weight:600}

/* ══ REFERRAL ══ */
.ref-steps{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--l1);margin-top:56px}
.ref-step{background:var(--card);padding:48px 40px;position:relative;overflow:hidden;transition:background .3s}
.ref-step:hover{background:var(--card2)}
.ref-step-num{font-size:88px;font-weight:900;color:rgba(255,255,255,.03);position:absolute;top:-10px;right:14px;line-height:1;pointer-events:none}
.ref-step-ico{width:52px;height:52px;background:rgba(255,255,255,.03);border:1px solid var(--l1);display:flex;align-items:center;justify-content:center;font-size:22px;margin-bottom:22px;transition:all .3s}
.ref-step:hover .ref-step-ico{background:var(--gd);border-color:var(--gm)}
.ref-step-title{font-size:17px;font-weight:800;margin-bottom:10px;color:var(--t0)}
.ref-step-desc{font-size:13px;color:var(--t3);line-height:1.92}
.comm-card{background:var(--card2);border:1px solid var(--l2);padding:60px;text-align:center}
.comm-pct{font-size:88px;font-weight:900;color:var(--gold);line-height:1;margin-bottom:8px}
.comm-label{font-size:12px;font-weight:700;color:var(--t4);letter-spacing:.12em;text-transform:uppercase;margin-bottom:32px}
.rform{display:flex;flex-direction:column;gap:12px;max-width:440px;margin:0 auto}
.rform input{width:100%;background:rgba(8,13,13,.7);border:1px solid var(--l1);color:var(--t1);font-family:var(--font);font-size:14px;padding:13px 16px;outline:none;transition:border-color .2s}
.rform input:focus{border-color:var(--gold)}
.rform input::placeholder{color:var(--t4)}
.rform .rform-btn{background:var(--gold);color:var(--black);font-family:var(--font);font-size:10px;font-weight:800;letter-spacing:.12em;text-transform:uppercase;padding:14px;border:none;cursor:pointer;transition:background .2s}
.rform .rform-btn:hover{background:var(--gold2)}

/* ══ CTA BANNER ══ */
.cta-banner{padding:120px 52px;text-align:center;background:var(--bg2);border-top:1px solid var(--l1);border-bottom:1px solid var(--l1);position:relative;overflow:hidden}
.cta-banner::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 65% 85% at 50% 50%,rgba(212,168,67,.04),transparent 65%);pointer-events:none}
/* Grid lines in CTA */
.cta-banner::after{content:'';position:absolute;inset:0;background-image:linear-gradient(var(--l1) 1px,transparent 1px),linear-gradient(90deg,var(--l1) 1px,transparent 1px);background-size:60px 60px;pointer-events:none;opacity:.5}
.cta-banner .sec-h,.cta-banner .sub,.cta-banner .cta-btns{position:relative;z-index:1}
.cta-banner .sub{font-size:15px;color:var(--t3);max-width:440px;margin:0 auto 52px;line-height:1.95}
.cta-btns{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}

/* ══ CAREERS ══ */
.jobs{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--l1);margin-top:56px}
.jcard{background:var(--card);padding:44px;transition:background .3s;display:flex;flex-direction:column}
.jcard:hover{background:var(--card2)}
.jbadge{display:inline-block;font-size:8px;font-weight:700;letter-spacing:.25em;text-transform:uppercase;padding:4px 12px;margin-bottom:18px;border:1px solid var(--gm);color:var(--gold);background:var(--gb)}
.jtitle{font-size:20px;font-weight:900;margin-bottom:12px;color:var(--t0)}
.jdesc{font-size:13px;color:var(--t3);line-height:1.92;flex:1;margin-bottom:28px}
.japply{background:none;border:1px solid var(--l1);color:var(--t3);font-family:var(--font);font-size:10px;font-weight:800;letter-spacing:.14em;text-transform:uppercase;padding:10px 20px;width:fit-content;transition:all .22s}
.japply:hover{border-color:var(--gold);color:var(--gold);background:var(--gd)}

/* ══ FORMS ══ */
.contact-wrap{display:grid;grid-template-columns:1fr 1.4fr;gap:72px;align-items:start}
.ci-label{font-size:9px;font-weight:700;letter-spacing:.28em;text-transform:uppercase;color:var(--t4);margin-bottom:7px}
.ci-val{font-size:15px;color:var(--t1);line-height:1.75}
.ci-val a{color:var(--gold);transition:color .2s}
.ci-val a:hover{color:var(--gold2)}
.contact-item{margin-bottom:34px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.fg{display:flex;flex-direction:column;gap:7px}
.fg.wide{grid-column:1/-1}
.fg label{font-size:9px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--t4)}
.fg input,.fg select,.fg textarea{background:rgba(12,18,18,.8);border:1px solid var(--l1);color:var(--t1);font-family:var(--font);font-size:14px;padding:13px 16px;outline:none;transition:all .22s;width:100%;-webkit-appearance:none}
.fg input:focus,.fg select:focus,.fg textarea:focus{border-color:var(--gold);background:rgba(18,26,26,.9)}
.fg input::placeholder,.fg textarea::placeholder{color:var(--t4)}
.fg select{cursor:pointer}
.fg select option{background:var(--card);color:var(--t1)}
.fg textarea{resize:vertical;min-height:130px;line-height:1.65}
.form-submit{grid-column:1/-1;margin-top:8px}
.form-msg{font-size:13px;padding:13px 16px;border-left:3px solid var(--teal2);background:rgba(92,168,152,.07);color:var(--teal2);display:none}
.form-msg.ok{display:block}
.form-msg.err{border-left-color:#8B5050;background:rgba(139,80,80,.07);color:#B07070}

/* ══ MODAL ══ */
.modal-bg{display:none;position:fixed;inset:0;z-index:950;background:rgba(4,8,8,.92);backdrop-filter:blur(14px);align-items:center;justify-content:center;padding:24px}
.modal-bg.open{display:flex}
.modal-box{background:var(--card);border:1px solid var(--l2);width:100%;max-width:520px;padding:52px;position:relative;max-height:90vh;overflow-y:auto}
.modal-box::before{content:'';position:absolute;top:0;left:0;right:0;height:2px;background:linear-gradient(90deg,var(--gold),var(--teal2))}
.modal-close{position:absolute;top:16px;right:16px;background:none;border:1px solid var(--l1);color:var(--t4);width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:13px;transition:all .2s}
.modal-close:hover{border-color:var(--gold);color:var(--gold)}
.modal-title{font-size:26px;font-weight:900;margin-bottom:6px;color:var(--t0)}
.modal-sub{font-size:13px;color:var(--t4);margin-bottom:30px}
.mform{display:flex;flex-direction:column;gap:14px}
.mfg{display:flex;flex-direction:column;gap:6px}
.mfg label{font-size:9px;font-weight:700;letter-spacing:.26em;text-transform:uppercase;color:var(--t4)}
.mfg input,.mfg textarea{background:rgba(8,13,13,.8);border:1px solid var(--l1);color:var(--t1);font-family:var(--font);font-size:14px;padding:12px 14px;outline:none;transition:border-color .2s;width:100%}
.mfg input:focus,.mfg textarea:focus{border-color:var(--gold)}
.mfg input::placeholder,.mfg textarea::placeholder{color:var(--t4)}
.mfg textarea{resize:vertical;min-height:110px;line-height:1.65}
.modal-submit{margin-top:4px;width:100%;display:flex;justify-content:center}

/* ══ FOOTER ══ */
footer{border-top:1px solid var(--l1);background:var(--bg2)}
.foot-top{display:grid;grid-template-columns:1.8fr 1fr 1fr 1fr;gap:52px;padding:80px 52px 60px}
.foot-tagline{font-size:13px;color:var(--t3);line-height:1.92;max-width:280px;margin:14px 0 20px}
.foot-email{font-size:12px;font-weight:700;color:var(--gold);transition:color .2s;letter-spacing:.04em}
.foot-email:hover{color:var(--gold2)}
.fcol h5{font-size:9px;font-weight:700;letter-spacing:.3em;text-transform:uppercase;color:var(--t2);margin-bottom:20px}
.fcol ul{list-style:none;display:flex;flex-direction:column;gap:13px}
.fcol ul a{font-size:13px;color:var(--t3);transition:color .2s,padding-left .2s}
.fcol ul a:hover{color:var(--t1);padding-left:4px}
.foot-bar{border-top:1px solid var(--l1);padding:20px 52px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}
.foot-copy{font-size:12px;color:var(--t4)}
.foot-admin{font-size:9px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--t4);transition:color .2s}
.foot-admin:hover{color:var(--gold)}

/* ══ TOAST ══ */
.toast{position:fixed;bottom:28px;right:28px;z-index:9999;font-size:10px;font-weight:800;letter-spacing:.1em;text-transform:uppercase;padding:13px 24px;color:var(--black);background:var(--gold);transform:translateY(72px);opacity:0;transition:all .35s var(--e);pointer-events:none}
.toast.show{transform:translateY(0);opacity:1}
.toast.err{background:#8B5050;color:#fff}
.toast.ok{background:var(--teal2);color:var(--black)}

/* ══ RESPONSIVE ══ */
@media(max-width:1200px){.hero-centrepiece{right:28px}.hero-divider{left:51%}}
@media(max-width:1024px){
  .sec{padding:88px 32px}
  #nav{padding:0 32px}
  .page-hero{padding:96px 32px 48px}
  #hero{padding:64px 32px 60px}
  .hero-centrepiece,.hero-divider{display:none}
  .scroll-cue{left:32px}
  .work-hdr{padding:0 32px}
  .work-grid,.work-grid-duo{grid-template-columns:1fr}
  .wcard,.wcard:nth-child(3){grid-column:1;height:420px}
  .wcard-duo{height:420px}
  .svc-grid{grid-template-columns:1fr 1fr}
  .psteps{grid-template-columns:1fr 1fr;gap:1px}
  .team-grid{grid-template-columns:1fr}
  .pricing-grid{grid-template-columns:1fr}
  .prc-card.featured{transform:none}
  .ref-steps{grid-template-columns:1fr 1fr}
  .values-grid{grid-template-columns:1fr 1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .foot-top{grid-template-columns:1fr 1fr;gap:36px;padding:60px 32px 48px}
  .foot-top .foot-brand{grid-column:1/-1}
  .foot-bar{padding:20px 32px}
  .contact-wrap{grid-template-columns:1fr;gap:48px}
  .jobs{grid-template-columns:1fr 1fr}
  .cta-banner{padding:88px 32px}
}
@media(max-width:768px){
  .sec{padding:72px 20px}
  #nav{padding:0 20px}
  .nav-links,.nav-cta{display:none}
  .nav-ham{display:flex}
  .page-hero{padding:84px 20px 40px;min-height:280px}
  #hero{padding:64px 20px 56px}
  h1.hero-h{font-size:clamp(52px,14vw,86px)}
  .hero-acts{flex-direction:column;align-items:flex-start}
  .hero-stats{flex-direction:column;gap:22px;padding-top:28px}
  .h-stat{padding:0}
  .h-stat+.h-stat{padding-left:0;border-left:none}
  .scroll-cue{left:20px}
  .work-hdr{padding:0 20px;flex-direction:column}
  .svc-grid{grid-template-columns:1fr}
  .psteps,.jobs{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .fg.wide{grid-column:1}
  .foot-top{grid-template-columns:1fr;gap:32px;padding:48px 20px}
  .foot-bar{padding:18px 20px}
  .values-grid{grid-template-columns:1fr}
  .stats-row{grid-template-columns:1fr 1fr}
  .cta-banner{padding:72px 20px}
  .cta-btns{flex-direction:column;align-items:center}
  .ref-steps{grid-template-columns:1fr}
  .comm-card{padding:44px 20px}
  .comm-pct{font-size:72px}
  .modal-box{padding:32px 20px}
  .pricing-grid{grid-template-columns:1fr}
  .btn-primary,.btn-outline,.btn-coral{width:100%;max-width:320px;justify-content:center}
  .wcard-duo-ov{padding:36px 32px}
}
@media(max-width:480px){
  .wcard,.wcard:nth-child(3){height:320px}
  .wcard-duo{height:360px}
  .stats-row{grid-template-columns:1fr}
}