/* ════════════════════════════════════════════════════════════════════════
   DESKMAN STUDIO — theme.css
   Mission-control aesthetic · Sora / Inter / Space Mono · violet→azure
   ════════════════════════════════════════════════════════════════════════ */

/* ── Tokens ─────────────────────────────────────────────────────────────── */
:root{
  --space-0:#05060c;      /* deepest background */
  --space-1:#0a0c16;      /* panels */
  --space-2:#10131f;      /* raised cards */
  --space-3:#161a29;      /* hover raise */
  --ink:#f3f4f8;          /* primary text */
  --mist:#9aa3b8;         /* secondary text */
  --faint:#5f677d;        /* tertiary / labels */
  --line:rgba(255,255,255,.08);
  --line-2:rgba(255,255,255,.14);

  --violet:#7b5cff;
  --azure:#4d9bff;
  --magenta:#b56bff;
  --amber:#ffb547;
  --grad:linear-gradient(120deg,var(--violet),var(--azure));
  --grad-soft:linear-gradient(120deg,#8d72ff,#5aa6ff);

  --r-sm:12px; --r:18px; --r-lg:26px; --r-xl:34px;
  --shell:1200px;
  --ease:cubic-bezier(.22,.61,.36,1);
  --shadow:0 30px 60px -25px rgba(0,0,0,.7);
  --glow:0 0 0 1px var(--line), 0 24px 60px -30px rgba(123,92,255,.55);

  --f-display:"Sora",system-ui,sans-serif;
  --f-body:"Inter",system-ui,sans-serif;
  --f-mono:"Space Mono","SFMono-Regular",ui-monospace,monospace;
}

/* ── Reset / base ───────────────────────────────────────────────────────── */
*,*::before,*::after{box-sizing:border-box}
html{-webkit-text-size-adjust:100%;scroll-behavior:smooth}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto}}
body{
  margin:0;background:var(--space-0);color:var(--ink);
  font-family:var(--f-body);font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer}
h1,h2,h3,h4{font-family:var(--f-display);line-height:1.08;margin:0;letter-spacing:-.02em;font-weight:700}
p{margin:0}
ul{margin:0;padding:0;list-style:none}
::selection{background:var(--violet);color:#fff}

/* hide default cursor only when custom cursor is active (added via JS) */
body.ds-has-cursor, body.ds-has-cursor a, body.ds-has-cursor button{cursor:none}

/* ── Utility ────────────────────────────────────────────────────────────── */
.ds-shell{width:min(100% - 44px,var(--shell));margin-inline:auto}
.ds-mono{font-family:var(--f-mono);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}
.ds-grad{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ds-center{text-align:center;margin-inline:auto}
.ds-skip{position:absolute;left:-999px;top:0;z-index:1000;background:var(--violet);color:#fff;padding:10px 16px;border-radius:0 0 8px 0}
.ds-skip:focus{left:0}
.ds-empty{color:var(--mist);text-align:center;padding:40px;border:1px dashed var(--line);border-radius:var(--r)}

/* ── Atmosphere: starfield + aurora + grid ──────────────────────────────── */
.ds-atmos{position:fixed;inset:0;z-index:-2;pointer-events:none;overflow:hidden}
#ds-stars{position:absolute;inset:0;width:100%;height:100%}
.ds-aurora{
  position:absolute;width:80vmax;height:80vmax;left:var(--mx,30%);top:var(--my,10%);
  transform:translate(-50%,-50%);
  background:radial-gradient(circle at center,rgba(123,92,255,.20),rgba(77,155,255,.08) 38%,transparent 62%);
  filter:blur(20px);transition:left .8s var(--ease),top .8s var(--ease);
}
.ds-grid{
  position:absolute;inset:0;opacity:.35;
  background-image:linear-gradient(var(--line) 1px,transparent 1px),linear-gradient(90deg,var(--line) 1px,transparent 1px);
  background-size:64px 64px;
  -webkit-mask-image:radial-gradient(circle at 50% 0,#000,transparent 70%);
  mask-image:radial-gradient(circle at 50% 0,#000,transparent 70%);
}

/* ── Custom cursor ──────────────────────────────────────────────────────── */
.ds-cursor{position:fixed;left:0;top:0;z-index:999;pointer-events:none;mix-blend-mode:screen;display:none}
.ds-cursor__dot{position:absolute;width:7px;height:7px;border-radius:50%;background:#fff;transform:translate(-50%,-50%)}
.ds-cursor__ring{
  position:absolute;width:34px;height:34px;border-radius:50%;
  border:1.5px solid rgba(157,140,255,.9);transform:translate(-50%,-50%);
  transition:width .25s var(--ease),height .25s var(--ease),border-color .25s,background .25s;
}
.ds-cursor.is-hot .ds-cursor__ring{width:56px;height:56px;background:rgba(123,92,255,.14);border-color:var(--azure)}
.ds-cursor.is-down .ds-cursor__ring{width:24px;height:24px}

/* ── Scroll progress ────────────────────────────────────────────────────── */
.ds-progress{position:fixed;top:0;left:0;right:0;height:2px;z-index:120;background:transparent}
.ds-progress span{display:block;height:100%;width:0;background:var(--grad);box-shadow:0 0 12px var(--violet)}

/* ── Header ─────────────────────────────────────────────────────────────── */
.ds-header{position:fixed;top:0;left:0;right:0;z-index:100;transition:background .4s,backdrop-filter .4s,border-color .4s;border-bottom:1px solid transparent}
.ds-header.is-stuck{background:rgba(8,9,16,.72);backdrop-filter:blur(14px);border-bottom-color:var(--line)}
.ds-header__inner{display:flex;align-items:center;justify-content:space-between;height:74px;gap:18px}
.ds-logo{display:inline-flex;align-items:center;gap:11px}
.ds-logo__mark{display:grid;place-items:center;filter:drop-shadow(0 8px 18px rgba(123,92,255,.45))}
.ds-logo__type{font-family:var(--f-display);font-weight:800;font-size:1.06rem;letter-spacing:.02em;line-height:1;display:flex;flex-direction:column}
.ds-logo__type small{font-weight:600;font-size:.6rem;letter-spacing:.42em;color:var(--mist);margin-top:3px}
.ds-logo--lg .ds-logo__type{font-size:1.3rem}

.ds-nav__list{display:flex;align-items:center;gap:30px}
.ds-nav__list a{font-size:.94rem;font-weight:500;color:var(--mist);position:relative;padding:6px 0;transition:color .25s}
.ds-nav__list a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:2px;background:var(--grad);transition:width .3s var(--ease)}
.ds-nav__list a:hover,.ds-nav__list .current-menu-item a{color:var(--ink)}
.ds-nav__list a:hover::after,.ds-nav__list .current-menu-item a::after{width:100%}

.ds-header__cta{display:flex;align-items:center;gap:12px}

/* burger */
.ds-burger{display:none;width:42px;height:42px;border:1px solid var(--line-2);background:var(--space-1);border-radius:12px;padding:0;position:relative}
.ds-burger span{position:absolute;left:11px;width:20px;height:2px;background:var(--ink);border-radius:2px;transition:.3s var(--ease)}
.ds-burger span:nth-child(1){top:14px}.ds-burger span:nth-child(2){top:20px}.ds-burger span:nth-child(3){top:26px}
body.ds-menu-open .ds-burger span:nth-child(1){top:20px;transform:rotate(45deg)}
body.ds-menu-open .ds-burger span:nth-child(2){opacity:0}
body.ds-menu-open .ds-burger span:nth-child(3){top:20px;transform:rotate(-45deg)}

/* mobile menu */
.ds-mobile{position:fixed;inset:0;z-index:95;background:rgba(5,6,12,.6);backdrop-filter:blur(8px);opacity:0;visibility:hidden;transition:.35s}
body.ds-menu-open .ds-mobile{opacity:1;visibility:visible}
.ds-mobile__panel{position:absolute;top:0;right:0;height:100%;width:min(86vw,360px);background:var(--space-1);border-left:1px solid var(--line);padding:96px 30px 30px;transform:translateX(100%);transition:transform .4s var(--ease);display:flex;flex-direction:column;gap:8px}
body.ds-menu-open .ds-mobile__panel{transform:translateX(0)}
.ds-mobile__list{display:flex;flex-direction:column;gap:4px;margin-bottom:18px}
.ds-mobile__list a{font-family:var(--f-display);font-weight:600;font-size:1.4rem;padding:12px 0;border-bottom:1px solid var(--line)}
.ds-mobile__coord{margin-top:auto;text-align:center}

/* ── Buttons ────────────────────────────────────────────────────────────── */
.ds-btn{display:inline-flex;align-items:center;gap:9px;font-family:var(--f-display);font-weight:600;font-size:.95rem;padding:13px 22px;border-radius:50px;border:1px solid transparent;position:relative;transition:transform .25s var(--ease),box-shadow .3s,background .3s,color .3s;will-change:transform}
.ds-btn svg{transition:transform .3s var(--ease)}
.ds-btn:hover svg{transform:translateX(3px)}
.ds-btn--grad{background:var(--grad);color:#fff;box-shadow:0 14px 30px -12px rgba(123,92,255,.7)}
.ds-btn--grad:hover{box-shadow:0 20px 44px -12px rgba(123,92,255,.85)}
.ds-btn--ghost{border-color:var(--line-2);color:var(--ink);background:rgba(255,255,255,.02)}
.ds-btn--ghost:hover{background:rgba(255,255,255,.07);border-color:var(--violet)}
.ds-btn--light{background:#fff;color:#0b1020;box-shadow:0 14px 34px -12px rgba(0,0,0,.5)}
.ds-btn--light:hover{background:#eef0ff}
.ds-btn--sm{padding:10px 16px;font-size:.86rem}
.ds-btn--block{width:100%;justify-content:center}

/* ── Section scaffolding ────────────────────────────────────────────────── */
.ds-main{position:relative;z-index:1}
.ds-section{padding:clamp(64px,9vw,120px) 0;position:relative}
.ds-section--alt{background:linear-gradient(180deg,transparent,rgba(255,255,255,.015),transparent)}
.ds-sechead{max-width:680px;margin-bottom:54px}
.ds-sechead--center{margin-inline:auto;text-align:center}
.ds-sechead--row{max-width:none;display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap}
.ds-sechead__title{font-size:clamp(1.8rem,4vw,2.9rem);font-weight:700;margin:14px 0 12px}
.ds-sechead__sub{color:var(--mist);font-size:1.05rem;max-width:54ch}
.ds-sechead--center .ds-sechead__sub{margin-inline:auto}

.ds-eyebrow{display:inline-flex;align-items:center;gap:9px}
.ds-eyebrow__dot{width:7px;height:7px;border-radius:50%;background:var(--violet);box-shadow:0 0 12px var(--violet);animation:dsPulse 2.4s ease-in-out infinite}
@keyframes dsPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}

/* ── Reveal on scroll ───────────────────────────────────────────────────── */
[data-reveal]{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease) var(--d,0ms),transform .7s var(--ease) var(--d,0ms)}
[data-reveal].is-in{opacity:1;transform:none}

/* ── Hero ───────────────────────────────────────────────────────────────── */
.ds-hero{position:relative;min-height:100svh;display:flex;align-items:center;padding-top:90px}
.ds-hero__grid{display:grid;grid-template-columns:1.1fr .9fr;align-items:center;gap:40px;width:min(100% - 44px,var(--shell));margin-inline:auto}
.ds-hero__title{font-size:clamp(2.6rem,6.6vw,5rem);font-weight:800;letter-spacing:-.035em;line-height:1.02}
.ds-hero__sub{color:var(--mist);font-size:clamp(1rem,1.6vw,1.2rem);max-width:46ch;margin:22px 0 30px}
.ds-hero__actions{display:flex;gap:14px;flex-wrap:wrap}
.ds-hero__ticker{display:flex;gap:30px;margin-top:40px;flex-wrap:wrap}
.ds-hero__ticker dt{color:var(--faint);font-size:.62rem;margin-bottom:4px}
.ds-hero__ticker dd{margin:0;color:var(--ink);font-size:.78rem;letter-spacing:.06em}

.ds-hero__visual{position:relative;display:grid;place-items:center;min-height:380px}
.ds-astro{position:relative;z-index:2;animation:dsFloat 7s ease-in-out infinite;filter:drop-shadow(0 30px 50px rgba(91,75,255,.35))}
.ds-astro__svg{width:clamp(220px,30vw,340px);height:auto}
@keyframes dsFloat{0%,100%{transform:translateY(0) rotate(-2deg)}50%{transform:translateY(-22px) rotate(2deg)}}
.ds-orbit{position:absolute;inset:0;display:grid;place-items:center}
.ds-orbit__ring{position:absolute;border:1px solid var(--line-2);border-radius:50%}
.ds-orbit__ring--1{width:min(70%,360px);aspect-ratio:1;animation:dsSpin 26s linear infinite}
.ds-orbit__ring--2{width:min(94%,470px);aspect-ratio:1;border-style:dashed;opacity:.5;animation:dsSpin 40s linear infinite reverse}
.ds-orbit__planet{position:absolute;width:14px;height:14px;border-radius:50%;background:var(--grad);box-shadow:0 0 16px var(--violet);top:8%;animation:dsSpin 26s linear infinite}
@keyframes dsSpin{to{transform:rotate(360deg)}}

.ds-scrollcue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:8px;color:var(--faint)}
.ds-scrollcue__line{width:1px;height:38px;background:linear-gradient(var(--violet),transparent);animation:dsCue 2s ease-in-out infinite}
@keyframes dsCue{0%,100%{transform:scaleY(.4);opacity:.3;transform-origin:top}50%{transform:scaleY(1);opacity:1;transform-origin:top}}

/* ── Pillars ────────────────────────────────────────────────────────────── */
.ds-pillars{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.ds-pillar{padding:26px 22px;border:1px solid var(--line);border-radius:var(--r);background:linear-gradient(180deg,var(--space-1),var(--space-0));transition:transform .35s var(--ease),border-color .35s,background .35s}
.ds-pillar:hover{transform:translateY(-6px);border-color:var(--line-2);background:linear-gradient(180deg,var(--space-2),var(--space-1))}
.ds-pillar__icon{display:grid;place-items:center;width:46px;height:46px;border-radius:13px;background:rgba(123,92,255,.12);color:var(--azure);margin-bottom:16px}
.ds-pillar h3{font-size:1.12rem;margin-bottom:8px}
.ds-pillar p{color:var(--mist);font-size:.92rem}

/* ── Services grid ──────────────────────────────────────────────────────── */
.ds-svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ds-svc{position:relative;padding:30px 26px 26px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--space-1);overflow:hidden;transform-style:preserve-3d;transition:border-color .35s,box-shadow .35s,transform .12s var(--ease)}
.ds-svc:hover{border-color:var(--line-2);box-shadow:var(--glow)}
.ds-svc__glow{position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(123,92,255,.22),transparent 60%);left:var(--gx,50%);top:var(--gy,0);transform:translate(-50%,-50%);opacity:0;transition:opacity .4s;pointer-events:none}
.ds-svc:hover .ds-svc__glow{opacity:1}
.ds-svc__code{position:absolute;top:20px;right:22px;color:var(--faint);font-size:.66rem}
.ds-svc__icon{display:grid;place-items:center;width:52px;height:52px;border-radius:14px;background:var(--grad);color:#fff;margin-bottom:20px;box-shadow:0 12px 26px -12px rgba(123,92,255,.7)}
.ds-svc__title{font-size:1.22rem;margin-bottom:10px}
.ds-svc__blurb{color:var(--mist);font-size:.93rem;margin-bottom:18px}
.ds-svc__more{display:inline-flex;align-items:center;gap:7px;color:var(--azure);font-weight:600;font-size:.9rem;transition:gap .25s}
.ds-svc__more:hover{gap:12px}

/* ── Stats ──────────────────────────────────────────────────────────────── */
.ds-stats__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;text-align:center}
.ds-stat{padding:30px 16px;border:1px solid var(--line);border-radius:var(--r);background:var(--space-1)}
.ds-stat__num{font-size:clamp(2rem,4vw,3rem);font-weight:700;line-height:1;display:inline-flex;align-items:baseline}
.ds-count{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ds-stat__suffix{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}
.ds-stat__label{color:var(--mist);font-size:.86rem;margin-top:12px;letter-spacing:.02em}

/* ── Portfolio ──────────────────────────────────────────────────────────── */
.ds-proj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ds-proj-grid--3{grid-template-columns:repeat(3,1fr)}
.ds-proj{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--space-1);transition:transform .12s var(--ease),border-color .35s,box-shadow .35s;transform-style:preserve-3d}
.ds-proj:hover{border-color:var(--line-2);box-shadow:var(--glow)}
.ds-proj__media{position:relative;aspect-ratio:16/11;overflow:hidden;background:linear-gradient(135deg,#1a1f33,#0c0f1a)}
.ds-proj__media img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ds-proj:hover .ds-proj__media img{transform:scale(1.06)}
.ds-proj__placeholder{position:absolute;inset:0;display:grid;place-items:center;font-family:var(--f-display);font-weight:800;font-size:3rem;color:rgba(255,255,255,.12)}
.ds-proj__shine{position:absolute;inset:0;background:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.14),transparent 70%);transform:translateX(-120%);transition:transform .7s var(--ease)}
.ds-proj:hover .ds-proj__shine{transform:translateX(120%)}
.ds-proj__body{padding:22px}
.ds-proj__tag{display:inline-block;color:var(--azure);font-size:.62rem;margin-bottom:10px}
.ds-proj__title{font-size:1.24rem;margin-bottom:8px}
.ds-proj__desc{color:var(--mist);font-size:.92rem;margin-bottom:16px}
.ds-proj-hero{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;margin-bottom:30px}

/* ── FAQ ────────────────────────────────────────────────────────────────── */
.ds-faq__grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:48px;align-items:start}
.ds-faq__intro .ds-sechead__title{font-size:clamp(1.7rem,3.5vw,2.6rem);margin:14px 0 16px}
.ds-faq__intro .ds-btn{margin-top:24px}
.ds-acc{border:1px solid var(--line);border-radius:var(--r);margin-bottom:12px;background:var(--space-1);overflow:hidden;transition:border-color .3s,background .3s}
.ds-acc.is-open{border-color:var(--line-2);background:var(--space-2)}
.ds-acc__q{width:100%;display:flex;align-items:center;justify-content:space-between;gap:16px;padding:20px 22px;background:none;border:0;color:var(--ink);font-family:var(--f-display);font-weight:600;font-size:1.02rem;text-align:left}
.ds-acc__icon{position:relative;flex:none;width:20px;height:20px}
.ds-acc__icon::before,.ds-acc__icon::after{content:"";position:absolute;background:var(--azure);border-radius:2px;transition:transform .3s var(--ease),opacity .3s}
.ds-acc__icon::before{left:0;top:9px;width:20px;height:2px}
.ds-acc__icon::after{left:9px;top:0;width:2px;height:20px}
.ds-acc.is-open .ds-acc__icon::after{transform:scaleY(0)}
.ds-acc__a{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.ds-acc__a p{padding:0 22px 22px;color:var(--mist);font-size:.95rem}

/* ── Testimonials carousel ──────────────────────────────────────────────── */
.ds-carousel{position:relative;display:flex;align-items:center;gap:14px}
.ds-carousel__viewport{overflow:hidden;flex:1}
.ds-carousel__track{display:flex;gap:22px;transition:transform .55s var(--ease);will-change:transform}
.ds-quote{flex:0 0 calc((100% - 22px)/2);min-width:0;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--space-1);padding:30px;transform-style:preserve-3d}
.ds-stars{display:inline-flex;gap:3px;margin-bottom:16px}
.ds-stars svg{fill:rgba(255,255,255,.14)}
.ds-stars svg.on{fill:var(--amber)}
.ds-quote blockquote{margin:0 0 22px;font-family:var(--f-display);font-weight:500;font-size:1.12rem;line-height:1.5;color:var(--ink)}
.ds-quote figcaption{display:flex;align-items:center;gap:13px}
.ds-quote__avatar{width:46px;height:46px;border-radius:50%;background:var(--grad);display:grid;place-items:center;font-family:var(--f-display);font-weight:700;color:#fff;overflow:hidden;flex:none}
.ds-quote__avatar img{width:100%;height:100%;object-fit:cover}
.ds-quote__who strong{display:block;font-family:var(--f-display);font-size:.98rem}
.ds-quote__who small{color:var(--mist);font-size:.82rem}
.ds-carousel__nav{flex:none;width:46px;height:46px;border-radius:50%;border:1px solid var(--line-2);background:var(--space-1);color:var(--ink);font-size:1.5rem;line-height:1;display:grid;place-items:center;transition:background .25s,border-color .25s,transform .25s}
.ds-carousel__nav:hover{background:var(--violet);border-color:var(--violet)}

/* ── Big CTA ────────────────────────────────────────────────────────────── */
.ds-cta{position:relative;text-align:center;padding:clamp(40px,6vw,72px);border-radius:var(--r-xl);background:var(--grad);overflow:hidden;transform-style:preserve-3d;box-shadow:0 40px 80px -30px rgba(123,92,255,.7)}
.ds-cta__shine{position:absolute;inset:0;background:radial-gradient(circle at 30% 0,rgba(255,255,255,.35),transparent 55%)}
.ds-cta h2{position:relative;font-size:clamp(1.8rem,4.5vw,3rem);color:#fff;margin-bottom:14px}
.ds-cta p{position:relative;color:rgba(255,255,255,.9);max-width:48ch;margin:0 auto 26px;font-size:1.05rem}
.ds-cta .ds-btn{position:relative}

/* ── Page hero (inner pages) ────────────────────────────────────────────── */
.ds-page-hero{padding:calc(74px + clamp(50px,8vw,90px)) 0 clamp(20px,4vw,40px);position:relative}
.ds-page-hero__title{font-size:clamp(2.2rem,5.5vw,4rem);font-weight:800;letter-spacing:-.03em}
.ds-page-hero__sub{color:var(--mist);font-size:1.1rem;max-width:60ch;margin-top:18px}

/* ── About ──────────────────────────────────────────────────────────────── */
.ds-about__grid{display:grid;grid-template-columns:1fr .85fr;gap:48px;align-items:start}
.ds-tl{display:grid;grid-template-columns:80px 1fr;gap:22px;position:relative;padding-bottom:40px}
.ds-tl::before{content:"";position:absolute;left:79px;top:8px;bottom:-12px;width:1px;background:linear-gradient(var(--violet),transparent)}
.ds-tl:last-child::before{display:none}
.ds-tl__year{align-self:start;color:var(--azure);font-size:.78rem;padding-top:2px}
.ds-tl__dot{position:absolute;left:74px;top:6px;width:11px;height:11px;border-radius:50%;background:var(--grad);box-shadow:0 0 12px var(--violet)}
.ds-tl__body h3{font-size:1.3rem;margin-bottom:8px}
.ds-tl__body p{color:var(--mist)}
.ds-about__panel{position:sticky;top:100px;aspect-ratio:4/5;border:1px solid var(--line);border-radius:var(--r-xl);background:radial-gradient(circle at 60% 20%,rgba(123,92,255,.35),var(--space-1) 60%);overflow:hidden;display:flex;align-items:flex-end;padding:30px}
.ds-about__panel .ds-mono{position:relative;z-index:2;color:var(--ink);font-size:.78rem;line-height:1.8}
.ds-beam{position:absolute;top:-10%;left:50%;width:42%;height:120%;background:linear-gradient(180deg,rgba(255,255,255,.5),transparent 70%);transform:translateX(-50%) rotate(8deg);filter:blur(6px);opacity:.5}

/* ── Service rows (services page) ───────────────────────────────────────── */
.ds-svc-rows{display:flex;flex-direction:column;gap:clamp(40px,6vw,72px)}
.ds-svc-row{display:grid;grid-template-columns:.8fr 1.2fr;gap:42px;align-items:center}
.ds-svc-row.is-flip .ds-svc-row__media{order:2}
.ds-svc-row__media{position:relative;aspect-ratio:5/4;border-radius:var(--r-xl);background:radial-gradient(circle at 30% 20%,rgba(123,92,255,.4),var(--space-1) 65%);border:1px solid var(--line);display:grid;place-items:center;overflow:hidden}
.ds-svc-row__icon{display:grid;place-items:center;width:96px;height:96px;border-radius:26px;background:rgba(255,255,255,.06);backdrop-filter:blur(6px);color:#fff}
.ds-svc-row__icon svg{width:44px;height:44px}
.ds-svc-row__code{position:absolute;top:20px;left:22px;color:rgba(255,255,255,.4)}
.ds-svc-row__copy h2{font-size:clamp(1.6rem,3vw,2.2rem);margin-bottom:14px}
.ds-svc-row__copy>p{color:var(--mist);font-size:1.04rem;margin-bottom:20px}
.ds-feat{display:grid;grid-template-columns:1fr 1fr;gap:10px 22px;margin-bottom:24px}
.ds-feat li{display:flex;gap:9px;align-items:flex-start;font-size:.92rem;color:var(--ink)}
.ds-feat svg{color:var(--azure);flex:none;margin-top:3px}

/* ── Contact ────────────────────────────────────────────────────────────── */
.ds-contact{padding-top:calc(74px + clamp(40px,7vw,80px))}
.ds-contact__grid{display:grid;grid-template-columns:1fr 1.05fr;gap:54px;align-items:start}
.ds-contact__title{font-size:clamp(2.2rem,5vw,3.6rem);font-weight:800;margin:14px 0 16px;letter-spacing:-.03em}
.ds-contact__lead{color:var(--mist);font-size:1.08rem;max-width:44ch;margin-bottom:34px}
.ds-contact__details{display:flex;flex-direction:column;gap:22px;margin-bottom:30px}
.ds-contact__details li{display:flex;gap:16px;align-items:flex-start}
.ds-contact__ic{flex:none;display:grid;place-items:center;width:46px;height:46px;border-radius:13px;background:rgba(123,92,255,.12);color:var(--azure)}
.ds-contact__details strong{display:block;font-family:var(--f-display);font-size:1.05rem;margin-bottom:3px}
.ds-contact__details a,.ds-contact__details span{color:var(--mist)}
.ds-guarantee{border:1px solid var(--line);border-radius:var(--r);padding:20px 22px;background:var(--space-1)}
.ds-guarantee .ds-mono{color:var(--azure);display:block;margin-bottom:8px}
.ds-guarantee p{color:var(--mist);font-size:.92rem}

.ds-formwrap{position:relative;border:1px solid var(--line);border-radius:var(--r-xl);background:var(--space-1);padding:clamp(26px,3vw,40px);overflow:hidden;transform-style:preserve-3d}
.ds-formwrap__glow{position:absolute;top:-40%;right:-20%;width:60%;height:80%;background:radial-gradient(circle,rgba(123,92,255,.3),transparent 60%);pointer-events:none}
.ds-form{position:relative;display:flex;flex-direction:column;gap:18px}
.ds-field{display:flex;flex-direction:column;gap:7px}
.ds-field-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ds-field label{font-size:.86rem;font-weight:600;font-family:var(--f-display)}
.ds-field label span{color:var(--magenta)}
.ds-field input,.ds-field select,.ds-field textarea{
  width:100%;padding:13px 15px;border-radius:12px;border:1px solid var(--line-2);
  background:var(--space-0);color:var(--ink);font-family:var(--f-body);font-size:.96rem;transition:border-color .25s,box-shadow .25s
}
.ds-field textarea{resize:vertical;min-height:96px}
.ds-field input:focus,.ds-field select:focus,.ds-field textarea:focus{outline:none;border-color:var(--violet);box-shadow:0 0 0 3px rgba(123,92,255,.2)}
.ds-field select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' fill='none' stroke='%239aa3b8' stroke-width='2'%3E%3Cpath d='m3 5 4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}
.ds-hp{position:absolute!important;left:-9999px!important;width:1px;height:1px;opacity:0}
.ds-form__spin{display:none;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:dsSpin .7s linear infinite}
.ds-form.is-loading .ds-form__spin{display:inline-block}
.ds-form.is-loading .ds-form__label{opacity:.6}
.ds-form__status{font-size:.92rem;min-height:1.2em}
.ds-form__status.is-ok{color:#5fe3a1}.ds-form__status.is-err{color:#ff7a8a}

/* ── Prose / blog ───────────────────────────────────────────────────────── */
.ds-prose{max-width:760px;margin-inline:auto;color:var(--mist);font-size:1.05rem}
.ds-prose h2,.ds-prose h3{color:var(--ink);margin:34px 0 14px}
.ds-prose a{color:var(--azure);text-decoration:underline;text-underline-offset:3px}
.ds-prose__hero{border-radius:var(--r-lg);margin-bottom:30px}
.ds-center-prose{max-width:760px;margin-inline:auto}
.ds-blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ds-post-card{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden;background:var(--space-1);transition:transform .12s var(--ease),border-color .3s}
.ds-post-card:hover{border-color:var(--line-2)}
.ds-post-card__media img{aspect-ratio:16/10;object-fit:cover;width:100%}
.ds-post-card__body{padding:22px}
.ds-post-card__date{color:var(--azure);font-size:.64rem}
.ds-post-card__body h2{font-size:1.2rem;margin:10px 0 8px}
.ds-post-card__body p{color:var(--mist);font-size:.92rem}
.ds-pagination{margin-top:40px;text-align:center}
.ds-pagination .page-numbers{display:inline-block;padding:8px 13px;margin:0 3px;border:1px solid var(--line);border-radius:10px;color:var(--mist)}
.ds-pagination .current{background:var(--grad);color:#fff;border-color:transparent}

/* ── Footer ─────────────────────────────────────────────────────────────── */
.ds-footer{position:relative;padding-top:clamp(70px,10vw,130px);border-top:1px solid var(--line);overflow:hidden}
.ds-footer__glow{position:absolute;bottom:-60%;left:50%;transform:translateX(-50%);width:120%;height:120%;background:radial-gradient(ellipse at center,rgba(77,155,255,.18),rgba(123,92,255,.08) 35%,transparent 60%);pointer-events:none}
.ds-footer__grid{position:relative;display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:34px;padding-bottom:54px}
.ds-footer__pitch{color:var(--mist);font-size:.94rem;max-width:34ch;margin:18px 0 14px}
.ds-footer__coord{color:var(--faint)}
.ds-footer__col h4{margin-bottom:18px}
.ds-footer__col li{margin-bottom:11px}
.ds-footer__col a{color:var(--mist);font-size:.94rem;transition:color .2s}
.ds-footer__col a:hover{color:var(--ink)}
.ds-footer__hours{color:var(--mist);font-size:.94rem}
.ds-socials{display:flex;gap:10px;margin-top:18px}
.ds-socials a{display:grid;place-items:center;width:40px;height:40px;border-radius:11px;border:1px solid var(--line-2);color:var(--mist);transition:.25s}
.ds-socials a:hover{color:#fff;background:var(--grad);border-color:transparent;transform:translateY(-3px)}
.ds-footer__bottom{position:relative;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;padding:22px 0;border-top:1px solid var(--line);color:var(--faint);font-size:.82rem}

/* ── Responsive ─────────────────────────────────────────────────────────── */
@media (max-width:1024px){
  .ds-svc-grid,.ds-proj-grid,.ds-proj-grid--3,.ds-blog-grid{grid-template-columns:repeat(2,1fr)}
  .ds-pillars{grid-template-columns:repeat(2,1fr)}
  .ds-stats__grid{grid-template-columns:repeat(2,1fr)}
  .ds-faq__grid{grid-template-columns:1fr;gap:32px}
  .ds-about__grid{grid-template-columns:1fr}
  .ds-about__panel{position:relative;top:0;aspect-ratio:16/9;order:-1}
  .ds-contact__grid{grid-template-columns:1fr;gap:36px}
}
@media (max-width:860px){
  .ds-nav,.ds-header__cta .ds-btn--grad{display:none}
  .ds-burger{display:block}
  .ds-hero{min-height:auto;padding:120px 0 70px}
  .ds-hero__grid{grid-template-columns:1fr;text-align:center}
  .ds-hero__sub{margin-inline:auto}
  .ds-hero__actions,.ds-hero__ticker{justify-content:center}
  .ds-hero__visual{order:-1;min-height:300px}
  .ds-sechead--row{flex-direction:column;align-items:flex-start}
  .ds-svc-row,.ds-svc-row.is-flip .ds-svc-row__media{grid-template-columns:1fr;order:0}
  .ds-svc-row__media{order:-1!important;max-width:420px}
  .ds-quote{flex:0 0 100%}
  .ds-scrollcue{display:none}
}
@media (max-width:560px){
  .ds-shell{width:min(100% - 32px,var(--shell))}
  .ds-svc-grid,.ds-proj-grid,.ds-proj-grid--3,.ds-blog-grid,.ds-pillars,.ds-stats__grid{grid-template-columns:1fr}
  .ds-field-row{grid-template-columns:1fr}
  .ds-feat{grid-template-columns:1fr}
  .ds-footer__grid{grid-template-columns:1fr 1fr}
  .ds-footer__brand{grid-column:1 / -1}
  .ds-footer__bottom{flex-direction:column;text-align:center}
  .ds-hero__title{font-size:clamp(2.4rem,11vw,3.4rem)}
}

/* ── Reduced motion ─────────────────────────────────────────────────────── */
@media (prefers-reduced-motion:reduce){
  *{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  [data-reveal]{opacity:1;transform:none}
  .ds-cursor{display:none!important}
  body.ds-has-cursor,body.ds-has-cursor a,body.ds-has-cursor button{cursor:auto}
}
/* Touch / no-hover devices: never hide the native cursor */
@media (hover:none){
  body.ds-has-cursor,body.ds-has-cursor a,body.ds-has-cursor button{cursor:auto}
  .ds-cursor{display:none!important}
}

/* ════════════════════════════════════════════════════════════════════════
   v1.1 — real brand assets, article styling, alignment polish
   ════════════════════════════════════════════════════════════════════════ */

/* Logo as image (Customizer / brand URL) */
.ds-logo__img{height:34px;width:auto;display:block;filter:drop-shadow(0 6px 18px rgba(123,92,255,.35))}
.ds-logo--lg .ds-logo__img{height:44px}
.custom-logo{height:36px;width:auto}
.ds-logo--lg .custom-logo{height:46px}
.ds-footer__brand .custom-logo-link{display:inline-block;margin-bottom:4px}

/* Real astronaut image in hero */
.ds-astro__img{
  width:clamp(230px,30vw,360px);height:auto;display:block;position:relative;z-index:2;
  filter:drop-shadow(0 34px 60px rgba(91,75,255,.45));
}

/* Auto-generated article CTA + prose polish */
.ds-prose .ds-article-cta,.ds-prose .wp-block-pullquote{
  margin:36px 0;padding:24px 26px;border:1px solid var(--line-2);border-left:3px solid var(--violet);
  border-radius:var(--r);background:linear-gradient(120deg,rgba(123,92,255,.12),rgba(77,155,255,.06));
}
.ds-prose .ds-article-cta p{margin:0;color:var(--ink)}
.ds-prose ul{margin:18px 0;padding-left:0;display:grid;gap:10px}
.ds-prose ul li{position:relative;padding-left:28px;color:var(--mist)}
.ds-prose ul li::before{content:"";position:absolute;left:0;top:9px;width:14px;height:14px;border-radius:4px;background:var(--grad)}
.ds-prose h2{font-size:1.6rem}
.ds-prose h3{font-size:1.25rem}
.ds-prose p{margin:0 0 18px}
.ds-prose img{border-radius:var(--r);margin:24px 0}

/* ── Alignment / frame refinements ──────────────────────────────────────── */
/* keep header items vertically centered regardless of logo type */
.ds-header__inner{align-items:center}
.ds-brand{display:flex;align-items:center;min-height:46px}
/* equalise card heights so grids read as clean frames */
.ds-svc-grid,.ds-proj-grid,.ds-pillars{align-items:stretch}
.ds-svc,.ds-proj,.ds-pillar{height:100%;display:flex;flex-direction:column}
.ds-svc__blurb,.ds-proj__desc,.ds-pillar p{flex:1 0 auto}
.ds-svc__more{margin-top:auto}
.ds-proj__body{display:flex;flex-direction:column;height:100%}
.ds-proj__body .ds-btn{margin-top:auto;align-self:flex-start}
/* tighten testimonial card heights to align baseline */
.ds-carousel__track{align-items:stretch}
.ds-quote{display:flex;flex-direction:column}
.ds-quote blockquote{flex:1 0 auto}
/* consistent section heads */
.ds-sechead__title{text-wrap:balance}
.ds-hero__title,.ds-page-hero__title,.ds-contact__title{text-wrap:balance}
/* landing page frame */
.ds-landing-meta{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin-top:18px}
.ds-landing-meta .ds-mono{display:inline-flex;align-items:center;gap:7px;padding:7px 14px;border:1px solid var(--line);border-radius:30px;color:var(--mist)}
