/* Brand fonts — self-hosted @font-face so typography is independent of Elementor */
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-Light.ttf') format('truetype');font-weight:300;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-Regular.ttf') format('truetype');font-weight:400;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-RegularItalic.ttf') format('truetype');font-weight:400;font-style:italic;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-Medium.ttf') format('truetype');font-weight:500;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-MediumItalic.ttf') format('truetype');font-weight:500;font-style:italic;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-Bold.ttf') format('truetype');font-weight:600 700;font-style:normal;font-display:swap}
@font-face{font-family:'Gilroy';src:url('/wp-content/uploads/2022/06/Gilroy-ExtraBold.ttf') format('truetype');font-weight:800 900;font-style:normal;font-display:swap}
@font-face{font-family:'Noe Display';src:url('/wp-content/uploads/2022/06/Noe-Display-Medium.ttf') format('truetype');font-weight:400 500;font-style:normal;font-display:swap}
@font-face{font-family:'Noe Display';src:url('/wp-content/uploads/2022/06/NoeDisplay-Bold.ttf') format('truetype');font-weight:600 700;font-style:normal;font-display:swap}
/* ============================================================
   DESENO Blog — design system + fluid UI  (vanilla, WP-portable)
   Brand tokens from live Elementor kit (ID 9):
     headings = Noe Display  (Playfair Display stands in for the mockup)
     body     = Gilroy       (Montserrat stands in for the mockup)
     colors   = black #000 + coral #EF3D5F, editorial / light
   Fluid effects ported to plain CSS/JS from:
     • magicui ....... shimmer button, border-beam, marquee, magic-card
                       spotlight, blur-fade, animated gradient text, dot grid
     • react-bits .... blur-in text, magnetic hover, spotlight card
     • shadcn-landing  layout + spacing language
   All GPU-cheap and gated behind prefers-reduced-motion.
   ============================================================ */

:root{
  --black:#000; --ink:#111; --secondary:#3C3C3C; --text:#555; --muted:#8a8a8a;
  --light:#D3D3D3; --line:#e8e8e8; --bg:#fff; --tint:#F7F7F8; --card:#fafafa;
  --coral:#EF3D5F; --coral-600:#e0264a; --coral-700:#c01e3d; --coral-soft:#ffe9ee;
  --serif:"Noe Display","Playfair Display",Georgia,"Times New Roman",serif;
  --sans:"Gilroy","Montserrat",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  --container:1180px; --gutter:24px; --radius:16px;
  --shadow-sm:0 1px 2px rgba(0,0,0,.04),0 4px 14px rgba(0,0,0,.05);
  --shadow:0 22px 55px -16px rgba(17,17,17,.22);
  --ease:cubic-bezier(.22,.61,.36,1);
  --header-h:96px; --nav-ink:#2D2D2D;
}
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
body{margin:0;background:var(--bg);color:var(--text);font-family:var(--sans);
  font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
h1,h2,h3,h4,h5{font-family:var(--serif);color:var(--black);font-weight:700;line-height:1.15;letter-spacing:-.01em;margin:0 0 .5em}
p{margin:0 0 1.1em}
::selection{background:var(--coral);color:#fff}
.ds-container{max-width:var(--container);margin:0 auto;padding:0 var(--gutter)}
.ds-eyebrow{font-family:var(--sans);font-size:12.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:var(--coral);margin:0 0 16px}

/* ---------- buttons ---------- */
.ds-btn{position:relative;display:inline-flex;align-items:center;gap:9px;padding:13px 24px;border-radius:999px;
  font-family:var(--sans);font-weight:600;font-size:14.5px;border:1px solid transparent;cursor:pointer;
  transition:transform .25s var(--ease),background .25s,box-shadow .25s,color .25s;white-space:nowrap}
.ds-btn--coral{background:var(--coral);color:#fff;box-shadow:0 10px 24px -10px rgba(239,61,95,.7)}
.ds-btn--coral:hover{background:var(--coral-600);transform:translateY(-2px);box-shadow:0 16px 32px -10px rgba(239,61,95,.8)}
.ds-btn--ghost{background:transparent;border-color:var(--line);color:var(--black)}
.ds-btn--ghost:hover{border-color:var(--black);transform:translateY(-2px)}
.ds-btn--dark{background:#0b0b0b;color:#fff;box-shadow:0 10px 24px -12px rgba(0,0,0,.6)}
.ds-btn--dark:hover{background:#000;transform:translateY(-2px);box-shadow:0 16px 32px -12px rgba(0,0,0,.7)}
.ds-btn--block{width:100%;justify-content:center}
/* shimmer (magicui) */
.ds-shimmer{overflow:hidden}
.ds-shimmer::after{content:"";position:absolute;inset:0;background:linear-gradient(110deg,transparent 30%,rgba(255,255,255,.5) 50%,transparent 70%);background-size:240% 100%;animation:ds-shine 3.2s linear infinite}
@keyframes ds-shine{from{background-position:240% 0}to{background-position:-40% 0}}

/* ---------- site header (faithful clone of live Elementor header, id 14) ---------- */
.ds-site-header{position:sticky;top:0;z-index:100;background:#fff;transition:box-shadow .3s}
.ds-site-header.is-stuck{box-shadow:0 8px 30px -22px rgba(0,0,0,.55)}
.ds-site-header__inner{position:relative;max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:28px;padding:15px 30px}
.ds-site-logo{flex:none;display:block;line-height:0}
.ds-site-logo img{width:165px;height:auto;display:block}
.ds-site-nav{margin-left:auto}
.ds-menu{display:flex;align-items:center;gap:40px;list-style:none;margin:0;padding:0}
.ds-menu>li{position:relative}
.ds-menu a{font-family:var(--sans);font-weight:300;font-size:16px;color:var(--nav-ink);position:relative;display:inline-flex;align-items:center;gap:7px;padding:6px 0;transition:color .2s}
.ds-menu>li>a:hover{color:#000}
.ds-menu .ds-has-sub>a::after{content:"";width:6px;height:6px;border-right:1.5px solid currentColor;border-bottom:1.5px solid currentColor;transform:rotate(45deg) translateY(-2px);transition:transform .25s var(--ease)}
.ds-menu .ds-has-sub:hover>a::after{transform:rotate(225deg)}
.ds-menu a.is-active{color:var(--coral)}
.ds-menu>li>a.is-active::before{content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--coral)}
.ds-submenu{position:absolute;top:calc(100% + 14px);left:-18px;min-width:228px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:10px;list-style:none;margin:0;opacity:0;visibility:hidden;transform:translateY(8px);transition:.25s var(--ease);z-index:20}
.ds-has-sub:hover .ds-submenu{opacity:1;visibility:visible;transform:none}
.ds-submenu a{display:block;font-size:14.5px;padding:9px 12px;border-radius:8px;color:var(--secondary)}
.ds-submenu a:hover{background:var(--tint);color:#000}
.ds-site-cta{flex:none;font-family:var(--sans);font-weight:300;font-size:15px;color:var(--nav-ink);border:1px solid var(--nav-ink);background:transparent;padding:11px 22px;transition:.25s var(--ease)}
.ds-site-cta:hover{background:var(--nav-ink);color:#fff}
.ds-site-burger{display:none;flex-direction:column;justify-content:center;gap:5px;width:44px;height:44px;border:0;background:transparent;cursor:pointer;margin-left:6px}
.ds-site-burger span{width:26px;height:2px;background:var(--nav-ink);transition:.3s var(--ease)}
.ds-site-burger.is-open span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ds-site-burger.is-open span:nth-child(2){opacity:0}
.ds-site-burger.is-open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
/* .ds-logo kept for footer brand wordmark */
.ds-logo{font-family:var(--sans);font-weight:800;font-size:23px;letter-spacing:.16em;color:var(--black);text-transform:uppercase}
.ds-logo span{color:var(--coral)}

/* ---------- hero ---------- */
.ds-hero{position:relative;padding:80px 0 54px;text-align:center;overflow:hidden}
.ds-hero__bg{position:absolute;inset:0;z-index:-2;background:
  radial-gradient(55% 55% at 50% -5%,rgba(239,61,95,.12),transparent 70%),
  radial-gradient(40% 40% at 88% 10%,rgba(239,61,95,.08),transparent 70%)}
.ds-hero__dots{position:absolute;inset:0;z-index:-1;
  background-image:radial-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:22px 22px;
  -webkit-mask-image:radial-gradient(58% 58% at 50% 28%,#000,transparent 76%);
  mask-image:radial-gradient(58% 58% at 50% 28%,#000,transparent 76%)}
.ds-hero__title{font-size:clamp(38px,6.4vw,68px);line-height:1.04;max-width:18ch;margin:0 auto 18px}
.ds-hero__title em{font-style:italic;background:linear-gradient(100deg,var(--coral),#ff8aa1,var(--coral));
  background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:ds-gradient 6s linear infinite}
@keyframes ds-gradient{to{background-position:200% center}}
.ds-hero__sub{font-size:18.5px;color:var(--text);max-width:58ch;margin:0 auto 30px}

/* image-backed editorial hero (uses Higgsfield hero-a; subject right, text left) */
.ds-hero--image{text-align:left;padding:0;min-height:clamp(440px,52vw,580px);display:flex;align-items:center;color:#fff}
.ds-hero--image .ds-hero__photo{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center right;transform:scale(1.02)}
.ds-hero--image::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(11,11,13,.94) 0%,rgba(11,11,13,.8) 36%,rgba(11,11,13,.3) 68%,rgba(11,11,13,.05) 100%)}
.ds-hero--image .ds-eyebrow{color:#ff9bad}
.ds-hero--image .ds-hero__title{color:#fff;margin:0 0 18px;max-width:15ch}
.ds-hero--image .ds-hero__sub{color:rgba(255,255,255,.82);margin:0 0 30px;max-width:46ch}
.ds-hero--image .ds-search{margin:0}
@media(max-width:760px){
  .ds-hero--image{min-height:auto;padding:60px 0}
  .ds-hero--image .ds-hero__photo{background-position:center top}
  .ds-hero--image::after{background:linear-gradient(180deg,rgba(11,11,13,.62),rgba(11,11,13,.9))}
  .ds-hero--image .ds-hero__title,.ds-hero--image .ds-hero__sub{max-width:none}
}

/* image-backed editorial hero (uses Higgsfield hero-a; subject right, text left) */
.ds-hero--image{text-align:left;padding:0;min-height:clamp(440px,52vw,580px);display:flex;align-items:center;color:#fff}
.ds-hero--image .ds-hero__photo{position:absolute;inset:0;z-index:-2;background-size:cover;background-position:center right;transform:scale(1.02)}
.ds-hero--image::after{content:"";position:absolute;inset:0;z-index:-1;
  background:linear-gradient(90deg,rgba(11,11,13,.94) 0%,rgba(11,11,13,.8) 36%,rgba(11,11,13,.3) 68%,rgba(11,11,13,.05) 100%)}
.ds-hero--image .ds-eyebrow{color:#ff9bad}
.ds-hero--image .ds-hero__title{color:#fff;margin:0 0 18px;max-width:15ch}
.ds-hero--image .ds-hero__sub{color:rgba(255,255,255,.82);margin:0 0 30px;max-width:46ch}
.ds-hero--image .ds-search{margin:0}
@media(max-width:760px){
  .ds-hero--image{min-height:auto;padding:60px 0}
  .ds-hero--image .ds-hero__photo{background-position:center top}
  .ds-hero--image::after{background:linear-gradient(180deg,rgba(11,11,13,.62),rgba(11,11,13,.9))}
  .ds-hero--image .ds-hero__title,.ds-hero--image .ds-hero__sub{max-width:none}
}
.ds-search{display:flex;align-items:center;gap:8px;max-width:560px;margin:0 auto;background:#fff;
  border:1px solid var(--line);border-radius:999px;padding:7px 7px 7px 20px;box-shadow:var(--shadow-sm);transition:.3s}
.ds-search:focus-within{border-color:var(--coral);box-shadow:0 0 0 4px var(--coral-soft)}
.ds-search svg{flex:none;color:var(--muted)}
.ds-search input{flex:1;border:0;outline:0;font:inherit;font-size:15.5px;background:transparent;color:var(--ink)}

/* ---------- filter tabs ---------- */
.ds-filter{position:relative;z-index:5;background:#fff;border-bottom:1px solid var(--line)}
.ds-tabs{display:flex;gap:6px;overflow-x:auto;padding:14px 0;scrollbar-width:none}
.ds-tabs::-webkit-scrollbar{display:none}
.ds-tab{flex:none;border:1px solid var(--line);background:#fff;color:var(--secondary);font:inherit;font-size:14px;font-weight:600;padding:9px 18px;border-radius:999px;cursor:pointer;transition:.22s var(--ease)}
.ds-tab:hover{border-color:var(--black);color:var(--black)}
.ds-tab.is-active{background:var(--black);border-color:var(--black);color:#fff}

/* ---------- marquee (magicui) ---------- */
.ds-marquee{overflow:hidden;padding:10px 0;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 12%,#000 88%,transparent)}
.ds-marquee__track{display:flex;gap:14px;width:max-content;animation:ds-marquee 34s linear infinite}
.ds-marquee:hover .ds-marquee__track{animation-play-state:paused}
@keyframes ds-marquee{to{transform:translateX(-50%)}}
.ds-chip{flex:none;border:1px solid var(--line);border-radius:999px;padding:8px 16px;font-size:13.5px;font-weight:600;color:var(--secondary);background:var(--tint)}
.ds-chip b{color:var(--coral)}

/* ---------- listing grid + cards ---------- */
.ds-section{padding:52px 0}
.ds-grid{display:grid;gap:26px;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));align-items:start}
.ds-grid--3{grid-template-columns:repeat(3,1fr)}
.ds-card{position:relative;background:#fff;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease),border-color .4s}
.ds-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.ds-card::before{content:"";position:absolute;inset:0;z-index:3;pointer-events:none;opacity:0;transition:opacity .35s;
  background:radial-gradient(240px circle at var(--mx,50%) var(--my,50%),rgba(239,61,95,.15),transparent 60%)}
.ds-card:hover::before{opacity:1}
.ds-card__media{position:relative;display:block;aspect-ratio:16/10;overflow:hidden;background:linear-gradient(135deg,#1a1a1a,#3C3C3C)}
.ds-card__media .ds-thumb{position:absolute;inset:0;transition:transform .6s var(--ease)}
.ds-card:hover .ds-card__media .ds-thumb{transform:scale(1.06)}
.ds-card__body{padding:22px 22px 24px}
.ds-tag{display:inline-block;font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--coral);margin-bottom:12px}
.ds-card__title{font-size:21px;line-height:1.25;margin:0 0 10px}
.ds-card:hover .ds-card__title a{color:var(--coral-700)}
.ds-card__excerpt{font-size:14.5px;color:var(--text);margin:0 0 18px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ds-meta{display:flex;align-items:center;gap:9px;font-size:13px;color:var(--muted)}
.ds-meta__name{color:var(--secondary);font-weight:600}
.ds-dot{opacity:.5}
.ds-avatar{flex:none;width:32px;height:32px;border-radius:50%;background:var(--black);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:11.5px;font-weight:700}
.ds-avatar--coral{background:var(--coral)}

/* image placeholders (duotone) */
.ds-thumb{display:grid;place-items:center;color:rgba(255,255,255,.9)}
.ds-thumb__label{font-family:var(--serif);font-weight:800;font-size:clamp(26px,4vw,46px);letter-spacing:.04em;text-transform:uppercase;opacity:.17}
.ds-thumb--seo{background:linear-gradient(135deg,#0b0b0b,#3C3C3C)}
.ds-thumb--aeo{background:linear-gradient(135deg,#EF3D5F,#5e1020)}
.ds-thumb--geo{background:linear-gradient(135deg,#161616,#EF3D5F)}
.ds-thumb--branding{background:linear-gradient(135deg,#3C3C3C,#0b0b0b)}
.ds-thumb--social{background:linear-gradient(135deg,#EF3D5F,#b01f3b)}
.ds-thumb--web{background:linear-gradient(135deg,#1f1f1f,#636363)}
.ds-thumb--strategy{background:linear-gradient(135deg,#0b0b0b,#7a1226)}

/* pagination */
.ds-pager{display:flex;justify-content:center;align-items:center;gap:8px;margin-top:46px}
.ds-pager a,.ds-pager span{min-width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid var(--line);border-radius:11px;font-size:14px;font-weight:600;color:var(--secondary);transition:.2s}
.ds-pager a:hover{border-color:var(--black);color:var(--black)}
.ds-pager .is-active{background:var(--coral);border-color:var(--coral);color:#fff}
.ds-pager .ds-pager__edge{padding:0 16px}

/* newsletter + border-beam */
.ds-news{padding:48px 0}
.ds-news__inner{position:relative;overflow:hidden;background:var(--black);color:#fff;border-radius:26px;padding:54px 44px;display:flex;align-items:center;justify-content:space-between;gap:30px;flex-wrap:wrap}
.ds-news__inner h2{color:#fff;font-size:clamp(26px,3.4vw,38px);margin:0 0 10px}
.ds-news__inner p{color:rgba(255,255,255,.7);margin:0;max-width:42ch}
/* coral-flip variant (About CTA): coral bg, dark text + black button */
/* white box with coral accent glow (highlight) */
.ds-news__inner--coral{background:#fff;border:1px solid var(--coral-soft);box-shadow:0 30px 70px -28px rgba(239,61,95,.55),0 6px 22px -14px rgba(239,61,95,.4)}
.ds-news__inner--coral h2{color:var(--ink)}
.ds-news__inner--coral .ds-eyebrow{color:var(--coral)}
.ds-news__inner--coral p{color:var(--text)}
.ds-news .ds-eyebrow{color:#ff9bad}
.ds-news__form{display:flex;gap:10px;flex:1 1 360px;max-width:480px;justify-content:flex-end;align-items:center;z-index:1}
.ds-news__form input{flex:1 1 auto;min-width:0}
.ds-news__form .ds-btn{flex:none}
.ds-news__form input{border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.06);color:#fff;border-radius:999px;padding:13px 20px;font:inherit;font-size:15px;min-width:240px}
.ds-news__form input::placeholder{color:rgba(255,255,255,.5)}
.ds-news__msg{flex-basis:100%;width:100%;margin:12px 0 0;font-size:13.5px;min-height:18px;color:#9be29b;text-align:right}
.ds-beam{position:absolute;inset:0;border-radius:26px;padding:1.6px;pointer-events:none;
  background:conic-gradient(from var(--beam),transparent 0 72%,#ff9bad 86%,var(--coral) 95%,transparent 100%);
  -webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;
  animation:ds-beam 6s linear infinite}
@keyframes ds-beam{to{--beam:360deg}}
@property --beam{syntax:'<angle>';inherits:false;initial-value:0deg}

/* footer */
.ds-footer{background:#0b0b0b;color:rgba(255,255,255,.6);padding:64px 0 30px;font-size:14.5px}
.ds-footer a{color:rgba(255,255,255,.6);transition:color .2s}.ds-footer a:hover{color:#fff}
.ds-footer__top{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:40px;padding-bottom:44px;border-bottom:1px solid rgba(255,255,255,.1)}
.ds-footer__brand .ds-logo{color:#fff;display:inline-block;margin-bottom:16px}
.ds-footer__brand p{max-width:34ch;margin:0 0 20px}
.ds-footer h5{color:#fff;font-family:var(--sans);font-size:13px;letter-spacing:.12em;text-transform:uppercase;margin:0 0 18px}
.ds-footer ul{list-style:none;margin:0;padding:0;display:grid;gap:11px}
.ds-footer__bottom{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;padding-top:24px;font-size:13px}
.ds-socials{display:flex;gap:10px}
.ds-socials a{width:38px;height:38px;border:1px solid rgba(255,255,255,.16);border-radius:50%;display:grid;place-items:center;transition:.25s}
.ds-socials a:hover{background:var(--coral);border-color:var(--coral);color:#fff;transform:translateY(-3px)}

/* ============ single post ============ */
.ds-progress{position:fixed;top:0;left:0;height:3px;width:0;background:linear-gradient(90deg,var(--coral),#ff9bad);z-index:200}
.ds-crumbs{font-size:13px;color:var(--muted);margin-bottom:18px;display:flex;gap:8px;align-items:center;flex-wrap:wrap}
.ds-crumbs a:hover{color:var(--coral)}
.ds-post__head{padding:34px 0 8px}
.ds-post__head-grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center}
.ds-post__title{font-size:clamp(30px,4.6vw,50px);line-height:1.08;margin:14px 0 22px}
.ds-meta--lg{font-size:14.5px;gap:12px}
.ds-meta--lg .ds-avatar{width:46px;height:46px;font-size:15px}
.ds-meta__role{display:block;font-size:12.5px;color:var(--muted);font-weight:400}
.ds-post__cover{aspect-ratio:5/4;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.ds-post__body{padding:30px 0 6px}
/* 2-column reading layout (Mavlers-style): sticky TOC card left + wide content right */
.ds-post__grid{display:grid;grid-template-columns:300px minmax(0,1fr);gap:58px;align-items:start;max-width:1200px;margin:0 auto}

/* ---------- Table of Contents (sticky bordered card, scroll-spy) ----------
   The grid CELL itself must be the sticky element (with align-self:start) — a
   sticky child inside an auto-height grid cell has no room to travel and just
   scrolls away. This is the canonical grid sticky-sidebar fix. */
.ds-toc-rail{position:sticky;top:calc(var(--header-h) + 20px);align-self:start;max-height:calc(100vh - var(--header-h) - 40px);display:flex}
.ds-toc-card{flex:1;border:1px solid var(--line);border-radius:16px;padding:24px 22px;background:#fff;display:flex;flex-direction:column;min-height:0;max-height:100%;box-shadow:0 10px 30px -24px rgba(0,0,0,.5)}
.ds-toc__label{font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--ink);margin:0 0 16px;flex:none}
.ds-toc{list-style:none;margin:0;padding:0;border-left:2px solid var(--line);overflow-y:auto;min-height:0;scrollbar-width:thin}
.ds-toc::-webkit-scrollbar{width:5px}.ds-toc::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}
.ds-toc li{margin:0}
.ds-toc a{display:block;font-family:var(--sans);font-size:14px;line-height:1.4;color:var(--text);padding:9px 0 9px 18px;margin-left:-2px;border-left:2px solid transparent;transition:color .2s,border-color .2s}
.ds-toc a:hover{color:var(--black)}
.ds-toc a.is-active{color:var(--ink);border-left-color:var(--coral);font-weight:600}
.ds-toc__progress{margin-top:18px;padding-top:16px;border-top:1px solid var(--line);font-size:11.5px;letter-spacing:.04em;color:var(--muted);display:flex;align-items:center;gap:8px;flex:none}
.ds-toc__bar{flex:1;height:3px;background:var(--line);border-radius:2px;overflow:hidden}
.ds-toc__bar span{display:block;height:100%;width:0;background:var(--coral);transition:width .15s linear}
.ds-article h2{scroll-margin-top:calc(var(--header-h) + 20px)}

.ds-article{font-size:18px;color:#3a3a3a;line-height:1.8;max-width:none;overflow-wrap:break-word;word-break:normal;min-width:0}
.ds-article p,.ds-article li,.ds-article h2,.ds-article h3,.ds-article td,.ds-article th{overflow-wrap:break-word}
.ds-article h2{font-size:clamp(25px,3vw,33px);margin:46px 0 16px}
.ds-article h3{font-size:22px;margin:32px 0 12px}
.ds-article p{margin:0 0 22px}
.ds-article a:not(.ds-btn){color:var(--coral-700);text-decoration:underline;text-underline-offset:3px}
/* buttons inside the article keep their own styling (white text, no underline) */
.ds-article a.ds-btn{color:#fff;text-decoration:none}
.ds-article a.ds-btn:hover{color:#fff}
.ds-article ul,.ds-article ol{margin:0 0 24px;padding-left:24px}
.ds-article li{margin:0 0 11px}.ds-article li::marker{color:var(--coral)}
.ds-lead{font-family:var(--serif);font-size:24px;line-height:1.45;color:var(--ink);font-weight:500;margin:0 0 28px}
.ds-article blockquote{margin:34px 0;padding:6px 0 6px 26px;border-left:3px solid var(--coral);font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.5;color:var(--ink)}
.ds-article blockquote cite{display:block;margin-top:12px;font-family:var(--sans);font-style:normal;font-size:13px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted)}
.ds-article figure{margin:30px 0}
.ds-article figure .ds-thumb{aspect-ratio:16/9;border-radius:14px}
.ds-article figcaption{font-size:13px;color:var(--muted);margin-top:10px;text-align:center}
.ds-takeaways{background:var(--tint);border:1px solid var(--line);border-left:4px solid var(--coral);border-radius:14px;padding:24px 26px;margin:0 0 34px}
.ds-takeaways h2{font-size:14px;font-family:var(--sans);letter-spacing:.14em;text-transform:uppercase;color:var(--coral);margin:0 0 14px}
.ds-takeaways ul{margin:0;padding-left:20px}.ds-takeaways li{font-size:16px;color:var(--ink)}
.ds-table-wrap{overflow-x:auto;margin:0 0 28px;border:1px solid var(--line);border-radius:14px}
.ds-table{width:100%;border-collapse:collapse;font-size:15px;min-width:540px}
.ds-table th,.ds-table td{text-align:left;padding:14px 18px;border-bottom:1px solid var(--line)}
.ds-table thead th{background:var(--black);color:#fff;font-family:var(--sans);font-size:12.5px;letter-spacing:.05em;text-transform:uppercase}
.ds-table tbody tr:last-child td{border-bottom:0}
.ds-table tbody tr:nth-child(even){background:var(--tint)}
.ds-table td:first-child{font-weight:600;color:var(--ink)}
.ds-callout{background:var(--coral-soft);border-radius:14px;padding:22px 26px;margin:30px 0;font-size:16px;color:#5a2230}
.ds-callout strong{color:var(--coral-700)}

.ds-side__sticky{position:sticky;top:calc(var(--header-h) + 22px);display:grid;gap:22px}
.ds-side__card{border:1px solid var(--line);border-radius:16px;padding:22px}
.ds-side__card h4{font-family:var(--sans);font-size:12.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin:0 0 18px}
.ds-related-list{list-style:none;margin:0;padding:0;display:grid;gap:16px}
.ds-related-list a{display:grid;grid-template-columns:64px 1fr;gap:12px;align-items:center}
.ds-related-thumb{position:relative;display:block;width:64px;height:64px;border-radius:9px;overflow:hidden;background:var(--tint)}
.ds-related-thumb .ds-thumb{position:absolute;inset:0;width:100%;height:100%;border-radius:9px}
.ds-related-list a:hover .ds-related-thumb .ds-thumb{transform:scale(1.06);transition:transform .4s var(--ease)}
.ds-related-list h5{font-family:var(--serif);font-size:14.5px;line-height:1.3;margin:0;color:var(--ink);transition:color .2s}
.ds-related-list a:hover h5{color:var(--coral)}
.ds-cta-card{position:relative;overflow:hidden;background:var(--black);color:#fff;border-radius:16px;padding:26px}
.ds-cta-card h4{font-family:var(--serif);font-size:20px;text-transform:none;letter-spacing:0;color:#fff;margin:0 0 8px}
.ds-cta-card p{font-size:14px;color:rgba(255,255,255,.72);margin:0 0 18px}
/* wide CTA banner that lives inside the article column (replaces the stacked sidebar card) */
.ds-cta-card--wide{display:flex;align-items:center;justify-content:space-between;gap:28px;flex-wrap:wrap;padding:32px 34px;margin:44px 0 0}
.ds-cta-card--wide p{margin:0;font-size:15px}
.ds-cta-card--wide h4{font-size:24px;margin:0 0 6px}
.ds-cta-card--wide .ds-btn{flex:none}

.ds-faq{margin:52px 0 0}
.ds-faq>h2{font-size:clamp(25px,3vw,33px);margin:0 0 22px}
.ds-acc{border:1px solid var(--line);border-radius:14px;overflow:hidden;margin-bottom:12px;background:#fff;transition:border-color .25s,box-shadow .25s}
.ds-acc.is-open{border-color:var(--coral);box-shadow:0 12px 34px -20px rgba(239,61,95,.6)}
.ds-acc__q{width:100%;text-align:left;background:none;border:0;cursor:pointer;font-family:var(--serif);font-weight:600;font-size:18px;color:var(--ink);padding:20px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px}
.ds-acc__icon{flex:none;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;transition:.3s var(--ease);color:var(--coral)}
.ds-acc.is-open .ds-acc__icon{transform:rotate(45deg);background:var(--coral);color:#fff;border-color:var(--coral)}
.ds-acc__a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.ds-acc__a p{padding:0 22px 20px;margin:0;font-size:16px}

.ds-author{margin:60px 0 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:40px 0}
.ds-author__inner{display:flex;gap:24px;align-items:flex-start}
.ds-avatar--xl{width:84px;height:84px;font-size:28px;flex:none}
.ds-author h3{font-size:24px;margin:6px 0 4px}
.ds-author__role{font-size:14px;color:var(--coral);font-weight:600;margin:0 0 12px}
.ds-author__bio{font-size:15.5px;margin:0 0 14px;max-width:62ch}

/* Entrance reveal — CSS-ONLY, content ALWAYS visible (never depends on JS).
   Hardened after an incident where JS-gated opacity:0 + LiteSpeed JS-delay
   left the page blank. Base state is fully visible; the animation only adds
   a gentle rise/fade on load. If animations are stripped/disabled, content
   still shows. */
@keyframes ds-reveal{from{opacity:0;transform:translateY(20px);filter:blur(6px)}to{opacity:1;transform:none;filter:none}}
[data-reveal]{opacity:1}                 /* SAFE DEFAULT: visible no matter what */
@media (prefers-reduced-motion:no-preference){
  [data-reveal]{animation:ds-reveal .7s var(--ease) both}
}

/* ---------- responsive ---------- */
@media(max-width:1024px){
  .ds-site-cta{display:none}
  .ds-site-burger{display:flex}
  .ds-site-nav{position:absolute;top:100%;left:0;right:0;margin:0;background:#fff;border-top:1px solid var(--line);box-shadow:var(--shadow);max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
  .ds-site-nav.is-open{max-height:84vh;overflow:auto}
  .ds-menu{flex-direction:column;align-items:stretch;gap:0;padding:8px 30px 18px}
  .ds-menu>li{border-bottom:1px solid var(--line)}
  .ds-menu>li>a{padding:15px 0;font-size:17px;justify-content:space-between}
  .ds-menu .ds-has-sub>a::after{display:none}
  .ds-menu>li>a.is-active::before{display:none}
  .ds-submenu{position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:0;border-radius:0;padding:0 0 10px 14px;min-width:0}
  .ds-submenu a{padding:8px 0;color:var(--text)}
}
@media(max-width:980px){
  .ds-post__head-grid{grid-template-columns:1fr;gap:22px}
  .ds-post__cover{order:-1;aspect-ratio:16/10}
  .ds-post__grid{grid-template-columns:1fr;gap:40px}
  .ds-side__sticky{position:static}
  .ds-grid--3{grid-template-columns:repeat(2,1fr)}
  .ds-footer__top{grid-template-columns:1fr 1fr;gap:30px}
}
/* TOC: left rail on desktop; below 1024px collapse to inline "On this page" + single column */
@media(max-width:1024px){
  .ds-post__grid{grid-template-columns:1fr;gap:0;max-width:760px}
  .ds-toc-rail{display:none}
  .ds-toc-inline{display:block}
}
@media(min-width:1025px){ .ds-toc-inline{display:none} }
/* inline TOC (mobile/tablet) */
.ds-toc-inline{margin:0 0 28px;border:1px solid var(--line);border-radius:14px;background:var(--tint);overflow:hidden}
.ds-toc-inline summary{cursor:pointer;list-style:none;padding:16px 20px;font-family:var(--sans);font-weight:700;font-size:13px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink);display:flex;justify-content:space-between;align-items:center}
.ds-toc-inline summary::-webkit-details-marker{display:none}
.ds-toc-inline summary::after{content:"+";color:var(--coral);font-size:18px}
.ds-toc-inline[open] summary::after{content:"\2212"}
.ds-toc-inline ol{margin:0;padding:0 20px 18px 38px}
.ds-toc-inline a{color:var(--text);font-size:15px;line-height:1.6;display:block;padding:4px 0}
.ds-toc-inline a:hover{color:var(--coral)}
@media(max-width:640px){
  body{font-size:16px;overflow-x:hidden}     /* hard guard against any stray horizontal overflow */
  .ds-article{font-size:17px}
  .ds-article h2{font-size:clamp(22px,6vw,28px)}
  .ds-article h3{font-size:20px}
  .ds-post__title{font-size:clamp(26px,7vw,34px)}
  .ds-news__inner{padding:32px 24px;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:18px;text-align:center}
  .ds-news__form{flex:0 0 auto;width:100%;max-width:none;flex-direction:column;align-items:stretch;justify-content:flex-start;gap:10px}
  .ds-news__form input{flex:0 0 auto;width:100%;height:52px;border-radius:14px;text-align:center}
  .ds-news__form .ds-btn{flex:0 0 auto;width:100%;justify-content:center}
  .ds-news__msg{text-align:center;margin:0}
  .ds-grid--3{grid-template-columns:1fr}
  .ds-author__inner{flex-direction:column}
  .ds-cta-card--wide{flex-direction:column;align-items:flex-start;padding:26px 24px}
  .ds-cta-card--wide .ds-btn{width:100%;justify-content:center}
}
@media(prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto!important}
  [data-reveal]{opacity:1!important;transform:none!important;filter:none!important}
}

/* ============================================================
   FOOTER FIX (blog context) — a pre-existing snippet (dsn-fonts-inline)
   pollutes Elementor's global color vars with a stray teal #54F0DA,
   which breaks the footer's var()-based colors on our custom-rendered
   pages. Force DESENO's real footer palette with high specificity.
   ============================================================ */
/* dark footer background (footer template id 59, top section e887401) */
footer.elementor-location-footer .elementor-element-e887401,
.elementor-59 .elementor-element-e887401{background-color:#000 !important}
/* whole footer document fallback: ensure dark base + light text */
footer.elementor-location-footer{background-color:#000}
footer.elementor-location-footer,
footer.elementor-location-footer .elementor-heading-title,
footer.elementor-location-footer p,
footer.elementor-location-footer a,
footer.elementor-location-footer .elementor-icon-list-text{color:#fff !important}
footer.elementor-location-footer a:hover{color:#EF3D5F !important}
/* footer logo + images must display (lazy already off, but guard) */
footer.elementor-location-footer img{opacity:1 !important;visibility:visible !important}
/* social icons visible (white, coral on hover) */
footer.elementor-location-footer .elementor-social-icon,
footer.elementor-location-footer .elementor-icon{color:#fff !important;fill:#fff !important;opacity:1 !important;visibility:visible !important}
footer.elementor-location-footer .elementor-social-icon svg,
footer.elementor-location-footer .elementor-icon svg{fill:#fff !important}
footer.elementor-location-footer .elementor-social-icon:hover{color:#EF3D5F !important}
/* newsletter Send + Contact Now buttons: branded, not grey */
footer.elementor-location-footer .elementor-button,
footer.elementor-location-footer button[type=submit]{background-color:#EF3D5F !important;color:#fff !important;border-color:#EF3D5F !important;opacity:1 !important}
footer.elementor-location-footer .elementor-field-group input{background:#1a1a1a !important;color:#fff !important;border:1px solid #333 !important}
/* keep section/copyright divider visible */
footer.elementor-location-footer hr,
footer.elementor-location-footer .elementor-divider-separator{border-color:rgba(255,255,255,.15) !important}

/* ============================================================
   ABOUT PAGE — blog design language (editorial values, team, FAQ)
   ============================================================ */
/* text-forward editorial intro (replaces dark image hero) */
.ds-about-intro{position:relative;overflow:hidden;padding:96px 0 70px;background:#fff}
.ds-about-intro__bg{position:absolute;inset:0;z-index:0;background:radial-gradient(60% 60% at 18% -8%,rgba(239,61,95,.12),transparent 70%),radial-gradient(38% 40% at 92% 8%,rgba(239,61,95,.08),transparent 70%)}
.ds-about-intro__dots{position:absolute;inset:0;z-index:0;background-image:radial-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:22px 22px;-webkit-mask-image:radial-gradient(60% 60% at 30% 20%,#000,transparent 75%);mask-image:radial-gradient(60% 60% at 30% 20%,#000,transparent 75%)}
.ds-about-intro .ds-container{position:relative;z-index:1}
.ds-about-intro__title{font-size:clamp(40px,6vw,76px);line-height:1.03;letter-spacing:-.015em;margin:0 0 22px;max-width:18ch}
.ds-about-intro__title em{font-style:italic;background:linear-gradient(100deg,var(--coral),#ff8aa1,var(--coral));background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:ds-gradient 6s linear infinite}
.ds-about-intro__lede{font-size:clamp(18px,2.1vw,22px);color:var(--secondary);max-width:54ch;margin:0 0 44px}
.ds-about-goal{display:grid;grid-template-columns:auto 1fr;gap:34px;align-items:center;border-top:1px solid var(--line);padding-top:40px;max-width:920px}
.ds-about-goal__num{font-family:var(--serif);font-weight:700;font-size:clamp(64px,9vw,110px);line-height:.9;color:var(--coral);letter-spacing:-.02em}
.ds-about-goal__text{font-size:17.5px;line-height:1.75;color:var(--text);margin:0}
.ds-about-goal__text strong{color:var(--ink)}
@media(max-width:640px){
  .ds-about-intro{padding:64px 0 48px}
  .ds-about-goal{grid-template-columns:1fr;gap:8px;text-align:left}
}

.ds-about-hero{position:relative;overflow:hidden;background:#0b0b0b;color:#fff}
.ds-about-hero__grid{position:relative;z-index:2;max-width:var(--container);margin:0 auto;padding:0 var(--gutter);
  min-height:520px;display:grid;grid-template-columns:1fr 1fr;align-items:center;gap:40px}
.ds-about-hero__copy{padding:70px 0}
.ds-about-hero .ds-eyebrow{color:#ff9bad}
.ds-about-hero h1{font-size:clamp(38px,5.4vw,62px);line-height:1.05;color:#fff;margin:0 0 20px}
.ds-about-hero h1 em{font-style:italic;background:linear-gradient(100deg,var(--coral),#ff8aa1,var(--coral));background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:ds-gradient 6s linear infinite}
.ds-about-hero__sub{font-size:18.5px;color:rgba(255,255,255,.72);max-width:46ch;margin:0 0 28px}
.ds-about-hero__photo{position:absolute;inset:0 0 0 42%;background-size:cover;background-position:center;z-index:1}
.ds-about-hero__photo::before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,#0b0b0b 0%,rgba(11,11,11,.5) 22%,transparent 55%)}

.ds-about-section{padding:80px 0}
.ds-about-section--tint{background:var(--tint)}
.ds-about-head{text-align:center;max-width:60ch;margin:0 auto 48px}
.ds-about-head h2{font-size:clamp(28px,3.6vw,42px);margin:0 0 14px}
.ds-about-head p{font-size:18px;color:var(--text);margin:0}
.ds-about-lead{font-family:var(--serif);font-size:clamp(22px,2.6vw,30px);line-height:1.4;color:var(--ink);max-width:24ch}

/* Vision / Mission / Core Purpose — dark manifesto band */
.ds-manifesto{background:#0b0b0b;color:#fff;padding:90px 0}
.ds-manifesto .ds-about-head h2{color:#fff}
.ds-manifesto .ds-about-head p{color:rgba(255,255,255,.66)}
.ds-vmp{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.ds-vmp__card{position:relative;border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:38px 32px;overflow:hidden;background:linear-gradient(180deg,rgba(255,255,255,.04),rgba(255,255,255,0));transition:transform .45s var(--ease),border-color .45s;display:flex;flex-direction:column}
.ds-vmp__card:hover{transform:translateY(-6px);border-color:transparent}
.ds-vmp__card .ds-beam{border-radius:18px;opacity:0;transition:opacity .4s}
.ds-vmp__card:hover .ds-beam{opacity:1}
.ds-vmp__icon{position:relative;z-index:1;width:54px;height:54px;border-radius:14px;background:rgba(239,61,95,.16);color:var(--coral);display:grid;place-items:center;margin:0 0 24px;transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease)}
.ds-vmp__card:hover .ds-vmp__icon{background:var(--coral);color:#fff;transform:translateY(-2px) rotate(-6deg)}
.ds-vmp__icon svg{width:26px;height:26px}
.ds-vmp__label{position:relative;z-index:1;font-family:var(--sans);font-size:12px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:#ff9bad;margin:0 0 14px}
.ds-vmp__statement{position:relative;z-index:1;font-family:var(--serif);font-size:24px;line-height:1.32;color:#fff;margin:0;letter-spacing:-.01em}
.ds-vmp__body{position:relative;z-index:1;font-size:15px;line-height:1.7;color:rgba(255,255,255,.66);margin:0}
.ds-vmp__body strong{color:#fff}
@media(max-width:980px){.ds-vmp{grid-template-columns:1fr}.ds-manifesto{padding:64px 0}}

/* values — creative editorial layout: big ghost numbers, icon, coral keyline, reveal */
.ds-values{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;background:#fff}
.ds-value{position:relative;padding:44px 34px 40px;overflow:hidden;border-right:1px solid var(--line);border-bottom:1px solid var(--line);transition:background .4s var(--ease),transform .4s var(--ease)}
.ds-value:nth-child(3n){border-right:0}
.ds-value:nth-last-child(-n+3){border-bottom:0}
/* giant ghost number watermark */
.ds-value__num{position:absolute;top:8px;right:18px;font-family:var(--serif);font-weight:700;font-size:120px;line-height:.8;color:var(--coral);opacity:.07;transition:opacity .45s var(--ease),transform .45s var(--ease);z-index:0;pointer-events:none}
.ds-value__icon{position:relative;z-index:1;width:52px;height:52px;border-radius:14px;background:var(--coral-soft);color:var(--coral);display:grid;place-items:center;margin:0 0 22px;transition:background .4s var(--ease),color .4s var(--ease),transform .4s var(--ease)}
.ds-value__icon svg{width:24px;height:24px}
.ds-value h3{position:relative;z-index:1;font-size:21px;margin:0 0 10px;display:flex;align-items:center;gap:10px}
.ds-value h3::before{content:"";width:0;height:2px;background:var(--coral);transition:width .4s var(--ease)}
.ds-value p{position:relative;z-index:1;font-size:15.5px;color:var(--text);line-height:1.7;margin:0}
.ds-value:hover{background:#0b0b0b;transform:none;z-index:2}
.ds-value:hover .ds-value__num{opacity:.16;transform:translateY(-4px)}
.ds-value:hover .ds-value__num{color:var(--coral)}
.ds-value:hover .ds-value__icon{background:var(--coral);color:#fff;transform:translateY(-2px) rotate(-6deg)}
.ds-value:hover h3{color:#fff}
.ds-value:hover h3::before{width:22px}
.ds-value:hover p{color:rgba(255,255,255,.72)}

/* team — premium portrait cards (real founder photos) */
.ds-team{display:grid;grid-template-columns:repeat(2,minmax(0,380px));gap:30px;justify-content:center}
.ds-team__card{position:relative;border-radius:22px;overflow:hidden;aspect-ratio:4/5;display:block;transition:transform .45s var(--ease),box-shadow .45s var(--ease);box-shadow:var(--shadow-sm)}
.ds-team__card:hover{transform:translateY(-8px);box-shadow:var(--shadow)}
.ds-team__photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:top center;transition:transform .6s var(--ease);filter:grayscale(.15)}
.ds-team__card:hover .ds-team__photo{transform:scale(1.05);filter:grayscale(0)}
.ds-team__scrim{position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,11,0) 38%,rgba(11,11,11,.45) 62%,rgba(11,11,11,.92) 100%)}
.ds-team__beam{position:absolute;inset:0;border-radius:22px;padding:2px;pointer-events:none;background:conic-gradient(from var(--beam),transparent 0 72%,#ff9bad 86%,var(--coral) 95%,transparent 100%);-webkit-mask:linear-gradient(#000 0 0) content-box,linear-gradient(#000 0 0);-webkit-mask-composite:xor;mask-composite:exclude;opacity:0;transition:opacity .4s;animation:ds-beam 6s linear infinite}
.ds-team__card:hover .ds-team__beam{opacity:1}
.ds-team__info{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:30px 30px 28px;color:#fff}
.ds-team__role{display:inline-block;color:#fff;background:var(--coral);font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:5px 12px;border-radius:999px;margin:0 0 12px}
.ds-team__card h3{color:#fff;font-size:26px;margin:0 0 6px}
.ds-team__card p{color:rgba(255,255,255,.82);font-size:14.5px;line-height:1.55;margin:0;max-width:34ch}

/* about CTA reuse ds-news; about FAQ reuses ds-faq/ds-acc from single post */
.ds-about-faq{max-width:820px;margin:0 auto}

/* office gallery — "Inside the studio" */
.ds-studio{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:auto auto;gap:18px}
.ds-studio__fig{position:relative;overflow:hidden;border-radius:18px;margin:0;background:var(--tint)}
.ds-studio__fig img{display:block;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);filter:grayscale(.1)}
.ds-studio__fig:hover img{transform:scale(1.05);filter:grayscale(0)}
.ds-studio__fig::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(11,11,11,.5));opacity:0;transition:opacity .4s}
.ds-studio__fig:hover::after{opacity:1}
.ds-studio__cap{position:absolute;left:18px;bottom:16px;z-index:2;color:#fff;font-family:var(--sans);font-size:13px;font-weight:600;letter-spacing:.04em;opacity:0;transform:translateY(6px);transition:.4s var(--ease)}
.ds-studio__fig:hover .ds-studio__cap{opacity:1;transform:none}
.ds-studio__big{grid-row:1 / span 2}
.ds-studio__fig--tall{min-height:0}
@media(max-width:760px){
  .ds-studio{grid-template-columns:1fr;grid-template-rows:none}
  .ds-studio__big{grid-row:auto}
  .ds-studio__fig{aspect-ratio:16/10}
}

@media(max-width:1024px){
  .ds-about-hero__grid{grid-template-columns:1fr;min-height:0}
  .ds-about-hero__copy{padding:60px 0 calc(56vw + 30px)}
  .ds-about-hero__photo{inset:auto 0 0 0;height:54vw}
  .ds-about-hero__photo::before{background:linear-gradient(0deg,transparent,rgba(11,11,11,.3))}
  .ds-values{grid-template-columns:repeat(2,1fr)}
  .ds-value:nth-child(3n){border-right:1px solid var(--line)}
  .ds-value:nth-child(2n){border-right:0}
  .ds-value:nth-last-child(-n+3){border-bottom:1px solid var(--line)}
  .ds-value:nth-last-child(-n+2){border-bottom:0}
}
@media(max-width:640px){
  .ds-values{grid-template-columns:1fr}
  .ds-value{border-right:0 !important;border-bottom:1px solid var(--line) !important}
  .ds-value:last-child{border-bottom:0 !important}
  .ds-value__num{font-size:92px}
  .ds-team{grid-template-columns:minmax(0,360px)}
  .ds-about-section{padding:54px 0}
}

/* ============================================================
   CASE STUDIES listing — blog/about design language
   ============================================================ */
.ds-cs-hero{position:relative;overflow:hidden;padding:90px 0 56px;background:#fff}
.ds-cs-hero__bg{position:absolute;inset:0;z-index:0;background:radial-gradient(58% 58% at 22% -8%,rgba(239,61,95,.12),transparent 70%),radial-gradient(40% 42% at 90% 6%,rgba(239,61,95,.08),transparent 70%)}
.ds-cs-hero__dots{position:absolute;inset:0;z-index:0;background-image:radial-gradient(rgba(0,0,0,.05) 1px,transparent 1px);background-size:22px 22px;-webkit-mask-image:radial-gradient(58% 58% at 28% 26%,#000,transparent 76%);mask-image:radial-gradient(58% 58% at 28% 26%,#000,transparent 76%)}
.ds-cs-hero .ds-container{position:relative;z-index:1}
.ds-cs-hero h1{font-size:clamp(40px,6vw,72px);line-height:1.04;letter-spacing:-.015em;margin:0 0 18px;max-width:16ch}
.ds-cs-hero h1 em{font-style:italic;background:linear-gradient(100deg,var(--coral),#ff8aa1,var(--coral));background-size:200% auto;-webkit-background-clip:text;background-clip:text;color:transparent;animation:ds-gradient 6s linear infinite}
.ds-cs-hero__sub{font-size:clamp(17px,2vw,21px);color:var(--secondary);max-width:54ch;margin:0}

/* results strip */
.ds-cs-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;background:#0b0b0b;border-radius:24px;padding:44px 40px;margin:48px 0 0;text-align:center;position:relative;overflow:hidden}
.ds-cs-stats>div{position:relative;z-index:1}
.ds-cs-stats>div:not(:last-child){border-right:1px solid rgba(255,255,255,.1)}
.ds-cs-stat__num{font-family:var(--serif);font-weight:700;font-size:clamp(34px,4.4vw,52px);line-height:1;letter-spacing:-.02em;background:linear-gradient(100deg,#fff,#ffb9c6);-webkit-background-clip:text;background-clip:text;color:transparent}
.ds-cs-stat__label{font-size:13px;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:#ff9bad;margin:12px 0 0}
@media(max-width:640px){.ds-cs-stats{grid-template-columns:repeat(2,1fr);gap:34px 18px;padding:36px 26px}.ds-cs-stats>div:not(:last-child){border-right:0}}

/* case study cards */
.ds-cs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.ds-cs-card{position:relative;display:flex;flex-direction:column;border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;text-decoration:none;color:inherit;transition:transform .45s var(--ease),box-shadow .45s var(--ease),border-color .45s}
.ds-cs-card:hover{transform:translateY(-8px);box-shadow:var(--shadow);border-color:transparent}
.ds-cs-card__media{position:relative;aspect-ratio:16/10;overflow:hidden;display:grid;place-items:center}
.ds-cs-card__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ds-cs-card:hover .ds-cs-card__media img{transform:scale(1.06)}
.ds-cs-card__media--logo{background:var(--tint);border-bottom:1px solid var(--line)}
.ds-cs-card__media--logo img{position:relative;width:auto;height:auto;max-width:64%;max-height:56%;object-fit:contain;filter:none;mix-blend-mode:multiply}
.ds-cs-card__media--coral{background:linear-gradient(135deg,#EF3D5F,#7a1226)}
.ds-cs-card__tag{position:absolute;top:16px;left:16px;z-index:2;background:#fff;color:var(--ink);font-size:11.5px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:999px}
.ds-cs-card__body{padding:26px 26px 28px;display:flex;flex-direction:column;flex:1}
.ds-cs-card__client{font-size:12.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:var(--coral);margin:0 0 10px}
.ds-cs-card__title{font-size:22px;line-height:1.28;margin:0 0 14px}
.ds-cs-card:hover .ds-cs-card__title{color:var(--coral-700)}
.ds-cs-card__result{margin-top:auto;display:flex;align-items:center;gap:8px;font-size:14px;color:var(--secondary);font-weight:600}
.ds-cs-card__result b{font-family:var(--serif);font-size:20px;color:var(--coral)}
.ds-cs-card__cta{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:600;color:var(--ink);margin-top:16px}
.ds-cs-card__cta svg{transition:transform .3s var(--ease)}
.ds-cs-card:hover .ds-cs-card__cta svg{transform:translateX(4px)}
.ds-cs-card__cta{color:var(--coral-700)}
/* "coming soon" placeholder cards */
.ds-cs-card--soon{cursor:default}
.ds-cs-card--soon:hover{transform:none;box-shadow:var(--shadow-sm);border-color:var(--line)}
.ds-cs-card--soon .ds-cs-card__media{aspect-ratio:16/10}
.ds-cs-soon-badge{position:absolute;top:16px;right:16px;z-index:2;background:rgba(255,255,255,.16);color:#fff;font-size:11px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:6px 12px;border-radius:999px;backdrop-filter:blur(6px)}
.ds-cs-card--soon .ds-cs-card__title{color:#fff}
.ds-cs-card--soon .ds-cs-card__body{position:absolute;inset:auto 0 0 0;color:#fff;background:linear-gradient(180deg,transparent,rgba(0,0,0,.55))}
.ds-cs-card--soon .ds-cs-card__media img{filter:grayscale(.2)}
@media(max-width:1024px){.ds-cs-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:640px){.ds-cs-grid{grid-template-columns:1fr}}
.ds-cs-card__title{font-size:20px}

/* ============================================================
   CASE STUDY DETAIL page (blog/about design language)
   ============================================================ */
.ds-csd-hero{padding:30px 0 6px;background:#fff}
.ds-csd-hero__grid{display:grid;grid-template-columns:1.05fr .95fr;gap:48px;align-items:center;margin-top:14px}
.ds-csd-hero__title{font-size:clamp(32px,4.6vw,52px);line-height:1.08;letter-spacing:-.015em;margin:14px 0 16px}
/* full-bleed cinematic hero (e.g. Bella Casa tower render) */
.ds-csd-hero--full{position:relative;min-height:clamp(460px,74vh,720px);overflow:hidden;background:#0b0b0b;padding:0}
.ds-csd-hero__photo{position:absolute;inset:0;background-size:cover;background-position:center 30%;z-index:0}
.ds-csd-hero__veil{position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(8,9,12,.32),rgba(8,9,12,.05) 34%,rgba(8,9,12,.55) 74%,rgba(8,9,12,.9))}
.ds-csd-hero--full>.ds-container{position:relative;z-index:2;min-height:clamp(460px,74vh,720px);display:flex;flex-direction:column;justify-content:space-between;padding-top:26px;padding-bottom:clamp(32px,5.5vh,60px)}
.ds-csd-hero--full .ds-crumbs--light,.ds-csd-hero--full .ds-crumbs--light a{color:rgba(255,255,255,.8)}
.ds-csd-hero--full .ds-crumbs--light span{color:#fff}
.ds-csd-hero__cap{max-width:780px;color:#fff}
.ds-csd-hero--full .ds-eyebrow{color:#ff9bad}
.ds-csd-hero--full .ds-csd-hero__title{color:#fff;margin:10px 0 14px;max-width:20ch}
.ds-csd-hero--full .ds-csd-hero__svc{color:rgba(255,255,255,.85)}
.ds-csd-glance-sec{background:#fff;padding:28px 0 4px}
@media(max-width:760px){.ds-csd-hero--full,.ds-csd-hero--full>.ds-container{min-height:clamp(440px,64vh,560px)}}
.ds-csd-hero__svc{font-size:13.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--coral);margin:0}
.ds-csd-hero__media{aspect-ratio:16/10;border-radius:20px;overflow:hidden;box-shadow:var(--shadow)}
.ds-csd-hero__media img{width:100%;height:100%;object-fit:cover}
.ds-csd-hero__media--logo{background:var(--tint);box-shadow:var(--shadow-sm);border:1px solid var(--line);display:grid;place-items:center}
.ds-csd-hero__media--logo img{width:auto;height:auto;max-width:60%;max-height:54%;object-fit:contain;mix-blend-mode:multiply}

/* ---- AT-A-GLANCE spec strip ---- */
.ds-csd-glance{display:grid;grid-template-columns:repeat(4,1fr);border:1px solid var(--line);border-radius:18px;overflow:hidden;background:#fff;margin:36px 0 4px;box-shadow:var(--shadow-sm)}
.ds-csd-glance__cell{padding:22px 24px;border-right:1px solid var(--line);display:flex;gap:14px;align-items:flex-start}
.ds-csd-glance__cell:last-child{border-right:0}
.ds-csd-glance__ic{flex:0 0 auto;width:40px;height:40px;border-radius:11px;background:var(--tint);color:var(--coral);display:grid;place-items:center}
.ds-csd-glance__ic svg{width:21px;height:21px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.ds-csd-glance__label{font-size:11px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#9a9a9a;margin:1px 0 6px}
.ds-csd-glance__val{font-size:15px;font-weight:600;line-height:1.35;color:#141414}

/* ---- section scaffolding ---- */
.ds-csd-sec{padding:60px 0 0}
.ds-csd-sec--tint{background:var(--tint);padding:64px 0;margin-top:60px}
.ds-csd-sec__head{max-width:780px}
.ds-csd-sec__eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);margin:0 0 12px}
.ds-csd-sec h2{font-size:clamp(26px,3.2vw,38px);line-height:1.12;letter-spacing:-.015em;margin:0 0 16px}
.ds-csd-sec__lead{font-size:18px;line-height:1.8;color:#3a3a3a;margin:0}
.ds-csd-sec__lead+.ds-csd-sec__lead{margin-top:18px}
.ds-csd-point{display:flex;gap:14px;align-items:flex-start;margin-top:26px;padding:20px 24px;border-radius:14px;background:#fff;border:1px solid var(--line);border-left:3px solid var(--coral);font-size:17px;font-weight:600;color:#141414;max-width:780px;box-shadow:var(--shadow-sm)}
.ds-csd-point svg{flex:0 0 auto;width:22px;height:22px;fill:none;stroke:var(--coral);stroke-width:2;stroke-linecap:round;stroke-linejoin:round;margin-top:1px}

/* ---- APPROACH process steps ---- */
.ds-csd-process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:38px}
.ds-csd-step{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 22px 24px;transition:transform .35s,box-shadow .35s}
.ds-csd-step:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ds-csd-step__n{font-size:13px;font-weight:800;letter-spacing:.12em;color:var(--coral)}
.ds-csd-step__ic{width:48px;height:48px;border-radius:13px;background:#0b0b0b;color:#fff;display:grid;place-items:center;margin:14px 0 16px}
.ds-csd-step__ic svg{width:23px;height:23px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.ds-csd-step__t{font-size:17px;font-weight:700;letter-spacing:-.01em;margin:0 0 9px}
.ds-csd-step__d{font-size:14px;line-height:1.65;color:#5a5a5a;margin:0}

/* ---- RESULTS dark band ---- */
.ds-csd-results{background:#0b0b0b;border-radius:28px;padding:52px 48px;color:#fff;margin-top:36px}
.ds-csd-results__eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);margin:0 0 28px;text-align:center}
.ds-csd-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;text-align:center}
.ds-csd-metric{padding:0 10px}
.ds-csd-metric__num{font-family:var(--serif);font-weight:700;font-size:clamp(40px,5vw,62px);line-height:1;letter-spacing:-.02em;background:linear-gradient(100deg,#fff,#ffb9c6);-webkit-background-clip:text;background-clip:text;color:transparent}
.ds-csd-metric__label{font-size:12.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#ff9bad;margin:12px 0 0}
.ds-csd-metric__ctx{font-size:13px;line-height:1.5;color:#9d9d9d;margin:7px 0 0}
.ds-csd-funnel{margin:42px auto 0;max-width:600px;border-top:1px solid rgba(255,255,255,.1);padding-top:34px}
.ds-csd-funnel__cap{font-size:12px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#7d7d7d;text-align:center;margin:0 0 22px}
.ds-csd-funnel__row{display:flex;align-items:center;gap:18px;margin:0 0 13px}
.ds-csd-funnel__lab{flex:0 0 96px;text-align:right;font-size:13px;font-weight:600;color:#bdbdbd;letter-spacing:.02em}
.ds-csd-funnel__track{flex:1}
.ds-csd-funnel__bar{height:46px;border-radius:11px;background:linear-gradient(90deg,#EF3D5F,#8c1530);display:flex;align-items:center;justify-content:flex-end;padding:0 18px;font-family:var(--serif);font-weight:700;font-size:20px;color:#fff;box-shadow:0 12px 30px -16px rgba(239,61,95,.85)}

/* ---- outcome callout ---- */
.ds-csd-callout{display:flex;gap:24px;align-items:center;flex-wrap:wrap;background:#fff;border:1px solid #f1d0d8;border-left:4px solid var(--coral);border-radius:18px;padding:28px 32px;margin:30px auto 0;box-shadow:0 26px 60px -38px rgba(239,61,95,.65);max-width:940px}
.ds-csd-callout__big{font-family:var(--serif);font-weight:700;font-size:clamp(34px,4vw,46px);line-height:1;color:var(--coral)}
.ds-csd-callout__txt{font-size:17px;font-weight:500;line-height:1.5;color:#222;flex:1;min-width:220px}

/* ---- pull quote ---- */
.ds-csd-quote{max-width:860px;margin:0 auto;text-align:center;padding:8px 0}
.ds-csd-quote__mark{color:var(--coral);display:inline-flex;margin-bottom:4px}
.ds-csd-quote p{font-family:var(--serif);font-weight:500;font-size:clamp(22px,2.7vw,30px);line-height:1.5;color:#121212;margin:0}
.ds-csd-quote cite{display:block;margin-top:20px;font-size:12px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#9a9a9a;font-style:normal}

/* legacy fallback body (unmapped case studies) */
.ds-csd-body{max-width:760px}
.ds-csd-body .ds-lead{margin-bottom:30px}
.ds-csd-body h2{font-size:clamp(24px,3vw,32px);margin:40px 0 14px}
.ds-csd-body p{font-size:18px;line-height:1.8;color:#3a3a3a;margin:0 0 20px}

@media(max-width:980px){.ds-csd-process{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.ds-csd-hero__grid{grid-template-columns:1fr;gap:24px}.ds-csd-hero__media{order:-1}}
@media(max-width:760px){.ds-csd-glance{grid-template-columns:1fr 1fr}.ds-csd-glance__cell:nth-child(2n){border-right:0}.ds-csd-glance__cell:nth-child(-n+2){border-bottom:1px solid var(--line)}}
@media(max-width:640px){.ds-csd-metrics{grid-template-columns:1fr;gap:30px}.ds-csd-results{padding:40px 22px}.ds-csd-process{grid-template-columns:1fr}.ds-csd-funnel__lab{flex-basis:74px}.ds-csd-glance{grid-template-columns:1fr}.ds-csd-glance__cell{border-right:0;border-bottom:1px solid var(--line)}.ds-csd-glance__cell:last-child{border-bottom:0}}
/* case study — proof gallery (real Search Console / analytics screenshots) */
.ds-csd-gallery{margin-top:40px}
.ds-csd-gallery__cap{font-family:var(--serif);font-weight:700;font-size:clamp(20px,2.4vw,26px);letter-spacing:-.012em;color:var(--ink);text-align:center;margin:0 0 26px}
.ds-csd-gallery__grid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px}
.ds-csd-shot{margin:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff;box-shadow:0 22px 50px -36px rgba(0,0,0,.4);transition:transform .3s var(--ease),box-shadow .3s}
.ds-csd-shot:hover{transform:translateY(-3px);box-shadow:0 30px 60px -34px rgba(0,0,0,.5)}
.ds-csd-shot img{display:block;width:100%;height:auto;border-bottom:1px solid var(--line)}
.ds-csd-shot figcaption{padding:14px 18px;font-size:13.5px;font-weight:600;color:var(--secondary);letter-spacing:-.005em}
/* case study — paid performance cards */
.ds-csd-paid{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:30px}
.ds-csd-paidcard{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px 30px 26px;box-shadow:0 24px 54px -40px rgba(0,0,0,.4)}
.ds-csd-paidcard__h{font-family:var(--serif);font-weight:700;font-size:19px;color:var(--ink);margin:0 0 18px}
.ds-csd-paidcard__stats{display:flex;flex-wrap:wrap;gap:24px;margin:0 0 16px}
.ds-csd-paidcard__stats>div{display:flex;flex-direction:column}
.ds-csd-paidcard__stats b{font-family:var(--serif);font-weight:700;font-size:clamp(22px,2.6vw,28px);color:var(--coral);line-height:1}
.ds-csd-paidcard__stats span{font-size:12px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--muted);margin-top:6px}
.ds-csd-paidcard__note{font-size:14.5px;line-height:1.6;color:var(--text);margin:0}
@media(max-width:760px){.ds-csd-gallery__grid{grid-template-columns:1fr}.ds-csd-paid{grid-template-columns:1fr}}
/* case study — client logo lockup in hero */
.ds-csd-hero__logo{margin:0 0 18px}
.ds-csd-hero__logo img{height:38px;width:auto;max-width:230px;display:block}
/* case study — gallery reels variant (portrait Instagram content, 4-up) */
.ds-csd-gallery--reels .ds-csd-gallery__grid{grid-template-columns:repeat(4,1fr)}
.ds-csd-gallery--reels .ds-csd-shot figcaption{font-size:12.5px;padding:11px 14px;text-align:center}
.ds-csd-gallery--wide .ds-csd-gallery__grid{grid-template-columns:1fr;max-width:940px;margin:0 auto;gap:26px}
/* case study — 'what didn't work' lessons */
.ds-csd-lessons{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ds-csd-lesson{background:#fff;border:1px solid var(--line);border-left:4px solid var(--coral);border-radius:14px;padding:24px 24px 22px;box-shadow:0 22px 50px -40px rgba(0,0,0,.4)}
.ds-csd-lesson h3{font-family:var(--serif);font-weight:700;font-size:17px;color:var(--ink);margin:0 0 8px}
.ds-csd-lesson p{font-size:14px;line-height:1.55;color:var(--text);margin:0}
@media(max-width:760px){.ds-csd-gallery--reels .ds-csd-gallery__grid{grid-template-columns:repeat(2,1fr)}.ds-csd-lessons{grid-template-columns:1fr}}
/* case study — 4-metric results band (clean 4-across on desktop, 2x2 on tablet) */
.ds-csd-results--m4 .ds-csd-metrics{grid-template-columns:repeat(4,1fr)}
@media(max-width:900px){.ds-csd-results--m4 .ds-csd-metrics{grid-template-columns:repeat(2,1fr);gap:30px}}

/* ============================================================
   CONTACT page (blog/about design language)
   ============================================================ */
.ds-ct-hero{padding:30px 0 10px;background:#fff}
.ds-ct-hero h1{font-size:clamp(34px,5.4vw,62px);line-height:1.04;letter-spacing:-.02em;margin:12px 0 18px;max-width:14ch}
.ds-ct-hero h1 em{font-style:italic;color:var(--coral)}
.ds-ct-hero__lead{font-size:clamp(17px,1.7vw,20px);line-height:1.6;color:#3a3a3a;max-width:60ch;margin:0}

.ds-ct-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:48px;align-items:start;margin-top:40px}

/* contact channels (left) */
.ds-ct-aside__h{font-size:13px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#9a9a9a;margin:0 0 16px}
.ds-ct-channels{display:flex;flex-direction:column;gap:13px}
.ds-ct-channel{display:flex;gap:15px;align-items:center;padding:17px 19px;border:1px solid var(--line);border-radius:16px;background:#fff;text-decoration:none;transition:transform .3s var(--ease),border-color .3s,box-shadow .3s}
.ds-ct-channel:hover{border-color:var(--coral);transform:translateX(4px);box-shadow:var(--shadow-sm)}
.ds-ct-channel__ic{flex:0 0 auto;width:46px;height:46px;border-radius:13px;background:var(--tint);color:var(--coral);display:grid;place-items:center}
.ds-ct-channel__ic svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.85;stroke-linecap:round;stroke-linejoin:round}
.ds-ct-channel>span:last-child{display:flex;flex-direction:column;gap:3px;min-width:0}
.ds-ct-channel__label{display:block;font-size:11px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:#9a9a9a}
.ds-ct-channel__val{display:block;font-size:16px;font-weight:600;color:#141414;line-height:1.3}
.ds-ct-social{display:flex;gap:12px;margin-top:22px}
.ds-ct-social a{width:42px;height:42px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;color:#222;transition:.3s var(--ease)}
.ds-ct-social a:hover{background:var(--coral);color:#fff;border-color:var(--coral);transform:translateY(-3px)}
.ds-ct-social a i{font-size:17px}

/* form card (right) */
.ds-ct-form-card{background:#fff;border:1px solid var(--line);border-radius:24px;padding:34px 34px 30px;box-shadow:var(--shadow)}
.ds-ct-form-card__eyebrow{font-size:12px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--coral);margin:0 0 8px}
.ds-ct-form-card__h{font-family:var(--serif);font-weight:700;font-size:clamp(23px,2.6vw,30px);letter-spacing:-.01em;margin:0 0 24px;line-height:1.15}
.ds-ct-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ds-ct-field{display:flex;flex-direction:column;gap:7px;margin-bottom:17px}
.ds-ct-field label{font-size:12.5px;font-weight:700;letter-spacing:.03em;color:#4a4a4a}
.ds-ct-field input,.ds-ct-field select,.ds-ct-field textarea{width:100%;padding:13px 15px;border:1px solid var(--line);border-radius:12px;font-size:15px;font-family:inherit;color:#141414;background:#fff;transition:border-color .25s,box-shadow .25s;-webkit-appearance:none;appearance:none}
.ds-ct-field input::placeholder,.ds-ct-field textarea::placeholder{color:#aaa}
.ds-ct-field input:focus,.ds-ct-field select:focus,.ds-ct-field textarea:focus{outline:none;border-color:var(--coral);box-shadow:0 0 0 4px rgba(239,61,95,.12)}
.ds-ct-field textarea{resize:vertical;min-height:108px;line-height:1.55}
.ds-ct-field select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%23EF3D5F' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;padding-right:42px;cursor:pointer}
.ds-ct-hp{position:absolute!important;left:-9999px!important;width:1px!important;height:1px!important;opacity:0!important;pointer-events:none}
.ds-ct-submit{margin-top:6px;width:100%;justify-content:center}
.ds-ct-submit[disabled]{opacity:.6;cursor:wait}
.ds-ct-formnote{font-size:13px;color:#8a8a8a;text-align:center;margin:14px 0 0}
.ds-ct-err{background:#fff0f3;border:1px solid #f3c2cd;color:#b3203c;font-size:14px;font-weight:600;border-radius:12px;padding:12px 16px;margin:0 0 16px}
.ds-ct-success{text-align:center;padding:46px 32px;border:1px solid #f1d0d8;border-radius:24px;background:linear-gradient(180deg,#fff,#fff6f8);box-shadow:0 30px 70px -44px rgba(239,61,95,.6)}
.ds-ct-success__ic{width:66px;height:66px;border-radius:50%;background:var(--coral);color:#fff;display:grid;place-items:center;margin:0 auto 18px;box-shadow:0 16px 40px -16px rgba(239,61,95,.8)}
.ds-ct-success__ic svg{width:32px;height:32px;fill:none;stroke:currentColor;stroke-width:2.6;stroke-linecap:round;stroke-linejoin:round}
.ds-ct-success h3{font-size:26px;margin:0 0 10px}
.ds-ct-success p{font-size:16px;color:#555;margin:0 auto;max-width:46ch}

/* offices */
.ds-ct-offices{display:grid;grid-template-columns:1fr 1fr;gap:26px;margin-top:34px}
.ds-ct-office{border:1px solid var(--line);border-radius:20px;overflow:hidden;background:#fff;box-shadow:var(--shadow-sm);transition:transform .35s var(--ease),box-shadow .35s}
.ds-ct-office:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.ds-ct-office__map{aspect-ratio:16/8;background:var(--tint);overflow:hidden}
.ds-ct-office__map iframe{width:100%;height:100%;border:0;display:block;filter:grayscale(.25) contrast(1.02)}
.ds-ct-office__body{padding:22px 24px 24px}
.ds-ct-office__city{font-family:var(--serif);font-weight:700;font-size:21px;margin:0 0 6px;display:flex;align-items:center;gap:9px}
.ds-ct-office__city svg{width:18px;height:18px;fill:none;stroke:var(--coral);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ds-ct-office__addr{font-size:15px;line-height:1.6;color:#555;margin:0 0 14px}
.ds-ct-office__dir{display:inline-flex;align-items:center;gap:7px;font-size:14px;font-weight:700;color:var(--coral);text-decoration:none}
.ds-ct-office__dir svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:transform .3s}
.ds-ct-office__dir:hover svg{transform:translateX(4px)}

@media(max-width:900px){.ds-ct-grid{grid-template-columns:1fr;gap:34px}.ds-ct-offices{grid-template-columns:1fr}}
@media(max-width:560px){.ds-ct-row{grid-template-columns:1fr}.ds-ct-form-card{padding:26px 22px 24px}}

/* ============================================================
   HOME — custom landing page (replaces Elementor front page)
   ============================================================ */
.ds-hm-hero{padding:46px 0 16px;background:#fff;position:relative;overflow:hidden}
.ds-hm-hero__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:54px;align-items:center}
.ds-hm-hero h1{font-size:clamp(36px,5.6vw,66px);line-height:1.03;letter-spacing:-.022em;margin:14px 0 20px}
.ds-hm-hero h1 em{font-style:italic;color:var(--coral)}
.ds-hm-hero__sub{font-size:clamp(17px,1.7vw,20px);line-height:1.6;color:#3a3a3a;max-width:50ch;margin:0 0 28px}
.ds-hm-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.ds-hm-hero__media{position:relative;aspect-ratio:4/5;border-radius:24px;overflow:hidden;box-shadow:var(--shadow);background:var(--tint)}
.ds-hm-hero__media img{width:100%;height:100%;object-fit:cover}
.ds-hm-hero__badge{position:absolute;left:18px;bottom:18px;background:rgba(11,11,11,.78);backdrop-filter:blur(6px);color:#fff;border-radius:14px;padding:12px 18px;font-size:13px;font-weight:600;letter-spacing:.02em}
.ds-hm-hero__badge b{color:#ff9bad}

/* stats strip (dark rounded, count-up) */
.ds-hm-stats{display:grid;grid-template-columns:repeat(5,1fr);gap:18px;background:#0b0b0b;border-radius:24px;padding:40px 34px;margin:42px 0 0;text-align:center}
.ds-hm-stat{position:relative}
.ds-hm-stat+.ds-hm-stat::before{content:"";position:absolute;left:-9px;top:16%;height:68%;width:1px;background:rgba(255,255,255,.12)}
.ds-hm-stat__num{font-family:var(--serif);font-weight:700;font-size:clamp(30px,3.4vw,48px);line-height:1;letter-spacing:-.01em;color:#fff}
.ds-hm-stat__label{font-size:11px;font-weight:700;letter-spacing:.11em;text-transform:uppercase;color:#ff9bad;margin:11px 0 0}

/* mission */
.ds-hm-mission{display:grid;grid-template-columns:1fr 1fr;gap:50px;align-items:center}
.ds-hm-mission h2{font-size:clamp(28px,3.6vw,44px);line-height:1.1;letter-spacing:-.018em;margin:10px 0 0}
.ds-hm-mission h2 em{font-style:italic;color:var(--coral)}
.ds-hm-mission__body p{font-size:17px;line-height:1.8;color:#4a4a4a;margin:0 0 18px}

/* clients logo strip (below Why DESENO) */
.ds-hm-clients-sec{padding:46px 0 50px;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.ds-hm-clients__label{text-align:center;font-size:12.5px;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:#9a9a9a;margin:0 0 28px}
.ds-hm-clients{overflow:hidden;-webkit-mask:linear-gradient(90deg,transparent,#000 3.5%,#000 96.5%,transparent);mask:linear-gradient(90deg,transparent,#000 3.5%,#000 96.5%,transparent)}
.ds-hm-clients__track{display:flex;align-items:center;gap:26px;width:max-content;animation:ds-marquee 55s linear infinite}
.ds-hm-clients:hover .ds-hm-clients__track{animation-play-state:paused}
.ds-hm-clients__logo{flex:none;height:110px;width:auto;opacity:.9;transition:opacity .3s var(--ease),transform .3s var(--ease)}
.ds-hm-clients__logo:hover{opacity:1;transform:scale(1.05)}
@keyframes ds-marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(prefers-reduced-motion:reduce){.ds-hm-clients__track{animation:none;flex-wrap:wrap;justify-content:center;width:auto;gap:30px}}
@media(max-width:680px){.ds-hm-clients__track{gap:14px}.ds-hm-clients__logo{height:84px}}

/* section heading helper */
.ds-hm-head{max-width:680px;margin:0 0 8px}
.ds-hm-head h2{font-size:clamp(28px,3.8vw,46px);line-height:1.08;letter-spacing:-.02em;margin:8px 0 12px}
.ds-hm-head h2 em{font-style:italic;color:var(--coral)}
.ds-hm-head p{font-size:17px;line-height:1.7;color:#555;margin:0;max-width:60ch}

/* featured work — full-width 4-up portfolio strip (edge to edge) */
.ds-hm-fwork{padding:62px 0 0}
.ds-hm-fwrow{display:grid;grid-template-columns:repeat(4,1fr);width:100%;margin-top:40px}
.ds-hm-fwc{position:relative;aspect-ratio:4/5;overflow:hidden;display:block;text-decoration:none;background:#0b0b0b}
.ds-hm-fwc img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .7s var(--ease)}
.ds-hm-fwc:hover img{transform:scale(1.08)}
.ds-hm-fwc::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(11,11,11,.05) 18%,rgba(11,11,11,.88));transition:background .4s}
.ds-hm-fwc:hover::after{background:linear-gradient(180deg,rgba(11,11,11,.28) 6%,rgba(11,11,11,.93))}
.ds-hm-fwc__c{position:absolute;left:0;right:0;bottom:0;z-index:2;padding:30px 28px;color:#fff}
.ds-hm-fwc__tag{font-size:11px;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:#ff9bad;margin:0 0 10px}
.ds-hm-fwc__t{font-family:var(--serif);font-weight:700;font-size:23px;line-height:1.16;margin:0;color:#fff;text-shadow:0 1px 16px rgba(0,0,0,.45)}
.ds-hm-fwc__d{font-size:14px;line-height:1.55;color:rgba(255,255,255,.85);overflow:hidden;max-height:0;opacity:0;margin:0;transition:max-height .45s var(--ease),opacity .4s,margin .45s}
.ds-hm-fwc:hover .ds-hm-fwc__d{max-height:120px;opacity:1;margin-top:10px}
.ds-hm-fwc__cta{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700;color:#fff;overflow:hidden;max-height:0;opacity:0;margin:0;transition:max-height .45s var(--ease),opacity .4s,margin .45s}
.ds-hm-fwc:hover .ds-hm-fwc__cta{max-height:30px;opacity:1;margin-top:15px}
.ds-hm-fwc__cta svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2}

/* services grid */
.ds-hm-svcs{display:grid;grid-template-columns:repeat(2,1fr);gap:22px;margin-top:44px}
.ds-hm-svc{position:relative;overflow:hidden;display:flex;gap:24px;align-items:center;background:#0b0b0b;border:1px solid rgba(255,255,255,.08);border-radius:22px;padding:24px 30px;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.ds-hm-svc::before{content:"";position:absolute;width:460px;height:460px;left:var(--mx,26%);top:var(--my,50%);transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(239,61,95,.24),transparent 60%);opacity:0;transition:opacity .35s;pointer-events:none}
.ds-hm-svc:hover{transform:translateY(-6px);box-shadow:0 30px 62px -28px rgba(239,61,95,.5),0 14px 34px -20px rgba(0,0,0,.7);border-color:rgba(239,61,95,.55)}
.ds-hm-svc:hover::before{opacity:1}
.ds-hm-svc__n{position:absolute;top:20px;right:28px;font-family:var(--serif);font-weight:700;font-size:34px;line-height:1;color:var(--coral);opacity:.5}
.ds-hm-svc__ic{position:relative;flex:none;width:108px;height:108px;border-radius:20px;object-fit:cover;background:#f4f1ec;box-shadow:0 14px 30px -14px rgba(0,0,0,.7);transition:transform .5s var(--ease),box-shadow .35s}
.ds-hm-svc:hover .ds-hm-svc__ic{transform:scale(1.05) rotate(-2deg);box-shadow:0 0 0 2px rgba(239,61,95,.55),0 16px 34px -14px rgba(0,0,0,.7)}
.ds-hm-svc__body{position:relative;flex:1;min-width:0}
.ds-hm-svc__t{font-size:21px;font-weight:700;letter-spacing:-.012em;margin:0 0 9px;color:#fff}
.ds-hm-svc__d{font-size:15px;line-height:1.62;color:rgba(255,255,255,.66);margin:0;max-width:42ch}

/* approach steps */
/* approach — zig-zag alternating rows with big 3D icon + giant ghost number */
.ds-hm-steps{position:relative;margin-top:46px;display:flex;flex-direction:column}
.ds-hm-step{position:relative;display:grid;grid-template-columns:1fr 1fr;gap:54px;align-items:center;padding:50px 0}
.ds-hm-step+.ds-hm-step{border-top:1px solid var(--line)}
.ds-hm-step__visual{position:relative;display:grid;place-items:center;min-height:250px}
.ds-hm-step__n{position:absolute;z-index:0;font-family:var(--serif);font-weight:700;font-size:clamp(180px,22vw,300px);line-height:.78;color:var(--coral);opacity:.12;pointer-events:none;user-select:none}
.ds-hm-step__ic{position:relative;z-index:1;width:clamp(184px,19vw,236px);aspect-ratio:1;border-radius:30px;object-fit:cover;background:#f4f1ec;box-shadow:0 28px 56px -24px rgba(0,0,0,.34);transition:transform .5s var(--ease)}
.ds-hm-step:hover .ds-hm-step__ic{transform:translateY(-6px) scale(1.02)}
.ds-hm-step__body{position:relative}
.ds-hm-step__label{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);margin:0 0 14px}
.ds-hm-step__t{font-family:var(--serif);font-weight:700;font-size:clamp(26px,3.3vw,40px);line-height:1.1;letter-spacing:-.018em;margin:0 0 14px}
.ds-hm-step__d{font-size:16px;line-height:1.7;color:#555;margin:0;max-width:46ch}
.ds-hm-step:nth-child(even) .ds-hm-step__visual{order:2}
.ds-hm-step:nth-child(even) .ds-hm-step__body{order:1}
/* staggered scroll reveal (JS-gated; content visible if JS off) */
html.ds-hmjs .ds-hm-fwc,html.ds-hmjs .ds-hm-svc,html.ds-hmjs .ds-hm-step{opacity:0;transform:translateY(32px)}
html.ds-hmjs .ds-hm-fwc.ds-in,html.ds-hmjs .ds-hm-svc.ds-in,html.ds-hmjs .ds-hm-step.ds-in{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}

@media(max-width:960px){
  .ds-hm-hero__grid{grid-template-columns:1fr;gap:30px}
  .ds-hm-hero__media{order:-1;aspect-ratio:16/10;max-height:380px}
  .ds-hm-mission{grid-template-columns:1fr;gap:22px}
  .ds-hm-svcs{grid-template-columns:1fr}
  .ds-hm-fwrow{grid-template-columns:repeat(2,1fr)}
  .ds-hm-step{grid-template-columns:1fr;gap:18px;padding:34px 0;text-align:center}
  .ds-hm-step:nth-child(even) .ds-hm-step__visual,.ds-hm-step:nth-child(even) .ds-hm-step__body{order:0}
  .ds-hm-step__visual{min-height:160px}
  .ds-hm-step__ic{width:150px}
  .ds-hm-step__n{font-size:120px}
  .ds-hm-step__d{margin-left:auto;margin-right:auto}
  .ds-hm-stats{grid-template-columns:repeat(2,1fr);gap:26px 18px;padding:34px 24px}
  .ds-hm-stat:nth-child(2)::before{display:none}
}
@media(max-width:600px){
  /* hero badge: centered + smaller */
  .ds-hm-hero__badge{left:50%;right:auto;transform:translateX(-50%);bottom:14px;padding:8px 14px;font-size:11px;white-space:nowrap}
  /* featured work: one card per row, content revealed (no hover on touch) */
  .ds-hm-fwrow{grid-template-columns:1fr}
  .ds-hm-fwc{aspect-ratio:4/5}
  .ds-hm-fwc::after{background:linear-gradient(180deg,rgba(11,11,11,.05) 0%,rgba(11,11,11,.5) 46%,rgba(11,11,11,.93))}
  .ds-hm-fwc__d{max-height:140px;opacity:1;margin-top:8px}
  .ds-hm-fwc__cta{max-height:30px;opacity:1;margin-top:12px}
  .ds-hm-svcs{grid-template-columns:1fr}
  .ds-hm-svc{flex-direction:column;gap:16px;padding:28px 24px}
  .ds-hm-svc__n{font-size:30px;top:20px;right:22px}
  .ds-hm-stats{grid-template-columns:1fr;gap:24px}
  .ds-hm-stat+.ds-hm-stat::before{display:none}
  .ds-hm-hero__cta .ds-btn{width:100%;justify-content:center}
  /* CTA card button: centered instead of stretched-left */
  .ds-news__inner .ds-btn{align-self:center}
}

/* ============================================================
   SERVICES page — cinematic dark, sticky split-scroll chapters
   ============================================================ */
.ds-sv{background:#0a0a0a}
.ds-sv-hero{position:relative;overflow:hidden;background:#0a0a0a;color:#fff;padding:96px 0 84px;text-align:center}
.ds-sv-hero__glow{position:absolute;top:-26%;left:50%;transform:translateX(-50%);width:min(960px,120vw);height:640px;background:radial-gradient(ellipse at center,rgba(239,61,95,.30),transparent 64%);pointer-events:none}
.ds-sv-hero__in{position:relative;z-index:1;max-width:940px;margin:0 auto}
.ds-sv-hero .ds-eyebrow{color:#ff9bad}
.ds-sv-hero h1{font-size:clamp(42px,6.6vw,86px);line-height:1.01;letter-spacing:-.025em;color:#fff;margin:16px 0 22px}
.ds-sv-hero h1 em{font-style:italic;color:var(--coral)}
.ds-sv-hero__sub{font-size:clamp(17px,1.8vw,20px);line-height:1.6;color:rgba(255,255,255,.66);max-width:62ch;margin:0 auto 34px}
.ds-sv-hero__stats{display:inline-flex;align-items:center;flex-wrap:wrap;justify-content:center}
.ds-sv-hero__stat{padding:0 34px;position:relative}
.ds-sv-hero__stat+.ds-sv-hero__stat::before{content:"";position:absolute;left:0;top:12%;height:76%;width:1px;background:rgba(255,255,255,.16)}
.ds-sv-hero__stat b{display:block;font-family:var(--serif);font-weight:700;font-size:clamp(28px,3.4vw,40px);color:#fff;line-height:1}
.ds-sv-hero__stat span{display:block;margin-top:8px;font-size:11.5px;font-weight:700;letter-spacing:.14em;text-transform:uppercase;color:#ff9bad}

.ds-sv-cat{position:relative;background:#0a0a0a;border-top:1px solid rgba(255,255,255,.09)}
.ds-sv-cat__grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:64px;align-items:start;padding:90px 0}
.ds-sv-cat__left{position:sticky;top:108px;align-self:start}
.ds-sv-cat__n{font-family:var(--serif);font-weight:700;font-size:clamp(38px,3.6vw,52px);line-height:1;color:var(--coral);display:block;margin:0 0 12px}
.ds-sv-cat__title{font-family:var(--serif);font-weight:700;font-size:clamp(32px,4.2vw,56px);line-height:1.03;letter-spacing:-.02em;color:#fff;margin:0 0 16px}
.ds-sv-cat__tag{font-size:16px;line-height:1.6;color:rgba(255,255,255,.6);margin:0 0 26px;max-width:32ch}
.ds-sv-cat__right{min-width:0}
.ds-sv-cat__visual{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:16/11;margin:0 0 6px;box-shadow:0 50px 100px -50px rgba(239,61,95,.5)}
.ds-sv-cat__visual img{width:100%;height:100%;object-fit:cover;display:block}
.ds-sv-list{list-style:none;margin:0;padding:0}
.ds-sv-svc{position:relative;display:flex;align-items:center;gap:22px;padding:26px 10px;border-bottom:1px solid rgba(255,255,255,.1);transition:padding .35s var(--ease),background .35s}
.ds-sv-svc:hover{padding-left:24px;background:linear-gradient(90deg,rgba(239,61,95,.1),transparent 70%)}
.ds-sv-svc__i{flex:none;width:30px;font-size:13px;font-weight:700;letter-spacing:.04em;color:rgba(255,255,255,.38);transition:color .35s}
.ds-sv-svc__name{flex:1;font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.5vw,31px);letter-spacing:-.012em;color:#fff;transition:color .35s}
.ds-sv-svc__arrow{flex:none;width:26px;height:26px;color:var(--coral);opacity:0;transform:translateX(-10px);transition:opacity .35s var(--ease),transform .35s var(--ease)}
.ds-sv-svc__arrow svg{width:100%;height:100%;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.ds-sv-svc:hover .ds-sv-svc__i{color:var(--coral)}
.ds-sv-svc:hover .ds-sv-svc__name{color:var(--coral)}
.ds-sv-svc:hover .ds-sv-svc__arrow{opacity:1;transform:none}
.ds-sv-cta{background:#0a0a0a;padding:64px 0;border-top:1px solid rgba(255,255,255,.09)}
@media(max-width:900px){
  .ds-sv-hero{padding:62px 0 56px}
  .ds-sv-cat__grid{grid-template-columns:1fr;gap:26px;padding:54px 0}
  .ds-sv-cat__left{position:static}
  .ds-sv-cat__visual{aspect-ratio:16/10}
  .ds-sv-hero__stat{padding:0 20px}
}

/* ============================================================
   WORK CULTURE PAGE (page 1256) — .ds-wc-*  (black + coral + white)
   ============================================================ */
.ds-wc{--wc-dark:#0a0a0a}

/* HERO — full-bleed real team photo (black studio + coral light streak) */
.ds-wc-hero{position:relative;min-height:clamp(580px,92vh,900px);display:flex;align-items:flex-end;
  padding-top:clamp(120px,15vh,178px);
  background:#0a0a0a;background-size:cover;background-position:center right;background-repeat:no-repeat;color:#fff;overflow:hidden}
.ds-wc-hero::before{content:"";position:absolute;inset:0;pointer-events:none;
  background:linear-gradient(101deg,rgba(7,7,9,.95) 0%,rgba(7,7,9,.86) 26%,rgba(7,7,9,.5) 52%,rgba(7,7,9,.14) 76%,rgba(7,7,9,0) 100%),linear-gradient(0deg,rgba(7,7,9,.92) 0%,rgba(7,7,9,.2) 32%,transparent 58%)}
.ds-wc-hero__in{position:relative;z-index:2;width:100%;padding-bottom:clamp(56px,7vw,104px)}
.ds-wc-hero__copy{max-width:700px}
.ds-wc-hero .ds-eyebrow{color:#ff9bad}
.ds-wc-hero h1{font-size:clamp(46px,7.4vw,96px);line-height:.98;letter-spacing:-.03em;color:#fff;margin:14px 0 22px;max-width:15ch}
.ds-wc-hero h1 em{font-style:italic;color:var(--coral)}
.ds-wc-hero__sub{font-size:clamp(17px,1.9vw,21px);line-height:1.62;color:rgba(255,255,255,.8);max-width:52ch;margin:0 0 32px}
.ds-wc-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.ds-wc-ghost{background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.34);color:#fff}
.ds-wc-ghost:hover{background:rgba(255,255,255,.16);border-color:#fff;transform:translateY(-2px)}
.ds-wc-hero__scroll{position:absolute;left:0;right:0;bottom:18px;z-index:2;text-align:center;font-size:10.5px;font-weight:700;letter-spacing:.22em;text-transform:uppercase;color:rgba(255,255,255,.5)}
.ds-wc-hero__scroll i{display:block;width:1px;height:34px;margin:9px auto 0;background:linear-gradient(rgba(255,255,255,.7),transparent);animation:ds-wcdrop 1.9s var(--ease) infinite}
@keyframes ds-wcdrop{0%{transform:scaleY(.25);transform-origin:top;opacity:0}45%{opacity:1}100%{transform:scaleY(1);transform-origin:top;opacity:0}}

/* INTRO / manifesto + stats */
.ds-wc-intro{padding:clamp(64px,8vw,112px) 0 clamp(20px,3vw,34px)}
.ds-wc-intro__grid{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(28px,5vw,76px);align-items:start}
.ds-wc-intro__big{font-family:var(--serif);font-weight:700;font-size:clamp(30px,4.4vw,56px);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin:10px 0 0}
.ds-wc-intro__big em{font-style:italic;color:var(--coral)}
.ds-wc-intro__body p{font-size:clamp(16px,1.2vw,18px);line-height:1.86;color:#4a4a4a;margin:0 0 18px}
.ds-wc-intro__body p:last-child{margin-bottom:0}
.ds-wc-stats{grid-template-columns:repeat(4,1fr);margin-top:clamp(40px,5vw,60px)}
.ds-wc-stats__cap{text-align:center;font-size:11.5px;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin:18px 0 0}

/* CULTURE VALUES */
.ds-wc-vals{background:var(--tint);padding:clamp(64px,8vw,110px) 0}
.ds-wc-vals__head{max-width:760px;margin:0 0 clamp(34px,5vw,56px)}
.ds-wc-vals__head h2{font-size:clamp(30px,4.6vw,54px);line-height:1.05;letter-spacing:-.02em;margin:10px 0 14px}
.ds-wc-vals__head h2 em{font-style:italic;color:var(--coral)}
.ds-wc-vals__head p{font-size:clamp(16px,1.3vw,18px);line-height:1.7;color:var(--text);margin:0;max-width:60ch}
.ds-wc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ds-wc-val{position:relative;overflow:hidden;background:#fff;border:1px solid var(--line);border-radius:22px;padding:32px 30px 34px;transition:transform .42s var(--ease),box-shadow .42s,border-color .42s}
.ds-wc-val::before{content:"";position:absolute;width:440px;height:440px;left:var(--mx,30%);top:var(--my,0%);transform:translate(-50%,-50%);background:radial-gradient(circle,rgba(239,61,95,.13),transparent 60%);opacity:0;transition:opacity .42s;pointer-events:none}
.ds-wc-val:hover{transform:translateY(-7px);box-shadow:0 34px 70px -34px rgba(17,17,17,.3);border-color:rgba(239,61,95,.4)}
.ds-wc-val:hover::before{opacity:1}
.ds-wc-val__ic{position:relative;width:92px;height:92px;border-radius:20px;object-fit:cover;background:#f4f1ec;box-shadow:0 16px 34px -18px rgba(0,0,0,.32);transition:transform .55s var(--ease)}
.ds-wc-val:hover .ds-wc-val__ic{transform:scale(1.06) rotate(-3deg)}
.ds-wc-val__tx{position:relative}
.ds-wc-val__t{font-size:21px;font-weight:700;letter-spacing:-.012em;margin:22px 0 9px;color:var(--ink)}
.ds-wc-val__d{font-size:14.5px;line-height:1.66;color:var(--text);margin:0}
.ds-wc-val--feat{grid-column:span 2;display:flex;align-items:center;gap:30px}
.ds-wc-val--feat .ds-wc-val__ic{width:124px;height:124px;flex:none}
.ds-wc-val--feat .ds-wc-val__t{margin-top:0;font-size:26px}
.ds-wc-val--feat .ds-wc-val__d{font-size:15.5px;max-width:46ch}

/* LIFE AT DESENO — bento gallery */
.ds-wc-life{padding:clamp(64px,8vw,110px) 0}
.ds-wc-life__head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;flex-wrap:wrap;margin:0 0 clamp(28px,4vw,42px)}
.ds-wc-life__head h2{font-size:clamp(30px,4.6vw,54px);line-height:1.04;letter-spacing:-.02em;margin:10px 0 0}
.ds-wc-life__head h2 em{font-style:italic;color:var(--coral)}
.ds-wc-life__head p{font-size:15.5px;color:var(--text);margin:0;max-width:40ch}
.ds-wc-bento{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:clamp(146px,16.5vw,208px);gap:16px}
.ds-wc-tile{position:relative;overflow:hidden;border-radius:20px;background:#0a0a0a}
.ds-wc-tile img{width:100%;height:100%;object-fit:cover;transition:transform .85s var(--ease)}
.ds-wc-tile:hover img{transform:scale(1.07)}
.ds-wc-tile::after{content:"";position:absolute;inset:0;background:linear-gradient(0deg,rgba(0,0,0,.55),transparent 46%);opacity:.0;transition:opacity .45s}
.ds-wc-tile:hover::after{opacity:1}
.ds-wc-tile__cap{position:absolute;left:18px;bottom:15px;z-index:1;color:#fff;font-size:13px;font-weight:600;letter-spacing:.01em;opacity:0;transform:translateY(9px);transition:opacity .45s var(--ease),transform .45s var(--ease)}
.ds-wc-tile:hover .ds-wc-tile__cap{opacity:1;transform:none}
.ds-wc-tile--big{grid-column:span 2;grid-row:span 2}
.ds-wc-tile--wide{grid-column:span 2}

/* AIMS + ethics (dark band) */
.ds-wc-aims{position:relative;overflow:hidden;background:var(--wc-dark);color:#fff;padding:clamp(64px,8vw,112px) 0}
.ds-wc-aims__glow{position:absolute;top:-30%;right:-6%;width:min(680px,80vw);height:560px;background:radial-gradient(ellipse at center,rgba(239,61,95,.22),transparent 64%);pointer-events:none}
.ds-wc-aims__top{position:relative;max-width:760px}
.ds-wc-aims__quote{font-family:var(--serif);font-weight:500;font-style:italic;font-size:clamp(24px,3.5vw,44px);line-height:1.2;letter-spacing:-.012em;color:#fff;margin:14px 0 0}
.ds-wc-aims__quote em{color:var(--coral);font-style:italic}
.ds-wc-aims__grid{position:relative;display:grid;grid-template-columns:repeat(4,1fr);gap:26px;margin-top:clamp(42px,5vw,64px);border-top:1px solid rgba(255,255,255,.13);padding-top:clamp(34px,4vw,48px)}
.ds-wc-aim__n{font-family:var(--serif);font-weight:700;color:var(--coral);font-size:30px;line-height:1}
.ds-wc-aim__t{font-size:18px;font-weight:700;color:#fff;margin:12px 0 8px;letter-spacing:-.01em}
.ds-wc-aim__d{font-size:14px;line-height:1.6;color:rgba(255,255,255,.62);margin:0}
.ds-wc-ethics{position:relative;display:flex;align-items:flex-start;gap:13px;margin-top:clamp(36px,4vw,52px);padding-top:clamp(28px,3vw,38px);border-top:1px solid rgba(255,255,255,.13);max-width:80ch}
.ds-wc-ethics b{display:inline-block;flex:none;width:9px;height:9px;border-radius:50%;background:var(--coral);margin-top:8px;box-shadow:0 0 0 6px rgba(239,61,95,.18)}
.ds-wc-ethics p{font-size:14.5px;line-height:1.7;color:rgba(255,255,255,.66);margin:0}
.ds-wc-ethics strong{color:#fff;font-weight:700}

/* JOIN / CTA */
.ds-wc-join{padding:clamp(20px,3vw,30px) 0 clamp(72px,9vw,120px)}
.ds-wc-join__card{position:relative;overflow:hidden;background:#0a0a0a;border-radius:30px;padding:clamp(42px,6vw,86px) clamp(24px,5vw,72px);text-align:center;color:#fff}
.ds-wc-join__glow{position:absolute;left:50%;top:-40%;transform:translateX(-50%);width:min(900px,120%);height:620px;background:radial-gradient(ellipse at center,rgba(239,61,95,.28),transparent 62%);pointer-events:none}
.ds-wc-join__in{position:relative;z-index:1;max-width:760px;margin:0 auto}
.ds-wc-join .ds-eyebrow{color:#ff9bad}
.ds-wc-join h2{font-size:clamp(30px,4.8vw,58px);line-height:1.04;letter-spacing:-.02em;color:#fff;margin:10px 0 16px}
.ds-wc-join h2 em{font-style:italic;color:var(--coral)}
.ds-wc-join__sub{font-size:clamp(16px,1.6vw,19px);line-height:1.6;color:rgba(255,255,255,.74);max-width:56ch;margin:0 auto 30px}
.ds-wc-join__chips{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 0 34px}
.ds-wc-chip{border:1px solid rgba(255,255,255,.22);border-radius:999px;padding:9px 18px;font-size:13.5px;font-weight:600;color:rgba(255,255,255,.86);transition:border-color .3s,color .3s,background .3s}
.ds-wc-chip:hover{border-color:var(--coral);color:#fff;background:rgba(239,61,95,.14)}
.ds-wc-join__cta{display:flex;gap:14px;justify-content:center;flex-wrap:wrap}
.ds-wc-join__note{margin:24px 0 0;font-size:14px;color:rgba(255,255,255,.52)}
.ds-wc-join__note a{color:#ff9bad;text-decoration:underline;text-underline-offset:3px}

/* scroll-reveal stagger (gated so content stays visible if JS fails) */
html.ds-wcjs .ds-wc-val,html.ds-wcjs .ds-wc-tile,html.ds-wcjs .ds-wc-aim{opacity:0;transform:translateY(26px)}
html.ds-wcjs .ds-wc-val.ds-in,html.ds-wcjs .ds-wc-tile.ds-in,html.ds-wcjs .ds-wc-aim.ds-in{opacity:1;transform:none;transition:opacity .6s var(--ease),transform .6s var(--ease)}

@media(max-width:960px){
  .ds-wc-intro__grid{grid-template-columns:1fr;gap:22px}
  .ds-wc-grid{grid-template-columns:repeat(2,1fr)}
  .ds-wc-val--feat{grid-column:span 2}
  .ds-wc-stats{grid-template-columns:repeat(2,1fr);gap:26px 18px}
  .ds-wc-aims__grid{grid-template-columns:repeat(2,1fr);gap:30px 24px}
}
@media(max-width:760px){
  .ds-wc-hero{background-position:68% center;min-height:clamp(500px,80vh,680px);padding-top:clamp(92px,12vh,128px)}
  .ds-wc-hero h1{font-size:clamp(40px,10vw,58px)}
  .ds-wc-bento{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(132px,40vw,180px)}
  .ds-wc-tile--big{grid-column:span 2;grid-row:span 2}
  .ds-wc-tile--wide{grid-column:span 2}
}
@media(max-width:560px){
  .ds-wc-grid{grid-template-columns:1fr}
  .ds-wc-val--feat{grid-column:span 1;flex-direction:column;align-items:flex-start;gap:16px}
  .ds-wc-val--feat .ds-wc-val__t{margin-top:18px}
  .ds-wc-stats{grid-template-columns:1fr;gap:22px}
  .ds-wc-aims__grid{grid-template-columns:1fr}
}

/* ============================================================
   DESKTOP NAV — hover dropdown for "Our Work" categories.
   On our custom template_redirect pages Elementor's frontend JS isn't loaded,
   so the header submenu never opens. Drive it with pure CSS on hover. Auto-scoped:
   deseno-blog.css is embedded ONLY on custom pages, and the rules target the
   desktop main nav (hidden on mobile), so they have no effect elsewhere.
   ============================================================ */
@media(min-width:1025px){
  header.elementor-location-header{position:relative;z-index:9999}
  nav.elementor-nav-menu--main ul.elementor-nav-menu>li.menu-item-has-children{position:relative}
  nav.elementor-nav-menu--main li.menu-item-has-children>ul.sub-menu{
    display:block!important;position:absolute!important;top:100%!important;left:0!important;margin:0;padding:10px 0;
    min-width:238px;list-style:none;background:#fff;border:1px solid var(--line);border-radius:14px;
    box-shadow:0 26px 54px -22px rgba(0,0,0,.28),0 10px 24px -12px rgba(239,61,95,.25);
    opacity:0;visibility:hidden;transform:translateY(10px);pointer-events:none;
    transition:opacity .22s var(--ease),transform .22s var(--ease),visibility .22s;z-index:9999}
  nav.elementor-nav-menu--main li.menu-item-has-children>ul.sub-menu::before{content:"";position:absolute;top:-14px;left:0;right:0;height:14px}
  nav.elementor-nav-menu--main li.menu-item-has-children:hover>ul.sub-menu{opacity:1;visibility:visible;transform:none;pointer-events:auto}
  nav.elementor-nav-menu--main li.menu-item-has-children>ul.sub-menu li{display:block;margin:0;width:100%;float:none}
  nav.elementor-nav-menu--main li.menu-item-has-children>ul.sub-menu .elementor-sub-item{
    display:block;padding:9px 22px;white-space:nowrap;font-family:var(--sans);font-size:14.5px;font-weight:500;color:#3a3a3a;line-height:1.3;transition:color .2s,background .2s}
  nav.elementor-nav-menu--main li.menu-item-has-children>ul.sub-menu .elementor-sub-item:hover{color:var(--coral);background:#fff5f7}
}

/* ============================================================
   LEGAL / POLICY PAGES — .ds-legal-*  (privacy, refund, terms)
   Clean document layout: dark header + sticky TOC + readable body. No CTA.
   ============================================================ */
.ds-legal-hero{position:relative;overflow:hidden;background:#0b0b0b;color:#fff;padding:clamp(54px,7vw,92px) 0 clamp(38px,5vw,56px)}
.ds-legal-hero__glow{position:absolute;top:-44%;left:50%;transform:translateX(-50%);width:min(760px,92vw);height:520px;background:radial-gradient(ellipse at center,rgba(239,61,95,.20),transparent 64%);pointer-events:none}
.ds-legal-hero__in{position:relative;z-index:1;max-width:820px}
.ds-legal-hero .ds-eyebrow{color:#ff9bad}
.ds-legal-hero h1{font-size:clamp(34px,5.4vw,60px);line-height:1.04;letter-spacing:-.022em;color:#fff;margin:14px 0 18px}
.ds-legal-hero__meta{display:flex;flex-wrap:wrap;gap:6px 22px;font-size:13.5px;color:rgba(255,255,255,.62)}
.ds-legal-hero__meta b{color:#fff;font-weight:600}
.ds-legal-hero__meta span{display:inline-flex;align-items:center;gap:8px}
.ds-legal-hero__meta span+span::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--coral);margin-right:14px;margin-left:-8px}

.ds-legal{background:#fff;padding:clamp(46px,6vw,76px) 0 clamp(56px,8vw,100px)}
.ds-legal__grid{display:grid;grid-template-columns:236px 1fr;gap:clamp(34px,5vw,76px);align-items:start}
.ds-legal__toc{position:sticky;top:108px;align-self:start}
.ds-legal__toc-label{font-size:11.5px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin:0 0 14px}
.ds-legal__toc ol{list-style:none;margin:0;padding:0;counter-reset:dstoc}
.ds-legal__toc li{counter-increment:dstoc;margin:0}
.ds-legal__toc a{display:block;position:relative;padding:8px 0 8px 40px;font-size:13.5px;line-height:1.4;color:var(--text);border-left:2px solid var(--line);transition:color .2s,border-color .2s,background .2s}
.ds-legal__toc a::before{content:counter(dstoc,decimal-leading-zero);position:absolute;left:14px;top:8px;font-size:11px;font-weight:700;color:var(--muted);transition:color .2s}
.ds-legal__toc a:hover{color:var(--ink)}
.ds-legal__toc a.is-active{color:var(--coral);border-color:var(--coral);font-weight:600}
.ds-legal__toc a.is-active::before{color:var(--coral)}
.ds-legal__body{max-width:74ch;min-width:0}
.ds-legal__body>*:first-child{margin-top:0}
.ds-legal__body h2{font-family:var(--serif);font-weight:700;font-size:clamp(22px,2.6vw,31px);line-height:1.18;letter-spacing:-.012em;color:var(--ink);margin:46px 0 14px;scroll-margin-top:100px}
.ds-legal__body h2::after{content:"";display:block;width:42px;height:3px;border-radius:2px;background:var(--coral);margin:14px 0 0}
.ds-legal__body h3{font-size:17.5px;font-weight:700;letter-spacing:-.005em;color:var(--ink);margin:28px 0 10px}
.ds-legal__body p{font-size:16px;line-height:1.8;color:#444;margin:0 0 16px}
.ds-legal__body ul,.ds-legal__body ol{margin:0 0 18px;padding-left:4px;list-style:none}
.ds-legal__body li{position:relative;font-size:16px;line-height:1.72;color:#444;margin:0 0 9px;padding-left:26px}
.ds-legal__body li::before{content:"";position:absolute;left:4px;top:11px;width:7px;height:7px;border-radius:2px;background:var(--coral);opacity:.8}
.ds-legal__body ol{counter-reset:dsol}
.ds-legal__body ol>li{counter-increment:dsol}
.ds-legal__body ol>li::before{content:counter(dsol);top:0;left:0;width:auto;height:auto;background:none;border-radius:0;color:var(--coral);font-weight:700;font-size:14px}
.ds-legal__body a{color:var(--coral);text-decoration:underline;text-underline-offset:2px;word-break:break-word}
.ds-legal__body a:hover{color:var(--coral-700)}
.ds-legal__body strong{color:var(--ink);font-weight:700}
.ds-legal__body figure,.ds-legal__body img{max-width:100%}
.ds-legal__updated{margin-top:46px;padding-top:22px;border-top:1px solid var(--line);font-size:13.5px;color:var(--muted)}

/* mobile: TOC becomes a compact box at the top */
@media(max-width:900px){
  .ds-legal__grid{grid-template-columns:1fr;gap:26px}
  .ds-legal__toc{position:static;background:var(--tint);border:1px solid var(--line);border-radius:16px;padding:20px 22px}
  .ds-legal__toc ol{columns:2;column-gap:18px}
  .ds-legal__toc a{padding:6px 0 6px 34px;border-left:0}
  .ds-legal__toc a.is-active{border-color:transparent}
}
@media(max-width:560px){ .ds-legal__toc ol{columns:1} }
@media print{
  .ds-site-header,.ds-legal__toc,footer,.elementor-location-footer{display:none!important}
  .ds-legal-hero{background:#fff!important;color:#000!important;padding:0 0 18px}
  .ds-legal-hero h1{color:#000!important}.ds-legal-hero .ds-eyebrow{color:#000!important}.ds-legal-hero__meta{color:#333!important}
  .ds-legal__body p,.ds-legal__body li{color:#000}
}

/* ============================================================
   CAREERS PAGE — .ds-cr-*  (hero reuses .ds-wc-hero)
   ============================================================ */
.ds-cr-sec{padding:clamp(58px,8vw,98px) 0}
.ds-cr-sec--tint{background:var(--tint)}
.ds-cr-head{max-width:740px;margin:0 0 clamp(30px,4vw,46px)}
.ds-cr-head h2{font-size:clamp(30px,4.4vw,52px);line-height:1.05;letter-spacing:-.02em;margin:10px 0 12px}
.ds-cr-head h2 em{font-style:italic;color:var(--coral)}
.ds-cr-head p{font-size:clamp(16px,1.3vw,18px);line-height:1.7;color:var(--text);margin:0;max-width:62ch}

/* perks zig-zag */
.ds-cr-perks{display:flex;flex-direction:column;gap:clamp(24px,4vw,44px)}
.ds-cr-perk{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,5vw,64px);align-items:center}
.ds-cr-perk__visual{position:relative;display:grid;place-items:center;min-height:200px}
.ds-cr-perk__n{position:absolute;z-index:0;font-family:var(--serif);font-weight:700;font-size:clamp(120px,15vw,200px);line-height:.8;color:var(--coral);opacity:.1;user-select:none;pointer-events:none}
.ds-cr-perk__ic{position:relative;z-index:1;width:clamp(150px,17vw,208px);aspect-ratio:1;border-radius:28px;object-fit:cover;background:#f4f1ec;box-shadow:0 26px 54px -24px rgba(0,0,0,.3);transition:transform .5s var(--ease)}
.ds-cr-perk:hover .ds-cr-perk__ic{transform:translateY(-6px) scale(1.03)}
.ds-cr-perk__label{display:inline-block;font-size:12px;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--coral);margin:0 0 12px}
.ds-cr-perk__t{font-family:var(--serif);font-weight:700;font-size:clamp(24px,3vw,36px);line-height:1.1;letter-spacing:-.018em;margin:0 0 12px}
.ds-cr-perk__d{font-size:16px;line-height:1.75;color:#4a4a4a;margin:0;max-width:46ch}
.ds-cr-perk:nth-child(even) .ds-cr-perk__visual{order:2}
.ds-cr-perk:nth-child(even) .ds-cr-perk__body{order:1}

/* open positions accordion */
.ds-cr-jobs{border-top:1px solid var(--line)}
.ds-cr-job{border-bottom:1px solid var(--line)}
.ds-cr-job__head{display:flex;align-items:center;gap:18px;width:100%;background:none;border:0;cursor:pointer;text-align:left;padding:24px 4px;font-family:inherit;color:inherit;transition:padding .3s var(--ease)}
.ds-cr-job__head:hover{padding-left:14px}
.ds-cr-job__t{flex:1;min-width:0;font-family:var(--serif);font-weight:700;font-size:clamp(20px,2.4vw,29px);letter-spacing:-.014em;color:var(--ink);transition:color .25s}
.ds-cr-job__head:hover .ds-cr-job__t,.ds-cr-job.is-open .ds-cr-job__t{color:var(--coral)}
.ds-cr-job__meta{flex:none;display:none;gap:8px}
.ds-cr-job__tag{font-size:11.5px;font-weight:600;color:var(--text);background:var(--tint);border:1px solid var(--line);border-radius:999px;padding:5px 12px;white-space:nowrap}
.ds-cr-job__toggle{flex:none;width:36px;height:36px;border-radius:50%;border:1px solid var(--line);position:relative;transition:border-color .25s,background .25s}
.ds-cr-job.is-open .ds-cr-job__toggle{background:var(--coral);border-color:var(--coral)}
.ds-cr-job__toggle::before,.ds-cr-job__toggle::after{content:"";position:absolute;left:50%;top:50%;background:var(--ink);transition:transform .3s var(--ease),background .25s}
.ds-cr-job__toggle::before{width:13px;height:2px;transform:translate(-50%,-50%)}
.ds-cr-job__toggle::after{width:2px;height:13px;transform:translate(-50%,-50%)}
.ds-cr-job.is-open .ds-cr-job__toggle::before,.ds-cr-job.is-open .ds-cr-job__toggle::after{background:#fff}
.ds-cr-job.is-open .ds-cr-job__toggle::after{transform:translate(-50%,-50%) scaleY(0)}
.ds-cr-job__panel{overflow:hidden;max-height:0;transition:max-height .5s var(--ease)}
.ds-cr-job__inner{padding:2px 4px 34px}
.ds-cr-job__blurb{font-size:16.5px;line-height:1.7;color:#444;margin:0 0 22px;max-width:72ch}
.ds-cr-job__cols{display:grid;grid-template-columns:1fr 1fr;gap:26px 44px}
.ds-cr-job__col h4{font-size:12.5px;font-weight:700;letter-spacing:.15em;text-transform:uppercase;color:var(--coral);margin:0 0 14px}
.ds-cr-job__col ul{list-style:none;margin:0;padding:0}
.ds-cr-job__col li{position:relative;font-size:15px;line-height:1.6;color:#444;margin:0 0 11px;padding-left:24px}
.ds-cr-job__col li::before{content:"";position:absolute;left:2px;top:9px;width:7px;height:7px;border-radius:2px;background:var(--coral);opacity:.85}
.ds-cr-job__apply{margin-top:24px}
@media(min-width:760px){.ds-cr-job__meta{display:flex}}

/* application form */
.ds-cr-apply{background:var(--tint)}
.ds-cr-apply__grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(34px,5vw,72px);align-items:start}
.ds-cr-apply__intro{position:sticky;top:108px}
.ds-cr-apply__intro h2{font-size:clamp(28px,3.8vw,46px);line-height:1.06;letter-spacing:-.02em;margin:10px 0 16px}
.ds-cr-apply__intro h2 em{font-style:italic;color:var(--coral)}
.ds-cr-apply__intro p{color:var(--text);font-size:16px;line-height:1.7;margin:0 0 12px;max-width:40ch}
.ds-cr-apply__intro a{color:var(--coral);text-decoration:underline;text-underline-offset:2px}
.ds-cr-form{background:#fff;border:1px solid var(--line);border-radius:24px;padding:clamp(24px,3.4vw,38px);box-shadow:var(--shadow-sm)}
.ds-cr-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.ds-cr-field{margin:0 0 16px}
.ds-cr-field label{display:block;font-size:13px;font-weight:600;color:var(--ink);margin:0 0 7px}
.ds-cr-field label span{color:var(--coral)}
.ds-cr-input{width:100%;box-sizing:border-box;font:inherit;font-size:15px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:12px;padding:12px 15px;transition:border-color .2s,box-shadow .2s}
.ds-cr-input:focus{outline:0;border-color:var(--coral);box-shadow:0 0 0 3px rgba(239,61,95,.12)}
textarea.ds-cr-input{min-height:118px;resize:vertical}
select.ds-cr-input{appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2' stroke-linecap='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;background-size:18px;padding-right:42px}
.ds-cr-file{display:flex;align-items:center;gap:12px;flex-wrap:wrap;border:1px dashed var(--line);border-radius:12px;padding:13px 15px}
.ds-cr-file input[type=file]{font-size:13px;color:var(--text);max-width:100%}
.ds-cr-form__note{font-size:12.5px;color:var(--muted);margin:4px 0 18px}
.ds-cr-submit{width:100%;justify-content:center}
.ds-cr-msg{margin:14px 0 0;font-size:14px;min-height:18px;text-align:center}
.ds-cr-msg.is-err{color:var(--coral-700)}
.ds-cr-success{text-align:center;padding:24px 10px}
.ds-cr-success__ic{width:60px;height:60px;border-radius:50%;background:var(--coral-soft);color:var(--coral);display:grid;place-items:center;margin:0 auto 16px}
.ds-cr-success__ic svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:2.4;stroke-linecap:round;stroke-linejoin:round}
.ds-cr-success h3{font-size:23px;margin:0 0 8px}
.ds-cr-success p{color:var(--text);margin:0}

@media(max-width:860px){
  .ds-cr-perk{grid-template-columns:1fr;gap:18px;text-align:center}
  .ds-cr-perk:nth-child(even) .ds-cr-perk__visual,.ds-cr-perk:nth-child(even) .ds-cr-perk__body{order:0}
  .ds-cr-perk__visual{min-height:150px}.ds-cr-perk__ic{width:132px}.ds-cr-perk__n{font-size:108px}
  .ds-cr-perk__d{margin-left:auto;margin-right:auto}
  .ds-cr-job__cols{grid-template-columns:1fr;gap:20px}
  .ds-cr-apply__grid{grid-template-columns:1fr;gap:24px}.ds-cr-apply__intro{position:static}
  .ds-cr-row{grid-template-columns:1fr}
}

/* ============================================================
   PRESS PAGE — .ds-pr-*  (hero reuses .ds-wc-hero; facts reuse .ds-hm-stats)
   ============================================================ */
.ds-pr-about{padding:clamp(58px,8vw,98px) 0}
.ds-pr-about__grid{display:grid;grid-template-columns:1fr 1.1fr;gap:clamp(30px,5vw,72px);align-items:start}
.ds-pr-about__big{font-family:var(--serif);font-weight:700;font-size:clamp(28px,4vw,48px);line-height:1.06;letter-spacing:-.02em;color:var(--ink);margin:10px 0 0}
.ds-pr-about__big em{font-style:italic;color:var(--coral)}
.ds-pr-about__body p{font-size:clamp(16px,1.2vw,18px);line-height:1.85;color:#4a4a4a;margin:0 0 18px}
.ds-pr-about__body p:last-child{margin:0}
.ds-pr-sec{padding:clamp(54px,7vw,92px) 0}
.ds-pr-sec--tint{background:var(--tint)}
.ds-pr-head{max-width:720px;margin:0 0 clamp(28px,4vw,44px)}
.ds-pr-head h2{font-size:clamp(28px,4.2vw,48px);line-height:1.05;letter-spacing:-.02em;margin:10px 0 12px}
.ds-pr-head h2 em{font-style:italic;color:var(--coral)}
.ds-pr-head p{font-size:clamp(16px,1.3vw,18px);line-height:1.7;color:var(--text);margin:0;max-width:60ch}
.ds-pr-kit{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.ds-pr-card{background:#fff;border:1px solid var(--line);border-radius:20px;padding:30px 28px;display:flex;flex-direction:column;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.ds-pr-card:hover{transform:translateY(-5px);box-shadow:0 30px 60px -30px rgba(17,17,17,.25);border-color:rgba(239,61,95,.4)}
.ds-pr-card__ic{width:50px;height:50px;border-radius:14px;background:var(--coral-soft);color:var(--coral);display:grid;place-items:center;margin:0 0 18px}
.ds-pr-card__ic svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.ds-pr-card h3{font-size:19px;letter-spacing:-.01em;margin:0 0 8px}
.ds-pr-card p{font-size:14.5px;line-height:1.62;color:var(--text);margin:0 0 18px;flex:1}
.ds-pr-card__link{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:700;color:var(--coral)}
.ds-pr-card__link svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
@media(max-width:860px){.ds-pr-about__grid{grid-template-columns:1fr;gap:22px}.ds-pr-kit{grid-template-columns:1fr}}

/* press: featured coverage cards (.ds-pr-news / .ds-pr-article) */
.ds-pr-news{display:flex;flex-direction:column;gap:20px}
.ds-pr-article{display:grid;grid-template-columns:40% 1fr;background:#fff;border:1px solid var(--line);border-radius:20px;overflow:hidden;text-decoration:none;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.ds-pr-article:hover{transform:translateY(-5px);box-shadow:0 30px 60px -30px rgba(17,17,17,.25);border-color:rgba(239,61,95,.4)}
.ds-pr-article__media{position:relative;overflow:hidden;background:#0b0b0b;min-height:210px}
.ds-pr-article__media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease)}
.ds-pr-article:hover .ds-pr-article__media img{transform:scale(1.05)}
.ds-pr-article__body{padding:clamp(24px,3vw,34px);display:flex;flex-direction:column;justify-content:center}
.ds-pr-article__pub{display:flex;align-items:center;gap:12px;font-size:11.5px;font-weight:700;letter-spacing:.08em;text-transform:uppercase;margin:0 0 13px}
.ds-pr-article__src{color:var(--coral)}
.ds-pr-article__pub b{font-weight:700;color:var(--muted);display:inline-flex;align-items:center;gap:12px}
.ds-pr-article__pub b::before{content:"";width:4px;height:4px;border-radius:50%;background:var(--light)}
.ds-pr-article__t{font-family:var(--serif);font-weight:700;font-size:clamp(20px,2.4vw,28px);line-height:1.18;letter-spacing:-.014em;color:var(--ink);margin:0 0 12px;transition:color .25s}
.ds-pr-article:hover .ds-pr-article__t{color:var(--coral)}
.ds-pr-article__d{font-size:15px;line-height:1.62;color:var(--text);margin:0 0 20px;max-width:52ch}
.ds-pr-article__cta{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:var(--coral)}
.ds-pr-article__cta svg{width:16px;height:16px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s var(--ease)}
.ds-pr-article:hover .ds-pr-article__cta svg{transform:translateX(4px)}
@media(max-width:620px){.ds-pr-article{grid-template-columns:1fr}.ds-pr-article__media{min-height:190px}}

/* ============================================================
   CLIENTS PAGE — .ds-cl-*  (grayscale logos → colour on hover; CPT-driven)
   ============================================================ */
.ds-cl-hero{padding:clamp(54px,7vw,92px) 0 clamp(26px,3vw,40px);text-align:center}
.ds-cl-hero .ds-eyebrow{justify-content:center}
.ds-cl-hero h1{font-size:clamp(38px,6vw,78px);line-height:1.02;letter-spacing:-.026em;margin:14px 0 18px}
.ds-cl-hero h1 em{font-style:italic;color:var(--coral)}
.ds-cl-hero__sub{font-size:clamp(17px,1.8vw,20px);line-height:1.6;color:var(--text);max-width:60ch;margin:0 auto 26px}
.ds-cl-hero__stats{display:inline-flex;flex-wrap:wrap;justify-content:center}
.ds-cl-hero__stat{padding:0 30px;position:relative}
.ds-cl-hero__stat+.ds-cl-hero__stat::before{content:"";position:absolute;left:0;top:14%;height:72%;width:1px;background:var(--line)}
.ds-cl-hero__stat b{display:block;font-family:var(--serif);font-weight:700;font-size:clamp(26px,3.2vw,38px);color:var(--ink);line-height:1}
.ds-cl-hero__stat span{display:block;margin-top:7px;font-size:11.5px;font-weight:700;letter-spacing:.13em;text-transform:uppercase;color:var(--coral)}

.ds-cl-body{padding:clamp(36px,5vw,60px) 0 clamp(56px,8vw,96px)}
/* centered category + a uniform-height "logo wall" (the logo file itself, no box) */
.ds-cl-cat{margin:0 0 clamp(46px,6vw,72px);text-align:center}
.ds-cl-cat--feat{background:var(--tint);border:1px solid var(--line);border-radius:26px;padding:clamp(32px,4.5vw,56px) clamp(22px,4vw,44px)}
.ds-cl-cat__head{display:flex;align-items:center;justify-content:center;gap:12px;margin:0 0 clamp(28px,3.6vw,44px)}
.ds-cl-cat__name{font-family:var(--serif);font-weight:700;font-size:clamp(20px,2.6vw,31px);letter-spacing:-.014em;color:var(--ink);margin:0}
.ds-cl-cat__count{font-size:12px;font-weight:700;letter-spacing:.04em;color:var(--coral);background:var(--coral-soft);border-radius:999px;padding:4px 11px;line-height:1}
.ds-cl-cat__line{display:none}
.ds-cl-grid{display:flex;flex-wrap:wrap;align-items:center;justify-content:center;gap:clamp(34px,4vw,56px) clamp(22px,2.6vw,36px)}
.ds-cl-logo{display:flex;align-items:center;justify-content:center;flex:0 0 auto;width:clamp(140px,18vw,196px);height:clamp(84px,9.5vw,124px)}
.ds-cl-cat--feat .ds-cl-logo{width:clamp(150px,19vw,212px);height:clamp(94px,10.5vw,140px)}
.ds-cl-logo img{max-width:100%;max-height:100%;width:auto;object-fit:contain;filter:grayscale(1);opacity:.6;transition:filter .45s var(--ease),opacity .45s var(--ease),transform .45s var(--ease)}
.ds-cl-logo:hover img{filter:grayscale(0);opacity:1;transform:scale(1.08)}
@media(max-width:680px){
  .ds-cl-logo{width:clamp(118px,40vw,162px);height:clamp(70px,18vw,98px)}
  .ds-cl-cat--feat{padding:26px 14px}
  .ds-cl-cat--feat .ds-cl-logo{width:clamp(110px,34vw,150px);height:clamp(72px,17vw,100px)}
  .ds-cl-grid{gap:30px 20px}
  .ds-cl-hero__stat{padding:0 18px}
}

/* ============================================================
   SERVICE DETAIL PAGES — .ds-sd-*  (/services/<slug>/) — reuses .ds-acc, .ds-card, .ds-news
   ============================================================ */
.ds-sd-crumb{font-size:13px;color:var(--muted);margin:0 0 16px;display:flex;flex-wrap:wrap;gap:7px;align-items:center}
.ds-sd-crumb a{color:var(--muted);transition:color .2s}.ds-sd-crumb a:hover{color:var(--coral)}
.ds-sd-crumb span{color:var(--light)}
.ds-sd-hero{padding:clamp(30px,4vw,48px) 0 clamp(40px,5vw,64px)}
.ds-sd-hero__grid{display:grid;grid-template-columns:1.08fr .92fr;gap:clamp(34px,5vw,72px);align-items:center}
.ds-sd-hero .ds-eyebrow{margin-bottom:14px}
.ds-sd-hero h1{font-size:clamp(34px,5vw,62px);line-height:1.03;letter-spacing:-.026em;margin:0 0 20px}
.ds-sd-hero h1 em{font-style:italic;color:var(--coral)}
.ds-sd-hero__intro{font-size:clamp(16.5px,1.5vw,19px);line-height:1.7;color:#3e3e3e;margin:0 0 28px;max-width:54ch}
.ds-sd-hero__cta{display:flex;gap:14px;flex-wrap:wrap}
.ds-sd-hero__media{position:relative;border-radius:24px;overflow:hidden;aspect-ratio:4/3;box-shadow:0 44px 90px -44px rgba(239,61,95,.5)}
.ds-sd-hero__media img{width:100%;height:100%;object-fit:cover}
.ds-sd-sec{padding:clamp(50px,6.5vw,84px) 0}
.ds-sd-sec--tint{background:var(--tint)}
.ds-sd-head{max-width:720px;margin:0 0 clamp(30px,4vw,46px)}
.ds-sd-head h2{font-size:clamp(28px,4vw,46px);line-height:1.06;letter-spacing:-.02em;margin:10px 0 12px}
.ds-sd-head h2 em{font-style:italic;color:var(--coral)}
.ds-sd-head p{font-size:clamp(16px,1.3vw,18px);line-height:1.7;color:var(--text);margin:0;max-width:60ch}
/* what we do grid */
.ds-sd-do{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.ds-sd-item{position:relative;background:#fff;border:1px solid var(--line);border-radius:18px;padding:26px 26px 28px;transition:transform .35s var(--ease),box-shadow .35s,border-color .35s}
.ds-sd-item:hover{transform:translateY(-5px);box-shadow:0 28px 56px -30px rgba(17,17,17,.26);border-color:rgba(239,61,95,.4)}
.ds-sd-item__n{font-family:var(--serif);font-weight:700;font-size:15px;color:var(--coral);opacity:.65;margin:0 0 14px;display:block}
.ds-sd-item h3{font-size:19px;letter-spacing:-.01em;margin:0 0 9px}
.ds-sd-item p{font-size:14.5px;line-height:1.62;color:var(--text);margin:0}
/* process (generic 4-step) */
.ds-sd-process{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:sdp}
.ds-sd-step{counter-increment:sdp;position:relative;padding:26px 0 0;border-top:2px solid var(--line)}
.ds-sd-step::before{content:counter(sdp,decimal-leading-zero);position:absolute;top:-14px;left:0;background:var(--bg);padding-right:12px;font-family:var(--serif);font-weight:700;font-size:15px;color:var(--coral)}
.ds-sd-sec--tint .ds-sd-step::before{background:var(--tint)}
.ds-sd-step h3{font-size:18px;margin:0 0 8px;letter-spacing:-.01em}
.ds-sd-step p{font-size:14.5px;line-height:1.6;color:var(--text);margin:0}
/* why (3-col) */
.ds-sd-why{display:grid;grid-template-columns:repeat(3,1fr);gap:22px}
.ds-sd-why__item{padding:0}
.ds-sd-why__ic{width:46px;height:46px;border-radius:13px;background:var(--coral-soft);color:var(--coral);display:grid;place-items:center;font-family:var(--serif);font-weight:700;font-size:20px;margin:0 0 16px}
.ds-sd-why__item h3{font-size:20px;letter-spacing:-.012em;margin:0 0 9px}
.ds-sd-why__item p{font-size:15px;line-height:1.65;color:var(--text);margin:0}
/* related blogs */
.ds-sd-rel{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:clamp(28px,3.5vw,42px)}
@media(max-width:980px){
  .ds-sd-hero__grid{grid-template-columns:1fr;gap:24px}.ds-sd-hero__media{order:-1;max-height:340px}
  .ds-sd-do,.ds-sd-why,.ds-sd-rel{grid-template-columns:repeat(2,1fr)}
  .ds-sd-process{grid-template-columns:repeat(2,1fr);gap:30px 20px}
}
@media(max-width:600px){
  .ds-sd-do,.ds-sd-why,.ds-sd-rel,.ds-sd-process{grid-template-columns:1fr}
}
/* sibling-service chips (internal linking) */
.ds-sd-more{display:flex;flex-wrap:wrap;gap:12px}
.ds-sd-chip{display:inline-flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:999px;padding:12px 20px;font-family:var(--serif);font-weight:600;font-size:15.5px;color:var(--ink);transition:border-color .25s,transform .25s,box-shadow .25s,color .25s}
.ds-sd-chip span{color:var(--coral);transition:transform .25s var(--ease)}
.ds-sd-chip:hover{border-color:var(--coral);color:var(--coral);transform:translateY(-3px);box-shadow:0 16px 34px -22px rgba(239,61,95,.6)}
.ds-sd-chip:hover span{transform:translateX(4px)}
.ds-sd-cta__act{display:flex;justify-content:flex-end;z-index:1}
@media(max-width:600px){.ds-sd-cta__act{width:100%}.ds-sd-cta__act .ds-btn{width:100%;text-align:center}}
/* services hub: make each service row link to its detail page (stretched link) */
.ds-sv-svc__link{position:absolute;inset:0;z-index:2;border-radius:8px}
.ds-sv-svc__link:focus-visible{outline:2px solid var(--coral);outline-offset:2px}

/* ============================================================
   OUR WORK — .ds-ow-*  (Behance-style portfolio + filters + modal + randomized Shorts)
   ============================================================ */
.ds-ow-hero{padding:clamp(34px,5vw,60px) 0 clamp(22px,3vw,34px);text-align:center}
.ds-ow-hero h1{font-size:clamp(38px,6vw,76px);line-height:1.02;letter-spacing:-.03em;margin:12px 0 16px}
.ds-ow-hero h1 em{font-style:italic;color:var(--coral)}
.ds-ow-hero__sub{font-size:clamp(16px,1.5vw,19px);line-height:1.65;color:var(--text);max-width:62ch;margin:0 auto}
/* filter bar */
.ds-ow-filter{position:sticky;top:0;z-index:30;background:rgba(255,255,255,.86);backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--line);padding:14px 0}
.ds-ow-filter__in{display:flex;flex-wrap:wrap;gap:10px;justify-content:center}
.ds-ow-pill{appearance:none;border:1px solid var(--line);background:#fff;color:var(--ink);font-family:var(--sans);font-weight:600;font-size:14px;padding:9px 18px;border-radius:999px;cursor:pointer;transition:all .25s var(--ease)}
.ds-ow-pill:hover{border-color:var(--coral);color:var(--coral)}
.ds-ow-pill.is-active{background:var(--ink);color:#fff;border-color:var(--ink)}
.ds-ow-pill b{opacity:.5;font-weight:600;margin-left:5px}
/* project grid (masonry via columns) */
.ds-ow-body{padding-bottom:clamp(44px,6vw,84px)}
.ds-ow-grid{display:flex;gap:20px;align-items:flex-start;margin:clamp(26px,3.4vw,40px) 0 0}
.ds-ow-col{flex:1 1 0;min-width:0;display:flex;flex-direction:column;gap:20px}
.ds-ow-card{margin:0;position:relative;display:block;width:100%;min-height:80px;border:0;padding:0;background:#0c0c0c;border-radius:16px;overflow:hidden;cursor:pointer;text-align:left;transition:transform .4s var(--ease),box-shadow .4s var(--ease)}
.ds-ow-card img{display:block;width:100%;height:auto}
.ds-ow-card:hover{transform:translateY(-5px);box-shadow:0 28px 54px -26px rgba(8,8,10,.55)}
.ds-ow-card__ov{position:absolute;inset:0;display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-end;gap:10px;padding:18px;background:linear-gradient(0deg,rgba(8,8,10,.94) 0%,rgba(8,8,10,.62) 38%,rgba(8,8,10,.12) 72%,transparent 100%);opacity:0;transition:opacity .35s}
.ds-ow-card:hover .ds-ow-card__ov,.ds-ow-card:focus-visible .ds-ow-card__ov{opacity:1}
.ds-ow-card__t{font-family:var(--serif);font-weight:600;font-size:18px;line-height:1.22;color:#fff;text-shadow:0 1px 14px rgba(0,0,0,.55);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.ds-ow-card__c{display:inline-block;background:var(--coral);color:#fff;font-size:11px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:4px 11px;border-radius:999px;box-shadow:0 4px 14px -4px rgba(239,61,95,.7)}
.ds-ow-card__exp{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.16);backdrop-filter:blur(6px);display:grid;place-items:center;color:#fff;opacity:0;transform:scale(.8);transition:.3s var(--ease)}
.ds-ow-card:hover .ds-ow-card__exp{opacity:1;transform:none}
.ds-ow-empty{text-align:center;color:var(--muted);padding:60px 0;grid-column:1/-1}
/* ---- modal / lightbox ---- */
.ds-ow-modal{position:fixed;inset:0;z-index:9999;display:none;opacity:0;transition:opacity .3s}
.ds-ow-modal.is-open{display:block;opacity:1}
.ds-ow-modal__bd{position:absolute;inset:0;background:rgba(8,8,10,.86);backdrop-filter:blur(4px)}
.ds-ow-modal__panel{position:absolute;inset:0;overflow-y:auto;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.ds-ow-modal__inner{position:relative;max-width:920px;margin:0 auto;padding:clamp(70px,9vh,110px) 0 80px;transform:translateY(14px);transition:transform .4s var(--ease)}
.ds-ow-modal.is-open .ds-ow-modal__inner{transform:none}
.ds-ow-modal__head{background:#fff;border-radius:18px 18px 0 0;padding:26px 30px 22px;margin:0 14px}
.ds-ow-modal__c{font-size:12px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--coral);margin:0 0 8px}
.ds-ow-modal__t{font-size:clamp(23px,3vw,33px);line-height:1.1;letter-spacing:-.02em;margin:0 0 14px}
.ds-ow-modal__bh{display:inline-flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--ink);border:1px solid var(--line);padding:8px 16px;border-radius:999px;transition:.25s}
.ds-ow-modal__bh:hover{border-color:var(--coral);color:var(--coral)}
.ds-ow-modal__imgs{background:#fff;border-radius:0 0 18px 18px;margin:0 14px;overflow:hidden}
.ds-ow-modal__imgs img{display:block;width:100%;height:auto}
.ds-ow-x{position:fixed;top:18px;right:20px;z-index:3;width:46px;height:46px;border-radius:50%;border:0;background:rgba(255,255,255,.14);backdrop-filter:blur(8px);color:#fff;font-size:22px;cursor:pointer;display:grid;place-items:center;transition:.25s}
.ds-ow-x:hover{background:var(--coral);transform:rotate(90deg)}
.ds-ow-modal__hint{position:fixed;left:0;right:0;bottom:16px;text-align:center;font-size:12px;letter-spacing:.05em;color:rgba(255,255,255,.5);pointer-events:none}
body.ds-ow-lock{overflow:hidden}
/* ---- content creation: randomized Shorts ---- */
.ds-ow-shorts{background:var(--ink);color:#fff;padding:clamp(54px,7vw,96px) 0}
.ds-ow-shorts .ds-ow-shead{text-align:center;max-width:640px;margin:0 auto clamp(28px,3.6vw,44px)}
.ds-ow-shorts .ds-eyebrow{color:#ff9bad}
.ds-ow-shorts h2{font-size:clamp(28px,4vw,46px);line-height:1.05;letter-spacing:-.02em;margin:10px 0 12px;color:#fff}
.ds-ow-shorts h2 em{font-style:italic;color:var(--coral)}
.ds-ow-shorts__p{color:rgba(255,255,255,.72);font-size:clamp(15px,1.3vw,17px);line-height:1.6;margin:0}
.ds-ow-shuf{margin:22px auto 0;display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);color:#fff;font-weight:600;font-size:14px;padding:11px 22px;border-radius:999px;cursor:pointer;transition:.25s}
.ds-ow-shuf:hover{background:var(--coral);border-color:var(--coral)}
.ds-ow-reels{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,22px)}
.ds-ow-reel{position:relative;aspect-ratio:9/16;border-radius:16px;overflow:hidden;background:#000;cursor:pointer;border:0;padding:0}
.ds-ow-reel img{width:100%;height:100%;object-fit:cover;opacity:.92;transition:transform .5s var(--ease),opacity .3s}
.ds-ow-reel:hover img{transform:scale(1.06);opacity:1}
.ds-ow-reel__play{position:absolute;inset:0;display:grid;place-items:center;pointer-events:none}
.ds-ow-reel__play span{width:54px;height:54px;border-radius:50%;background:rgba(239,61,95,.92);display:grid;place-items:center;box-shadow:0 10px 30px -8px rgba(239,61,95,.7);transition:transform .3s}
.ds-ow-reel:hover .ds-ow-reel__play span{transform:scale(1.12)}
.ds-ow-reel__play svg{width:20px;height:20px;fill:#fff;margin-left:3px}
.ds-ow-reel iframe{position:absolute;inset:0;width:100%;height:100%;border:0;border-radius:16px;z-index:1}
.ds-ow-reel__hit{position:absolute;inset:0;z-index:2;cursor:pointer}
.ds-ow-reel.is-playing img,.ds-ow-reel.is-playing .ds-ow-reel__play{opacity:0}
.ds-ow-reel__mute{position:absolute;bottom:10px;right:10px;z-index:3;width:34px;height:34px;border-radius:50%;background:rgba(8,8,10,.6);backdrop-filter:blur(6px);place-items:center;color:#fff;pointer-events:none;display:none;transition:background .25s}
.ds-ow-reel.is-playing .ds-ow-reel__mute{display:grid}
.ds-ow-reel.is-unmuted .ds-ow-reel__mute{background:var(--coral)}
.ds-ow-reel__mute svg{width:15px;height:15px;fill:#fff}
@media(max-width:1100px){.ds-ow-reels{grid-template-columns:repeat(3,1fr)}}
@media(max-width:680px){.ds-ow-reels{grid-template-columns:repeat(2,1fr)}.ds-ow-modal__inner{padding-top:64px}}

/* ============================================================
   SITE CHROME — custom header + footer (.ds-hdr / .ds-ftr) — replaces Elementor Theme Builder
   ============================================================ */
.ds-hdr{position:sticky;top:0;z-index:1000;background:#fff;border-bottom:1px solid rgba(0,0,0,.07);transition:box-shadow .3s}
.ds-hdr.is-stuck{box-shadow:0 8px 30px -22px rgba(0,0,0,.4)}
.ds-hdr__in{max-width:1340px;margin:0 auto;padding:0 clamp(18px,4vw,52px);min-height:92px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.ds-hdr__logo{flex:none;display:inline-flex;align-items:center}
.ds-hdr__logo img{height:48px;width:auto;display:block}
.ds-hdr__nav{display:flex;align-items:center;gap:clamp(18px,2.6vw,40px)}
.ds-hdr__nav a{font-family:var(--sans);font-weight:500;font-size:16px;color:var(--ink);transition:color .2s}
.ds-hdr__nav a:hover,.ds-hdr__nav a[aria-current="page"]{color:var(--coral)}
.ds-hdr__right{display:flex;align-items:center;gap:14px}
.ds-hdr__cta{display:inline-flex;align-items:center;gap:8px;background:transparent;color:var(--ink);font-family:var(--sans);font-weight:500;font-size:16px;padding:14px 30px;border:1px solid rgba(0,0,0,.32);border-radius:7px;transition:background .25s var(--ease),color .25s,border-color .25s}
.ds-hdr__cta:hover{background:var(--ink);border-color:var(--ink);color:#fff}
.ds-hdr__burger{display:none;flex-direction:column;gap:5px;width:44px;height:44px;border:1px solid var(--line);border-radius:11px;background:#fff;cursor:pointer;align-items:center;justify-content:center}
.ds-hdr__burger span{width:18px;height:2px;background:var(--ink);transition:.3s var(--ease)}
.ds-hdr.is-open .ds-hdr__burger span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.ds-hdr.is-open .ds-hdr__burger span:nth-child(2){opacity:0}
.ds-hdr.is-open .ds-hdr__burger span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
@media(min-width:981px){.ds-hdr__burger{display:none!important}}
@media(max-width:980px){
  .ds-hdr__burger{display:flex}
  .ds-hdr__in{min-height:74px}
  .ds-hdr__logo img{height:40px}
  .ds-hdr__nav{position:fixed;left:0;right:0;top:74px;flex-direction:column;align-items:flex-start;gap:0;background:#fff;border-bottom:1px solid var(--line);padding:8px clamp(18px,5vw,32px) 22px;transform:translateY(-130%);opacity:0;pointer-events:none;transition:transform .38s var(--ease),opacity .3s;max-height:calc(100vh - 74px);overflow:auto}
  .ds-hdr.is-open .ds-hdr__nav{transform:none;opacity:1;pointer-events:auto}
  .ds-hdr__nav a{width:100%;padding:15px 0;font-size:18px;border-bottom:1px solid var(--line)}
  .ds-hdr__cta{display:none}
}
/* footer — original DESENO layout: left-aligned CTA stack + ABOUT/WORK/LINKS/NEWSLETTER cols */
.ds-ftr{background:#0a0a0a;color:#fff}
.ds-ftr__cta{padding:clamp(54px,7vw,96px) 0 clamp(38px,5vw,60px)}
.ds-ftr__cta-in{max-width:1340px;margin:0 auto;padding:0 clamp(18px,4vw,52px)}
.ds-ftr__cta h2{font-family:var(--sans);font-weight:800;font-size:clamp(32px,5.2vw,62px);line-height:1.05;letter-spacing:-.02em;margin:0 0 28px;max-width:20ch;color:#fff}
.ds-ftr__cta h2 em{font-style:normal;color:inherit}
.ds-ftr__contact{display:inline-flex;align-items:center;gap:10px;background:var(--coral);color:#fff;font-weight:600;font-size:16px;padding:15px 30px;border-radius:0;transition:transform .25s var(--ease),box-shadow .25s}
.ds-ftr__contact:hover{transform:translateY(-3px);box-shadow:0 18px 40px -14px rgba(239,61,95,.7);color:#fff}
.ds-ftr__find{display:flex;align-items:center;gap:16px;flex-wrap:wrap;margin:34px 0 0}
.ds-ftr__find>span{color:rgba(255,255,255,.6);font-size:14.5px}
.ds-ftr__social{display:flex;gap:10px;flex-wrap:wrap}
.ds-ftr__social a{width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.22);display:grid;place-items:center;color:rgba(255,255,255,.85);transition:.25s}
.ds-ftr__social a:hover{background:var(--coral);border-color:var(--coral);color:#fff;transform:translateY(-3px)}
.ds-ftr__social svg{width:16px;height:16px;fill:currentColor}
.ds-ftr__main{max-width:1340px;margin:0 auto;padding:clamp(40px,5vw,64px) clamp(18px,4vw,52px) clamp(30px,3.4vw,46px);display:grid;grid-template-columns:1.7fr 1fr 1fr 1fr 1.5fr;gap:clamp(22px,3vw,46px);border-top:1px solid rgba(255,255,255,.1)}
.ds-ftr__brand img{height:30px;width:auto;margin:0 0 18px}
.ds-ftr__brand p{color:rgba(255,255,255,.62);font-size:15px;line-height:1.6;margin:0 0 16px;max-width:30ch}
.ds-ftr__gt{color:rgba(255,255,255,.5)!important;font-size:12px!important;font-weight:700;letter-spacing:.1em;text-transform:uppercase;margin:0 0 8px!important}
.ds-ftr__brand .ds-ftr__mail{color:#fff;font-weight:600;font-size:15px;border-bottom:1px solid var(--coral);padding-bottom:2px}
.ds-ftr__col h4,.ds-ftr__news h4{font-size:12px;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.5);margin:0 0 18px}
.ds-ftr__col ul{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}
.ds-ftr__col a{color:rgba(255,255,255,.82);font-size:15px;transition:color .2s,padding-left .2s}
.ds-ftr__col a:hover{color:var(--coral);padding-left:4px}
.ds-ftr__news p{color:rgba(255,255,255,.62);font-size:14.5px;line-height:1.6;margin:0 0 16px}
.ds-ftr__news form{display:flex;gap:8px;flex-wrap:wrap}
.ds-ftr__news input{flex:1 1 150px;min-width:0;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.2);color:#fff;border-radius:0;padding:13px 16px;font:inherit;font-size:14.5px}
.ds-ftr__news input::placeholder{color:rgba(255,255,255,.5)}
.ds-ftr__news button{flex:none;background:var(--coral);color:#fff;border:0;border-radius:0;padding:13px 24px;font-weight:600;font-size:14.5px;cursor:pointer;transition:transform .2s}
.ds-ftr__news button:hover{transform:translateY(-2px)}
.ds-ftr__news .ds-ftr__msg{flex-basis:100%;font-size:13px;margin:8px 0 0;min-height:16px;color:#9be29b}
.ds-ftr__bar{border-top:1px solid rgba(255,255,255,.1)}
.ds-ftr__bar-in{max-width:1340px;margin:0 auto;padding:22px clamp(18px,4vw,52px);display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:14px;font-size:13.5px;color:rgba(255,255,255,.55)}
.ds-ftr__bar nav{display:flex;flex-wrap:wrap;gap:22px}
.ds-ftr__bar a{color:rgba(255,255,255,.55);transition:color .2s}.ds-ftr__bar a:hover{color:#fff}
@media(max-width:1024px){.ds-ftr__main{grid-template-columns:1fr 1fr 1fr}.ds-ftr__brand,.ds-ftr__news{grid-column:1/-1}}
@media(max-width:560px){.ds-ftr__main{grid-template-columns:1fr 1fr}.ds-ftr__brand,.ds-ftr__news{grid-column:1/-1}}
/* post-Elementor guard: theme/bootstrap [type=button] reset (border/padding/radius #c36) must not
   bleed into custom button components — Elementor's CSS used to mask it. */
.ds-ow-card,.ds-ow-reel{border:0!important;padding:0!important;border-radius:16px!important;background-color:#0c0c0c;color:inherit}
.ds-ow-reel{background-color:#000!important}
.ds-ow-pill,.ds-ow-shuf,.ds-acc__q,.ds-hdr__burger,.ds-tab,.ds-news__form button,.ds-ftr__news button,.ds-cr-job__q{color:inherit}
/* ---- 404 + search edge pages (branded custom chrome) ---- */
.ds-edge{padding:clamp(96px,13vh,156px) 0 clamp(72px,10vh,120px);min-height:62vh;background:var(--bg)}
.ds-edge__title{font-family:var(--serif);font-weight:700;font-size:clamp(34px,5vw,58px);line-height:1.05;letter-spacing:-.02em;color:var(--ink);margin:6px 0 16px;max-width:20ch}
.ds-edge__sub{font-size:18px;line-height:1.6;color:var(--text);max-width:56ch;margin:0 0 30px}
.ds-edge__search{display:flex;gap:10px;max-width:540px;margin:0 0 26px;flex-wrap:wrap}
.ds-edge__search input{flex:1 1 220px;min-width:0;border:1px solid var(--line);border-radius:999px;padding:13px 22px;font:inherit;font-size:15.5px;background:var(--tint);color:var(--ink)}
.ds-edge__search input:focus{outline:none;border-color:var(--coral);background:#fff}
.ds-edge__links{display:flex;gap:12px;flex-wrap:wrap}
.ds-edge__results{list-style:none;margin:16px 0 32px;padding:0;display:grid;gap:14px;max-width:780px}
.ds-edge__results li{border:1px solid var(--line);border-radius:14px;background:#fff;transition:border-color .25s,transform .25s,box-shadow .25s}
.ds-edge__results li:hover{border-color:var(--coral);transform:translateY(-2px);box-shadow:0 16px 32px -20px rgba(0,0,0,.35)}
.ds-edge__results a{display:block;padding:18px 22px;color:inherit;text-decoration:none}
.ds-edge__results h3{font-family:var(--serif);font-weight:700;font-size:19px;line-height:1.25;color:var(--ink);margin:0 0 6px}
.ds-edge__results p{font-size:14.5px;line-height:1.55;color:var(--text);margin:0}
.ds-edge__pag{display:flex;gap:8px;flex-wrap:wrap}
.ds-edge__pag .page-numbers{display:inline-flex;min-width:42px;height:42px;align-items:center;justify-content:center;padding:0 13px;border:1px solid var(--line);border-radius:10px;color:var(--ink);text-decoration:none;font-weight:600;font-size:14px;transition:border-color .2s,color .2s}
.ds-edge__pag .page-numbers.current{background:var(--coral);color:#fff;border-color:var(--coral)}
.ds-edge__pag a.page-numbers:hover{border-color:var(--coral);color:var(--coral)}
@media(max-width:640px){.ds-edge{padding-top:clamp(84px,11vh,120px)}.ds-edge__links .ds-btn{width:100%;justify-content:center}}

/* restore EXACT brand base typography (Elementor kit used to set this; theme default was overriding).
   High specificity (html body / body h*) beats the theme's body{font-family:system} rule. */
html body{font-family:var(--sans);font-weight:300;font-size:17px}
body h1,body h2,body h3,body h4,body h5,body h6{font-family:var(--serif);font-weight:700}
