/* ============================================================
   GLOBAL LUXURY LINK — bespoke site
   Concept: "The Link Network" — dark luxury, constellation motif
   ============================================================ */

:root{
  --orange:#F15a22;
  --orange-bright:#ff7a3d;
  --orange-dark:#D14A18;
  --blue:#3955a5;
  --blue-bright:#5d7fd8;
  --navy:#05080f;
  --navy-2:#070d18;
  --navy-3:#0a1322;
  --card:#0c1729;
  --card-hover:#11203a;
  --white:#f7f9fc;
  --off:#a8b6cc;
  --muted:#5c6b82;
  --border:rgba(255,255,255,.07);
  --border-glow:rgba(241,90,34,.25);
  --serif:'Playfair Display',Georgia,serif;
  --sans:'DM Sans',-apple-system,sans-serif;
  --ease:cubic-bezier(.16,1,.3,1);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  background:var(--navy);
  color:var(--white);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
::selection{background:var(--orange);color:var(--navy)}
img{max-width:100%;display:block}
a{color:inherit}

.container{max-width:1240px;margin:0 auto;padding:0 28px}

/* ---------- scroll progress ---------- */
.progress{position:fixed;top:0;left:0;height:2px;width:0%;background:linear-gradient(90deg,var(--orange),var(--orange-bright));z-index:1001;box-shadow:0 0 12px rgba(241,90,34,.7)}

/* ---------- cursor glow (desktop) ---------- */
.cursor-glow{position:fixed;width:520px;height:520px;border-radius:50%;pointer-events:none;z-index:0;background:radial-gradient(circle,rgba(241,90,34,.045),transparent 65%);transform:translate(-50%,-50%);transition:opacity .4s;opacity:0}
@media(hover:hover){.cursor-glow{opacity:1}}

/* ---------- nav ---------- */
.nav{position:fixed;top:0;left:0;right:0;z-index:1000;transition:all .45s var(--ease)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:22px 36px;max-width:1400px;margin:0 auto}
.nav.scrolled{background:rgba(5,8,15,.78);backdrop-filter:blur(18px);-webkit-backdrop-filter:blur(18px);border-bottom:1px solid var(--border)}
.nav.scrolled .nav-inner{padding:14px 36px}
.nav-logo img{height:46px;width:auto;transition:height .45s var(--ease)}
.nav.scrolled .nav-logo img{height:38px}
.nav-links{display:flex;align-items:center;gap:36px;list-style:none}
.nav-links a{font-size:12px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--off);text-decoration:none;position:relative;transition:color .3s}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;bottom:-6px;left:0;width:0;height:1px;background:var(--orange);transition:width .35s var(--ease)}
.nav-links a:hover{color:var(--white)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{padding:11px 24px;background:var(--orange);color:var(--navy)!important;border-radius:2px;transition:all .3s!important}
.nav-cta:hover{background:var(--orange-bright);transform:translateY(-1px);box-shadow:0 6px 20px rgba(241,90,34,.35)}
.nav-burger{display:none;background:none;border:none;cursor:pointer;width:30px;height:22px;position:relative;z-index:1002}
.nav-burger span{display:block;position:absolute;left:0;width:100%;height:2px;background:var(--white);transition:all .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-burger.open span:nth-child(1){top:10px;transform:rotate(45deg)}
.nav-burger.open span:nth-child(2){opacity:0}
.nav-burger.open span:nth-child(3){top:10px;transform:rotate(-45deg)}
@media(max-width:920px){
  .nav-burger{display:block}
  .nav-links{position:fixed;top:0;left:0;right:0;bottom:0;width:100%;height:100vh;background:linear-gradient(165deg,#070d18,#05080f);flex-direction:column;justify-content:center;gap:34px;transform:translateY(-105%);transition:transform .5s var(--ease);z-index:1001;visibility:hidden}
  .nav-links.open{visibility:visible}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:16px}
}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:12px;padding:18px 42px;font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;text-decoration:none;border-radius:2px;border:none;cursor:pointer;position:relative;overflow:hidden;transition:all .35s var(--ease);will-change:transform}
.btn-fill{background:var(--orange);color:var(--navy)}
.btn-fill::before{content:'';position:absolute;inset:0;background:linear-gradient(110deg,transparent 25%,rgba(255,255,255,.25) 50%,transparent 75%);transform:translateX(-120%);transition:transform .6s ease}
.btn-fill:hover::before{transform:translateX(120%)}
.btn-fill:hover{box-shadow:0 12px 40px rgba(241,90,34,.4);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--white);border:1px solid rgba(255,255,255,.18)}
.btn-ghost:hover{border-color:var(--orange);color:var(--orange)}
.btn svg{width:15px;height:15px;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;transition:transform .35s var(--ease)}
.btn:hover svg{transform:translateX(5px)}

/* ---------- section primitives ---------- */
.eyebrow{font-size:11px;font-weight:700;letter-spacing:5px;text-transform:uppercase;color:var(--orange);display:flex;align-items:center;gap:14px;margin-bottom:20px}
.eyebrow::before{content:'';width:36px;height:1px;background:linear-gradient(90deg,var(--orange),transparent)}
.eyebrow.center{justify-content:center}
.eyebrow.center::before{display:none}
h2.title{font-family:var(--serif);font-size:clamp(34px,4.6vw,58px);font-weight:500;line-height:1.1;letter-spacing:-.5px}
h2.title em{font-style:italic;color:var(--orange)}
h2.title .b{color:var(--blue-bright);font-style:italic}
.lede{font-size:17px;font-weight:300;color:var(--off);line-height:1.8;max-width:600px}

/* reveals */
.reveal{opacity:0;transform:translateY(44px);transition:opacity .9s var(--ease),transform .9s var(--ease)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-d1{transition-delay:.12s}.reveal-d2{transition-delay:.24s}.reveal-d3{transition-delay:.36s}

/* ============================================================
   HERO
   ============================================================ */
.hero{min-height:100svh;display:flex;align-items:center;position:relative;overflow:hidden;background:radial-gradient(ellipse 80% 60% at 70% 20%,rgba(57,85,165,.12),transparent 55%),radial-gradient(ellipse 60% 50% at 20% 90%,rgba(241,90,34,.07),transparent 60%),var(--navy)}
#net{position:absolute;inset:0;width:100%;height:100%;z-index:1}
.hero-vignette{position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse 100% 100% at 50% 50%,transparent 40%,rgba(5,8,15,.55) 100%);pointer-events:none}
.hero-inner{position:relative;z-index:3;width:100%;padding-top:160px;padding-bottom:120px}
.hero-tag{display:inline-flex;align-items:center;gap:10px;padding:9px 20px;border:1px solid rgba(241,90,34,.3);border-radius:100px;font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--orange);background:rgba(241,90,34,.06);margin-bottom:36px}
.hero-tag .dot{width:6px;height:6px;border-radius:50%;background:var(--orange);animation:blink 2s ease infinite}
@keyframes blink{0%,100%{opacity:1;box-shadow:0 0 8px var(--orange)}50%{opacity:.35;box-shadow:none}}
.hero h1{font-family:var(--serif);font-weight:500;font-size:clamp(44px,7.2vw,96px);line-height:1.04;letter-spacing:-1.5px;max-width:1000px;margin-bottom:34px}
.hero h1 .line{display:block;overflow:hidden}
.hero h1 .line>span{display:block;transform:translateY(110%);animation:riseUp 1.1s var(--ease) forwards}
.hero h1 .line:nth-child(2)>span{animation-delay:.15s}
.hero h1 .line:nth-child(3)>span{animation-delay:.3s}
@keyframes riseUp{to{transform:translateY(0)}}
.swap-wrap{display:inline-block;position:relative;color:var(--orange);font-style:italic;white-space:nowrap}
.swap-wrap .swap{display:inline-block}
.swap-wrap .swap.out{animation:wordOut .45s var(--ease) forwards}
.swap-wrap .swap.in{animation:wordIn .45s var(--ease) forwards}
@keyframes wordOut{to{opacity:0;transform:translateY(-26px) rotate(-2deg);filter:blur(6px)}}
@keyframes wordIn{from{opacity:0;transform:translateY(26px) rotate(2deg);filter:blur(6px)}to{opacity:1;transform:translateY(0) rotate(0);filter:blur(0)}}
.hero-sub{font-size:18px;font-weight:300;color:var(--off);line-height:1.8;max-width:560px;margin-bottom:48px;opacity:0;animation:fadeIn 1s ease .7s forwards}
.hero-actions{display:flex;gap:18px;flex-wrap:wrap;opacity:0;animation:fadeIn 1s ease .9s forwards}
@keyframes fadeIn{to{opacity:1}}
.hero-scroll{position:absolute;bottom:36px;left:50%;transform:translateX(-50%);z-index:3;display:flex;flex-direction:column;align-items:center;gap:10px;font-size:10px;letter-spacing:3px;text-transform:uppercase;color:var(--muted);opacity:0;animation:fadeIn 1s ease 1.4s forwards}
.hero-scroll .wheel{width:1px;height:44px;background:rgba(255,255,255,.12);position:relative;overflow:hidden}
.hero-scroll .wheel::after{content:'';position:absolute;top:-40%;left:0;width:100%;height:40%;background:var(--orange);animation:drip 1.8s ease-in-out infinite}
@keyframes drip{to{top:110%}}
@media(max-width:640px){.hero-actions{flex-direction:column}.hero-actions .btn{justify-content:center}}

/* ============================================================
   STATS
   ============================================================ */
.stats{padding:0;background:var(--navy);position:relative;z-index:4}
.stats-inner{display:grid;grid-template-columns:repeat(4,1fr);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.stat{padding:54px 30px;text-align:center;border-right:1px solid var(--border);position:relative;overflow:hidden;transition:background .4s}
.stat:hover{background:rgba(241,90,34,.03)}
.stat:last-child{border-right:none}
.stat-num{font-family:var(--serif);font-size:52px;font-weight:500;color:var(--white);line-height:1;margin-bottom:12px}
.stat-num .suffix{color:var(--orange)}
.stat-label{font-size:11px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--muted)}
@media(max-width:820px){.stats-inner{grid-template-columns:1fr 1fr}.stat{padding:36px 20px;border-bottom:1px solid var(--border)}.stat:nth-child(2){border-right:none}.stat:nth-child(3),.stat:nth-child(4){border-bottom:none}.stat-num{font-size:38px}}

/* ============================================================
   MARQUEE DIVIDER
   ============================================================ */
.tape{padding:34px 0;background:var(--navy-2);border-bottom:1px solid var(--border);overflow:hidden;position:relative}
.tape-track{display:flex;gap:0;width:max-content;animation:tape 36s linear infinite}
.tape span{font-family:var(--serif);font-size:30px;font-style:italic;color:rgba(255,255,255,.16);white-space:nowrap;padding:0 28px;display:flex;align-items:center;gap:56px}
.tape span::after{content:'✦';font-size:15px;color:var(--orange);opacity:.6;font-style:normal}
@keyframes tape{to{transform:translateX(-50%)}}

/* ============================================================
   SERVICES
   ============================================================ */
.services{padding:140px 0;background:var(--navy);position:relative}
.services-head{display:flex;justify-content:space-between;align-items:flex-end;gap:40px;margin-bottom:72px;flex-wrap:wrap}
.services-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}
.svc{position:relative;background:var(--card);border:1px solid var(--border);border-radius:6px;padding:52px 44px;overflow:hidden;transition:transform .45s var(--ease),border-color .45s,background .45s;cursor:default}
.svc::before{content:'';position:absolute;inset:0;background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(241,90,34,.09),transparent 65%);opacity:0;transition:opacity .4s;pointer-events:none}
.svc.blue::before{background:radial-gradient(420px circle at var(--mx,50%) var(--my,50%),rgba(93,127,216,.1),transparent 65%)}
.svc:hover{transform:translateY(-6px);border-color:var(--border-glow);background:var(--card-hover)}
.svc.blue:hover{border-color:rgba(93,127,216,.3)}
.svc:hover::before{opacity:1}
.svc-num{position:absolute;top:26px;right:34px;font-family:var(--serif);font-size:74px;font-style:italic;line-height:1;color:rgba(241,90,34,.08);transition:color .4s}
.svc.blue .svc-num{color:rgba(93,127,216,.1)}
.svc:hover .svc-num{color:rgba(241,90,34,.2)}
.svc.blue:hover .svc-num{color:rgba(93,127,216,.25)}
.svc-icon{width:54px;height:54px;border-radius:3px;display:flex;align-items:center;justify-content:center;background:rgba(241,90,34,.08);border:1px solid rgba(241,90,34,.16);margin-bottom:30px;transition:transform .4s var(--ease)}
.svc:hover .svc-icon{transform:scale(1.08) rotate(-4deg)}
.svc.blue .svc-icon{background:rgba(93,127,216,.1);border-color:rgba(93,127,216,.2)}
.svc-icon svg{width:24px;height:24px;stroke:var(--orange);fill:none;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.svc.blue .svc-icon svg{stroke:var(--blue-bright)}
.svc h3{font-family:var(--serif);font-size:27px;font-weight:500;margin-bottom:16px}
.svc p{font-size:15px;color:var(--off);line-height:1.8;margin-bottom:26px}
.svc-tags{display:flex;flex-wrap:wrap;gap:8px}
.svc-tags span{font-size:10.5px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:7px 14px;border:1px solid var(--border);border-radius:100px;transition:all .3s}
.svc:hover .svc-tags span{border-color:rgba(241,90,34,.25);color:var(--off)}
.svc.blue:hover .svc-tags span{border-color:rgba(93,127,216,.3)}
@media(max-width:820px){.services{padding:100px 0}.services-grid{grid-template-columns:1fr}.svc{padding:40px 30px}}

/* ============================================================
   MAP
   ============================================================ */
.map-section{padding:140px 0;background:var(--navy-2);border-top:1px solid var(--border);position:relative;overflow:hidden}
.map-section::before{content:'';position:absolute;top:-200px;right:-200px;width:600px;height:600px;background:radial-gradient(circle,rgba(57,85,165,.1),transparent 65%);pointer-events:none}
.map-head{text-align:center;max-width:680px;margin:0 auto 64px}
.map-head .lede{margin:18px auto 0}
.map-frame{position:relative;border-radius:10px;overflow:hidden;border:1px solid rgba(255,255,255,.1);box-shadow:0 40px 120px rgba(0,0,0,.6),0 0 0 1px rgba(241,90,34,.05)}
#clientMap{width:100%;height:560px;background:var(--navy);z-index:1}
.map-hud{position:absolute;top:18px;left:18px;z-index:500;display:flex;flex-direction:column;gap:10px;pointer-events:none}
.map-hud .hud-chip{pointer-events:auto;display:inline-flex;align-items:center;gap:10px;padding:10px 18px;background:rgba(5,8,15,.85);backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:100px;font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--off)}
.map-hud .hud-chip .dot{width:7px;height:7px;border-radius:50%;background:#3ddc84;animation:blink 2s ease infinite}
.map-tour-btn{position:absolute;bottom:18px;left:18px;z-index:500;display:inline-flex;align-items:center;gap:10px;padding:13px 26px;background:rgba(241,90,34,.95);color:var(--navy);border:none;border-radius:100px;font-family:var(--sans);font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;cursor:pointer;transition:all .3s;box-shadow:0 8px 30px rgba(241,90,34,.4)}
.map-tour-btn:hover{transform:translateY(-2px);background:var(--orange-bright)}
.map-tour-btn.touring{background:rgba(5,8,15,.85);color:var(--orange);border:1px solid rgba(241,90,34,.4);backdrop-filter:blur(12px)}
.map-spot{position:absolute;bottom:18px;right:18px;z-index:500;background:rgba(5,8,15,.88);backdrop-filter:blur(14px);border:1px solid rgba(241,90,34,.3);border-radius:8px;padding:16px 22px;min-width:230px;opacity:0;transform:translateY(12px);transition:all .45s var(--ease);pointer-events:none}
.map-spot.show{opacity:1;transform:translateY(0)}
.map-spot .ms-name{font-family:var(--serif);font-size:18px;font-weight:500;color:var(--white)}
.map-spot .ms-loc{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-top:5px}
.map-counters{display:flex;justify-content:center;gap:70px;margin-top:52px;flex-wrap:wrap}
.map-c{text-align:center}
.map-c-num{font-family:var(--serif);font-size:42px;font-weight:500;color:var(--orange)}
.map-c-label{font-size:11px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:6px}
@media(max-width:768px){.map-section{padding:100px 0}#clientMap{height:420px}.map-counters{gap:34px}.map-c-num{font-size:32px}.map-spot{display:none}}

/* leaflet skin */
.map-frame .leaflet-control-zoom{border:1px solid rgba(255,255,255,.12)!important;border-radius:6px!important;overflow:hidden;margin:18px!important}
.map-frame .leaflet-control-zoom a{background:rgba(7,13,24,.92)!important;color:var(--off)!important;border-color:var(--border)!important;width:34px!important;height:34px!important;line-height:34px!important;font-size:17px!important}
.map-frame .leaflet-control-zoom a:hover{background:rgba(17,32,58,.95)!important;color:var(--orange)!important}
.map-frame .leaflet-control-attribution{background:rgba(5,8,15,.8)!important;color:var(--muted)!important;font-size:9px!important}
.map-frame .leaflet-control-attribution a{color:var(--muted)!important}
/* NOTE: never set position on .map-pin — Leaflet positions markers with
   position:absolute + transform; overriding it scatters the pins */
.map-pin{width:14px;height:14px}
.map-pin-dot{width:9px;height:9px;background:var(--orange);border:2px solid rgba(241,90,34,.4);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);box-shadow:0 0 14px rgba(241,90,34,.6);transition:transform .3s}
.map-pin:hover .map-pin-dot{transform:translate(-50%,-50%) scale(1.4)}
.map-pin-pulse{width:26px;height:26px;background:rgba(241,90,34,.14);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);animation:pinPulse 2.6s ease-out infinite}
@keyframes pinPulse{0%{transform:translate(-50%,-50%) scale(.45);opacity:1}100%{transform:translate(-50%,-50%) scale(2.6);opacity:0}}
.map-tooltip{background:rgba(5,8,15,.95)!important;border:1px solid rgba(241,90,34,.3)!important;border-radius:5px!important;padding:9px 15px!important;color:var(--white)!important;font-family:var(--sans)!important;font-size:12px!important;font-weight:600!important;letter-spacing:.4px!important;box-shadow:0 10px 30px rgba(0,0,0,.5)!important}
.map-tooltip::before{display:none!important}

/* ============================================================
   LOGOS
   ============================================================ */
.logos{padding:90px 0;background:var(--navy-2);border-top:1px solid var(--border);overflow:hidden}
.logos-head{text-align:center;margin-bottom:54px}
.logo-belt{overflow:hidden;mask-image:linear-gradient(to right,transparent,black 12%,black 88%,transparent);-webkit-mask-image:linear-gradient(to right,transparent,black 12%,black 88%,transparent)}
.logo-track{display:flex;gap:36px;align-items:center;width:max-content;animation:tape 28s linear infinite}
/* white pills: several client logos are dark art that vanishes on navy */
.logo-track img{height:52px;width:auto;padding:10px 22px;background:rgba(247,249,252,.92);border-radius:8px;opacity:.85;transition:all .4s;box-sizing:content-box}
.logo-track img:hover{opacity:1;transform:translateY(-3px)}
.logo-belt:hover .logo-track{animation-play-state:paused}

/* ============================================================
   $97 OFFER
   ============================================================ */
.offer{padding:150px 0;background:var(--navy);position:relative;overflow:hidden}
.offer::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse 55% 65% at 50% 45%,rgba(241,90,34,.08),transparent 65%)}
.offer-panel{position:relative;max-width:1000px;margin:0 auto;border-radius:14px;padding:2px;background:linear-gradient(120deg,rgba(241,90,34,.55),rgba(57,85,165,.4),rgba(241,90,34,.55));background-size:250% 250%;animation:borderFlow 7s ease infinite}
@keyframes borderFlow{0%,100%{background-position:0% 50%}50%{background-position:100% 50%}}
.offer-inner{background:linear-gradient(160deg,#0a1322,#070d18);border-radius:12px;padding:76px 70px;display:grid;grid-template-columns:1.25fr .75fr;gap:60px;align-items:center}
.offer-badge{display:inline-flex;align-items:center;gap:8px;padding:8px 18px;background:rgba(241,90,34,.12);border:1px solid rgba(241,90,34,.35);border-radius:100px;font-size:10.5px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--orange);margin-bottom:26px}
.offer h2{font-family:var(--serif);font-size:clamp(30px,3.8vw,46px);font-weight:500;line-height:1.12;margin-bottom:20px}
.offer h2 em{font-style:italic;color:var(--orange)}
.offer-inner>div>p{font-size:16px;color:var(--off);line-height:1.8;margin-bottom:30px;max-width:460px}
.offer-list{list-style:none;display:grid;gap:13px;margin-bottom:38px}
.offer-list li{display:flex;align-items:flex-start;gap:13px;font-size:14.5px;color:var(--off)}
.offer-list svg{width:17px;height:17px;stroke:var(--orange);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px}
.offer-price{text-align:center;padding:46px 36px;background:rgba(241,90,34,.05);border:1px solid rgba(241,90,34,.18);border-radius:10px}
.offer-price .from{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.offer-price .amount{font-family:var(--serif);font-size:92px;font-weight:500;line-height:.9;color:var(--white)}
.offer-price .amount sup{font-size:34px;color:var(--orange);top:-36px;position:relative}
.offer-price .per{font-size:13px;color:var(--muted);margin:14px 0 30px;letter-spacing:1px}
.offer-price .btn{width:100%;justify-content:center}
@media(max-width:880px){.offer{padding:100px 0}.offer-inner{grid-template-columns:1fr;padding:50px 32px;gap:42px}.offer-price .amount{font-size:74px}}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testimonials{padding:140px 0;background:var(--navy-3);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
.test-head{text-align:center;max-width:640px;margin:0 auto 70px}
.test-head .lede{margin:18px auto 0}
.vid-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;max-width:1000px;margin:0 auto}
.vid-card{aspect-ratio:9/16;background:var(--card);border:1px solid var(--border);border-radius:10px;overflow:hidden;position:relative;cursor:pointer;transition:all .45s var(--ease)}
.vid-card:hover{border-color:rgba(241,90,34,.3);transform:translateY(-8px);box-shadow:0 28px 70px rgba(0,0,0,.55)}
.vid-card video{width:100%;height:100%;object-fit:cover}
.vid-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(5,8,15,.8),transparent 45%);display:flex;align-items:flex-end;padding:26px;pointer-events:none;transition:opacity .35s}
.vid-label{font-family:var(--serif);font-size:19px;font-weight:500;color:var(--white)}
.vid-sub{font-size:10.5px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--orange);margin-top:4px}
.play-btn{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:64px;height:64px;border-radius:50%;background:rgba(241,90,34,.92);display:flex;align-items:center;justify-content:center;pointer-events:none;transition:all .35s var(--ease);box-shadow:0 0 0 0 rgba(241,90,34,.4)}
.vid-card:hover .play-btn{transform:translate(-50%,-50%) scale(1.12);box-shadow:0 0 0 16px rgba(241,90,34,.12)}
.play-btn svg{width:22px;height:22px;fill:var(--navy);margin-left:3px}
.vid-note{text-align:center;margin-top:32px;font-size:13px;color:var(--muted);font-style:italic}
@media(max-width:820px){.testimonials{padding:100px 0}.vid-grid{grid-template-columns:1fr;max-width:340px}}

/* ============================================================
   CTA + FOOTER
   ============================================================ */
.cta{padding:160px 0;background:var(--navy);text-align:center;position:relative;overflow:hidden}
#ctaNet{position:absolute;inset:0;width:100%;height:100%;z-index:1;opacity:.55}
.cta::after{content:'';position:absolute;inset:0;z-index:2;background:radial-gradient(ellipse 90% 90% at 50% 50%,transparent 30%,var(--navy) 100%);pointer-events:none}
.cta-content{position:relative;z-index:3;max-width:760px;margin:0 auto}
.cta h2{font-family:var(--serif);font-size:clamp(38px,5.6vw,68px);font-weight:500;line-height:1.08;margin-bottom:26px}
.cta h2 em{font-style:italic;color:var(--orange)}
.cta p{font-size:17px;color:var(--off);max-width:520px;margin:0 auto 48px;line-height:1.8}
.cta-actions{display:flex;gap:18px;justify-content:center;flex-wrap:wrap}
.cta-phone{margin-top:40px;font-size:14px;color:var(--muted)}
.cta-phone a{color:var(--orange);text-decoration:none;font-weight:600}

.footer{background:var(--navy-2);border-top:1px solid var(--border);padding:70px 0 36px}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:60px;margin-bottom:56px}
.footer-brand img{height:52px;margin-bottom:22px}
.footer-brand p{font-size:14px;color:var(--muted);line-height:1.8;max-width:320px}
.footer h4{font-size:11px;font-weight:700;letter-spacing:3px;text-transform:uppercase;color:var(--white);margin-bottom:22px}
.footer ul{list-style:none;display:grid;gap:13px}
.footer ul a{font-size:14px;color:var(--off);text-decoration:none;transition:color .3s}
.footer ul a:hover{color:var(--orange)}
.footer-social{display:flex;gap:14px;margin-top:26px}
.footer-social a{width:38px;height:38px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .3s}
.footer-social a:hover{border-color:var(--orange);transform:translateY(-3px)}
.footer-social svg{width:16px;height:16px;fill:var(--off);transition:fill .3s}
.footer-social a:hover svg{fill:var(--orange)}
.footer-bottom{border-top:1px solid var(--border);padding-top:32px;display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;font-size:12.5px;color:var(--muted)}
@media(max-width:820px){.footer-grid{grid-template-columns:1fr;gap:44px}}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  html{scroll-behavior:auto}
}

/* ============================================================
   SUBPAGE COMPONENTS
   ============================================================ */

/* active nav link */
.nav-links a.active{color:var(--white)}
.nav-links a.active:not(.nav-cta)::after{width:100%}

/* page hero */
.page-hero{padding:210px 0 110px;position:relative;overflow:hidden;background:radial-gradient(ellipse 80% 60% at 70% 0%,rgba(57,85,165,.12),transparent 55%),radial-gradient(ellipse 50% 50% at 15% 100%,rgba(241,90,34,.07),transparent 60%),var(--navy)}
.page-hero .net-canvas{position:absolute;top:0;left:0;width:100%;height:100%;opacity:.55;z-index:1}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{font-family:var(--serif);font-size:clamp(42px,6vw,76px);font-weight:500;line-height:1.06;letter-spacing:-1px;max-width:880px}
.page-hero h1 em{font-style:italic;color:var(--orange)}
.page-hero .lede{margin-top:26px}
.crumb{font-size:11px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--muted);margin-bottom:28px}
.crumb a{color:var(--muted);text-decoration:none;transition:color .3s}
.crumb a:hover{color:var(--orange)}
.crumb span{color:var(--orange)}
@media(max-width:768px){.page-hero{padding:150px 0 80px}}

/* generic section */
.section{padding:120px 0;background:var(--navy)}
.section.alt{background:var(--navy-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
@media(max-width:768px){.section{padding:90px 0}}

/* ---------- pricing ---------- */
.plans{display:grid;grid-template-columns:repeat(3,1fr);gap:26px;align-items:stretch;margin-top:70px}
.plan-shell{border-radius:12px;padding:1px;background:var(--border);display:flex}
.plan-shell.featured{padding:2px;background:linear-gradient(120deg,rgba(241,90,34,.65),rgba(57,85,165,.45),rgba(241,90,34,.65));background-size:250% 250%;animation:borderFlow 7s ease infinite;transform:translateY(-14px)}
.plan{background:linear-gradient(165deg,#0c1729,#070d18);border-radius:11px;padding:48px 40px;display:flex;flex-direction:column;width:100%;position:relative}
.plan-pop{position:absolute;top:-13px;left:50%;transform:translateX(-50%);padding:7px 18px;background:var(--orange);color:var(--navy);font-size:10px;font-weight:700;letter-spacing:2.5px;text-transform:uppercase;border-radius:100px;white-space:nowrap;box-shadow:0 6px 20px rgba(241,90,34,.4)}
.plan-tier{font-size:11px;font-weight:700;letter-spacing:4px;text-transform:uppercase;color:var(--orange);margin-bottom:14px}
.plan h3{font-family:var(--serif);font-size:26px;font-weight:500;margin-bottom:10px}
.plan-desc{font-size:14px;color:var(--off);line-height:1.7;margin-bottom:30px;min-height:48px}
.plan-amount{font-family:var(--serif);font-size:64px;font-weight:500;line-height:1;color:var(--white)}
.plan-amount sup{font-size:26px;color:var(--orange);position:relative;top:-26px;margin-right:2px}
.plan-per{font-size:12.5px;color:var(--muted);letter-spacing:1px;margin:10px 0 34px}
.plan-list{list-style:none;display:grid;gap:13px;margin-bottom:40px;flex:1}
.plan-list li{display:flex;align-items:flex-start;gap:12px;font-size:14px;color:var(--off);line-height:1.55}
.plan-list svg{width:16px;height:16px;stroke:var(--orange);fill:none;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:2px}
.plan-list li.head{font-size:11px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--muted);margin-top:6px}
.plan .btn{width:100%;justify-content:center;margin-top:auto}
.plans-note{text-align:center;margin-top:40px;font-size:13.5px;color:var(--muted)}
.plans-note a{color:var(--orange)}
@media(max-width:980px){.plans{grid-template-columns:1fr;max-width:480px;margin-left:auto;margin-right:auto}.plan-shell.featured{transform:none}}

/* faq */
.faq{max-width:760px;margin:70px auto 0}
.faq details{border:1px solid var(--border);border-radius:8px;background:var(--card);margin-bottom:14px;overflow:hidden;transition:border-color .3s}
.faq details[open]{border-color:rgba(241,90,34,.3)}
.faq summary{padding:24px 28px;cursor:pointer;font-size:16px;font-weight:600;color:var(--white);list-style:none;display:flex;justify-content:space-between;align-items:center;gap:18px}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:'+';font-family:var(--serif);font-size:26px;color:var(--orange);transition:transform .3s;flex-shrink:0;line-height:1}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq details p{padding:0 28px 26px;font-size:14.5px;color:var(--off);line-height:1.8}

/* ---------- our work ---------- */
.work-filters{display:flex;gap:10px;flex-wrap:wrap;justify-content:center;margin:54px 0 44px}
.chip{padding:11px 24px;background:transparent;border:1px solid var(--border);border-radius:100px;color:var(--off);font-family:var(--sans);font-size:11.5px;font-weight:600;letter-spacing:1.8px;text-transform:uppercase;cursor:pointer;transition:all .3s}
.chip:hover{border-color:rgba(241,90,34,.4);color:var(--white)}
.chip.active{background:var(--orange);border-color:var(--orange);color:var(--navy)}
.work-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.work-card{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:40px 34px;position:relative;overflow:hidden;transition:all .4s var(--ease)}
.work-card::before{content:'';position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--orange),transparent);opacity:0;transition:opacity .4s}
.work-card:hover{transform:translateY(-5px);border-color:rgba(241,90,34,.2);background:var(--card-hover)}
.work-card:hover::before{opacity:1}
.work-card.hidden{display:none}
.work-mono{font-family:var(--serif);font-size:40px;font-style:italic;color:rgba(241,90,34,.35);line-height:1;margin-bottom:24px}
.work-card:nth-child(even) .work-mono{color:rgba(93,127,216,.4)}
.work-name{font-family:var(--serif);font-size:21px;font-weight:500;color:var(--white);margin-bottom:12px}
.work-meta{display:flex;gap:8px;flex-wrap:wrap}
.work-meta span{font-size:10px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--muted);padding:6px 12px;border:1px solid var(--border);border-radius:100px}
@media(max-width:920px){.work-grid{grid-template-columns:1fr 1fr}}
@media(max-width:600px){.work-grid{grid-template-columns:1fr}}

/* ---------- service detail ---------- */
.inc-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;margin-top:60px}
.inc{display:flex;gap:18px;align-items:flex-start;background:var(--card);border:1px solid var(--border);border-radius:8px;padding:28px 30px;transition:all .35s var(--ease)}
.inc:hover{border-color:rgba(241,90,34,.22);transform:translateY(-3px)}
.inc svg{width:20px;height:20px;stroke:var(--orange);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;flex-shrink:0;margin-top:3px}
.inc h4{font-size:16px;font-weight:600;color:var(--white);margin-bottom:7px}
.inc p{font-size:13.5px;color:var(--off);line-height:1.7}
@media(max-width:768px){.inc-grid{grid-template-columns:1fr}}

.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;margin-top:64px}
.step{position:relative;padding:36px 28px;background:var(--card);border:1px solid var(--border);border-radius:8px}
.step-num{font-family:var(--serif);font-size:46px;font-style:italic;color:rgba(241,90,34,.3);line-height:1;margin-bottom:18px}
.step h4{font-size:16px;font-weight:600;margin-bottom:10px}
.step p{font-size:13.5px;color:var(--off);line-height:1.7}
@media(max-width:920px){.steps{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.steps{grid-template-columns:1fr}}

.svc-prose{max-width:780px;margin:0 auto}
.svc-prose p{font-size:16.5px;color:var(--off);line-height:1.9;margin-bottom:26px}
.svc-prose p strong{color:var(--white);font-weight:600}
.svc-prose h2{font-family:var(--serif);font-size:32px;font-weight:500;margin:50px 0 22px}
.svc-prose h2 em{font-style:italic;color:var(--orange)}

/* big link cards (services overview) */
.svc-link-card{text-decoration:none;display:block}
.svc-link-card .s-arrow{position:absolute;bottom:34px;right:36px;width:40px;height:40px;border:1px solid var(--border);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .35s var(--ease)}
.svc-link-card:hover .s-arrow{border-color:var(--orange);background:var(--orange)}
.svc-link-card .s-arrow svg{width:16px;height:16px;stroke:var(--off);fill:none;stroke-width:2;transition:stroke .3s}
.svc-link-card:hover .s-arrow svg{stroke:var(--navy)}

/* ---------- contact ---------- */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:64px}
.contact-card{background:var(--card);border:1px solid var(--border);border-radius:10px;padding:44px 36px;text-align:center;transition:all .4s var(--ease)}
.contact-card:hover{transform:translateY(-5px);border-color:rgba(241,90,34,.25)}
.contact-card .cc-icon{width:56px;height:56px;margin:0 auto 24px;border-radius:50%;background:rgba(241,90,34,.08);border:1px solid rgba(241,90,34,.18);display:flex;align-items:center;justify-content:center}
.contact-card .cc-icon svg{width:23px;height:23px;stroke:var(--orange);fill:none;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact-card h3{font-family:var(--serif);font-size:21px;font-weight:500;margin-bottom:10px}
.contact-card p{font-size:13.5px;color:var(--muted);margin-bottom:18px;line-height:1.7}
.contact-card a.cc-link{font-size:15px;font-weight:600;color:var(--orange);text-decoration:none}
.contact-card a.cc-link:hover{text-decoration:underline}
@media(max-width:880px){.contact-grid{grid-template-columns:1fr;max-width:440px;margin-left:auto;margin-right:auto}}

/* offer panel "compare plans" link */
.offer-more{display:block;margin-top:18px;font-size:13px;color:var(--muted);text-decoration:none;transition:color .3s}
.offer-more:hover{color:var(--orange)}
