.htm-portfolio{--bg:#000;--paper:#050505;--tile:#0b0b0b;--ink:rgba(238,234,226,0.94);--ink-strong:#f6f3ee;--mute:rgba(238,234,226,0.80);--mute-2:rgba(238,234,226,0.48);--border:rgba(255,255,255,0.14);--border-strong:rgba(255,255,255,0.26);--amber:#f7a835;--amber-soft:rgba(247,168,53,0.55);--amber-bg:rgba(247,168,53,0.06);--space-2xs:4px;--space-xs:8px;--space-sm:14px;--space-md:22px;--space-lg:36px;--space-xl:56px;--space-2xl:96px;--font-sans:var(--font-inter),sans-serif;--font-mono:var(--font-vt323),monospace;--font-display:"argent-pixel-cf",var(--font-vt323),monospace;--font-codey:var(--font-geist-mono),"JetBrains Mono","VT323",monospace;--space-3xl:144px;--ease:cubic-bezier(.16,1,.3,1);--anim-fast:200ms var(--ease);--anim-med:420ms var(--ease);--anim-slow:700ms var(--ease);--mx:50%;--my:50%;scroll-behavior:smooth;background:var(--bg);color:var(--ink);font-family:var(--font-sans);font-weight:300;padding:8px;position:relative}.htm-portfolio,.htm-portfolio *{box-sizing:border-box;margin:0;padding:0}.htm-portfolio:after{content:"";position:fixed;inset:0;pointer-events:none;z-index:60;background:repeating-linear-gradient(0deg,rgba(255,255,255,.012),rgba(255,255,255,.012) 1px,transparent 0,transparent 4px)}.htm-portfolio .sr-only{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;clip:rect(1px,1px,1px,1px);white-space:nowrap}.htm-portfolio .skip-link{position:absolute;left:8px;top:-40px;z-index:100;font-family:var(--font-mono);font-size:13px;letter-spacing:1.4px;text-transform:uppercase;color:var(--bg);background:var(--amber);padding:8px 14px;text-decoration:none;transition:top var(--anim-fast)}.htm-portfolio .skip-link:focus{top:8px;outline:2px solid var(--ink-strong);outline-offset:2px}.htm-portfolio .progress{position:fixed;top:0;left:0;right:0;height:2px;background:rgba(247,168,53,.08);z-index:70}.htm-portfolio .progress .bar{height:100%;width:0;background:var(--amber);opacity:.6;transition:width 80ms linear}.htm-portfolio .frame{border:1px solid var(--border);position:relative}.htm-portfolio .tty{position:-webkit-sticky;position:sticky;top:8px;z-index:30;font-family:var(--font-mono);font-size:17px;color:var(--mute);padding:var(--space-sm) var(--space-md);letter-spacing:.5px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;justify-content:space-between;align-items:center;gap:var(--space-lg)}.htm-portfolio .tty .amber{color:var(--amber)}.htm-portfolio .tty .ink{color:var(--ink-strong);font-weight:500}.htm-portfolio .tty .sep{color:var(--border-strong);margin:0 var(--space-xs)}.htm-portfolio .tty .wordmark{width:88px;height:14px;background:url(/work/htm/htm-wordmark.svg) 0/contain no-repeat;opacity:.8;display:inline-block;vertical-align:middle}.htm-portfolio .tty .led{display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber);animation:pulse 1.6s ease-in-out infinite;margin-left:var(--space-xs);vertical-align:middle}@keyframes pulse{0%,to{opacity:.45}50%{opacity:1}}.htm-portfolio .hand-pixel{width:24px;height:24px;background:url(/work/htm/hand-right.svg) 50%/contain no-repeat;flex-shrink:0;display:inline-block;transition:background-image var(--anim-fast),transform var(--anim-fast)}.htm-portfolio .hand-pixel.left{background-image:url(/work/htm/hand-left.svg)}.htm-portfolio .hand-pixel.down{transform:rotate(90deg)}.htm-portfolio .hand-pixel.up{transform:rotate(-90deg)}.htm-portfolio .cover{height:calc(100vh - 16px - 48px - 50px);min-height:560px;display:grid;grid-template-columns:minmax(0,1.5fr) minmax(0,1fr);grid-gap:var(--space-xs);gap:var(--space-xs);padding:var(--space-xs);position:relative;overflow:hidden}.htm-portfolio .cover[data-num]:after{content:attr(data-num);position:absolute;bottom:-.18em;right:2%;font-family:var(--font-display);font-style:italic;font-weight:400;color:var(--amber);opacity:.06;font-size:clamp(280px,36vw,520px);line-height:.78;letter-spacing:-12px;pointer-events:none;z-index:0;white-space:nowrap}.htm-portfolio .cover>:not(.hand-zone){position:relative;z-index:1}.htm-portfolio .case-file{position:relative;border:1px solid var(--border);background:var(--paper);overflow:hidden;cursor:crosshair;box-shadow:inset 0 0 0 1px rgba(255,255,255,.02),0 0 0 6px var(--bg),inset 0 0 90px rgba(247,168,53,.06);transition:box-shadow var(--anim-med)}.htm-portfolio .case-file:hover{box-shadow:inset 0 0 0 1px rgba(247,168,53,.2),0 0 0 6px var(--bg),inset 0 0 140px rgba(247,168,53,.12)}.htm-portfolio .case-file-img{position:absolute;inset:-10% 0 -10% 0;z-index:1;background-size:cover;background-position:50%;display:flex;align-items:center;justify-content:center;filter:saturate(.78) hue-rotate(-3deg) brightness(.92) contrast(1.05);will-change:transform;animation:bootIn var(--anim-slow)}.htm-portfolio .case-file-img.has-bg{animation:bootIn var(--anim-slow),kenBurns 24s ease-in-out infinite alternate}.htm-portfolio .case-file-img>svg{width:100%;height:100%;display:block}@keyframes kenBurns{0%{transform:scale(1.06) translateY(-2%)}to{transform:scale(1.12) translate(1.5%,2%)}}.htm-portfolio .case-file:before{content:"";position:absolute;inset:0;z-index:2;pointer-events:none;background:radial-gradient(circle at var(--mx) var(--my),rgba(247,168,53,.18),transparent 30%),radial-gradient(ellipse at center,rgba(0,0,0,0) 30%,rgba(0,0,0,.45) 100%),repeating-linear-gradient(0deg,rgba(0,0,0,.16) 0,rgba(0,0,0,.16) 1px,transparent 1px,transparent 3px)}.htm-portfolio .case-file.sweep:after{content:"";position:absolute;left:0;right:0;top:0;height:4px;z-index:3;background:linear-gradient(180deg,rgba(247,168,53,.65),rgba(247,168,53,0));transform:translateY(-100%);pointer-events:none;animation:sweepDown var(--anim-slow)}@keyframes sweepDown{0%{transform:translateY(-100%);opacity:0}30%{opacity:1}85%{opacity:.6}to{transform:translateY(2400%);opacity:0}}@keyframes bootIn{0%{opacity:0;filter:saturate(0) brightness(2.4) blur(3px)}to{opacity:1;filter:saturate(.78) hue-rotate(-3deg) brightness(.92) contrast(1.05) blur(0)}}.htm-portfolio .file-tag{position:absolute;left:var(--space-sm);bottom:var(--space-sm);z-index:4;font-family:var(--font-mono);font-size:13px;letter-spacing:1.6px;color:var(--amber);background:rgba(0,0,0,.55);padding:5px var(--space-xs);border:1px solid rgba(247,168,53,.38);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.htm-portfolio .file-tag .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--amber);margin-right:6px;animation:pulse 1.6s ease-in-out infinite;vertical-align:middle}.htm-portfolio .hand-zone{position:absolute;top:50%;transform:translateY(-50%);width:80px;height:140px;display:flex;align-items:center;justify-content:center;cursor:pointer;background:rgba(0,0,0,.55);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);border:1px solid var(--border);transition:background var(--anim-fast),border-color var(--anim-fast);z-index:10;padding:0}.htm-portfolio .hand-zone .hand-pixel{width:48px;height:48px}.htm-portfolio .hand-zone:focus-visible,.htm-portfolio .hand-zone:hover{background:var(--amber-bg);border-color:var(--amber);outline:none}.htm-portfolio .hand-zone:hover .hand-pixel{background-image:url(/work/htm/hand-right-amber.svg);transform:translateX(3px)}.htm-portfolio .hand-zone.left:hover .hand-pixel{background-image:url(/work/htm/hand-left-amber.svg);transform:translateX(-3px)}.htm-portfolio .hand-zone:active{transform:translateY(-50%) scale(.97)}.htm-portfolio .hand-zone.left{left:18px}.htm-portfolio .hand-zone.right{right:18px}.htm-portfolio .hand-zone[disabled]{opacity:.16;cursor:not-allowed;pointer-events:none}.htm-portfolio .hand-zone .hint{position:absolute;bottom:-22px;font-family:var(--font-mono);font-size:11px;color:var(--mute);letter-spacing:1.2px;white-space:nowrap;opacity:0;transition:opacity var(--anim-fast)}.htm-portfolio .hand-zone:focus-visible .hint,.htm-portfolio .hand-zone:hover .hint{opacity:.85}.htm-portfolio .readout{border:1px solid var(--border);background:var(--paper);padding:var(--space-lg) var(--space-md);display:flex;flex-direction:column;min-width:0;gap:var(--space-sm);overflow:hidden}.htm-portfolio .term-line{font-family:var(--font-mono);font-size:16px;color:var(--amber-soft);letter-spacing:.4px;min-height:1.4em;opacity:.85}.htm-portfolio .term-line .prompt{color:var(--mute);margin-right:var(--space-xs)}.htm-portfolio .term-line .blink{display:inline-block;width:.5em;height:1em;background:var(--amber);vertical-align:-.12em;margin-left:2px;opacity:.7;animation:caret 1.1s steps(2) infinite}@keyframes caret{50%{opacity:0}}.htm-portfolio .case-num{font-family:var(--font-mono);color:var(--mute);font-size:14px;letter-spacing:2.4px;text-transform:uppercase;display:inline-flex;align-items:center;gap:var(--space-xs);margin-bottom:var(--space-xs)}.htm-portfolio .case-num:before{content:"";display:inline-block;width:26px;height:1px;background:var(--amber)}.htm-portfolio .case-num:after{content:"";display:inline-block;width:7px;height:7px;border-radius:50%;background:var(--amber);box-shadow:0 0 8px var(--amber);animation:pulse 1.6s ease-in-out infinite;margin-left:4px}.htm-portfolio .case-mark{font-family:var(--font-display);font-style:italic;font-weight:300;font-size:clamp(20px,2.2vw,28px);line-height:1;color:var(--amber);margin-bottom:var(--space-xs);letter-spacing:-.4px}.htm-portfolio .case-mark.style-swich{font-family:var(--font-sans);font-style:normal;font-weight:800;letter-spacing:4px;text-transform:uppercase;font-size:clamp(15px,1.4vw,18px);color:var(--ink-strong)}.htm-portfolio .case-mark.style-fishbowl{font-family:var(--font-sans);font-style:italic;font-weight:900;letter-spacing:-1px;text-transform:lowercase;font-size:clamp(26px,2.8vw,36px);color:var(--ink-strong)}.htm-portfolio .case-mark.style-sbts{font-family:var(--font-display);font-style:italic;font-weight:200;letter-spacing:-.3px;font-size:clamp(22px,2.4vw,30px)}.htm-portfolio .case-mark.style-mdb{font-family:var(--font-sans);font-style:italic;font-weight:600;letter-spacing:1px;text-transform:uppercase;font-size:clamp(14px,1.3vw,17px)}.htm-portfolio .case-mark.style-maplemoon{font-family:var(--font-display);font-style:normal;font-weight:200;letter-spacing:6px;text-transform:lowercase;font-size:clamp(18px,1.8vw,22px)}.htm-portfolio .case-mark.style-ferrari{font-family:var(--font-display);font-style:italic;font-weight:500;letter-spacing:3px;text-transform:uppercase;font-size:clamp(16px,1.5vw,20px)}.htm-portfolio .case-mark.style-bankwest{font-weight:700;letter-spacing:-.5px}.htm-portfolio .case-mark.style-bankwest,.htm-portfolio .case-mark.style-refundid{font-family:var(--font-sans);font-style:normal;text-transform:lowercase;font-size:clamp(22px,2.2vw,28px)}.htm-portfolio .case-mark.style-refundid{font-weight:500;letter-spacing:-.4px}.htm-portfolio .case-mark.style-troodpratt{font-family:var(--font-display);font-style:normal;font-weight:400;letter-spacing:1.5px;text-transform:uppercase;font-size:clamp(14px,1.3vw,16px)}.htm-portfolio .case-mark.style-pureairo{font-family:var(--font-sans);font-style:normal;font-weight:500;letter-spacing:1px;font-size:clamp(20px,2vw,26px)}.htm-portfolio .case-title{font-family:var(--font-sans);font-weight:700;font-size:clamp(56px,6.6vw,104px);line-height:1.02;letter-spacing:-2px;color:var(--ink-strong)}.htm-portfolio .hr{height:1px;background:var(--border);margin:2px 0}.htm-portfolio .case-outcome{font-size:clamp(17px,1.4vw,22px);color:var(--ink)}.htm-portfolio .case-lesson,.htm-portfolio .case-outcome{font-family:var(--font-sans);font-weight:300;line-height:1.6;padding-right:clamp(16px,2.5vw,40px)}.htm-portfolio .case-lesson{font-size:clamp(14px,1.05vw,16px);color:var(--mute);border-left:2px solid var(--amber);padding-left:var(--space-sm)}.htm-portfolio .case-meta{display:grid;grid-template-columns:auto 1fr;grid-gap:6px var(--space-md);gap:6px var(--space-md);font-family:var(--font-mono);font-size:13px;color:var(--mute);letter-spacing:.4px}.htm-portfolio .case-meta .k{color:var(--mute-2);min-width:90px;text-transform:uppercase;letter-spacing:1.2px;font-size:12px}.htm-portfolio .case-meta .v{color:var(--ink)}.htm-portfolio .open-case{margin-top:auto;align-self:flex-start;display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:14px;letter-spacing:1.5px;color:var(--mute);text-decoration:none;padding:10px 16px 10px 12px;border:1px solid var(--border);transition:color var(--anim-fast),border-color var(--anim-fast),background var(--anim-fast),padding var(--anim-fast)}.htm-portfolio .open-case:focus-visible,.htm-portfolio .open-case:hover{color:var(--amber);border-color:var(--amber);background:var(--amber-bg);outline:none;padding-right:22px}.htm-portfolio .open-case .hand-pixel{width:22px;height:22px;transform:rotate(90deg);background-image:url(/work/htm/hand-right.svg)}.htm-portfolio .open-case:hover .hand-pixel{background-image:url(/work/htm/hand-right-amber.svg);transform:translateY(3px) rotate(90deg)}.htm-portfolio .scroll-cue{position:absolute;bottom:32px;left:50%;transform:translateX(-50%);font-family:var(--font-mono);font-size:11px;color:var(--mute-2);letter-spacing:2px;pointer-events:none;display:flex;flex-direction:column;align-items:center;gap:6px;max-width:160px;opacity:.5;animation:nudge 2.4s ease-in-out infinite}.htm-portfolio .scroll-cue .hand-pixel{width:18px;height:18px;max-width:24px;transform:rotate(90deg)}@media (max-height:640px){.htm-portfolio .scroll-cue{display:none}}@keyframes nudge{0%,to{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(4px)}}.htm-portfolio .detail{border-top:1px solid var(--border);padding:var(--space-2xl) var(--space-md);display:grid;grid-template-columns:minmax(0,1fr);grid-gap:var(--space-3xl);gap:var(--space-3xl);max-width:1280px;margin:0 auto}.htm-portfolio .reveal{opacity:0;transform:translateY(24px);transition:opacity var(--anim-slow),transform var(--anim-slow)}.htm-portfolio .reveal.in{opacity:1;transform:none}.htm-portfolio .section{position:relative;padding-top:var(--space-md);padding-left:clamp(96px,11vw,140px);scroll-margin-top:120px}.htm-portfolio .testimonial{scroll-margin-top:120px}.htm-portfolio .section .spine{position:absolute;top:-4px;left:0;width:clamp(80px,9vw,110px);display:flex;flex-direction:column;align-items:flex-start;gap:8px;padding-right:18px;border-right:1px solid rgba(247,168,53,.28);pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.htm-portfolio .section .spine .spine-icon{width:38px;height:38px;background-color:var(--amber);mask-position:center;mask-size:24px;mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:24px;-webkit-mask-repeat:no-repeat;border:1px solid rgba(247,168,53,.4);background-clip:content-box;padding:6px}.htm-portfolio .section .spine .spine-num{font-family:var(--font-display);font-weight:400;font-size:clamp(28px,3vw,38px);line-height:1;color:var(--ink-strong);letter-spacing:0}.htm-portfolio .section .spine .spine-lbl{display:none}.htm-portfolio .section .spine{max-height:160px}.htm-portfolio .section#challenge .spine-icon{-webkit-mask-image:url(/work/htm/icons/alert.svg);mask-image:url(/work/htm/icons/alert.svg)}.htm-portfolio .section#imagery .spine-icon{-webkit-mask-image:url(/work/htm/icons/grid.svg);mask-image:url(/work/htm/icons/grid.svg)}.htm-portfolio .section#solutions .spine-icon{-webkit-mask-image:url(/work/htm/icons/animation.svg);mask-image:url(/work/htm/icons/animation.svg)}.htm-portfolio .section#palette .spine-icon{-webkit-mask-image:url(/work/htm/icons/art-text.svg);mask-image:url(/work/htm/icons/art-text.svg)}.htm-portfolio .section#deliverables .spine-icon{-webkit-mask-image:url(/work/htm/icons/list.svg);mask-image:url(/work/htm/icons/list.svg)}.htm-portfolio .section#whatsnext .spine-icon{-webkit-mask-image:url(/work/htm/icons/arrow-right.svg);mask-image:url(/work/htm/icons/arrow-right.svg)}@media (max-width:700px){.htm-portfolio .section{padding-left:0}.htm-portfolio .section .spine{position:static;flex-direction:row;align-items:center;width:auto;border-right:none;padding-right:0;margin-bottom:var(--space-sm);border-bottom:1px solid rgba(247,168,53,.28);padding-bottom:var(--space-xs)}.htm-portfolio .section .spine .spine-lbl{writing-mode:horizontal-tb;transform:none;margin:0}}.htm-portfolio .detail .section,.htm-portfolio .testimonial{overflow:hidden}.htm-portfolio .detail .section[data-num]:after,.htm-portfolio .testimonial[data-num]:after{content:attr(data-num);position:absolute;top:50%;right:4%;transform:translateY(-50%);font-family:var(--font-display);font-style:italic;font-weight:400;color:var(--amber);opacity:.08;font-size:clamp(220px,26vw,360px);line-height:.85;letter-spacing:-8px;pointer-events:none;z-index:0;white-space:nowrap}.htm-portfolio .detail .section[data-num]>*,.htm-portfolio .testimonial[data-num]>*{position:relative;z-index:1}.htm-portfolio .detail .section#challenge{border-top:2px solid var(--case-accent-0,var(--amber))}.htm-portfolio .detail .section#solutions{border-top:2px solid var(--case-accent-1,var(--amber))}.htm-portfolio .detail .section#palette{border-top:2px solid var(--case-accent-2,var(--amber))}.htm-portfolio .testimonial{border-top:2px solid var(--case-accent-3,var(--amber))}.htm-portfolio .detail .section#deliverables{border-top:2px solid var(--case-accent-4,var(--amber))}.htm-portfolio .detail .section#whatsnext{border-top:2px solid var(--case-accent-5,var(--amber))}.htm-portfolio .chapter-strip{position:-webkit-sticky;position:sticky;top:calc(8px + 48px);z-index:20;background:rgba(0,0,0,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--border);padding:var(--space-xs) var(--space-md);display:flex;flex-wrap:wrap;gap:4px;max-width:1280px;margin:0 auto}.htm-portfolio .chap-tab{display:inline-flex;align-items:center;gap:8px;padding:8px 12px;border:1px solid transparent;font-family:var(--font-mono);font-size:11px;letter-spacing:1.4px;text-transform:uppercase;color:var(--mute);cursor:pointer;text-decoration:none;transition:all var(--anim-fast)}.htm-portfolio .chap-tab:hover{color:var(--ink-strong);border-color:var(--border);background:rgba(255,255,255,.02)}.htm-portfolio .chap-tab.current{color:var(--amber);border-color:rgba(247,168,53,.32);background:var(--amber-bg)}.htm-portfolio .chap-tab .chap-icon{width:14px;height:14px;background-color:currentColor;mask-position:center;mask-size:contain;mask-repeat:no-repeat;-webkit-mask-position:center;-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat}.htm-portfolio .chap-tab[data-section=challenge] .chap-icon{-webkit-mask-image:url(/work/htm/icons/alert.svg);mask-image:url(/work/htm/icons/alert.svg)}.htm-portfolio .chap-tab[data-section=imagery] .chap-icon{-webkit-mask-image:url(/work/htm/icons/grid.svg);mask-image:url(/work/htm/icons/grid.svg)}.htm-portfolio .chap-tab[data-section=solutions] .chap-icon{-webkit-mask-image:url(/work/htm/icons/animation.svg);mask-image:url(/work/htm/icons/animation.svg)}.htm-portfolio .chap-tab[data-section=palette] .chap-icon{-webkit-mask-image:url(/work/htm/icons/art-text.svg);mask-image:url(/work/htm/icons/art-text.svg)}.htm-portfolio .chap-tab[data-section=testimonial] .chap-icon{-webkit-mask-image:url(/work/htm/icons/contact.svg);mask-image:url(/work/htm/icons/contact.svg)}.htm-portfolio .chap-tab[data-section=deliverables] .chap-icon{-webkit-mask-image:url(/work/htm/icons/list.svg);mask-image:url(/work/htm/icons/list.svg)}.htm-portfolio .chap-tab[data-section=whatsnext] .chap-icon{-webkit-mask-image:url(/work/htm/icons/arrow-right.svg);mask-image:url(/work/htm/icons/arrow-right.svg)}.htm-portfolio .chap-tab .chap-num{font-family:var(--font-display);font-size:13px;color:var(--amber);letter-spacing:0}@media (max-width:1180px){.htm-portfolio .chap-tab .chap-lbl{display:none}}@media (max-width:700px){.htm-portfolio .chapter-strip{gap:2px;padding:6px;overflow-x:auto;flex-wrap:nowrap}}.htm-portfolio .detail h3{font-family:var(--font-mono);font-size:14px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink);margin-bottom:var(--space-md);display:inline-flex;align-items:center;gap:var(--space-xs)}.htm-portfolio .detail h3:before{content:"";display:inline-block;width:26px;height:1px;background:var(--amber)}.htm-portfolio .detail li,.htm-portfolio .detail p{font-family:var(--font-sans);font-weight:300;font-size:clamp(16px,1.25vw,20px);line-height:1.65;color:var(--ink)}.htm-portfolio .detail .lead-p{font-size:clamp(19px,1.5vw,24px);font-weight:300;line-height:1.6;color:var(--ink-strong);max-width:none;padding-right:clamp(24px,3vw,56px)}.htm-portfolio .detail .lead-p .drop{font-family:var(--font-display);font-weight:200;font-style:italic;font-size:3.2em;line-height:.92;float:left;color:var(--amber);margin:.04em .14em 0 0;letter-spacing:0}@media (max-width:480px){.htm-portfolio .detail .lead-p .drop{float:none;font-size:2.4em;margin:0 0 .1em;display:inline-block}}.htm-portfolio .detail ul{list-style:none;display:flex;flex-direction:column;gap:var(--space-sm)}.htm-portfolio .detail ul li{display:flex;gap:var(--space-sm);align-items:baseline}.htm-portfolio .detail ul li:before{content:"\2192";color:var(--amber);margin-right:0;flex-shrink:0;font-family:var(--font-mono);font-size:16px}.htm-portfolio .player{max-width:900px;margin:0 auto;background:var(--paper);border:1px solid var(--border);display:grid;grid-template-rows:auto auto auto auto;overflow:hidden}.htm-portfolio .player-head{display:flex;justify-content:space-between;align-items:center;padding:10px 16px;border-bottom:1px solid var(--border);background:rgba(0,0,0,.6);font-family:var(--font-mono);font-size:12px;color:var(--mute);letter-spacing:1.2px}.htm-portfolio .player-head .left{display:inline-flex;align-items:center;gap:8px}.htm-portfolio .player-head .left .dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--amber);animation:pulse 1.6s ease-in-out infinite}.htm-portfolio .player-head .counter{color:var(--amber);letter-spacing:1.4px}.htm-portfolio .stage{position:relative;aspect-ratio:16/10;background:#000;display:flex;align-items:center;justify-content:center;padding:clamp(20px,3vw,36px);cursor:zoom-in}.htm-portfolio .stage:after{content:"";position:absolute;inset:16px;border:1px solid rgba(255,255,255,.06);pointer-events:none}.htm-portfolio .stage img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;filter:saturate(.94) contrast(1.02);transition:transform var(--anim-med),filter var(--anim-fast)}.htm-portfolio .stage:hover img{transform:scale(1.02);filter:saturate(1) contrast(1.03)}.htm-portfolio .stage .img-svg{width:100%;height:100%;display:flex;align-items:center;justify-content:center}.htm-portfolio .stage .img-svg>svg{width:100%;height:100%;display:block}.htm-portfolio .stage .p-arrow{position:absolute;top:50%;transform:translateY(-50%);width:44px;height:44px;border-radius:50%;background:rgba(0,0,0,.65);border:1px solid var(--amber-soft);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background var(--anim-fast),border-color var(--anim-fast),color var(--anim-fast),transform var(--anim-fast);padding:0;color:var(--ink);font-family:var(--font-mono);font-size:22px;z-index:4}.htm-portfolio .stage .p-arrow:focus-visible,.htm-portfolio .stage .p-arrow:hover{background:var(--amber-bg);border-color:var(--amber);color:var(--amber);outline:none;transform:translateY(-50%) scale(1.06)}.htm-portfolio .stage .p-arrow.prev{left:12px}.htm-portfolio .stage .p-arrow.next{right:12px}.htm-portfolio .stage .p-arrow[disabled]{opacity:.32;cursor:not-allowed;border-color:var(--border);color:var(--mute-2)}.htm-portfolio .info{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--border);background:rgba(0,0,0,.32);display:grid;grid-template-columns:auto 1fr auto;grid-gap:var(--space-md) var(--space-lg);gap:var(--space-md) var(--space-lg);align-items:start}.htm-portfolio .info .info-num{font-family:var(--font-display);font-weight:200;font-size:52px;line-height:.9;letter-spacing:-2px;color:var(--amber);letter-spacing:0}.htm-portfolio .info .info-body{display:flex;flex-direction:column;gap:var(--space-xs);min-width:0}.htm-portfolio .info .info-title{font-family:var(--font-sans);font-weight:400;font-size:clamp(17px,1.4vw,20px);line-height:1.25;color:var(--ink-strong);letter-spacing:-.3px}.htm-portfolio .info .info-desc{font-family:var(--font-sans);font-weight:300;font-size:14px;line-height:1.55;color:var(--mute);max-width:60ch}.htm-portfolio .info .info-meta-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}.htm-portfolio .info .info-meta-row .tag{font-family:var(--font-mono);font-size:10px;letter-spacing:1.4px;text-transform:uppercase;color:var(--mute);padding:3px 8px;border:1px solid var(--border)}.htm-portfolio .info .info-meta-row .tag.amber{color:var(--amber);border-color:rgba(247,168,53,.4)}.htm-portfolio .info .info-side{text-align:right;font-family:var(--font-mono);font-size:11px;color:var(--mute-2);letter-spacing:1.2px;display:flex;flex-direction:column;gap:4px}.htm-portfolio .strip-row{position:relative;padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border);background:rgba(0,0,0,.4);overflow-x:auto;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.16) transparent}.htm-portfolio .strip-row:after{content:"";position:-webkit-sticky;position:sticky;right:0;top:0;bottom:0;width:36px;background:linear-gradient(270deg,rgba(0,0,0,.8),transparent);pointer-events:none;margin-left:-36px;flex-shrink:0}.htm-portfolio .strip-row::-webkit-scrollbar{height:6px}.htm-portfolio .strip-row::-webkit-scrollbar-track{background:transparent}.htm-portfolio .strip-row::-webkit-scrollbar-thumb{background:rgba(255,255,255,.16)}.htm-portfolio .strip{display:flex;gap:10px;padding-bottom:4px}.htm-portfolio .p-thumb{flex:0 0 160px;aspect-ratio:4/3;background:#000;border:1px solid var(--border);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:border-color var(--anim-fast),box-shadow var(--anim-fast);padding:8px;position:relative}.htm-portfolio .p-thumb:hover{border-color:rgba(247,168,53,.4)}.htm-portfolio .p-thumb.active{border-color:var(--amber);box-shadow:0 0 0 2px rgba(247,168,53,.18)}.htm-portfolio .p-thumb img{max-width:100%;max-height:100%;object-fit:contain;filter:saturate(.94);display:block;width:auto;height:auto}.htm-portfolio .p-thumb .t-num{position:absolute;top:4px;left:6px;font-family:var(--font-mono);font-size:10px;color:var(--mute);letter-spacing:1.2px;pointer-events:none;background:rgba(0,0,0,.55);padding:1px 4px}.htm-portfolio .p-thumb.active .t-num{color:var(--amber)}@media (max-width:700px){.htm-portfolio .player{max-width:100%}.htm-portfolio .info{grid-template-columns:1fr}.htm-portfolio .info .info-side{text-align:left}.htm-portfolio .p-thumb{flex-basis:120px}}.htm-portfolio .two-col{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-xl);gap:var(--space-xl)}@media (max-width:800px){.htm-portfolio .two-col{grid-template-columns:1fr}}.htm-portfolio .palette-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-sm)}@media (min-width:1440px){.htm-portfolio .palette-grid{grid-template-columns:repeat(6,1fr)}}@media (max-width:1023px){.htm-portfolio .palette-grid{grid-template-columns:repeat(2,1fr)}}.htm-portfolio .swatch-card{display:flex;flex-direction:column;border:1px solid var(--border);background:#000;transition:border-color var(--anim-fast),transform var(--anim-fast)}.htm-portfolio .swatch-card:hover{border-color:var(--amber-soft);transform:translateY(-2px)}.htm-portfolio .swatch-card .chip{height:180px;width:100%;position:relative;border-bottom:1px solid var(--border)}.htm-portfolio .swatch-card .chip-num{position:absolute;top:8px;right:10px;font-family:var(--font-mono);font-size:10px;letter-spacing:1.4px;color:rgba(0,0,0,.55);mix-blend-mode:difference;pointer-events:none}.htm-portfolio .swatch-card .chip:after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(0,0,0,.18);pointer-events:none}.htm-portfolio .swatch-card .meta{padding:var(--space-sm) var(--space-sm) var(--space-md);display:flex;flex-direction:column;gap:4px}.htm-portfolio .swatch-card .name{font-family:var(--font-sans);font-weight:400;font-size:14px;line-height:1.2;color:var(--ink-strong);letter-spacing:-.2px}.htm-portfolio .swatch-card .hex{font-family:var(--font-mono);font-size:13px;color:var(--mute);letter-spacing:1.2px;text-transform:uppercase}@media (max-width:700px){.htm-portfolio .palette-grid{grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.htm-portfolio .swatch-card .chip{height:80px}}.htm-portfolio .testimonial{padding:var(--space-2xl) var(--space-lg);background:rgba(247,168,53,.025);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;margin:0 calc(-1 * var(--space-md));display:grid;grid-template-columns:auto 1fr;grid-gap:var(--space-lg);gap:var(--space-lg);align-items:start}.htm-portfolio .testimonial:before{content:"\201C";grid-row:1/span 2;align-self:start;width:auto;height:auto;font-family:var(--font-display);font-style:italic;font-weight:400;font-size:clamp(120px,14vw,180px);line-height:.6;color:var(--amber);opacity:.45;letter-spacing:-8px;margin:-20px 0 0 -8px}.htm-portfolio .testimonial p{font-family:var(--font-sans);font-weight:300;font-style:normal;font-size:clamp(20px,2vw,30px);line-height:1.4;color:var(--ink-strong);letter-spacing:-.4px;margin:0;padding-right:clamp(24px,4vw,80px);grid-column:2}.htm-portfolio .testimonial cite{grid-column:2;align-self:start;font-family:var(--font-mono);font-size:13px;letter-spacing:1.6px;color:var(--amber);font-style:normal;text-transform:uppercase;display:inline-flex;align-items:center;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid rgba(247,168,53,.32);width:-moz-fit-content;width:fit-content}.htm-portfolio .testimonial cite:before{content:"";display:inline-block;width:22px;height:1px;background:var(--amber)}.htm-portfolio .testimonial[data-empty=true]{grid-template-columns:1fr;text-align:center;padding:var(--space-xl) var(--space-md)}.htm-portfolio .testimonial[data-empty=true]:before{display:none}.htm-portfolio .testimonial[data-empty=true] p{font-family:var(--font-mono);font-size:13px;color:var(--mute);letter-spacing:1.2px;text-transform:uppercase;max-width:60ch;grid-column:1;margin:0 auto}.htm-portfolio .testimonial[data-empty=true] cite{display:none}@media (max-width:700px){.htm-portfolio .testimonial{grid-template-columns:1fr}.htm-portfolio .testimonial:before{grid-row:auto;grid-column:1}.htm-portfolio .testimonial cite,.htm-portfolio .testimonial p{grid-column:1}}.htm-portfolio .detail ol.deliv-grid{list-style:none;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));grid-gap:var(--space-sm);gap:var(--space-sm)}.htm-portfolio .detail ol.deliv-grid li{border:1px solid var(--border);background:rgba(5,5,5,.6);padding:20px var(--space-md);display:flex;align-items:center;gap:var(--space-md);transition:border-color var(--anim-fast),background var(--anim-fast),transform var(--anim-fast);position:relative}.htm-portfolio .detail ol.deliv-grid li:hover{border-color:var(--amber);background:var(--amber-bg);transform:translateX(2px)}.htm-portfolio .detail ol.deliv-grid li .deliv-icon{width:36px;height:36px;background-color:var(--amber);-webkit-mask-size:26px;mask-size:26px;-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;flex-shrink:0;opacity:.85;transition:opacity var(--anim-fast)}.htm-portfolio .detail ol.deliv-grid li:hover .deliv-icon{opacity:1}.htm-portfolio .detail ol.deliv-grid li .deliv-num{font-family:var(--font-display);font-style:italic;color:var(--amber);font-size:24px;line-height:1;min-width:32px;letter-spacing:0;opacity:.7}.htm-portfolio .detail ol.deliv-grid li .deliv-name{flex:1 1;font-family:var(--font-sans);font-weight:400;font-size:14px;line-height:1.3;color:var(--ink);letter-spacing:-.1px}.htm-portfolio .deliv-icon[data-icon=animation]{-webkit-mask-image:url(/work/htm/icons/animation.svg);mask-image:url(/work/htm/icons/animation.svg)}.htm-portfolio .deliv-icon[data-icon=layout-header]{-webkit-mask-image:url(/work/htm/icons/layout-header.svg);mask-image:url(/work/htm/icons/layout-header.svg)}.htm-portfolio .deliv-icon[data-icon=camera-add]{-webkit-mask-image:url(/work/htm/icons/camera-add.svg);mask-image:url(/work/htm/icons/camera-add.svg)}.htm-portfolio .deliv-icon[data-icon=archive]{-webkit-mask-image:url(/work/htm/icons/archive.svg);mask-image:url(/work/htm/icons/archive.svg)}.htm-portfolio .deliv-icon[data-icon=frame-add]{-webkit-mask-image:url(/work/htm/icons/frame-add.svg);mask-image:url(/work/htm/icons/frame-add.svg)}.htm-portfolio .deliv-icon[data-icon=contact]{-webkit-mask-image:url(/work/htm/icons/contact.svg);mask-image:url(/work/htm/icons/contact.svg)}.htm-portfolio .deliv-icon[data-icon=analytics]{-webkit-mask-image:url(/work/htm/icons/analytics.svg);mask-image:url(/work/htm/icons/analytics.svg)}.htm-portfolio .deliv-icon[data-icon=art-text]{-webkit-mask-image:url(/work/htm/icons/art-text.svg);mask-image:url(/work/htm/icons/art-text.svg)}.htm-portfolio .deliv-icon[data-icon=article-multiple]{-webkit-mask-image:url(/work/htm/icons/article-multiple.svg);mask-image:url(/work/htm/icons/article-multiple.svg)}.htm-portfolio .deliv-icon[data-icon=grid]{-webkit-mask-image:url(/work/htm/icons/grid.svg);mask-image:url(/work/htm/icons/grid.svg)}.htm-portfolio .deliv-icon[data-icon=list]{-webkit-mask-image:url(/work/htm/icons/list.svg);mask-image:url(/work/htm/icons/list.svg)}.htm-portfolio .deliv-icon[data-icon=notes]{-webkit-mask-image:url(/work/htm/icons/notes.svg);mask-image:url(/work/htm/icons/notes.svg)}.htm-portfolio .deliv-icon[data-icon=chart]{-webkit-mask-image:url(/work/htm/icons/chart.svg);mask-image:url(/work/htm/icons/chart.svg)}.htm-portfolio .deliv-icon[data-icon=section]{-webkit-mask-image:url(/work/htm/icons/section.svg);mask-image:url(/work/htm/icons/section.svg)}.htm-portfolio .next-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:var(--space-md);gap:var(--space-md);margin-bottom:var(--space-xl)}.htm-portfolio .next-card{background:var(--paper);border:1px solid var(--border);padding:var(--space-lg) var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs);cursor:pointer;text-align:left;transition:border-color var(--anim-fast),transform var(--anim-fast),background var(--anim-fast);font:inherit;color:inherit;position:relative;min-height:200px;overflow:hidden}.htm-portfolio .next-card:before{content:"";position:absolute;inset:0;z-index:0;background-image:var(--next-hero,none);background-size:cover;background-position:50%;filter:saturate(.6) brightness(.5);opacity:.55;transition:opacity var(--anim-fast),filter var(--anim-fast)}.htm-portfolio .next-card:after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(180deg,rgba(0,0,0,.3),rgba(0,0,0,.75) 70%,rgba(0,0,0,.92));pointer-events:none}.htm-portfolio .next-card>*{position:relative;z-index:2}.htm-portfolio .next-card:focus-visible,.htm-portfolio .next-card:hover{border-color:var(--amber);transform:translateY(-3px);outline:none}.htm-portfolio .next-card:focus-visible:before,.htm-portfolio .next-card:hover:before{opacity:.75;filter:saturate(.9) brightness(.6)}.htm-portfolio .next-card[disabled]:before{background-image:none}.htm-portfolio .next-card.prev-case{text-align:left}.htm-portfolio .next-card.next-case{text-align:right;align-items:flex-end}.htm-portfolio .next-card .next-eyebrow{font-family:var(--font-mono);font-size:11px;letter-spacing:1.8px;color:var(--mute);text-transform:uppercase;display:inline-flex;align-items:center;gap:var(--space-xs)}.htm-portfolio .next-card:hover .next-eyebrow{color:var(--amber)}.htm-portfolio .next-card .next-eyebrow .hand-pixel{width:14px;height:14px}.htm-portfolio .next-card .next-num{font-family:var(--font-display);font-size:clamp(48px,5vw,72px);line-height:1;color:var(--amber);letter-spacing:-2px}.htm-portfolio .next-card .next-title{font-family:var(--font-sans);font-weight:500;font-size:clamp(20px,1.8vw,26px);line-height:1.2;color:var(--ink-strong);letter-spacing:-.4px}.htm-portfolio .next-card .next-sector{font-family:var(--font-mono);font-size:10px;letter-spacing:1.4px;color:var(--mute);text-transform:uppercase}.htm-portfolio .next-card[disabled]{opacity:.32;cursor:not-allowed;pointer-events:none}.htm-portfolio .cta-row{display:flex;flex-wrap:wrap;gap:var(--space-sm);padding-top:var(--space-lg);border-top:1px solid var(--border)}.htm-portfolio .cta{display:inline-flex;align-items:center;gap:var(--space-sm);padding:12px 18px;font-family:var(--font-mono);font-size:13px;letter-spacing:1.4px;text-transform:uppercase;text-decoration:none;border:1px solid var(--border);color:var(--ink);cursor:pointer;background:transparent;transition:all var(--anim-fast)}.htm-portfolio .cta:focus-visible,.htm-portfolio .cta:hover{border-color:var(--amber);color:var(--amber);background:var(--amber-bg);outline:none;padding-right:22px}.htm-portfolio .cta .hand-pixel{width:18px;height:18px}.htm-portfolio .cta:hover .hand-pixel{background-image:url(/work/htm/hand-right-amber.svg)}.htm-portfolio .cta-primary{border-color:var(--amber);color:var(--amber);background:var(--amber-bg)}.htm-portfolio .cta-primary:hover{background:rgba(247,168,53,.16)}@media (max-width:700px){.htm-portfolio .next-grid{grid-template-columns:1fr}.htm-portfolio .next-card.next-case{text-align:left;align-items:flex-start}.htm-portfolio .cta-row{flex-direction:column}.htm-portfolio .cta{width:100%;justify-content:center}}.htm-portfolio .lightbox{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.92);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);display:none;align-items:center;justify-content:center;padding:var(--space-md)}.htm-portfolio .lightbox.open{display:flex}.htm-portfolio .lightbox .lb-svg-host,.htm-portfolio .lightbox img{max-width:92vw;max-height:84vh;width:92vw;height:84vh;object-fit:contain;border:1px solid var(--border);filter:saturate(.95);animation:lbIn var(--anim-med);display:flex;align-items:center;justify-content:center;background:var(--tile)}.htm-portfolio .lightbox .lb-svg-host>svg{width:100%;height:100%;display:block;max-width:1200px;max-height:800px}@keyframes lbIn{0%{opacity:0;transform:scale(.97)}to{opacity:1;transform:none}}.htm-portfolio .lightbox-cap{bottom:var(--space-md);left:50%;transform:translateX(-50%);color:var(--mute);padding:4px 12px}.htm-portfolio .lb-hint,.htm-portfolio .lightbox-cap{position:absolute;font-family:var(--font-mono);font-size:11px;letter-spacing:1.4px}.htm-portfolio .lb-hint{top:var(--space-md);left:var(--space-md);color:var(--mute-2)}.htm-portfolio .lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:56px;height:56px;background:transparent;border:1px solid transparent;cursor:pointer;padding:0}.htm-portfolio .lb-nav .hand-pixel{width:40px;height:40px}.htm-portfolio .lb-nav:hover .hand-pixel{background-image:url(/work/htm/hand-right-amber.svg);transform:scale(1.06)}.htm-portfolio .lb-nav.prev{left:var(--space-md)}.htm-portfolio .lb-nav.prev .hand-pixel{background-image:url(/work/htm/hand-left.svg)}.htm-portfolio .lb-nav.prev:hover .hand-pixel{background-image:url(/work/htm/hand-left-amber.svg)}.htm-portfolio .lb-nav.next{right:var(--space-md)}.htm-portfolio .lb-nav[disabled]{opacity:.2;cursor:not-allowed}.htm-portfolio .lb-nav:focus-visible{outline:1px solid var(--amber);outline-offset:4px}.htm-portfolio .lb-close{position:absolute;top:var(--space-md);right:var(--space-md);width:36px;height:36px;padding:0;background:transparent;border:1px solid var(--border);color:var(--amber);font-family:var(--font-mono);font-size:16px;line-height:1;letter-spacing:0;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:border-color var(--anim-fast),color var(--anim-fast),background var(--anim-fast)}.htm-portfolio .lb-close:hover{border-color:var(--amber);background:rgba(247,168,53,.08)}.htm-portfolio .lb-close:focus-visible{outline:1px solid var(--amber);outline-offset:4px}.htm-portfolio .foot{position:-webkit-sticky;position:sticky;bottom:8px;z-index:30;border-top:1px solid var(--border);background:rgba(0,0,0,.92);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);padding:10px var(--space-md);display:flex;justify-content:space-between;align-items:center;font-family:var(--font-mono);font-size:14px;color:var(--mute);letter-spacing:.5px;gap:var(--space-md)}.htm-portfolio .foot .keys{display:flex;gap:var(--space-xs)}.htm-portfolio .foot a.key,.htm-portfolio .foot button.key{display:inline-flex;align-items:center;gap:6px;color:var(--mute);padding:5px 12px;border:1px solid var(--border);cursor:pointer;font-family:inherit;font-size:inherit;letter-spacing:inherit;background:transparent;text-decoration:none;transition:all var(--anim-fast)}.htm-portfolio .foot a.key:focus-visible,.htm-portfolio .foot a.key:hover,.htm-portfolio .foot button.key:focus-visible,.htm-portfolio .foot button.key:hover{color:var(--amber);border-color:var(--amber);background:var(--amber-bg);outline:none}.htm-portfolio .foot button.key[disabled]{opacity:.25;cursor:not-allowed;pointer-events:none}.htm-portfolio .foot .dots{display:flex;gap:7px}.htm-portfolio .foot .dot{width:7px;height:7px;border:1px solid var(--border-strong);background:transparent;cursor:pointer;padding:0;transition:all var(--anim-fast)}.htm-portfolio .foot .dot:focus-visible,.htm-portfolio .foot .dot:hover{border-color:var(--amber);outline:none}.htm-portfolio .foot .dot.on{background:var(--amber);border-color:var(--amber);box-shadow:0 0 6px rgba(247,168,53,.55)}.htm-portfolio .gallery{padding:var(--space-2xl) var(--space-md) var(--space-xl);border-bottom:1px solid var(--border)}.htm-portfolio .gallery-head{display:flex;flex-direction:column;gap:var(--space-sm);max-width:1280px;margin:0 auto var(--space-2xl)}.htm-portfolio .gallery-head .eyebrow{font-family:var(--font-mono);font-size:13px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;display:inline-flex;align-items:center;gap:var(--space-xs)}.htm-portfolio .gallery-head .eyebrow:before{content:"";display:inline-block;width:26px;height:1px;background:var(--amber)}.htm-portfolio .gallery-head h2{font-family:var(--font-sans);font-weight:200;font-size:clamp(48px,5.5vw,88px);line-height:1;letter-spacing:-2px;color:var(--ink-strong);max-width:22ch}.htm-portfolio .gallery-head h2 em{font-family:var(--font-display);font-style:italic;font-weight:200;letter-spacing:0;color:var(--amber)}.htm-portfolio .gallery-head p{font-family:var(--font-sans);font-weight:300;font-size:clamp(15px,1.1vw,17px);color:var(--mute);max-width:56ch}.htm-portfolio .gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));grid-gap:32px var(--space-md);gap:32px var(--space-md);max-width:1280px;margin:0 auto}.htm-portfolio .gallery-tile{background:#000;border:1px solid var(--border);padding:0;cursor:pointer;text-align:left;display:flex;flex-direction:column;transition:border-color var(--anim-fast),transform var(--anim-fast),box-shadow var(--anim-fast);font:inherit;color:inherit;outline:none;position:relative;text-decoration:none}.htm-portfolio .gallery-tile:focus-visible,.htm-portfolio .gallery-tile:hover{border-color:var(--amber);transform:translateY(-3px);box-shadow:0 0 0 3px var(--amber-bg)}.htm-portfolio .gallery-tile .thumb{aspect-ratio:1/1;background-color:var(--bg);background-size:contain;background-position:50%;background-repeat:no-repeat;background-origin:content-box;background-clip:content-box;padding:24px;transition:background-size var(--anim-fast)}.htm-portfolio .gallery-tile:hover .thumb{background-size:110%}.htm-portfolio .gallery-tile .meta{padding:var(--space-sm) var(--space-md) var(--space-md);display:flex;flex-direction:column;gap:var(--space-2xs);border-top:1px solid var(--border)}.htm-portfolio .gallery-tile .tile-num{font-family:var(--font-mono);font-size:11px;color:rgba(238,234,226,.5);letter-spacing:1.4px}.htm-portfolio .gallery-tile .tile-title{font-family:var(--font-sans);font-weight:500;font-size:22px;color:var(--ink-strong);letter-spacing:-.4px}.htm-portfolio .gallery-tile .tile-tag{font-family:var(--font-mono);font-size:10px;color:rgba(238,234,226,.55);letter-spacing:.08em;text-transform:uppercase}.htm-portfolio .gallery-tile .tile-cta{position:absolute;bottom:14px;right:18px;font-family:var(--font-mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--amber);opacity:0;transition:opacity .2s ease-out;pointer-events:none}.htm-portfolio .gallery-tile:focus-visible .tile-cta,.htm-portfolio .gallery-tile:hover .tile-cta{opacity:1}.htm-portfolio .gallery-tile.is-cta{border-style:dashed}.htm-portfolio .gallery-tile.is-cta .thumb{background-color:var(--amber-bg);background-image:none!important;padding:var(--space-md);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-style:italic;font-weight:200;font-size:clamp(28px,3vw,44px);line-height:1.05;color:var(--amber);text-align:center;letter-spacing:-.5px}.htm-portfolio .gallery-tile.is-cta:hover .thumb{background-color:rgba(247,168,53,.1);background-size:100%}.htm-portfolio .gallery-tile.is-cta .tile-num{color:var(--amber);opacity:.7}.htm-portfolio .sector-filter{max-width:1280px;margin:0 auto var(--space-lg);padding:var(--space-md) var(--space-xs) var(--space-sm);border-top:1px solid var(--border);display:grid;grid-template-columns:minmax(160px,max-content) 1fr;grid-gap:var(--space-md);gap:var(--space-md);align-items:baseline}.htm-portfolio .sector-filter-label{font-family:var(--font-mono);font-size:11px;letter-spacing:1.8px;color:var(--mute);text-transform:uppercase;display:inline-flex;align-items:center;gap:var(--space-xs)}.htm-portfolio .sector-filter-label:before{content:"";display:inline-block;width:18px;height:1px;background:var(--border-strong)}@media (max-width:720px){.htm-portfolio .sector-filter{grid-template-columns:1fr;gap:var(--space-xs)}}.htm-portfolio .sector-chips{display:flex;flex-wrap:wrap;gap:var(--space-sm) var(--space-md)}.htm-portfolio .sector-chips button{font-family:var(--font-mono);font-size:13px;letter-spacing:.1em;text-transform:uppercase;background:transparent;color:var(--mute);border:0;padding:8px 2px;cursor:pointer;transition:color var(--anim-fast);position:relative}.htm-portfolio .sector-chips button:hover{color:var(--ink-strong)}.htm-portfolio .sector-chips button:focus-visible{color:var(--ink-strong);outline:1px solid var(--amber);outline-offset:4px}.htm-portfolio .sector-chips button.active{color:var(--amber)}.htm-portfolio .sector-chips button.active:after{content:"";position:absolute;left:0;right:0;bottom:2px;height:2px;background:var(--amber)}.htm-portfolio .gallery-cta{text-align:center;padding:var(--space-2xl) var(--space-md);border-top:1px solid var(--border);margin-top:var(--space-xl);max-width:1280px;margin-left:auto;margin-right:auto}.htm-portfolio .gallery-cta h2{font-family:var(--font-display);font-weight:200;font-style:italic;font-size:clamp(30px,3.4vw,48px);line-height:1.05;letter-spacing:-.5px;color:var(--ink-strong);margin-bottom:var(--space-md)}.htm-portfolio .gallery-cta .cta{display:inline-flex;align-items:center;gap:var(--space-xs);font-family:var(--font-sans);font-weight:500;font-size:16px;color:var(--ink-strong);background:transparent;border:1px solid var(--amber);padding:14px 26px;text-decoration:none;letter-spacing:.02em;transition:background var(--anim-fast),color var(--anim-fast)}.htm-portfolio .gallery-cta .cta:hover{background:var(--amber);color:#000}.htm-portfolio .gallery-cta .cta:hover .hand-pixel{background-image:url(/work/htm/hand-right.svg);filter:invert(1)}.htm-portfolio .home-link{font-family:var(--font-mono);font-size:14px;color:var(--mute);text-decoration:none;cursor:pointer;background:transparent;border:1px solid transparent;padding:4px 10px;transition:color var(--anim-fast),border-color var(--anim-fast);display:inline-flex;align-items:center;gap:6px}.htm-portfolio .home-link:focus-visible,.htm-portfolio .home-link:hover{color:var(--amber);border-color:var(--border);outline:none}.htm-portfolio .home-link .hand-pixel{width:16px;height:16px;transform:rotate(180deg)}.htm-portfolio .home-link:hover .hand-pixel{background-image:url(/work/htm/hand-right-amber.svg)}.htm-portfolio .stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:var(--space-md);gap:var(--space-md);margin-top:var(--space-md)}.htm-portfolio .stat{position:relative;padding:var(--space-md) var(--space-md) var(--space-md);border:1px solid var(--border);background:rgba(5,5,5,.6);display:flex;flex-direction:column;gap:var(--space-xs)}.htm-portfolio .stat:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--amber);opacity:.7}.htm-portfolio .stat .num{font-family:var(--font-sans);font-weight:100;font-size:clamp(52px,5.2vw,80px);line-height:1;letter-spacing:-1.5px;color:var(--ink-strong);display:inline-flex;align-items:baseline;gap:2px}.htm-portfolio .stat .num em{color:var(--amber);font-style:normal;font-weight:200}.htm-portfolio .stat .num .suf{color:var(--mute);font-size:.32em;font-weight:300;letter-spacing:1px;align-self:flex-end;padding-bottom:.5em;margin-left:3px}.htm-portfolio .stat .label{font-size:11px;letter-spacing:1.4px;line-height:1.5;max-width:32ch}.htm-portfolio .stat .label,.htm-portfolio .subhead{font-family:var(--font-mono);color:var(--mute);text-transform:uppercase}.htm-portfolio .subhead{font-size:12px;letter-spacing:1.8px;margin:var(--space-xl) 0 var(--space-md);display:inline-flex;align-items:center;gap:var(--space-xs)}.htm-portfolio .subhead:before{content:"";display:inline-block;width:18px;height:1px;background:var(--border-strong)}.htm-portfolio .type-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:var(--space-md);gap:var(--space-md)}.htm-portfolio .type-card{border:1px solid var(--border);background:#050505;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-sm);position:relative;overflow:hidden}.htm-portfolio .type-card .type-role{font-family:var(--font-mono);font-size:10px;color:var(--amber);letter-spacing:1.6px;text-transform:uppercase}.htm-portfolio .type-card .type-sample{font-size:clamp(48px,4.6vw,72px);line-height:.95;color:var(--ink-strong);letter-spacing:-1px}.htm-portfolio .type-card .type-name{font-family:var(--font-mono);font-size:11px;color:var(--mute);letter-spacing:1.2px;display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--border);padding-top:10px}.htm-portfolio .type-card.display .type-sample{font-family:var(--font-display);font-weight:300;font-style:italic;letter-spacing:0}.htm-portfolio .type-card.headline .type-sample{font-family:var(--font-sans);font-weight:800;letter-spacing:-2px}.htm-portfolio .type-card.body .type-sample{font-family:var(--font-sans);font-weight:400;letter-spacing:-.5px}.htm-portfolio .type-card.label .type-sample{font-family:var(--font-sans);font-weight:600;text-transform:uppercase;letter-spacing:.25em;font-size:clamp(22px,2.4vw,32px)}.htm-portfolio .type-card.voice .type-sample{font-family:var(--font-sans);font-weight:900;font-style:italic;letter-spacing:-1px}.htm-portfolio .type-card.caption .type-sample{font-family:var(--font-sans);font-weight:400;letter-spacing:0}.htm-portfolio .type-card.tabloid .type-sample{font-family:var(--font-sans);font-weight:900;text-transform:uppercase;letter-spacing:-2px}.htm-portfolio .type-card.monogram .type-sample{font-family:var(--font-display);font-weight:400;letter-spacing:2px;text-transform:uppercase;letter-spacing:0}.htm-portfolio .type-card.mono .type-sample{font-family:var(--font-codey);font-weight:400;letter-spacing:0}@media (prefers-reduced-motion:reduce){.htm-portfolio *,.htm-portfolio :after,.htm-portfolio :before{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.htm-portfolio .reveal{opacity:1;transform:none}.htm-portfolio{scroll-behavior:auto}}@media (max-width:900px){.htm-portfolio .cover{grid-template-columns:1fr;grid-template-rows:minmax(280px,.9fr) minmax(0,1.3fr);height:auto;min-height:calc(100vh - 100px)}.htm-portfolio .case-title{font-size:clamp(44px,9vw,72px)}.htm-portfolio .gallery-head h2{font-size:clamp(36px,9vw,56px)}}.htm-portfolio .gallery-grid-wrap[data-sector-active]:not([data-sector-active=all]) .gallery-tile{display:none}.htm-portfolio .gallery-grid-wrap[data-sector-active="action sports"] .gallery-tile[data-sector="action sports"],.htm-portfolio .gallery-grid-wrap[data-sector-active="b2b / saas"] .gallery-tile[data-sector="b2b / saas"],.htm-portfolio .gallery-grid-wrap[data-sector-active="mould remediation"] .gallery-tile[data-sector="mould remediation"],.htm-portfolio .gallery-grid-wrap[data-sector-active="pet nutrition"] .gallery-tile[data-sector="pet nutrition"],.htm-portfolio .gallery-grid-wrap[data-sector-active="public art"] .gallery-tile[data-sector="public art"],.htm-portfolio .gallery-grid-wrap[data-sector-active=automotive] .gallery-tile[data-sector=automotive],.htm-portfolio .gallery-grid-wrap[data-sector-active=e-commerce] .gallery-tile[data-sector=e-commerce],.htm-portfolio .gallery-grid-wrap[data-sector-active=finance] .gallery-tile[data-sector=finance],.htm-portfolio .gallery-grid-wrap[data-sector-active=fmcg] .gallery-tile[data-sector=fmcg],.htm-portfolio .gallery-grid-wrap[data-sector-active=hospitality] .gallery-tile[data-sector=hospitality],.htm-portfolio .gallery-grid-wrap[data-sector-active=lifestyle] .gallery-tile[data-sector=lifestyle],.htm-portfolio .gallery-grid-wrap[data-sector-active=wellness] .gallery-tile[data-sector=wellness]{display:flex}.htm-portfolio .testimonial-polished{position:relative;max-width:28ch;margin:4rem auto;padding:2rem 1.5rem 1.5rem}.htm-portfolio .testimonial-polished .testimonial-glyph{position:absolute;top:0;left:0;font-family:Georgia,Times New Roman,serif;font-size:120px;line-height:1;color:var(--amber,#f7a835);opacity:.15;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.htm-portfolio .testimonial-polished .testimonial-quote{font-size:clamp(28px,3vw,32px);line-height:1.3;font-style:italic;margin:0 0 1rem;position:relative;z-index:1}.htm-portfolio .testimonial-polished .testimonial-rule{border:0;border-top:1px solid var(--amber,#f7a835);margin:1rem 0 .5rem;width:4rem}.htm-portfolio .testimonial-polished .testimonial-author{font-size:.875rem;letter-spacing:.05em;text-transform:uppercase;opacity:.8}.htm-portfolio .ddeliverables-polished{list-style:none;padding:0;margin:2rem 0}.htm-portfolio .deliverable-row{border-top:1px solid rgba(238,234,226,.12)}.htm-portfolio .deliverable-row:last-child{border-bottom:1px solid rgba(238,234,226,.12)}.htm-portfolio .deliverable-link{display:flex;align-items:center;gap:1rem;padding:1rem 0;color:inherit;text-decoration:none;position:relative;transition:background .15s ease}.htm-portfolio .deliverable-link:focus,.htm-portfolio .deliverable-link:hover{background:rgba(247,168,53,.04)}.htm-portfolio .deliverable-num{font-family:var(--font-vt323),monospace;font-size:1.25rem;opacity:.6;min-width:2.5rem}.htm-portfolio .deliverable-name{flex:1 1;font-size:1rem}.htm-portfolio .deliverable-arrow{font-size:1rem;opacity:0;transform:translateX(-4px);transition:opacity .2s ease,transform .2s ease}.htm-portfolio .deliverable-link:focus .deliverable-arrow,.htm-portfolio .deliverable-link:hover .deliverable-arrow{opacity:1;transform:translateX(0)}.htm-portfolio .deliverable-thumb{position:absolute;right:0;top:50%;width:96px;height:96px;object-fit:cover;transform:translateY(-50%) translateX(120%);opacity:0;transition:transform .25s ease,opacity .2s ease;pointer-events:none;border:1px solid rgba(247,168,53,.4);z-index:2}@media (hover:hover) and (pointer:fine){.htm-portfolio .deliverable-link:focus .deliverable-thumb,.htm-portfolio .deliverable-link:hover .deliverable-thumb{transform:translateY(-50%) translateX(0);opacity:1}}