:root{
  --bg-0: hsl(226 32% 4.8%);
  --bg-1: hsl(226 24% 8%);
  --bg-2: hsl(228 20% 12%);
  --text-0: hsl(220 24% 96%);
  --text-1: hsl(220 18% 80%);
  --text-2: hsl(220 12% 64%);
  --stroke: hsl(220 22% 100% / .10);
  --stroke-strong: hsl(220 24% 100% / .16);
  --shadow: 0 24px 80px hsl(220 40% 2% / .56);

  --accent-services: hsl(196 92% 60%);
  --accent-about: hsl(282 84% 72%);
  --accent-work: hsl(38 94% 64%);
  --accent-process: hsl(154 76% 56%);
  --accent-contact: hsl(12 94% 64%);
  --accent-home: hsl(198 90% 66%);
  --accent-legal: hsl(214 72% 72%);
  --accent: var(--accent-home);

  --r-sm: 14px;
  --r-md: 18px;
  --r-lg: 28px;
  --r-xl: 36px;
  --r-xxl: 42px;

  --display: clamp(50px, 5.2vw, 76px);
  --h1: clamp(38px, 4.3vw, 68px);
  --h2: clamp(23px, 2.3vw, 34px);
  --h3: clamp(16px, 1.25vw, 20px);
  --body: clamp(16px, 1.2vw, 18px);
  --small: 13.5px;
  --label: 12.5px;

  --px: 50vw;
  --py: 50vh;
  --pr: 0px;
}

*{box-sizing:border-box}
html,body{height:100%}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: Inter, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, sans-serif;
  background: var(--bg-0);
  color: var(--text-0);
  line-height:1.62;
  overflow:hidden;
  text-rendering:optimizeLegibility;
}

a{color:inherit;text-decoration:none}
button,input,select,textarea{font:inherit}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
.view{position:absolute;inset:0;display:none}
.view.is-active{display:block}
.view-home{background: var(--bg-0)}
.home-bg{position:absolute;inset:0;background:linear-gradient(112deg, hsl(197 90% 56%/.10), transparent 25%),radial-gradient(1300px 900px at 16% 24%, hsl(198 88% 50%/.20), transparent 63%),radial-gradient(1000px 780px at 84% 22%, hsl(283 84% 54%/.16), transparent 62%),radial-gradient(920px 740px at 53% 100%, hsl(154 80% 44%/.10), transparent 74%),linear-gradient(180deg, hsl(226 30% 10%/.25), transparent 30%, hsl(226 30% 3%/.35) 100%),repeating-linear-gradient(180deg, hsl(220 15% 100%/.024) 0 1px, transparent 1px 42px),linear-gradient(90deg, transparent 0%, hsl(220 20% 100%/.018) 50%, transparent 100%),linear-gradient(180deg, hsl(225 28% 8%), hsl(223 30% 5%))}
.home-header{position:absolute;left:50%;top:55%;transform:translate(-50%,-50%);width:min(620px, calc(100vw - 140px));text-align:center;z-index:4;pointer-events:none}
.home-kicker{margin:0 0 10px;font-size:var(--label);letter-spacing:.28em;text-transform:uppercase;color:hsl(220 22% 86% / .88)}
.home-title{margin:0 auto;max-width:12ch;font-size:var(--display);line-height:.98;letter-spacing:-.055em;font-weight:900;text-shadow:0 18px 60px hsl(220 38% 2% / .55), 0 0 24px hsl(220 18% 100%/.08)}
.home-subtitle{display:none;margin:0}
.bubble-field{position:absolute;inset:0;width:100vw;height:100vh;touch-action:manipulation;z-index:2}
.bubble{position:absolute;display:grid;place-items:center;padding:0;width:var(--sz, 176px);height:var(--sz, 176px);border-radius:49% 51% 50% 50% / 50% 48% 52% 50%;border:1px solid color-mix(in srgb, currentColor 32%, rgba(255,255,255,.96));background:radial-gradient(120px 110px at 30% 22%, hsl(220 18% 100%/.28), transparent 56%),radial-gradient(160px 160px at 52% 52%, color-mix(in srgb, currentColor 13%, transparent), transparent 68%),radial-gradient(140px 140px at 72% 78%, hsl(220 18% 100%/.08), transparent 64%),linear-gradient(180deg, hsl(220 18% 100%/.08), hsl(220 18% 100%/.01) 26%),radial-gradient(circle at 50% 52%, hsl(220 18% 100%/.06), transparent 74%);box-shadow:0 24px 80px rgba(8,18,34,.22),inset 0 0 0 1px hsl(220 18% 100%/.10),inset 0 -20px 48px color-mix(in srgb, currentColor 5%, transparent),0 0 0 1px color-mix(in srgb, currentColor 22%, transparent);cursor:pointer;left:50%;top:50%;color:var(--c, var(--accent-services));transform:translate3d(-50%, -50%, 0) translate3d(var(--bx,0px), var(--by,0px), 0) translate3d(var(--kx,0px), var(--ky,0px), 0) rotate(var(--br,0deg)) scale(var(--bs,1));opacity:var(--ba,1);will-change:transform, opacity;overflow:hidden}
.bubble[data-route="services"]{--c:var(--accent-services)}
.bubble[data-route="about"]{--c:var(--accent-about)}
.bubble[data-route="process"]{--c:var(--accent-process)}
.bubble[data-route="work"]{--c:var(--accent-work)}
.bubble[data-route="contact"]{--c:var(--accent-contact)}
.bubble-ring{position:absolute;inset:10px;border-radius:inherit;border:1px solid color-mix(in srgb, currentColor 16%, hsl(220 18% 100%/.18));opacity:.56}
.bubble-gloss{pointer-events:none;position:absolute;inset:-1px;border-radius:inherit;opacity:.95;background:radial-gradient(150px 112px at 35% 25%, hsl(220 18% 100%/.24), transparent 58%),radial-gradient(124px 124px at 70% 74%, color-mix(in srgb, currentColor 18%, transparent), transparent 64%);mix-blend-mode:screen}
.bubble::after{content:"";position:absolute;left:50%;top:106%;width:64%;height:18px;transform:translateX(-50%);border-radius:999px;background:radial-gradient(circle at 50% 50%, hsl(220 30% 2%/.62), transparent 70%);opacity:.66}
.bubble-inner{width:78%;height:78%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:9px;text-align:center;transform:translate3d(0,0,0)}
.bubble-icon{display:grid;place-items:center;line-height:0}
.bubble-icon svg{width:50px;height:50px;stroke:currentColor;fill:none;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round;transform:translate3d(var(--ix,0px), var(--iy,0px), 0);filter:drop-shadow(0 0 16px color-mix(in srgb, currentColor 20%, transparent))}
.bubble-label{font-size:14px;letter-spacing:.13em;text-transform:uppercase;font-weight:900;text-shadow:0 10px 30px hsl(220 30% 2%/.4);text-align:center}
.bubble-sub{font-size:13px;color:color-mix(in srgb, currentColor 66%, var(--text-1));opacity:0;transform:translateY(6px);transition:opacity .22s ease, transform .22s ease}
.bubble:hover .bubble-sub,.bubble:focus-visible .bubble-sub{opacity:1;transform:translateY(0)}
.bubble:hover,.bubble:focus-visible{filter:saturate(1.1) brightness(1.05)}
.bubble:focus-visible,.back:focus-visible,.tile:focus-visible,.icon:focus-visible,.primary:focus-visible,.check:focus-within,.pill:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,.footer-link:focus-visible,.legal-inline:focus-visible{outline:none;box-shadow:0 0 0 3px hsl(220 18% 100%/.16), 0 0 0 6px color-mix(in srgb, var(--accent) 26%, transparent)}
.site-footer{position:absolute;left:50%;bottom:20px;transform:translateX(-50%);z-index:5;display:flex;align-items:center;justify-content:center;gap:10px;width:min(360px, calc(100vw - 26px));padding:8px 10px;border:1px solid hsl(220 18% 100%/.08);border-radius:999px;background:linear-gradient(180deg, hsl(220 18% 100%/.05), hsl(220 18% 100%/.03)), hsl(224 26% 7% / .52);backdrop-filter:blur(14px);box-shadow:0 16px 44px hsl(220 34% 2%/.38)}
.footer-link{min-height:32px;display:inline-flex;align-items:center;justify-content:center;padding:0 12px;border-radius:999px;color:var(--text-1);font-size:12px;letter-spacing:.1em;text-transform:uppercase}
.footer-link:hover{background:hsl(220 18% 100%/.04);color:var(--text-0)}
@media (max-width: 820px) and (orientation: portrait) and (max-height: 760px){.home-header{top:18px}.home-title{font-size:clamp(40px,9.6vw,64px)}.home-subtitle{margin-top:8px;font-size:14px}.site-footer{bottom:8px}}
.wave{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;opacity:.32;mix-blend-mode:screen}
.view-home.hiding .bubble{transition:opacity 160ms ease, transform 240ms cubic-bezier(.2,.9,.1,1), filter 180ms ease}
.view-home.hiding .bubble:not(.active-bubble){opacity:0;pointer-events:none;filter:drop-shadow(0 16px 44px rgba(255,255,255,.65))}
.view-page{--section-accent: var(--accent);overflow:auto;background:radial-gradient(1180px 760px at 14% 10%, color-mix(in srgb, var(--section-accent) 22%, transparent), transparent 60%),radial-gradient(960px 720px at 86% 28%, color-mix(in srgb, var(--section-accent) 12%, transparent), transparent 64%),linear-gradient(180deg, hsl(223 30% 7%), hsl(224 30% 5%));scrollbar-gutter:stable both-edges;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}
.view-about{--section-accent:var(--accent-about)}
.view-services{--section-accent:var(--accent-services)}
.view-process{--section-accent:var(--accent-process)}
.view-work{--section-accent:var(--accent-work)}
.view-contact{--section-accent:var(--accent-contact)}
.view-legal{--section-accent:var(--accent-legal)}
.page{min-height:100%;padding:clamp(18px, 2vw, 28px);padding-top:clamp(76px, 8vw, 96px);padding-bottom:52px;width:min(1180px, 100%);margin:0 auto;display:flex;flex-direction:column;gap:20px}
.page--legal{width:min(920px,100%)}
.hero{display:flex;flex-direction:column;gap:14px}
.hero--wide{display:grid;grid-template-columns:minmax(0, 1.02fr) minmax(320px, .98fr);gap:18px;align-items:stretch}
.hero .chips{margin-top:2px;display:flex;gap:10px;flex-wrap:wrap}
.h1{font-size:var(--h1);line-height:.98;letter-spacing:-.05em;margin:0 0 10px;font-weight:900}
.h2{font-size:var(--h2);line-height:1.08;letter-spacing:-.035em;margin:0;font-weight:800}
.lede{font-size:var(--body);color:var(--text-1);margin:0 0 8px;max-width:74ch}
.small{font-size:13.5px;color:var(--text-1)}
.chips{display:flex;gap:10px;flex-wrap:wrap}
.chips--dense{gap:9px}
.chip{min-height:30px;padding:6px 11px;border-radius:999px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 16%, var(--stroke));background:linear-gradient(180deg, hsl(220 18% 100%/.05), hsl(220 18% 100%/.03));font-size:var(--label);line-height:1.1;letter-spacing:.08em;text-transform:uppercase}
.back{position:fixed;top:14px;left:14px;z-index:50;width:46px;height:46px;border-radius:999px;border:1px solid var(--stroke-strong);background:hsl(220 18% 10%/.62);color:var(--text-0);cursor:pointer;display:grid;place-items:center;backdrop-filter:blur(14px)}
.cards{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;align-items:stretch}
.cards--services{grid-template-columns:repeat(2,minmax(0,1fr))}
.cards--supporting{grid-template-columns:repeat(3,minmax(0,1fr))}
.cards--team-support{margin-top:2px}
.card,.mini-card,.tile,.step,.media-panel{border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 10%, var(--stroke));background:radial-gradient(220px 160px at 0% 0%, color-mix(in srgb, var(--section-accent, var(--accent)) 10%, transparent), transparent 60%),linear-gradient(180deg, hsl(220 18% 100%/.05), hsl(220 18% 100%/.02) 24%),hsl(220 18% 10%/.58);border-radius:var(--r-lg);box-shadow:0 18px 60px hsl(220 30% 2%/.30), inset 0 1px 0 hsl(220 18% 100%/.05);backdrop-filter:blur(14px)}
.card{padding:18px}
.card--soft{padding:20px}
.card-top{display:flex;align-items:center;gap:12px;margin-bottom:10px}
.ico{width:42px;height:42px;border-radius:15px;display:grid;place-items:center;background:color-mix(in srgb, var(--section-accent, var(--accent)) 14%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 20%, transparent);font-size:18px}
.card p,.mini-card p,.tile-copy{margin:0;color:var(--text-1);font-size:var(--body)}
.card h3,.mini-card h3{margin:0 0 8px;font-size:var(--h3);line-height:1.25;letter-spacing:-.01em}
.media-grid{display:grid;gap:14px}
.media-grid--triple{grid-template-columns:repeat(3,minmax(0,1fr))}
.media-panel{position:relative;min-height:180px;padding:18px;overflow:hidden;isolation:isolate}
.media-panel::before{content:"";position:absolute;inset:-20% -10% auto auto;width:180px;height:180px;border-radius:50%;background:radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--media-accent, var(--section-accent, var(--accent))) 30%, transparent), transparent 68%);opacity:.82;filter:blur(6px)}
.media-panel::after{content:"";position:absolute;inset:0;background:radial-gradient(140px 140px at 20% 20%, hsl(220 18% 100%/.10), transparent 60%),linear-gradient(180deg, transparent, hsl(220 18% 100%/.02)),repeating-linear-gradient(180deg, hsl(220 18% 100%/.028) 0 1px, transparent 1px 34px),linear-gradient(90deg, transparent 0, hsl(220 18% 100%/.012) 50%, transparent 100%);opacity:.9;pointer-events:none}
.media-panel > *{position:relative;z-index:1}
.media-panel[data-tone="about"]{--media-accent:var(--accent-about)}
.media-panel[data-tone="services"]{--media-accent:var(--accent-services)}
.media-panel[data-tone="process"]{--media-accent:var(--accent-process)}
.media-panel[data-tone="work"]{--media-accent:var(--accent-work)}
.media-panel[data-tone="contact"]{--media-accent:var(--accent-contact)}
.media-panel--hero{min-height:210px;display:flex;flex-direction:column;justify-content:flex-end}
.media-panel--tall{min-height:260px;display:flex;flex-direction:column;justify-content:flex-end}
.media-kicker{margin:0 0 10px;font-size:var(--label);letter-spacing:.18em;text-transform:uppercase;color:color-mix(in srgb, var(--media-accent, var(--section-accent, var(--accent))) 48%, var(--text-1))}
.media-title{margin:0;font-size:clamp(22px, 2.4vw, 32px);line-height:1.08;letter-spacing:-.04em;text-wrap:balance}
.media-copy{margin:10px 0 0;font-size:15px;color:var(--text-1);max-width:42ch}
.media-tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}
.media-tags span{font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-0);padding:5px 8px;border-radius:999px;border:1px solid hsl(220 18% 100%/.08);background:hsl(220 18% 100%/.04)}
.split{display:grid;grid-template-columns:1.15fr .85fr;gap:14px;align-items:start}
.split--services{grid-template-columns:1fr 1fr}
.stack{display:flex;flex-direction:column;gap:14px}.stack--xl{gap:16px}.aside-stack{display:flex;flex-direction:column;gap:14px}.copy-block{display:flex;flex-direction:column;gap:8px}.copy-block p{margin:0;color:var(--text-1);font-size:var(--body)}
.domain-grid,.triple-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:10px}.triple-list{grid-template-columns:repeat(3,minmax(0,1fr))}
.mini-card{padding:16px;background:radial-gradient(220px 160px at 0% 0%, color-mix(in srgb, var(--section-accent, var(--accent)) 11%, transparent), transparent 60%),hsl(220 18% 10%/.45)}.mini-card--tight{padding:15px}
.bullets{margin:12px 0 0;padding:0 0 0 18px;color:var(--text-1)}.bullets li{margin:8px 0}.bullets.compact{margin-top:8px}.bullets.compact li{margin:6px 0}
.grouped-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:8px}.two-col-list{columns:2;column-gap:20px}.support-note{margin:14px 0 0;color:var(--text-1);font-size:15px}.support-note--foot{margin-top:18px;font-size:14px}
.metric-card{padding-bottom:16px}.metric-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}.metric-grid--wide{grid-template-columns:repeat(4,minmax(0,1fr))}
.metric{border:1px solid hsl(220 18% 100%/.08);border-radius:22px;padding:14px;background:linear-gradient(180deg, hsl(220 18% 8%/.56), hsl(220 18% 8%/.42));min-height:106px;display:flex;flex-direction:column;justify-content:space-between}.metric-value{font-size:clamp(30px, 2vw, 36px);font-weight:800;line-height:1;letter-spacing:-.05em}.metric-label{font-size:var(--small);color:var(--text-1)}
.gallery{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px}.gallery--team{grid-template-columns:repeat(3,minmax(0,1fr))}
.tile{padding:12px;cursor:pointer;display:flex;flex-direction:column;gap:12px;text-align:left;transition:transform .18s ease, border-color .18s ease}.tile:hover{transform:translateY(-2px)}.tile .t{font-size:15px;letter-spacing:.08em;text-transform:uppercase;font-weight:800}.tile .g{font-size:13px;color:var(--text-1)}.tile-meta{display:flex;flex-direction:column;gap:7px}
.thumb{height:130px;border-radius:var(--r-md);border:1px solid hsl(220 18% 100%/.10);background:radial-gradient(140px 120px at 30% 35%, color-mix(in srgb, var(--section-accent, var(--accent)) 24%, transparent), transparent 62%),radial-gradient(180px 140px at 80% 75%, hsl(220 18% 100%/.10), transparent 70%),linear-gradient(180deg, hsl(220 18% 12%/.70), hsl(220 18% 10%/.70))}
.thumb--portrait{height:190px;background:radial-gradient(90px 90px at 50% 28%, hsl(220 18% 100%/.17), transparent 56%),radial-gradient(180px 160px at 50% 95%, color-mix(in srgb, var(--accent) 22%, transparent), transparent 62%),linear-gradient(180deg, hsl(220 18% 12%/.78), hsl(220 18% 9%/.82));position:relative;overflow:hidden}
.thumb--portrait::before{content:"";position:absolute;inset:0;background:radial-gradient(42px 42px at 50% 34%, hsl(220 18% 100%/.15), transparent 60%),radial-gradient(86px 56px at 50% 72%, hsl(220 18% 100%/.06), transparent 68%),linear-gradient(180deg, transparent 0%, hsl(220 18% 100%/.04) 100%)}
.thumb-1{--accent:var(--accent-about)}.thumb-2{--accent:var(--accent-process)}.thumb-3{--accent:var(--accent-services)}.thumb-4{--accent:var(--accent-work)}.thumb-5{--accent:var(--accent-contact)}.thumb-6{--accent:var(--accent-home)}.thumb-7{--accent:hsl(140 62% 54%)}.thumb-8{--accent:hsl(26 80% 60%)}
.tag-row{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}.mini-tag{font-size:12px;letter-spacing:.06em;text-transform:uppercase;color:var(--text-1);padding:4px 8px;border-radius:999px;border:1px solid hsl(220 18% 100%/.08);background:hsl(220 18% 100%/.03)}
.stepper{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:12px}.step{display:flex;gap:12px;padding:16px;align-items:flex-start}
.badge{width:44px;height:44px;border-radius:15px;display:grid;place-items:center;background:color-mix(in srgb, var(--section-accent, var(--accent)) 16%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 22%, transparent);font-size:13px;letter-spacing:.12em;flex:0 0 auto}.st{font-size:14px;letter-spacing:.10em;text-transform:uppercase;margin-bottom:8px}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px;align-items:start}.two--contact{grid-template-columns:minmax(280px,.9fr) minmax(320px,1.1fr)}
.row{display:flex;justify-content:space-between;gap:12px;padding:10px 0;border-bottom:1px solid hsl(220 18% 100%/.07)}.row:last-of-type{border-bottom:0}.k{font-size:var(--label);letter-spacing:.10em;text-transform:uppercase;color:var(--text-1)}.v{font-size:14px;max-width:60%;text-align:right}.inquiry-card{display:flex;flex-direction:column;gap:0}.inquiry-card .h2{margin-bottom:8px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:0 14px}.field{display:flex;flex-direction:column;gap:8px;margin-bottom:14px}.field--full{grid-column:1 / -1}
label{font-size:var(--label);letter-spacing:.10em;text-transform:uppercase;color:var(--text-1)}
input,select,textarea{width:100%;border-radius:16px;border:1px solid hsl(220 18% 100%/.12);background:linear-gradient(180deg, hsl(220 18% 8%/.58), hsl(220 18% 8%/.48));color:var(--text-0);padding:14px 14px;font-size:16px;outline:none}
select{appearance:none;background-image:linear-gradient(45deg, transparent 50%, var(--text-1) 50%), linear-gradient(135deg, var(--text-1) 50%, transparent 50%);background-position:calc(100% - 22px) calc(50% - 2px), calc(100% - 16px) calc(50% - 2px);background-size:6px 6px, 6px 6px;background-repeat:no-repeat}
textarea{resize:vertical;min-height:170px}
input[aria-invalid="true"],select[aria-invalid="true"],textarea[aria-invalid="true"]{border-color:color-mix(in srgb, var(--accent-contact) 55%, transparent)}
.err{min-height:18px;font-size:13px;color:color-mix(in srgb, var(--accent-contact) 72%, hsl(0 0% 100%))}
.checks{margin:6px 0 16px;padding:0;border:0;display:grid;gap:10px}.check{display:flex;align-items:flex-start;gap:10px;font-size:14px;color:var(--text-1);padding:10px 12px;border-radius:16px;border:1px solid hsl(220 18% 100%/.08);background:hsl(220 18% 100%/.03)}.check input{width:18px;height:18px;margin-top:1px;accent-color:var(--accent-contact);padding:0}
.primary{width:100%;min-height:48px;border-radius:999px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 35%, transparent);background:linear-gradient(180deg, color-mix(in srgb, var(--section-accent, var(--accent)) 22%, hsl(220 18% 12%)), hsl(220 18% 12%));color:var(--text-0);font-size:var(--label);letter-spacing:.14em;text-transform:uppercase;cursor:pointer}.primary--compact{width:auto;padding:0 18px;min-height:42px}.note{margin-top:10px;font-size:13px;color:var(--text-1);min-height:18px}
.legal-card{display:flex;flex-direction:column;gap:16px}.legal-card p{margin:0;color:var(--text-1)}
.cookie-table{margin-top:4px;border:1px solid hsl(220 18% 100%/.08);border-radius:22px;overflow:hidden}.cookie-row{display:grid;grid-template-columns:1.1fr 2fr .8fr;gap:10px;padding:12px 14px;border-top:1px solid hsl(220 18% 100%/.06)}.cookie-row:first-child{border-top:0;background:hsl(220 18% 100%/.04);font-size:12px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-1)}
.cookie-banner{position:fixed;left:20px;bottom:20px;z-index:90;width:min(470px, calc(100vw - 20px))}.cookie-banner[hidden]{display:none}
.cookie-banner__inner{border:1px solid hsl(220 18% 100%/.10);border-radius:28px;background:radial-gradient(220px 160px at 12% 18%, hsl(198 85% 52%/.12), transparent 60%),radial-gradient(220px 160px at 90% 90%, hsl(282 84% 62%/.10), transparent 62%),linear-gradient(180deg, hsl(220 18% 100%/.06), hsl(220 18% 100%/.03)),hsl(224 26% 7% / .82);backdrop-filter:blur(18px);box-shadow:0 24px 80px hsl(220 38% 2%/.45);padding:18px}
.cookie-banner__eyebrow{margin:0 0 8px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-1)}.cookie-banner__title{margin:0;font-size:clamp(21px, 2vw, 28px);line-height:1.08;letter-spacing:-.04em}.cookie-banner__text{margin:10px 0 0;color:var(--text-1);font-size:14px}.cookie-banner__links{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}.cookie-banner__links a{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--text-1)}.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}
.portal{position:fixed;inset:0;pointer-events:none;z-index:40;opacity:0;background:radial-gradient(900px 700px at 30% 25%, color-mix(in srgb, var(--accent) 18%, transparent), transparent 60%),radial-gradient(900px 700px at 75% 55%, color-mix(in srgb, var(--accent) 12%, transparent), transparent 70%);will-change:opacity}.portal.on{opacity:1}
.particles{position:fixed;inset:0;pointer-events:none;z-index:60;opacity:0}.particles.on{opacity:1}.p{position:absolute;width:12px;height:12px;border-radius:999px;background:radial-gradient(circle at 32% 30%, hsl(220 18% 100%/.70), hsl(220 18% 100%/.10) 32%, color-mix(in srgb, var(--accent) 42%, transparent) 65%, transparent 76%),radial-gradient(circle at 62% 70%, color-mix(in srgb, var(--accent) 55%, transparent), transparent 70%);border:1px solid color-mix(in srgb, var(--accent) 42%, transparent);opacity:0;transform:translate3d(var(--px), var(--py), 0) scale(.5);will-change:transform, opacity}
.dlg{position:fixed;inset:0;z-index:80;display:grid;place-items:center}.dlg[hidden]{display:none}.dlg-back{position:absolute;inset:0;background:hsl(220 30% 2%/.62);backdrop-filter:blur(10px)}.dlg-panel{width:min(620px, calc(100vw - 24px));border-radius:var(--r-xl);border:1px solid var(--stroke);background:hsl(220 18% 10%/.88);box-shadow:var(--shadow);padding:16px}.dlg-top{display:flex;align-items:flex-start;justify-content:space-between;gap:14px}.icon,.pill{height:44px;border-radius:999px;border:1px solid var(--stroke);background:hsl(220 18% 100%/.04);color:var(--text-0);cursor:pointer;display:grid;place-items:center}.icon{width:44px;flex:0 0 auto}.pill{padding:0 16px;display:inline-flex;align-items:center;gap:10px;background:hsl(220 18% 12% / .55);backdrop-filter:blur(10px)}.dlg-body{margin-top:14px}.dlg-body .bullets{margin-top:10px}.dlg-actions{margin-top:14px;display:flex;justify-content:flex-end}
.enter-in{animation:enterIn 300ms ease-out both}@keyframes enterIn{from{opacity:0}to{opacity:1;transform:translate3d(0,0,0)}}
@supports (clip-path: circle(10px at 10px 10px)){.portal{clip-path:circle(var(--pr) at var(--px) var(--py))}}
@media (min-width: 1280px){.home-header{width:min(580px, calc(100vw - 520px));top:55.5%}.home-subtitle{max-width:22ch}}
@media (max-width: 980px){.hero--wide{grid-template-columns:1fr}.cards--supporting{grid-template-columns:1fr}}
@media (max-width: 960px){.split,.split--services,.two,.two--contact{grid-template-columns:1fr}}
@media (max-width: 920px){.metric-grid--wide{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 900px){.media-grid--triple{grid-template-columns:1fr}}
@media (max-width: 840px){.cards,.cards--services{grid-template-columns:1fr}.home-header{width:min(620px, calc(100vw - 48px));top:52%}}
@media (max-width: 760px){.domain-grid,.grouped-list,.form-grid{grid-template-columns:1fr}.field--full{grid-column:auto}.two-col-list{columns:1}}
@media (max-width: 820px) and (orientation: portrait){.gallery,.gallery--team{grid-template-columns:1fr}.home-header{top:24px;transform:translateX(-50%);width:min(calc(100vw - 26px), 620px)}.home-kicker{font-size:11px;margin-bottom:8px;letter-spacing:.24em}.home-title{max-width:none;font-size:clamp(46px, 11vw, 82px);line-height:.95}.home-subtitle{font-size:clamp(15px, 3vw, 19px);max-width:19ch;margin-top:12px}.bubble-label{font-size:12px}.bubble-sub{display:none}.site-footer{width:calc(100vw - 18px);bottom:10px;padding:7px 8px;gap:6px}.footer-link{min-height:30px;padding:0 10px;font-size:11px}.row{flex-direction:column;align-items:flex-start}.v{max-width:none;text-align:left}.cookie-banner{left:9px;bottom:72px;width:calc(100vw - 18px)}.cookie-banner__actions{display:grid;grid-template-columns:1fr}}
@media (max-width: 520px){.metric-grid{grid-template-columns:1fr}.cookie-row{grid-template-columns:1fr}}
@media (prefers-reduced-motion: reduce){.bubble-sub,.tile{transition:none}}


/* Footer legal bubbles */
.site-footer{
  left:50%;
  bottom:18px;
  transform:translateX(-50%);
  z-index:5;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:14px;
  width:auto;
  padding:0;
  border:0;
  border-radius:0;
  background:none;
  backdrop-filter:none;
  box-shadow:none;
}
.footer-link--bubble{
  --legal-c:hsl(220 18% 88%);
  position:relative;
  width:74px;
  height:74px;
  min-height:74px;
  padding:0;
  border-radius:50%;
  border:1px solid color-mix(in srgb, var(--legal-c) 34%, rgba(255,255,255,.96));
  background:
    radial-gradient(48px 42px at 34% 24%, hsl(220 18% 100%/.26), transparent 58%),
    radial-gradient(72px 72px at 58% 60%, color-mix(in srgb, var(--legal-c) 12%, transparent), transparent 70%),
    linear-gradient(180deg, hsl(220 18% 100%/.08), hsl(220 18% 100%/.02) 28%),
    radial-gradient(circle at 50% 54%, hsl(220 18% 100%/.06), transparent 72%);
  color:hsl(220 20% 90% / .92);
  box-shadow:0 18px 48px rgba(8,18,34,.28), inset 0 0 0 1px hsl(220 18% 100%/.10), inset 0 -12px 28px hsl(220 18% 100%/.03), 0 0 0 1px hsl(220 18% 100%/.08);
  backdrop-filter:blur(14px);
  overflow:hidden;
}
.footer-link--bubble::before{
  content:"";
  position:absolute;
  inset:8px;
  border-radius:inherit;
  border:1px solid hsl(220 18% 100%/.14);
  opacity:.62;
}
.footer-link--bubble::after{
  content:"";
  position:absolute;
  left:50%;
  top:104%;
  width:58%;
  height:12px;
  transform:translateX(-50%);
  border-radius:999px;
  background:radial-gradient(circle at 50% 50%, hsl(220 28% 2%/.58), transparent 70%);
  opacity:.64;
}
.footer-link--bubble span{
  position:relative;
  z-index:1;
  display:inline-block;
  max-width:56px;
  text-align:center;
  font-size:11px;
  line-height:1.15;
  letter-spacing:.12em;
  text-transform:uppercase;
  font-weight:800;
  text-shadow:0 8px 24px hsl(220 30% 2%/.4);
}
.footer-link--bubble:hover{
  background:
    radial-gradient(48px 42px at 34% 24%, hsl(220 18% 100%/.32), transparent 58%),
    radial-gradient(72px 72px at 58% 60%, color-mix(in srgb, var(--legal-c) 18%, transparent), transparent 70%),
    linear-gradient(180deg, hsl(220 18% 100%/.10), hsl(220 18% 100%/.03) 28%),
    radial-gradient(circle at 50% 54%, hsl(220 18% 100%/.07), transparent 72%);
  color:hsl(220 24% 97%);
}

/* About page refinement */
.eyebrow,.card-kicker{
  margin:0 0 10px;
  font-size:12px;
  letter-spacing:.18em;
  text-transform:uppercase;
  color:color-mix(in srgb, var(--section-accent, var(--accent)) 52%, var(--text-1));
}
.about-hero{align-items:center}
.about-hero-copy{max-width:680px}
.about-hero-copy .lede{max-width:34ch;font-size:clamp(17px,1.28vw,21px)}
.about-portrait{min-height:390px}
.about-main{
  display:grid;
  grid-template-columns:minmax(0,1.04fr) minmax(320px,.96fr);
  gap:14px;
  align-items:start;
}
.about-stack,.about-rail{display:grid;gap:14px;align-items:start}
.about-operating-card p{margin:0;color:var(--text-1)}
.about-operating{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  margin-top:16px;
}
.about-mode{
  position:relative;
  padding:14px;
  border-radius:22px;
  border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 12%, var(--stroke));
  background:linear-gradient(180deg, hsl(220 18% 100%/.04), hsl(220 18% 100%/.02));
}
.about-mode__index{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:34px;
  height:34px;
  border-radius:999px;
  margin-bottom:12px;
  font-size:12px;
  font-weight:800;
  letter-spacing:.14em;
  color:var(--text-0);
  background:color-mix(in srgb, var(--section-accent, var(--accent)) 20%, hsl(220 18% 100%/.04));
  border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 20%, transparent);
}
.about-mode h3{margin:0 0 8px;font-size:18px;line-height:1.15}
.about-mode p{margin:0;font-size:15px;line-height:1.55;color:var(--text-1)}
.domain-grid--about{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px}
.domain-tile{padding:16px;display:flex;flex-direction:column;gap:8px}
.domain-tile h3{margin:0;font-size:18px;line-height:1.18}
.domain-tile p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.about-snapshot .h2,.about-applications .h2{margin-bottom:10px}
.about-bullets{margin:0}
.about-environment{min-height:280px}
.about-metric-card{padding-top:18px}
.about-pairs{display:grid;gap:14px;margin-top:10px}
.about-pairs div{padding:12px 0;border-top:1px solid hsl(220 18% 100%/.07)}
.about-pairs div:first-child{padding-top:0;border-top:0}
.about-pairs strong{display:block;margin-bottom:6px;font-size:15px;letter-spacing:.09em;text-transform:uppercase;color:var(--text-0)}
.about-pairs p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.about-bottom{
  display:grid;
  grid-template-columns:minmax(0,1.02fr) minmax(320px,.98fr);
  gap:14px;
  align-items:stretch;
}
.about-bench-story{min-height:300px}
.about-values{margin-top:12px}
.view-about .page{gap:16px}
.view-about .metric .metric-value{font-size:clamp(28px,2.5vw,38px)}
.view-about .metric .metric-label{font-size:13px;line-height:1.4}

@media (max-width: 1080px){
  .about-main,.about-bottom{grid-template-columns:1fr}
}
@media (max-width: 840px){
  .about-operating,.domain-grid--about,.about-values{grid-template-columns:1fr}
}
@media (max-width: 820px) and (orientation: portrait){
  .site-footer{gap:10px;bottom:12px}
  .footer-link--bubble{width:64px;height:64px;min-height:64px}
  .footer-link--bubble span{max-width:48px;font-size:10px;letter-spacing:.11em}
}
@media (max-width: 520px){
  .site-footer{gap:8px}
  .footer-link--bubble{width:60px;height:60px;min-height:60px}
  .footer-link--bubble span{max-width:44px;font-size:9.5px}
}


/* Services page refinement */
.services-hero{align-items:center}
.services-hero-copy{max-width:680px}
.services-hero-copy .lede{max-width:36ch;font-size:clamp(17px,1.28vw,21px)}
.services-overview{min-height:390px}
.services-framework{display:grid;grid-template-columns:minmax(0,.98fr) minmax(0,1.02fr);gap:14px;align-items:stretch}
.service-architecture,.service-scope-card,.service-output-card,.service-goals-card{height:100%}
.service-intro{margin:0;color:var(--text-1)}
.service-lanes{display:grid;gap:12px;margin-top:16px}
.service-lane{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:14px;border-radius:22px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 12%, var(--stroke));background:linear-gradient(180deg, hsl(220 18% 100%/.04), hsl(220 18% 100%/.02))}
.service-lane__index{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:color-mix(in srgb, var(--section-accent, var(--accent)) 20%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 22%, transparent);font-size:12px;font-weight:800;letter-spacing:.14em}
.service-lane h3{margin:0 0 6px;font-size:18px;line-height:1.18}
.service-lane p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.service-scope-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
.service-mini{display:flex;flex-direction:column;gap:8px}
.service-mini h3{margin:0;font-size:18px;line-height:1.18}
.service-mini p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.service-sector-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:stretch}
.service-sector{min-height:280px}
.service-modules{display:grid;gap:14px}
.service-modules__head{display:flex;align-items:end;justify-content:space-between;gap:16px}
.service-modules__head .h2{max-width:18ch}
.service-modules__note{max-width:34ch;margin:0;text-align:right}
.service-module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.service-tile{position:relative;min-height:280px;padding:18px;justify-content:flex-start;background:radial-gradient(220px 160px at 0% 0%, color-mix(in srgb, var(--section-accent, var(--accent)) 13%, transparent), transparent 60%),radial-gradient(220px 160px at 100% 0%, hsl(220 18% 100%/.06), transparent 70%),linear-gradient(180deg, hsl(220 18% 100%/.05), hsl(220 18% 100%/.02) 24%),hsl(220 18% 10%/.58);overflow:hidden}
.service-tile::before{content:"";position:absolute;right:-22px;top:-22px;width:132px;height:132px;border-radius:50%;background:radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--section-accent, var(--accent)) 22%, transparent), transparent 68%);opacity:.72;pointer-events:none}
.service-tile__top{display:flex;align-items:center;gap:10px;position:relative;z-index:1}
.service-tile__index{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:14px;background:color-mix(in srgb, var(--section-accent, var(--accent)) 18%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 20%, transparent);font-size:12px;font-weight:800;letter-spacing:.14em}
.service-tile__eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb, var(--section-accent, var(--accent)) 48%, var(--text-1))}
.service-tile__title{position:relative;z-index:1;display:block;margin-top:12px;font-size:clamp(25px,2.1vw,36px);line-height:1.02;letter-spacing:-.045em;font-weight:850;max-width:13ch}
.service-tile .tile-copy{position:relative;z-index:1;margin-top:10px;font-size:16px;line-height:1.62;max-width:40ch}
.service-tile .tag-row{position:relative;z-index:1;margin-top:auto;padding-top:12px}
.service-tile__cta{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;margin-top:12px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-0);opacity:.84}
.service-tile__cta::after{content:"↗";font-size:14px;line-height:1}
.service-tile:hover .service-tile__cta,.service-tile:focus-visible .service-tile__cta{opacity:1}
.services-bottom{align-items:stretch}
.service-grouped-list{margin-top:10px}
.services-rail{height:100%}
.service-cta-panel{min-height:260px}
.view-services .page{gap:18px}
.view-services .h2{max-width:22ch}

@media (max-width: 1080px){
  .services-framework,.services-bottom{grid-template-columns:1fr}
}
@media (max-width: 980px){
  .service-sector-grid{grid-template-columns:1fr}
}
@media (max-width: 840px){
  .service-module-grid,.service-scope-grid{grid-template-columns:1fr}
  .service-modules__head{align-items:flex-start;flex-direction:column}
  .service-modules__note{text-align:left;max-width:none}
}


/* Process page refinement */
.process-hero{align-items:center}
.process-hero-copy{max-width:700px}
.process-hero-copy .lede{max-width:36ch;font-size:clamp(17px,1.28vw,21px)}
.process-overview{min-height:390px}
.process-framework{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,.98fr);gap:14px;align-items:stretch}
.process-architecture,.process-lab-card,.process-support-card,.process-metric-card{height:100%}
.process-intro{margin:0;color:var(--text-1)}
.process-lanes{display:grid;gap:12px;margin-top:16px}
.process-lane{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:14px;border-radius:22px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 12%, var(--stroke));background:linear-gradient(180deg, hsl(220 18% 100%/.04), hsl(220 18% 100%/.02))}
.process-lane__index{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:color-mix(in srgb, var(--section-accent, var(--accent)) 20%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 22%, transparent);font-size:12px;font-weight:800;letter-spacing:.14em}
.process-lane h3{margin:0 0 6px;font-size:18px;line-height:1.18}
.process-lane p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.process-lab-grid{display:grid;gap:12px;margin-top:16px}
.process-mini{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start}
.process-mini__icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:14px;background:color-mix(in srgb, var(--section-accent, var(--accent)) 18%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 20%, transparent);font-size:18px;line-height:1;color:var(--text-0)}
.process-mini h3{margin:0 0 6px;font-size:18px;line-height:1.18}
.process-mini p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.process-media-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;align-items:stretch}
.process-media-card{min-height:290px}
.process-modules{display:grid;gap:14px}
.process-modules__head{display:flex;align-items:end;justify-content:space-between;gap:16px}
.process-modules__head .h2{max-width:20ch}
.process-modules__note{max-width:34ch;margin:0;text-align:right}
.process-module-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.process-tile{position:relative;min-height:272px;padding:18px;justify-content:flex-start;background:radial-gradient(220px 160px at 0% 0%, color-mix(in srgb, var(--section-accent, var(--accent)) 13%, transparent), transparent 60%),radial-gradient(180px 140px at 100% 0%, hsl(220 18% 100%/.06), transparent 70%),linear-gradient(180deg, hsl(220 18% 100%/.05), hsl(220 18% 100%/.02) 24%),hsl(220 18% 10%/.58);overflow:hidden}
.process-tile::before{content:"";position:absolute;right:-20px;top:-20px;width:124px;height:124px;border-radius:50%;background:radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--section-accent, var(--accent)) 22%, transparent), transparent 68%);opacity:.72;pointer-events:none}
.process-tile__top{display:flex;align-items:center;gap:10px;position:relative;z-index:1}
.process-tile__index{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:14px;background:color-mix(in srgb, var(--section-accent, var(--accent)) 18%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 20%, transparent);font-size:12px;font-weight:800;letter-spacing:.14em}
.process-tile__eyebrow{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb, var(--section-accent, var(--accent)) 48%, var(--text-1))}
.process-tile__title{position:relative;z-index:1;display:block;margin-top:12px;font-size:clamp(24px,2vw,34px);line-height:1.03;letter-spacing:-.043em;font-weight:850;max-width:14ch}
.process-tile .tile-copy{position:relative;z-index:1;margin-top:10px;font-size:16px;line-height:1.62;max-width:39ch}
.process-tile .tag-row{position:relative;z-index:1;margin-top:auto;padding-top:12px}
.process-tile__cta{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;margin-top:12px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-0);opacity:.84}
.process-tile__cta::after{content:"↗";font-size:14px;line-height:1}
.process-tile:hover .process-tile__cta,.process-tile:focus-visible .process-tile__cta{opacity:1}
.process-grouped-list{margin-top:10px}
.process-rail{height:100%}
.process-cta-panel{min-height:250px}
.view-process .page{gap:18px}
.view-process .h2{max-width:22ch}

@media (max-width: 1080px){
  .process-framework,.process-bottom{grid-template-columns:1fr}
}
@media (max-width: 980px){
  .process-media-grid{grid-template-columns:1fr}
}
@media (max-width: 840px){
  .process-module-grid{grid-template-columns:1fr}
  .process-modules__head{align-items:flex-start;flex-direction:column}
  .process-modules__note{text-align:left;max-width:none}
}


/* Work page refinement */
.work-hero{align-items:center}
.work-hero-copy{max-width:700px}
.work-hero-copy .lede{max-width:37ch;font-size:clamp(17px,1.28vw,21px)}
.work-overview{min-height:390px}
.work-framework{display:grid;grid-template-columns:minmax(0,1.02fr) minmax(0,.98fr);gap:14px;align-items:stretch}
.work-architecture,.work-capability-card,.work-metric-card,.work-expertise-card,.work-story{height:100%}
.work-intro{margin:0;color:var(--text-1)}
.work-lanes{display:grid;gap:12px;margin-top:16px}
.work-lane{display:grid;grid-template-columns:auto 1fr;gap:12px;align-items:start;padding:14px;border-radius:22px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 12%, var(--stroke));background:linear-gradient(180deg, hsl(220 18% 100%/.04), hsl(220 18% 100%/.02))}
.work-lane__index{display:inline-flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:999px;background:color-mix(in srgb, var(--section-accent, var(--accent)) 20%, hsl(220 18% 100%/.04));border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 22%, transparent);font-size:12px;font-weight:800;letter-spacing:.14em}
.work-lane h3{margin:0 0 6px;font-size:18px;line-height:1.18}
.work-lane p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.work-capability-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
.work-mini{display:flex;flex-direction:column;gap:8px}
.work-mini h3{margin:0;font-size:18px;line-height:1.18}
.work-mini p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.work-metric-card{padding-top:18px}
.work-team-section{display:grid;gap:14px}
.work-team-head{display:flex;align-items:end;justify-content:space-between;gap:16px}
.work-team-head .h2{max-width:18ch}
.work-team-note{max-width:36ch;margin:0;text-align:right;color:var(--text-1)}
.gallery--team-refined{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}
.work-tile{position:relative;min-height:100%;padding:14px;gap:14px;justify-content:flex-start;background:radial-gradient(220px 160px at 0% 0%, color-mix(in srgb, var(--section-accent, var(--accent)) 12%, transparent), transparent 60%),radial-gradient(200px 160px at 100% 0%, hsl(220 18% 100%/.06), transparent 70%),linear-gradient(180deg, hsl(220 18% 100%/.05), hsl(220 18% 100%/.02) 24%),hsl(220 18% 10%/.58);overflow:hidden}
.work-tile::before{content:"";position:absolute;right:-22px;top:-24px;width:128px;height:128px;border-radius:50%;background:radial-gradient(circle at 50% 50%, color-mix(in srgb, var(--section-accent, var(--accent)) 18%, transparent), transparent 68%);opacity:.72;pointer-events:none}
.work-tile .thumb--portrait{height:228px;border-radius:28px;border-color:color-mix(in srgb, var(--section-accent, var(--accent)) 12%, hsl(220 18% 100%/.14))}
.work-role-kicker{position:relative;z-index:1;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb, var(--section-accent, var(--accent)) 48%, var(--text-1))}
.work-tile .t{position:relative;z-index:1;font-size:22px;line-height:1.04;letter-spacing:-.03em;text-transform:none;font-weight:850}
.work-tile .g{position:relative;z-index:1;font-size:14px;color:var(--text-0)}
.work-tile .tile-copy{position:relative;z-index:1;font-size:15px;line-height:1.6}
.work-tile .tag-row{position:relative;z-index:1;margin-top:auto;padding-top:4px}
.work-tile__cta{position:relative;z-index:1;display:inline-flex;align-items:center;gap:8px;margin-top:10px;font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-0);opacity:.84}
.work-tile__cta::after{content:"↗";font-size:14px;line-height:1}
.work-tile:hover .work-tile__cta,.work-tile:focus-visible .work-tile__cta{opacity:1}
.work-bottom{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.94fr);gap:14px;align-items:stretch}
.work-expertise-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:14px}
.work-cluster{display:flex;flex-direction:column;gap:8px}
.work-cluster h3{margin:0;font-size:18px;line-height:1.18}
.work-cluster p{margin:0;font-size:15px;line-height:1.58;color:var(--text-1)}
.work-rail{display:grid;gap:14px}
.work-story{min-height:250px}
.view-work .page{gap:18px}

@media (max-width: 1180px){
  .gallery--team-refined{grid-template-columns:repeat(3,minmax(0,1fr))}
}
@media (max-width: 1080px){
  .work-framework,.work-bottom{grid-template-columns:1fr}
}
@media (max-width: 920px){
  .work-team-head{flex-direction:column;align-items:flex-start}
  .work-team-note{text-align:left;max-width:none}
  .gallery--team-refined{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 760px){
  .work-capability-grid,.work-expertise-grid{grid-template-columns:1fr}
}
@media (max-width: 640px){
  .gallery--team-refined{grid-template-columns:1fr}
  .work-tile .thumb--portrait{height:210px}
  .work-tile .t{font-size:20px}
}


/* v9 polish: mobile lift, desktop legal column, dark selects, visible dialogs */
.home-header{width:min(760px, calc(100vw - 180px))}
.home-title{max-width:none;font-size:clamp(64px, 7.4vw, 112px)}
.home-subtitle{max-width:20ch}

.dlg{padding:18px}
.dlg-back{background:hsl(220 30% 2%/.66);backdrop-filter:blur(12px) saturate(1.05)}
.dlg-panel{position:relative;z-index:2;width:min(760px, calc(100vw - 34px));max-height:min(84vh, 760px);overflow:auto;padding:20px 20px 18px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 16%, var(--stroke));background:radial-gradient(340px 220px at 12% 0%, color-mix(in srgb, var(--section-accent, var(--accent)) 14%, transparent), transparent 62%),linear-gradient(180deg, hsl(220 18% 100%/.06), hsl(220 18% 100%/.03) 22%),hsl(223 24% 10% / .94);box-shadow:0 32px 110px hsl(220 40% 2%/.56), inset 0 1px 0 hsl(220 18% 100%/.05)}
.dlg-top{position:sticky;top:0;z-index:3;padding-bottom:14px;margin-bottom:2px;background:linear-gradient(180deg, hsl(223 24% 10% / .98), hsl(223 24% 10% / .84) 72%, transparent);backdrop-filter:blur(8px)}
.dlg-body{margin-top:6px;display:grid;gap:14px}
.dlg-body .lede{margin:0;max-width:none}
.dlg-body .bullets{margin:0;padding-left:20px;display:grid;gap:10px}
.dlg-body .bullets li{color:var(--text-1);line-height:1.55}
.dlg-actions{position:sticky;bottom:0;padding-top:14px;background:linear-gradient(180deg, transparent, hsl(223 24% 10% / .94) 32%)}
.dlg-statline{display:flex;flex-wrap:wrap;gap:10px}
.dlg-chip{display:inline-flex;align-items:center;min-height:30px;padding:6px 11px;border-radius:999px;border:1px solid color-mix(in srgb, var(--section-accent, var(--accent)) 16%, var(--stroke));background:hsl(220 18% 100%/.04);font-size:12px;letter-spacing:.09em;text-transform:uppercase;color:var(--text-1)}

select,option,optgroup{color-scheme:dark}
select{background-color:hsl(220 18% 10%/.92)}
select option,select optgroup{background:hsl(222 22% 11%);color:hsl(220 18% 95%)}
select:focus,input:focus,textarea:focus{border-color:color-mix(in srgb, var(--section-accent, var(--accent)) 36%, hsl(220 18% 100%/.2));box-shadow:0 0 0 1px color-mix(in srgb, var(--section-accent, var(--accent)) 28%, transparent), 0 0 0 4px color-mix(in srgb, var(--section-accent, var(--accent)) 10%, transparent)}

@media (min-width: 821px){
  .site-footer{left:auto;right:24px;top:50%;bottom:auto;transform:translateY(74px);flex-direction:column;align-items:center;justify-content:center;gap:12px}
  .footer-link--bubble{width:78px;height:78px;min-height:78px}
  .footer-link--bubble span{max-width:58px}
}

@media (max-width: 820px) and (orientation: portrait){
  .home-header{top:20px;width:min(calc(100vw - 26px), 620px)}
  .home-title{font-size:clamp(44px, 10.3vw, 74px);line-height:.96}
  .home-subtitle{max-width:17ch;font-size:clamp(15px, 3.2vw, 19px);margin-top:10px}
  .site-footer{width:auto;left:50%;right:auto;bottom:10px;transform:translateX(-50%);flex-direction:row;gap:8px}
  .footer-link--bubble{width:70px;height:70px;min-height:70px}
  .footer-link--bubble span{max-width:52px;font-size:10px}
  .dlg{padding:10px}
  .dlg-panel{width:min(100%, calc(100vw - 18px));max-height:min(88vh, 800px);padding:16px 15px 14px}
}

@media (max-width: 420px){
  .footer-link--bubble{width:64px;height:64px;min-height:64px}
}


/* v11 home spacing refinements */
@media (min-width: 821px){
  .home-header{
    top:49%;
    width:min(760px, calc(100vw - 180px));
  }
}

@media (max-width: 820px) and (orientation: portrait){
  .home-header{
    top:12px;
    transform:translateX(-50%);
    width:min(calc(100vw - 24px), 620px);
  }
  .home-title{
    font-size:clamp(42px, 9.8vw, 72px);
    line-height:.95;
  }
}

@media (max-width: 820px) and (orientation: portrait) and (max-height: 760px){
  .home-header{top:8px}
}


/* ===== v12 polish fixes ===== */
html,body{overflow-x:hidden}
.view-page,.page{overflow-x:hidden}
.page{width:min(1220px,100%);gap:24px;padding-top:clamp(84px,8vw,104px);padding-bottom:64px}
.hero--wide{gap:22px;grid-template-columns:minmax(0,1.02fr) minmax(360px,.98fr)}
.tile{color:var(--text-0)}
.tile .t,.service-tile__title,.process-tile__title,.work-tile .t{color:var(--text-0)}
.tile .g,.work-role-kicker,.work-tile .g,.service-tile .tile-copy,.process-tile .tile-copy,.work-tile .tile-copy{color:var(--text-1)}
.service-modules__head,.process-modules__head,.work-team-head{align-items:flex-end;gap:20px}
.service-modules__head .h2,.process-modules__head .h2,.work-team-head .h2{max-width:16ch}
.service-modules__note,.process-modules__note,.work-team-note{max-width:32ch;line-height:1.55}
.service-module-grid,.process-module-grid{align-items:stretch}
.service-tile,.process-tile{min-height:308px}
.gallery--team-refined{align-items:stretch}
.work-tile{min-height:100%;padding:16px}
.work-tile .thumb--portrait{height:236px}
.work-tile .tile-copy{min-height:7.2em}
.work-tile .tag-row{margin-top:auto;padding-top:8px}
.work-tile__cta,.service-tile__cta,.process-tile__cta{margin-top:14px}
.home-header{top:50.2%;width:min(620px,calc(100vw - 560px))}
.home-title{max-width:9.2ch}
.site-footer{right:24px;left:auto;bottom:38px;transform:none;flex-direction:column;gap:16px;align-items:flex-end}
.footer-link--bubble{width:78px;height:78px;min-height:78px}
.footer-link--bubble span{font-size:12px;max-width:58px}
select,option,optgroup{background:hsl(224 25% 10%);color:var(--text-0)}
select{color-scheme:dark}
.dlg{z-index:120}
.dlg-back{z-index:0;background:hsl(220 34% 3%/.72);backdrop-filter:blur(12px)}
.dlg-panel{position:relative;z-index:1;width:min(760px,calc(100vw - 28px));max-height:min(86vh,860px);overflow:auto;color:var(--text-0);border-color:color-mix(in srgb,var(--accent) 18%, var(--stroke));background:radial-gradient(420px 240px at 100% 0%, color-mix(in srgb, var(--accent) 14%, transparent), transparent 66%),linear-gradient(180deg,hsl(220 18% 100%/.06),hsl(220 18% 100%/.03) 24%),hsl(222 26% 9%/.94)}
.dlg-top,.dlg-body,.dlg-actions{position:relative;z-index:1}
.dlg-top{padding-bottom:10px;border-bottom:1px solid hsl(220 18% 100%/.08)}
.dlg-body{display:grid;gap:14px;padding-top:6px}
.dlg-body .lede{margin:0;color:var(--text-1);font-size:18px;line-height:1.7}
.dlg-body .small{font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:color-mix(in srgb,var(--accent) 42%, var(--text-1))}
.dlg-body .bullets{margin:0;padding-left:18px;display:grid;gap:10px}
.dlg-body .bullets li{color:var(--text-1);line-height:1.62}
.dlg-statline{display:flex;flex-wrap:wrap;gap:8px}
.dlg-chip{display:inline-flex;align-items:center;min-height:30px;padding:6px 12px;border-radius:999px;border:1px solid hsl(220 18% 100%/.10);background:hsl(220 18% 100%/.04);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--text-1)}
.dlg-section{display:grid;gap:8px;padding:14px 16px;border:1px solid hsl(220 18% 100%/.07);border-radius:22px;background:linear-gradient(180deg,hsl(220 18% 100%/.04),hsl(220 18% 100%/.02))}
.dlg-section h3{margin:0;font-size:17px;line-height:1.2;letter-spacing:-.02em;color:var(--text-0)}
.dlg-section p{margin:0;color:var(--text-1);line-height:1.62}
.dlg-columns{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
.dlg-metrics{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}
.dlg-metric{padding:12px 14px;border-radius:18px;border:1px solid hsl(220 18% 100%/.08);background:hsl(220 18% 100%/.03)}
.dlg-metric .k{display:block;margin-bottom:4px;font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--text-1)}
.dlg-metric .v{display:block;max-width:none;text-align:left;font-size:14px;color:var(--text-0)}
@media (max-width: 1460px){.gallery--team-refined{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media (max-width: 1260px){.home-header{width:min(560px,calc(100vw - 460px));top:49.2%}.service-module-grid,.process-module-grid{grid-template-columns:1fr}.gallery--team-refined{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media (max-width: 980px){.service-sector-grid,.process-media-grid{grid-template-columns:1fr}.service-modules__head,.process-modules__head,.work-team-head{grid-template-columns:1fr;display:grid}.service-modules__note,.process-modules__note,.work-team-note{text-align:left;max-width:none}.gallery--team-refined{grid-template-columns:repeat(2,minmax(0,1fr))}.site-footer{right:18px;bottom:20px}}
@media (max-width: 820px) and (orientation: portrait){
  .home-header{top:18px;width:min(calc(100vw - 28px),620px);transform:translateX(-50%)}
  .home-kicker{margin-bottom:10px}
  .home-title{font-size:clamp(44px,10.6vw,78px);max-width:none}
  .site-footer{left:50%;right:auto;bottom:12px;transform:translateX(-50%);flex-direction:row;align-items:center;gap:10px}
  .footer-link--bubble{width:72px;height:72px;min-height:72px}
  .footer-link--bubble span{font-size:11px}
  .gallery--team-refined{grid-template-columns:1fr}
}
@media (max-width: 680px){.dlg-panel{width:min(100vw - 16px,760px)}.dlg-columns,.dlg-metrics{grid-template-columns:1fr}}


/* ===== v13 layout corrections ===== */
.hero--wide > *,
.about-main > *,
.about-bottom > *,
.services-framework > *,
.services-bottom > *,
.process-framework > *,
.process-bottom > *,
.work-framework > *,
.work-bottom > *,
.two--contact > *{min-width:0}

.h1,.h2,.media-title,.service-tile__title,.process-tile__title,.work-tile .t{word-break:normal;overflow-wrap:normal;hyphens:none}
.lede,.media-copy,.tile-copy,.work-team-note,.service-modules__note,.process-modules__note{overflow-wrap:anywhere}

@media (min-width: 821px){
  .home-header{
    top:50%;
    width:min(470px, calc(100vw - 720px));
    transform:translate(-50%,-50%);
  }
  .home-kicker{margin-bottom:14px}
  .home-title{
    font-size:clamp(88px, 7vw, 124px);
    line-height:.90;
    max-width:8.2ch;
  }
  .site-footer{
    right:24px;
    top:50%;
    bottom:auto;
    left:auto;
    transform:translateY(62px);
    gap:14px;
    align-items:center;
  }
}

@media (max-width: 820px) and (orientation: portrait){
  .home-header{
    top:18px;
    transform:translateX(-50%);
    width:min(calc(100vw - 24px), 560px);
  }
  .home-kicker{margin-bottom:8px; font-size:11px; letter-spacing:.24em}
  .home-title{
    font-size:clamp(44px, 10.4vw, 76px);
    line-height:.94;
    max-width:none;
  }
  .site-footer{
    left:50%;
    right:auto;
    bottom:10px;
    top:auto;
    transform:translateX(-50%);
    flex-direction:row;
    gap:8px;
    align-items:center;
  }
  .footer-link--bubble{width:64px;height:64px;min-height:64px}
  .footer-link--bubble span{max-width:46px;font-size:10px;letter-spacing:.10em}
}

@media (max-width: 980px){
  .page{
    width:100%;
    padding:84px 16px 64px;
    gap:16px;
  }
  .hero--wide,
  .about-main,
  .about-bottom,
  .services-framework,
  .services-bottom,
  .process-framework,
  .process-bottom,
  .work-framework,
  .work-bottom,
  .two,
  .two--contact{
    grid-template-columns:1fr !important;
  }
  .hero,
  .work-team-section,
  .services-hero,
  .process-hero,
  .about-hero,
  .work-hero{gap:12px}
  .about-hero-copy,
  .services-hero-copy,
  .process-hero-copy,
  .work-hero-copy,
  .service-modules__note,
  .process-modules__note,
  .work-team-note,
  .lede{max-width:none !important}
  .media-panel--hero,
  .services-overview,
  .process-overview,
  .work-overview,
  .about-portrait{min-height:260px}
  .service-modules__head,
  .process-modules__head,
  .work-team-head{display:flex;flex-direction:column;align-items:flex-start;gap:10px}
}

@media (max-width: 760px){
  .page{padding:78px 14px 60px}
  .h1{font-size:clamp(38px, 10.4vw, 50px)}
  .h2{font-size:clamp(24px, 7vw, 32px)}
  .lede{font-size:17px;line-height:1.6}
  .card,.mini-card,.media-panel,.tile,.step{padding-left:16px;padding-right:16px}
  .process-tile,.service-tile{min-height:unset}
  .thumb--portrait,.work-tile .thumb--portrait{height:210px}
  .work-tile .tile-copy{min-height:0}
}

@media (max-width: 420px){
  .home-title{font-size:clamp(40px, 10vw, 64px)}
  .footer-link--bubble{width:60px;height:60px;min-height:60px}
  .footer-link--bubble span{max-width:42px;font-size:9px}
}


/* ===== v14 home and responsive rebalancing ===== */
@media (min-width: 821px){
  .home-header{
    top:44.8%;
    width:min(520px, calc(100vw - 760px));
    transform:translate(-50%,-50%);
  }
  .home-kicker{margin-bottom:12px}
  .home-title{
    font-size:clamp(92px, 7.1vw, 124px);
    line-height:.90;
    max-width:7.2ch;
  }
  .site-footer{
    right:22px;
    top:50%;
    bottom:auto;
    left:auto;
    transform:translateY(88px);
    gap:14px;
    align-items:center;
  }
}

@media (max-width: 820px) and (orientation: portrait){
  .home-header{
    top:14px;
    width:min(calc(100vw - 22px), 560px);
    transform:translateX(-50%);
  }
  .home-kicker{
    margin-bottom:8px;
    font-size:11px;
    letter-spacing:.24em;
  }
  .home-title{
    font-size:clamp(40px, 10vw, 68px);
    line-height:.94;
    max-width:none;
  }
  .site-footer{
    left:50%;
    right:auto;
    top:auto;
    bottom:8px;
    transform:translateX(-50%);
    flex-direction:row;
    gap:8px;
    align-items:center;
  }
  .footer-link--bubble{
    width:62px;
    height:62px;
    min-height:62px;
  }
  .footer-link--bubble span{
    max-width:44px;
    font-size:9px;
    letter-spacing:.10em;
  }
}

@media (max-width: 1100px){
  .page{
    width:100%;
    padding-left:16px;
    padding-right:16px;
  }
  .hero--wide,
  .about-main,
  .about-bottom,
  .services-framework,
  .services-bottom,
  .process-framework,
  .process-bottom,
  .work-framework,
  .work-bottom,
  .two,
  .two--contact{
    grid-template-columns:1fr !important;
  }
  .hero--wide > *,
  .about-main > *,
  .about-bottom > *,
  .services-framework > *,
  .services-bottom > *,
  .process-framework > *,
  .process-bottom > *,
  .work-framework > *,
  .work-bottom > *,
  .two > *,
  .two--contact > *{
    width:100%;
    max-width:none !important;
    min-width:0;
  }
  .about-hero-copy,
  .services-hero-copy,
  .process-hero-copy,
  .work-hero-copy,
  .lede,
  .media-copy,
  .service-modules__note,
  .process-modules__note,
  .work-team-note{
    max-width:none !important;
  }
}

@media (max-width: 680px){
  .page{padding:76px 14px 60px}
  .hero{gap:12px}
  .media-panel--hero,
  .services-overview,
  .process-overview,
  .work-overview,
  .about-portrait{min-height:240px}
}

@media (max-width: 820px) and (orientation: portrait) {
  .home-header {
    top: clamp(22px, 5svh, 46px) !important;
    width: min(calc(100vw - 24px), 540px) !important;
  }

  .home-title {
    font-size: clamp(30px, 8.9vw, 38px) !important;
    line-height: 1 !important;
    letter-spacing: -0.045em !important;
  }

  .bubble-field {
    height: 100svh;
  }

  .bubble-sub {
    display: none;
  }

  .site-footer {
    bottom: max(10px, env(safe-area-inset-bottom)) !important;
  }
}

@media (max-width: 460px) and (orientation: portrait) {
  .home-kicker {
    font-size: 10px !important;
    letter-spacing: 0.2em !important;
  }

  .home-title {
    font-size: clamp(30px, 8.8vw, 36px) !important;
  }
}

@media (max-width: 820px) and (orientation: portrait) {
  .cookie-banner{
    left:9px;
    right:9px;
    width:auto !important;
    max-width:none;
  }

  .cookie-banner__title,
  .cookie-banner__text{
    overflow-wrap:anywhere;
  }

  .cookie-banner__title{
    font-size:clamp(18px, 5vw, 22px);
    line-height:1.16;
  }
}

@media (max-width: 920px) and (max-height: 500px) and (orientation: landscape) {
  .home-header{
    width:min(300px, calc(100vw - 360px)) !important;
  }

  .home-title{
    font-size:clamp(38px, 7vw, 54px) !important;
    line-height:.92 !important;
  }

  .site-footer{
    left:50% !important;
    right:auto !important;
    top:auto !important;
    bottom:max(8px, env(safe-area-inset-bottom)) !important;
    transform:translateX(-50%) !important;
    flex-direction:row !important;
    gap:8px !important;
    align-items:center !important;
  }

  .footer-link--bubble{
    width:56px !important;
    height:56px !important;
    min-height:56px !important;
  }

  .footer-link--bubble span{
    max-width:40px !important;
    font-size:8.5px !important;
  }
}
