/* =====================================================================
   WEBSITE DESIGN SERVICES — page-specific styles
   Reuses tokens + chrome from styles.css (:root, .mp-sec, .mp-kicker,
   .mp-title, .mp-grad, .nh-btn, .wb__bar, .wb__shot). Everything here is
   namespaced .wd-* so it cannot leak into other pages.
   ===================================================================== */

/* ---- shared centered section header ---- */
.wd-head{text-align:center;max-width:46rem;margin:0 auto clamp(.7rem,1.8vh,1.5rem)}
.wd-head__kicker{margin-left:auto;margin-right:auto;margin-bottom:.6rem}
.wd-head__title{font-size:clamp(1.6rem,3.4vw,2.9rem);margin-bottom:.4rem}
.wd-head__sub{font-size:clamp(.82rem,1.25vw,.98rem);line-height:1.55;color:var(--muted);font-weight:300;margin:0}

/* tighten the full-height content sections so each fits in 100vh while
   still clearing the fixed nav (content is vertically centered) */
.wd-packages,.wd-breakdown,.wd-process,.wd-flex,.wd-work{
  padding-top:calc(var(--navh) + 1vh);padding-bottom:2.5vh}

/* small leading icon inside nh buttons */
.nh-btn__lead{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}

/* =====================================================================
   1 · HERO — annotated browser showcase (matches reference)
   ===================================================================== */
.wd-hero{position:relative;z-index:1;min-height:100svh;display:flex;align-items:center;overflow:hidden;
  padding:calc(var(--navh) + 2vh) clamp(3rem,6vw,6rem) 3vh clamp(1.2rem,5vw,5rem)}
.wd-hero__grid{width:100%;max-width:1480px;margin:0 auto;display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(0,1.18fr);gap:clamp(1rem,3vw,3rem);align-items:center}
/* the page-wide dot nav is replaced on this page by the hero's numbered rail */
#navDots{display:none}

/* --- LEFT copy --- */
.wd-hero__copy{min-width:0}
.wd-badge{display:inline-flex;align-items:center;gap:.55rem;padding:.42rem .95rem;border-radius:999px;margin-bottom:1.3rem;
  border:1px solid rgba(168,85,247,.42);background:rgba(168,85,247,.06);
  font-size:.66rem;letter-spacing:.2em;text-transform:uppercase;font-weight:600}
.wd-badge i{width:7px;height:7px;border-radius:50%;flex:0 0 auto;background:linear-gradient(135deg,#ff2e9a,#a855f7);box-shadow:0 0 8px rgba(168,85,247,.9)}
.wd-badge b{font-weight:600;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.wd-hero__title{font-size:clamp(2.3rem,4.5vw,4.05rem);line-height:.98;font-weight:300;text-transform:uppercase;
  letter-spacing:.01em;color:#fff;margin:0}
.wd-hero__body{position:relative;padding-left:1.1rem;font-size:clamp(.86rem,1.15vw,1rem);line-height:1.7;color:var(--muted);
  font-weight:300;max-width:30rem;margin:1.5rem 0 1.7rem}
.wd-hero__body::before{content:"";position:absolute;left:0;top:.25em;bottom:.25em;width:2px;border-radius:2px;
  background:linear-gradient(180deg,#ff2e9a,#a855f7,#3b82f6)}
.wd-hero__cta{display:flex;flex-wrap:wrap;gap:.9rem;margin-bottom:1.8rem}
.wd-btn-grad{display:inline-flex;align-items:center;gap:.55rem;padding:.95rem 1.8rem;border-radius:12px;white-space:nowrap;
  font-size:.76rem;letter-spacing:.13em;text-transform:uppercase;font-weight:600;color:#fff;
  background:linear-gradient(95deg,#ff2e9a,#a855f7 52%,#3b82f6);box-shadow:0 14px 40px -12px rgba(168,85,247,.75);
  transition:transform .3s var(--ease),box-shadow .3s}
.wd-btn-grad:hover{transform:translateY(-2px);box-shadow:0 20px 52px -12px rgba(168,85,247,.95)}
.wd-btn-grad span{transition:transform .3s var(--ease)}
.wd-btn-grad:hover span{transform:translateX(4px)}
.wd-hero__mini{list-style:none;display:flex;flex-wrap:wrap;align-items:center}
.wd-hero__mini li{display:inline-flex;align-items:center;gap:.45rem;font-size:.58rem;letter-spacing:.08em;text-transform:uppercase;font-weight:600;color:#b7b2c9}
.wd-hero__mini li:not(:last-child){margin-right:.85rem;padding-right:.85rem;border-right:1px solid rgba(255,255,255,.16)}
.wd-hero__mini-ico{display:inline-grid;place-items:center;width:17px;height:17px;color:#d06bf0}
.wd-hero__mini-ico svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* --- RIGHT showcase stage --- */
.wd-stage{position:relative;min-width:0;height:clamp(440px,66vh,640px);perspective:2100px;perspective-origin:55% 42%}

/* tilted browser */
.wd-browser{position:absolute;left:15%;top:2%;width:84%;z-index:2;border-radius:15px;overflow:hidden;
  border:1px solid rgba(168,85,247,.3);background:#0b0817;
  box-shadow:0 56px 120px -36px rgba(120,40,210,.72),0 0 0 1px rgba(255,255,255,.04);
  transform:rotateY(-15deg) rotateX(4deg) rotate(.4deg);transform-origin:center;
  transition:transform .6s var(--ease),box-shadow .6s}
.wd-browser:hover{transform:rotateY(-9deg) rotateX(2deg)}
.wd-browser__bar{display:flex;align-items:center;gap:7px;height:38px;padding:0 14px;
  background:linear-gradient(180deg,#181230,#110c20);border-bottom:1px solid rgba(168,85,247,.16)}
.wd-browser__dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.wd-browser__dot:nth-child(1){background:#ff5f57}
.wd-browser__dot:nth-child(2){background:#febc2e}
.wd-browser__dot:nth-child(3){background:#28c840}
.wd-browser__url{margin:0 auto;display:inline-flex;align-items:center;gap:.45rem;padding:.3rem 1.1rem;border-radius:999px;
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.08);font-size:.66rem;color:#c2bcd4;letter-spacing:.02em}
.wd-browser__url svg{width:11px;height:11px;fill:none;stroke:#9a93b3;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.wd-browser__ctl{width:15px;height:13px;border-radius:4px;border:1.5px solid rgba(255,255,255,.22);flex:0 0 auto}
.wd-browser__page{position:relative;overflow:hidden;padding:clamp(1rem,2vw,1.7rem) clamp(1.1rem,2.2vw,2rem) clamp(1rem,2vh,1.6rem);
  min-height:clamp(232px,34vh,360px);background:radial-gradient(125% 130% at 82% 26%,#22103c 0,#120a22 46%,#090511 100%)}
.wd-lum__nav{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:clamp(1.1rem,3.4vh,2.4rem)}
.wd-lum__logo{font-size:clamp(.9rem,1.4vw,1.15rem);letter-spacing:.34em;color:#fff;font-weight:500;text-transform:uppercase}
.wd-lum__links{display:flex;gap:clamp(.7rem,1.5vw,1.5rem)}
.wd-lum__links b{font-size:.58rem;letter-spacing:.12em;text-transform:uppercase;color:#b7b2c9;font-weight:500}
.wd-lum__hero{position:relative;min-height:clamp(150px,22vh,230px)}
.wd-lum__copy{position:relative;z-index:2;max-width:62%}
.wd-lum__kick{display:block;font-size:.56rem;letter-spacing:.24em;text-transform:uppercase;color:#ad93d6;margin-bottom:.7rem}
.wd-lum__title{font-family:"Playfair Display",Georgia,"Times New Roman",serif;font-weight:500;
  font-size:clamp(1.4rem,2.9vw,2.5rem);line-height:1.06;color:#fff;margin:0 0 .7rem;letter-spacing:.005em}
.wd-lum__sub{font-size:.72rem;line-height:1.55;color:#9a93b3;max-width:21rem;margin:0 0 1.05rem}
.wd-lum__btn{display:inline-flex;align-items:center;gap:.45rem;padding:.5rem 1.05rem;border-radius:8px;
  font-size:.58rem;letter-spacing:.13em;text-transform:uppercase;font-weight:600;color:#fff;
  border:1px solid rgba(255,255,255,.26);background:rgba(255,255,255,.04)}
.wd-lum__btn em{font-style:normal}
/* neon portal */
.wd-lum__portal{position:absolute;right:-6%;top:-16%;bottom:-30%;width:62%;z-index:1;overflow:hidden;
  background:linear-gradient(180deg,transparent 34%,rgba(48,16,72,.5) 70%,rgba(22,8,38,.78) 100%)}
.wd-lum__ring{position:absolute;right:4%;top:48%;transform:translateY(-50%);width:min(94%,300px);aspect-ratio:1;border-radius:50%;
  background:radial-gradient(circle,transparent 57%,rgba(150,70,235,.22) 61%,rgba(205,120,255,.98) 65.5%,rgba(150,60,230,.35) 71%,transparent 79%);
  box-shadow:0 0 110px 20px rgba(175,75,255,.6);filter:saturate(1.3)}
.wd-lum__ring::after{content:"";position:absolute;right:15%;bottom:12%;width:30%;height:30%;border-radius:50%;
  background:radial-gradient(circle,#fff,rgba(255,190,255,.7) 40%,transparent 72%);filter:blur(2px)}
.wd-lum__horizon{position:absolute;left:-12%;right:-12%;bottom:12%;height:50%;
  background:radial-gradient(120% 100% at 60% 100%,rgba(205,105,255,.6),rgba(120,40,200,.14) 48%,transparent 72%)}

/* floating feature cards + dotted connectors */
.wd-fcard{position:absolute;z-index:5;width:clamp(146px,12.5vw,178px);padding:.85rem .95rem;border-radius:14px;
  background:linear-gradient(158deg,rgba(24,16,42,.84),rgba(12,9,22,.8));-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);
  border:1px solid rgba(168,85,247,.34);box-shadow:0 30px 60px -26px rgba(70,25,150,.7),inset 0 1px 0 rgba(255,255,255,.07);
  transform:rotateY(-15deg) rotateX(4deg) rotate(.4deg);transform-origin:center}
.wd-fcard__ico{display:inline-grid;place-items:center;width:32px;height:32px;border-radius:9px;margin-bottom:.55rem;
  border:1px solid rgba(168,85,247,.42);background:linear-gradient(150deg,rgba(168,85,247,.2),rgba(255,46,154,.08));color:#d6a3ff;
  box-shadow:inset 0 0 12px -4px rgba(168,85,247,.55)}
.wd-fcard__ico svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.wd-fcard b{display:block;font-size:.65rem;letter-spacing:.07em;text-transform:uppercase;font-weight:700;color:#fff;margin-bottom:.28rem}
.wd-fcard span{display:block;font-size:.62rem;line-height:1.4;color:#9a93b3}
.wd-fcard--cd{left:-1%;top:13%}
.wd-fcard--fa{left:-4%;top:45%}
.wd-fcard--seo{right:-2%;top:9%}
.wd-fcard--spd{right:-5%;top:41%}
.wd-conn{position:absolute;top:50%;height:0;border-top:1.5px dotted rgba(180,120,245,.6);z-index:1}
.wd-conn::after{content:"";position:absolute;top:-4px;width:7px;height:7px;border-radius:50%;
  background:#c98bff;box-shadow:0 0 9px rgba(168,85,247,.95)}
.wd-conn--r{right:-34px;width:34px}
.wd-conn--r::after{right:-4px}
.wd-conn--l{left:-34px;width:34px}
.wd-conn--l::after{left:-4px}

/* live performance index panel */
.wd-perf{position:absolute;left:8%;right:1%;bottom:0;z-index:6;border-radius:15px;
  padding:clamp(.85rem,1.5vw,1.25rem) clamp(1.05rem,2vw,1.6rem);
  background:linear-gradient(158deg,rgba(16,10,28,.86),rgba(10,7,18,.82));-webkit-backdrop-filter:blur(13px);backdrop-filter:blur(13px);
  border:1px solid rgba(168,85,247,.3);box-shadow:0 34px 78px -32px rgba(80,30,160,.72),inset 0 1px 0 rgba(255,255,255,.06);
  transform:rotateY(-15deg) rotateX(4deg) rotate(.4deg);transform-origin:center}
.wd-perf__head{display:flex;align-items:center;justify-content:space-between;margin-bottom:.7rem}
.wd-perf__h{font-size:.58rem;letter-spacing:.2em;text-transform:uppercase;color:#9a93b3;font-weight:600}
.wd-perf__live{display:inline-flex;align-items:center;gap:.4rem;font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:#c98bff;font-weight:600}
.wd-perf__live i{width:6px;height:6px;border-radius:50%;background:#c98bff;box-shadow:0 0 9px #a855f7;animation:wd-pulse 1.8s ease-in-out infinite}
@keyframes wd-pulse{0%,100%{opacity:1}50%{opacity:.25}}
.wd-perf__body{display:grid;grid-template-columns:auto 1fr;gap:clamp(1rem,2.4vw,2rem);align-items:center}
.wd-perf__score{padding-right:clamp(1rem,2.4vw,2rem);border-right:1px solid rgba(255,255,255,.1)}
.wd-perf__num{display:flex;align-items:baseline;gap:.12rem}
.wd-perf__num b{font-size:clamp(2.1rem,3.8vw,3.1rem);font-weight:700;line-height:1;background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.wd-perf__num em{font-size:1rem;font-style:normal;color:#7c7796;font-weight:500}
.wd-perf__score i{display:block;font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:#9a93b3;font-style:normal;font-weight:600;margin-top:.3rem}
.wd-perf__stats{display:grid;grid-template-columns:repeat(3,1fr);gap:.8rem;text-align:center}
.wd-perf__stat{display:flex;flex-direction:column;align-items:center;gap:.25rem}
.wd-perf__ico{color:#c98bff;line-height:0}
.wd-perf__ico svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.wd-perf__stat b{font-size:.55rem;letter-spacing:.1em;text-transform:uppercase;color:#9a93b3;font-weight:600}
.wd-perf__stat i{font-size:clamp(1rem,1.8vw,1.45rem);font-style:normal;font-weight:600;color:#fff}

/* high-detail animated hero icons (cards + performance index) */
.wd-ico{filter:drop-shadow(0 0 3px rgba(214,163,255,.5))}
.wd-ico--design .wd-ico__trace{stroke-dasharray:17;stroke-dashoffset:17;animation:wd-ico-trace 3.6s ease-in-out infinite}
@keyframes wd-ico-trace{0%{stroke-dashoffset:17;opacity:0}25%{opacity:1}55%{stroke-dashoffset:0;opacity:1}80%{stroke-dashoffset:0;opacity:0}100%{stroke-dashoffset:17;opacity:0}}
.wd-ico--design .wd-ico__spark{transform-box:fill-box;transform-origin:center;animation:wd-ico-spark 2.4s ease-in-out infinite}
@keyframes wd-ico-spark{0%,100%{opacity:.5;transform:scale(.75)}50%{opacity:1;transform:scale(1.25)}}
.wd-ico--fluid .wd-ico__flow{animation:wd-ico-flow 2.8s linear infinite}
@keyframes wd-ico-flow{to{transform:translateX(-12px)}}
.wd-ico--seo .wd-ico__bar{transform-box:fill-box;transform-origin:bottom;animation:wd-ico-bar 2.4s ease-in-out infinite}
.wd-ico--seo .wd-ico__bar--2{animation-delay:.35s}
.wd-ico--seo .wd-ico__bar--3{animation-delay:.7s}
@keyframes wd-ico-bar{0%,100%{transform:scaleY(.5)}50%{transform:scaleY(1)}}
.wd-ico--speed .wd-ico__needle{transform-box:view-box;transform-origin:12px 16.6px;animation:wd-ico-needle 3s ease-in-out infinite}
@keyframes wd-ico-needle{0%,100%{transform:rotate(-34deg)}50%{transform:rotate(36deg)}}
.wd-ico--layers .wd-ico__lyr{transform-box:fill-box}
.wd-ico--layers .wd-ico__lyr--a{animation:wd-ico-lyr 2.8s ease-in-out infinite}
.wd-ico--layers .wd-ico__lyr--c{animation:wd-ico-lyr 2.8s ease-in-out infinite reverse}
@keyframes wd-ico-lyr{0%,100%{transform:translateY(0)}50%{transform:translateY(-1.5px)}}
.wd-ico--bolt .wd-ico__bolt{transform-box:fill-box;transform-origin:center;animation:wd-ico-bolt 1.9s ease-in-out infinite}
@keyframes wd-ico-bolt{0%,100%{opacity:.55;transform:scale(.92)}50%{opacity:1;transform:scale(1.06)}}
.wd-ico--ekg .wd-ico__ekg{stroke-dasharray:42;animation:wd-ico-ekg 1.7s linear infinite}
@keyframes wd-ico-ekg{0%{stroke-dashoffset:42}100%{stroke-dashoffset:0}}

/* =====================================================================
   2 · PACKAGES & PRICING
   ===================================================================== */
.wd-price-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(.9rem,1.7vw,1.5rem);align-items:stretch}
.wd-tier{--ac:#ff2e9a;--ac2:#ff7ac8;position:relative;display:flex;flex-direction:column;
  padding:clamp(.85rem,1.3vw,1.15rem);border-radius:16px;border:1px solid rgba(168,85,247,.18);
  background:linear-gradient(165deg,rgba(22,16,40,.55),rgba(10,8,20,.5));
  box-shadow:0 26px 60px -34px rgba(0,0,0,.85);transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.wd-tier::before{content:"";position:absolute;inset:0;border-radius:16px;pointer-events:none;
  background:radial-gradient(120% 60% at 50% 0,color-mix(in srgb,var(--ac) 16%,transparent),transparent 60%);opacity:.7}
.wd-tier:hover{transform:translateY(-5px);border-color:color-mix(in srgb,var(--ac) 55%,transparent);
  box-shadow:0 34px 74px -30px color-mix(in srgb,var(--ac) 55%,rgba(0,0,0,.6))}
.wd-tier--i{--ac:#ff2e9a;--ac2:#ff7ac8}
.wd-tier--ii{--ac:#3b82f6;--ac2:#7db0ff;border-color:rgba(91,139,255,.4);
  box-shadow:0 30px 70px -30px rgba(59,130,246,.45)}
.wd-tier--iii{--ac:#a855f7;--ac2:#c98bff}
.wd-tier__top{position:relative}
.wd-tier__label{display:block;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:var(--ac2);margin-bottom:.35rem}
.wd-tier__price{font-size:clamp(1.6rem,2.9vw,2.3rem);font-weight:600;color:#fff;line-height:1;margin:0 0 .35rem;font-variant-numeric:tabular-nums}
.wd-tier__desc{font-size:.74rem;line-height:1.4;color:#9a93b3;margin:0 0 .65rem;min-height:1.5em}
.wd-tier__list{list-style:none;display:flex;flex-direction:column;gap:.1rem;margin:0 0 .6rem;
  padding-top:.6rem;border-top:1px solid rgba(255,255,255,.08)}
.wd-tier__examples{margin:0 0 .7rem}
.wd-tier__subhead{display:block;font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;font-weight:600;color:var(--ac2);
  text-align:center;margin-bottom:.5rem}
.wd-tier__tags{display:flex;flex-wrap:wrap;gap:.32rem;justify-content:center}
.wd-tier__tags span{font-size:.56rem;letter-spacing:.02em;font-weight:500;color:#c7c0dd;padding:.24rem .5rem;border-radius:6px;
  border:1px solid color-mix(in srgb,var(--ac) 32%,transparent);background:color-mix(in srgb,var(--ac) 9%,transparent);white-space:nowrap}
.wd-tier__btn{margin-top:auto;display:block;text-align:center;padding:.6rem 1rem;border-radius:10px;
  font-size:.68rem;letter-spacing:.14em;text-transform:uppercase;font-weight:600;color:#fff;
  border:1px solid color-mix(in srgb,var(--ac) 60%,transparent);background:color-mix(in srgb,var(--ac) 12%,transparent);
  transition:background .3s,box-shadow .3s,transform .3s}
.wd-tier__btn:hover{background:color-mix(in srgb,var(--ac) 26%,transparent);transform:translateY(-2px);
  box-shadow:0 0 28px -6px color-mix(in srgb,var(--ac) 80%,transparent)}

/* checklist item (shared by pricing + breakdown) */
.wd-check{position:relative;padding-left:1.55rem;font-size:.75rem;line-height:1.35;color:#cac6da;font-weight:300;margin:.24rem 0}
.wd-check::before{content:"";position:absolute;left:0;top:.02em;width:16px;height:16px;border-radius:50%;
  background:rgba(255,255,255,.04);border:1px solid var(--ac,#ff2e9a);opacity:.92}
.wd-check::after{content:"";position:absolute;left:5px;top:.24em;width:4px;height:7px;
  border:solid var(--ac,#ff2e9a);border-width:0 2px 2px 0;transform:rotate(43deg)}

/* =====================================================================
   3 · DETAILED PACKAGE BREAKDOWN
   ===================================================================== */
.wd-bd-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:clamp(1rem,2vw,1.8rem);align-items:start}
.wd-bd-col{--ac:#ff2e9a;position:relative;padding:clamp(1rem,1.6vw,1.4rem);border-radius:16px;
  border:1px solid rgba(168,85,247,.16);background:linear-gradient(165deg,rgba(20,15,36,.5),rgba(10,8,20,.45));
  transition:transform .55s cubic-bezier(.22,1,.36,1),box-shadow .55s cubic-bezier(.22,1,.36,1),border-color .4s;will-change:transform}
/* cursor-tracking surface sheen */
.wd-bd-col::after{content:"";position:absolute;inset:0;border-radius:inherit;pointer-events:none;mix-blend-mode:screen;opacity:0;transition:opacity .4s;
  background:radial-gradient(40% 50% at var(--gx,50%) var(--gy,50%),rgba(255,255,255,.13),transparent 62%)}
.wd-bd-col.is-lift::after{opacity:1}
/* lifted state: accent border + colored glow behind the card */
.wd-bd-col.is-lift{border-color:color-mix(in srgb,var(--ac) 50%,transparent);
  box-shadow:0 42px 70px -26px rgba(0,0,0,.85),0 0 62px -6px color-mix(in srgb,var(--ac) 68%,transparent)}
.wd-bd-col--i{--ac:#ff2e9a}
.wd-bd-col--ii{--ac:#3b82f6}
.wd-bd-col--iii{--ac:#a855f7}
.wd-bd__tier{display:inline-block;font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;font-weight:700;color:#fff;
  padding:.22rem .55rem;border-radius:6px;margin-bottom:.6rem;
  background:color-mix(in srgb,var(--ac) 22%,transparent);border:1px solid color-mix(in srgb,var(--ac) 55%,transparent)}
.wd-bd__h{font-size:clamp(.95rem,1.5vw,1.18rem);font-weight:600;color:#fff;margin:0 0 .35rem;letter-spacing:.01em}
.wd-bd__desc{font-size:.74rem;line-height:1.45;color:#9a93b3;margin:0 0 .9rem;min-height:2.9em}

/* mock screen frame */
.wd-bd__mock{position:relative;border-radius:11px;overflow:hidden;margin-bottom:.9rem;
  border:1px solid rgba(168,85,247,.22);box-shadow:0 18px 40px -22px rgba(0,0,0,.8)}
.wd-bd__screen{position:relative;display:block;height:clamp(118px,15vh,150px);padding:.7rem;
  background:linear-gradient(160deg,rgba(18,13,30,.96),rgba(10,8,18,.98));overflow:hidden}
/* skeleton primitives */
.wd-sk{display:block;border-radius:5px;background:rgba(255,255,255,.07)}
.wd-sk--hero{height:34px;margin-bottom:.5rem;border-radius:7px;
  background:linear-gradient(110deg,rgba(255,46,154,.35),rgba(91,139,255,.3))}
.wd-sk__row{display:block;margin-bottom:.34rem}
.wd-sk--w60{width:60%;height:7px}
.wd-sk--w40{width:40%;height:7px}
.wd-sk__cards{display:flex;gap:.4rem;margin-top:.55rem}
.wd-sk__cards b{flex:1;height:30px;border-radius:6px;background:rgba(168,85,247,.16);border:1px solid rgba(168,85,247,.2)}
/* landing variant gets a little phone overlapping */
.wd-phone{position:absolute;right:.6rem;bottom:.5rem;width:40px;height:74px;border-radius:9px;z-index:2;
  background:linear-gradient(160deg,#1a1330,#0c0a18);border:1.5px solid rgba(168,85,247,.4);
  box-shadow:0 12px 26px -10px rgba(0,0,0,.85);padding:7px 5px;display:flex;flex-direction:column;gap:4px}
.wd-phone__notch{position:absolute;top:4px;left:50%;transform:translateX(-50%);width:12px;height:2.5px;border-radius:2px;background:rgba(255,255,255,.25)}
.wd-phone__hero{height:20px;border-radius:4px;margin-top:4px;background:linear-gradient(110deg,rgba(255,46,154,.4),rgba(91,139,255,.34))}
.wd-phone__line{height:4px;border-radius:2px;background:rgba(255,255,255,.16)}
.wd-phone__line--s{width:62%}
/* services grid variant */
.wd-sk__nav{display:flex;gap:.34rem;margin-bottom:.55rem}
.wd-sk__nav b{height:6px;flex:1;border-radius:3px;background:rgba(255,255,255,.12)}
.wd-sk__nav b:first-child{background:linear-gradient(90deg,#3b82f6,#a855f7);flex:1.5}
.wd-sk__tiles{display:grid;grid-template-columns:1fr 1fr;gap:.45rem}
.wd-sk__tiles b{height:34px;border-radius:7px;background:rgba(91,139,255,.14);border:1px solid rgba(91,139,255,.22);position:relative}
.wd-sk__tiles b::before{content:"";position:absolute;left:7px;top:7px;width:40%;height:5px;border-radius:3px;background:rgba(255,255,255,.3)}
/* app dashboard variant */
.wd-app__stats{display:flex;gap:.4rem;margin-bottom:.5rem}
.wd-app__stats b{flex:1;height:26px;border-radius:6px;background:rgba(168,85,247,.16);border:1px solid rgba(168,85,247,.24);position:relative}
.wd-app__stats b::before{content:"";position:absolute;left:6px;top:6px;width:55%;height:4px;border-radius:2px;background:linear-gradient(90deg,#ff2e9a,#a855f7)}
.wd-app__chart{display:block;height:60px;border-radius:7px;overflow:hidden;background:rgba(255,255,255,.02);border:1px solid rgba(255,255,255,.06)}
.wd-app__chart svg{width:100%;height:100%;display:block}
.wd-bd__list{list-style:none;margin:0;display:flex;flex-direction:column;gap:.1rem}

/* =====================================================================
   4 · HOW WE BUILD YOUR WEBSITE — interactive guided reveal
   ===================================================================== */
.wd-process{--node:58px;--step-w:clamp(116px,12vw,142px);--conn-w:clamp(42px,4.6vw,72px);
  --ez:cubic-bezier(.22,1,.36,1)}

/* horizontally-scrollable stage; the revealed cluster stays centered + grows */
.wd-proc__flow{position:relative;overflow-x:auto;overflow-y:hidden;padding:2.6rem 0 2rem;
  scrollbar-width:none;-ms-overflow-style:none}
.wd-proc__flow::-webkit-scrollbar{display:none}
.wd-proc__steps{display:flex;align-items:flex-start;width:max-content;margin-inline:auto;padding:0 clamp(1rem,4vw,3rem)}

/* a step: hidden until revealed (display:none), then content animates in */
.wd-pstep{display:none;flex:0 0 auto;width:var(--step-w);flex-direction:column;align-items:center;text-align:center;will-change:transform}
.wd-pstep.is-shown{display:flex}

/* the icon node */
.wd-pstep__node{position:relative;width:var(--node);height:var(--node);border-radius:50%;display:grid;place-items:center;flex:0 0 auto;margin-bottom:.95rem;
  background:radial-gradient(circle at 50% 34%,rgba(34,22,54,.96),rgba(11,8,20,.99));border:1px solid rgba(168,85,247,.3);box-shadow:0 8px 22px -8px rgba(0,0,0,.6);
  transform:scale(.5);opacity:0;transition:transform .55s var(--ez) .08s,opacity .5s .08s}
.wd-pstep.is-revealed .wd-pstep__node{transform:scale(1);opacity:1}
.wd-pstep__ico{width:25px;height:25px;fill:none;stroke:#ff9bd4;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:2}
.wd-pstep__no{position:absolute;right:-5px;top:-5px;width:22px;height:22px;border-radius:50%;display:grid;place-items:center;z-index:3;
  font-size:.64rem;font-weight:700;color:#fff;background:linear-gradient(95deg,#ff2e9a,#a855f7);box-shadow:0 4px 12px -3px rgba(255,46,154,.95)}

/* node pulse on advance (scale pop; the plasma intensity boost is on canvas) */
.wd-pstep__node.is-pulse{animation:wd-node-pulse .74s var(--ez)}
@keyframes wd-node-pulse{0%{transform:scale(1)}38%{transform:scale(1.17)}100%{transform:scale(1)}}

.wd-pstep__h{font-size:.74rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#fff;margin:0 0 .35rem;line-height:1.2;
  opacity:0;transform:translateY(8px);transition:opacity .5s .24s,transform .5s .24s}
.wd-pstep__p{font-size:.68rem;line-height:1.42;color:#9a93b3;margin:0;
  opacity:0;transform:translateY(8px);transition:opacity .5s .32s,transform .5s .32s}
.wd-pstep.is-revealed .wd-pstep__h,.wd-pstep.is-revealed .wd-pstep__p{opacity:1;transform:none}

/* connector = an invisible spacer that holds the gap between two nodes; the
   energy arc itself is drawn on the overlay canvas, node-edge to node-edge */
.wd-pconn{display:none;flex:0 0 auto;width:var(--conn-w);height:var(--node)}
.wd-pconn.is-shown{display:block}

/* the plasma + arc overlay canvas spans the stage and sits above the nodes */
.wd-proc__stage{position:relative}
.wd-proc__fx{position:absolute;left:0;top:0;width:100%;height:100%;z-index:3;pointer-events:none}

/* guide: clean animated arrow + hint, trails the last revealed step */
.wd-proc__guide{flex:0 0 auto;display:flex;flex-direction:column;align-items:center;gap:.7rem;
  margin-left:clamp(8px,1.2vw,18px);margin-top:calc(var(--node)/2 - 24px)}
.wd-proc__guide.is-done{display:none}
.wd-proc__advance{position:relative;width:48px;height:48px;border-radius:50%;display:grid;place-items:center;cursor:pointer;color:#fff;
  border:1px solid rgba(168,85,247,.55);background:rgba(168,85,247,.1);box-shadow:0 0 22px -6px rgba(168,85,247,.8);
  animation:wd-arrow-nudge 1.8s var(--ez) infinite;transition:background .3s,border-color .3s,box-shadow .3s}
.wd-proc__advance svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.wd-proc__advance:hover{background:rgba(255,46,154,.2);border-color:rgba(255,46,154,.7);box-shadow:0 0 32px -4px rgba(255,46,154,.95)}
.wd-proc__advance:focus-visible{outline:2px solid #ff7ac8;outline-offset:3px}
.wd-proc__advance-pulse{position:absolute;inset:-3px;border-radius:50%;border:1px solid rgba(255,46,154,.6);animation:wd-arrow-ring 1.9s ease-out infinite}
.wd-proc__advance-pulse--2{animation-delay:.95s}
@keyframes wd-arrow-nudge{0%,100%{transform:translateX(0)}50%{transform:translateX(5px)}}
@keyframes wd-arrow-ring{0%{transform:scale(1);opacity:.65}100%{transform:scale(1.7);opacity:0}}
.wd-proc__hint{font-size:.6rem;letter-spacing:.06em;text-transform:uppercase;color:#bba9dc;font-weight:600;line-height:1.35;white-space:nowrap;text-align:center;
  animation:wd-hint-bob 2.6s ease-in-out infinite}
@keyframes wd-hint-bob{0%,100%{opacity:.55}50%{opacity:1}}

/* banner reveals once the journey completes */
.wd-proc__banner{display:flex;align-items:center;justify-content:center;gap:.6rem;text-align:center;max-width:60rem;margin:1.4rem auto 0;
  padding:.9rem 1.4rem;border-radius:12px;font-size:.8rem;line-height:1.5;color:#d6d2e6;font-weight:300;
  border:1px solid rgba(168,85,247,.24);background:linear-gradient(120deg,rgba(255,46,154,.06),rgba(91,139,255,.06));
  opacity:0;transform:translateY(10px);transition:opacity .7s var(--ez),transform .7s var(--ez)}
.wd-proc__banner.is-in{opacity:1;transform:none}
.wd-proc__star{color:#ffd54a;font-size:1rem;flex:0 0 auto;filter:drop-shadow(0 0 8px rgba(255,200,60,.7))}

/* =====================================================================
   5 · FLEXIBLE SOLUTIONS
   ===================================================================== */
.wd-flex__grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1.08fr);gap:clamp(1.4rem,4vw,3.5rem);align-items:center}
.wd-flex__h{font-size:clamp(1.7rem,3.4vw,2.8rem);line-height:1.06;font-weight:300;text-transform:uppercase;color:#fff;margin:0 0 1rem}
.wd-flex__body{font-size:clamp(.86rem,1.2vw,1rem);line-height:1.65;color:var(--muted);font-weight:300;max-width:28rem;margin:0 0 1.4rem}
.wd-flex__points{list-style:none;display:flex;flex-direction:column;gap:.9rem}
.wd-flex__point{display:flex;align-items:flex-start;gap:.8rem;font-size:.86rem;line-height:1.5;color:#cac6da;font-weight:300}
.wd-flex__point b{font-weight:600;color:#fff}
.wd-flex__pico{flex:0 0 auto;width:34px;height:34px;border-radius:9px;display:grid;place-items:center;margin-top:.05rem;
  border:1px solid rgba(168,85,247,.3);background:rgba(168,85,247,.1);color:#ff8ac8}
.wd-flex__pico svg{width:17px;height:17px;fill:none;stroke:currentColor;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}

.wd-flex__visual{position:relative;border-radius:18px;overflow:visible;padding:clamp(1.2rem,2.2vw,1.9rem);
  border:1px solid rgba(168,85,247,.12);box-shadow:0 34px 80px -34px rgba(80,40,160,.7);isolation:isolate}
/* audio-reactive waveform border (canvas injected by JS; bleeds outside the panel) */
.wd-flex__waves{position:absolute;top:-44px;left:-44px;width:calc(100% + 88px);height:calc(100% + 88px);
  z-index:1;pointer-events:none;display:block}
.wd-flex__sky{position:absolute;inset:0;z-index:-1;border-radius:17px;
  background:url("../assets/hero/04-skyline.png") center 70%/150% no-repeat,
             linear-gradient(165deg,rgba(40,12,46,.9),rgba(10,8,22,.95));opacity:.9}
.wd-flex__sky::after{content:"";position:absolute;inset:0;background:radial-gradient(70% 60% at 50% 36%,rgba(255,46,154,.3),transparent 70%)}
.wd-flex__tri{position:absolute;left:50%;top:34%;transform:translate(-50%,-50%);width:0;height:0;
  border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:104px solid transparent;
  filter:drop-shadow(0 0 20px rgba(255,46,154,.6));opacity:.55}
.wd-flex__tri::before{content:"";position:absolute;left:-60px;top:0;width:0;height:0;
  border-left:60px solid transparent;border-right:60px solid transparent;border-bottom:104px solid rgba(255,46,154,.18)}
.wd-flex__cards{position:relative;z-index:2;display:grid;grid-template-columns:1fr 1fr;gap:clamp(.6rem,1.2vw,1rem)}
.wd-flex-card{padding:.85rem .9rem;border-radius:12px;text-align:center;
  background:rgba(12,9,22,.66);-webkit-backdrop-filter:blur(9px);backdrop-filter:blur(9px);
  border:1px solid rgba(168,85,247,.26);box-shadow:0 18px 40px -22px rgba(0,0,0,.7);transition:transform .35s var(--ease),border-color .35s}
.wd-flex-card:hover{transform:translateY(-3px);border-color:rgba(255,46,154,.5)}
.wd-flex-card__ico{display:inline-grid;place-items:center;width:36px;height:36px;border-radius:10px;margin-bottom:.5rem;
  border:1px solid rgba(255,46,154,.35);background:rgba(255,46,154,.1);color:#ff8ac8}
.wd-flex-card__ico svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.5;stroke-linecap:round;stroke-linejoin:round}
.wd-flex-card b{display:block;font-size:.66rem;letter-spacing:.1em;text-transform:uppercase;font-weight:700;color:#fff;margin-bottom:.3rem}
.wd-flex-card span{display:block;font-size:.68rem;line-height:1.4;color:#a9a3bf}
.wd-flex__cap{position:relative;z-index:2;text-align:center;font-size:.74rem;color:#cbb8e0;font-style:italic;margin:.9rem 0 0;font-weight:300}

/* =====================================================================
   6 · OUR WORK
   ===================================================================== */
.wd-work-grid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:clamp(.7rem,1.4vw,1.2rem);align-items:start}
.wd-work-card{display:flex;flex-direction:column;padding:.7rem;border-radius:14px;
  border:1px solid rgba(168,85,247,.16);background:linear-gradient(165deg,rgba(20,15,36,.5),rgba(10,8,20,.45));
  transition:transform .4s var(--ease),border-color .4s,box-shadow .4s}
.wd-work-card:hover{transform:translateY(-5px);border-color:rgba(255,46,154,.42);box-shadow:0 26px 56px -26px rgba(255,46,154,.5)}
.wd-work__thumb{display:block;border-radius:9px;overflow:hidden;border:1px solid rgba(168,85,247,.22);margin-bottom:.7rem}
.wd-work__shot{display:block;height:clamp(96px,13vh,124px);background-size:cover;background-position:top center;position:relative}
.wd-work__shot img{width:100%;height:100%;object-fit:cover;object-position:top center;display:block}
.wd-work__shot--srs{background:#0b0814 url("../assets/hero/04-skyline.png") center 64%/126% no-repeat}
.wd-work__shot--stone{background:linear-gradient(150deg,#0b1322,#0a0a16) center/cover}
.wd-work__shot--stone::after{content:"";position:absolute;inset:0;background:url("../assets/Filler%20Photos/opt/sean-sinclair-1xZ0SqLPE4E-unsplash.jpg") center/cover;opacity:.62;mix-blend-mode:luminosity}
.wd-work__shot--atac{background:linear-gradient(150deg,#1a1024,#0a0a16) center/cover}
.wd-work__shot--atac::after{content:"";position:absolute;inset:0;background:url("../assets/Filler%20Photos/opt/elliott-engelmann-DjlKxYFJlTc-unsplash.jpg") center/cover;opacity:.6;mix-blend-mode:luminosity}
.wd-work__shot--fuller{background:#0b0814 url("../assets/Section%203%20Photos/Modeling%20Photo.jpg") center 20%/cover no-repeat}
.wd-work__domain{font-size:.78rem;font-weight:600;color:#fff;margin:0 0 .2rem;line-height:1.2;word-break:break-word}
.wd-work__cat{display:block;font-size:.54rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent;margin-bottom:.4rem}
.wd-work__desc{font-size:.68rem;line-height:1.45;color:#9a93b3;margin:0 0 .7rem;flex:1}
.wd-work__btn{display:inline-flex;align-items:center;gap:.3rem;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;font-weight:600;
  color:#ff8ac8;transition:gap .25s,color .25s}
.wd-work__btn:hover{gap:.5rem;color:#fff}

/* =====================================================================
   7 · FINAL CTA
   ===================================================================== */
.wd-cta{position:relative;z-index:1;min-height:100svh;display:flex;align-items:center;justify-content:center;overflow:hidden;
  padding:calc(var(--navh) + 3vh) clamp(1.2rem,5vw,5rem) 5vh;text-align:center}
.wd-cta__bg{position:absolute;inset:0;z-index:-1;pointer-events:none}
.wd-cta__sky{position:absolute;inset:auto 0 0 0;height:62%;
  background:url("../assets/hero/04-skyline.png") center bottom/cover no-repeat;opacity:.34;
  -webkit-mask-image:linear-gradient(to top,#000 30%,transparent);mask-image:linear-gradient(to top,#000 30%,transparent)}
.wd-cta__inner{position:relative;max-width:46rem}
.wd-cta__kicker{margin:0 auto .9rem}
.wd-cta__title{font-size:clamp(2.1rem,5vw,4rem);line-height:1.03;font-weight:300;text-transform:uppercase;color:#fff;margin:0 0 1.1rem}
.wd-cta__body{font-size:clamp(.88rem,1.3vw,1.05rem);line-height:1.65;color:var(--muted);font-weight:300;max-width:38rem;margin:0 auto 1.7rem}
.wd-cta__phone{display:inline-flex;align-items:center;gap:.8rem;margin-bottom:1.6rem;padding:.7rem 1.3rem;border-radius:14px;
  border:1px solid rgba(168,85,247,.3);background:rgba(12,9,22,.5);transition:border-color .3s,box-shadow .3s,transform .3s}
.wd-cta__phone:hover{border-color:rgba(255,46,154,.55);box-shadow:0 0 30px -8px rgba(255,46,154,.7);transform:translateY(-2px)}
.wd-cta__phone-ico{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;
  background:var(--grad);box-shadow:0 0 22px -6px rgba(255,46,154,.85)}
.wd-cta__phone-ico svg{width:21px;height:21px;fill:none;stroke:#fff;stroke-width:1.6;stroke-linecap:round;stroke-linejoin:round}
.wd-cta__phone-txt{display:flex;flex-direction:column;text-align:left;line-height:1.2}
.wd-cta__phone-txt b{font-size:clamp(1.3rem,2.6vw,1.9rem);font-weight:600;color:#fff;letter-spacing:.01em}
.wd-cta__phone-txt i{font-size:.66rem;letter-spacing:.06em;text-transform:uppercase;color:#9a93b3;font-style:normal;font-weight:600}
.wd-cta__btns{display:flex;flex-wrap:wrap;gap:.9rem;justify-content:center}

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width:1080px){
  .wd-price-grid{grid-template-columns:1fr;max-width:34rem;margin:0 auto}
  .wd-bd-grid{grid-template-columns:1fr;gap:1rem}
  .wd-work-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:960px){
  .wd-hero{min-height:auto;padding:calc(var(--navh) + 3vh) clamp(1.2rem,5vw,5rem) 5vh}
  .wd-hero__grid{grid-template-columns:1fr;gap:2.4rem}
  .wd-stage{order:2;height:clamp(380px,74vw,520px)}
  .wd-browser{left:7%;width:90%;transform:rotateY(-9deg) rotateX(3deg)}
  .wd-fcard--cd{left:0;top:8%}
  .wd-fcard--fa{left:-2%;top:43%}
  .wd-fcard--seo{right:0;top:6%}
  .wd-fcard--spd{right:-2%;top:40%}
  .wd-flex__grid{grid-template-columns:1fr;gap:2rem}
}
@media (max-width:680px){
  .wd-stage{height:auto;display:flex;flex-direction:column;gap:1rem;perspective:none}
  .wd-browser{position:relative;left:auto;top:auto;width:100%;transform:none}
  .wd-lum__links{display:none}
  .wd-lum__copy{max-width:80%}
  .wd-fcard{display:none}
  .wd-perf{position:relative;left:auto;right:auto;bottom:auto;transform:none}
  .wd-work-grid{grid-template-columns:1fr;max-width:26rem;margin:0 auto}
  .wd-flex__cards{grid-template-columns:1fr 1fr}
  .wd-cta__phone-txt b{font-size:1.5rem}
  .wd-hero__mini li:not(:last-child){margin-right:.7rem;padding-right:.7rem}
}

/* reduced motion: keep the tilt but kill the live pulse + transitions */
@media (prefers-reduced-motion:reduce){
  .wd-browser{transition:none}
  .wd-perf__live i{animation:none}
}
