
:root{
  --bg:#f5f3ed;
  --bg2:#ebe8e0;
  --paper:#fffdf8;
  --ink:#0f0f0d;
  --muted:#6b6560;
  --line:#ddd8cf;
  --dark:#080807;
  --accent:#c9a050;
  --accent-dark:#a08040;
  --red:#e71921;
  --radius:26px;
  --max:1240px;
  --font-display:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  --font-body:Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;background:var(--bg);-webkit-text-size-adjust:100%;text-size-adjust:100%}
body{margin:0;font-family:var(--font-body);font-weight:450;color:#1a1917;background:radial-gradient(circle at 15% -10%,#fff 0,#f7f4ec 36%,#e7e3da 100%);line-height:1.55;text-rendering:optimizeLegibility;overflow-x:hidden}
img,svg,video,iframe{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
a:hover{text-decoration:none}
.skip-link{position:absolute;left:1rem;top:1rem;transform:translateY(-150%);background:var(--ink);color:white;padding:.75rem 1rem;border-radius:999px;z-index:999}
.skip-link:focus{transform:translateY(0)}

/* Header */
.site-header{position:sticky;top:0;z-index:100;background:rgba(8,8,7,.96);backdrop-filter:blur(16px);border-bottom:1px solid rgba(255,255,255,.08);box-shadow:0 8px 34px rgba(0,0,0,.14)}
.nav-shell{max-width:var(--max);margin:0 auto;min-height:72px;padding:14px 24px;display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{display:block;line-height:0;flex:0 0 auto}.nav-logo img{width:176px;height:auto;filter:none}.nav-links{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}
.nav-links a{position:relative;font-size:.84rem;font-weight:760;color:#c8c2b9;padding:10px 14px;border-radius:999px;transition:color .3s ease,background .3s ease,box-shadow .3s ease}
.nav-links a::after{content:"";position:absolute;left:14px;right:14px;bottom:6px;height:1px;background:currentColor;transform:scaleX(0);transform-origin:right;transition:transform .35s cubic-bezier(.16,1,.3,1)}
.nav-links a:hover::after{transform:scaleX(1);transform-origin:left}.nav-links a.active{background:#f5f3ed;color:var(--ink);box-shadow:0 6px 18px rgba(0,0,0,.2)}.nav-links a.active::after{transform:scaleX(0)}

/* Common */
.section-pad{max-width:var(--max);margin:0 auto;padding:120px 24px}.section-pad.slim{max-width:980px;padding-top:84px;padding-bottom:84px}.section-pad-xl{max-width:var(--max);margin:0 auto;padding:160px 24px}.section-pad-slim{max-width:var(--max);margin:0 auto;padding:48px 24px}.eyebrow{font-size:.76rem;letter-spacing:.16em;text-transform:uppercase;color:var(--accent);font-weight:850;margin:0 0 16px}.lead{font-size:clamp(1.08rem,1.8vw,1.22rem);font-weight:500;line-height:1.58;color:#342f29;max-width:680px}.button{display:inline-flex;align-items:center;justify-content:center;min-height:50px;padding:0 22px;border-radius:999px;background:var(--ink);color:white;font-weight:780;box-shadow:0 18px 40px rgba(20,19,17,.14);border:1px solid var(--ink);transition:transform .3s cubic-bezier(.16,1,.3,1),background .3s ease,color .3s ease}.button:hover{transform:translateY(-3px);background:#000}.button.ghost{background:transparent;color:var(--ink);box-shadow:none;border-color:var(--line)}.button.ghost:hover{background:var(--paper)}.text-link{display:inline-flex;margin-top:20px;font-weight:780;border-bottom:1px solid currentColor}.text-link.light{color:white}
h1,h2,h3{font-family:var(--font-display);font-feature-settings:"ss01","ss02","cv11";text-wrap:balance}

/* Hero */
.hero-home{display:grid;grid-template-columns:minmax(0,1.08fr) minmax(300px,420px);gap:clamp(52px,8vw,120px);align-items:start;min-height:auto;padding-top:88px;padding-bottom:92px}
.hero-home h1{font-size:clamp(3.4rem,7vw,6.8rem);line-height:.93;letter-spacing:-.06em;margin:0 0 20px;max-width:760px;font-weight:880}.hero-home h1 span{display:block}.hero-home h1 .outline{-webkit-text-stroke:1.3px var(--ink);color:transparent}.role-line{font-size:clamp(1.05rem,1.6vw,1.25rem);color:var(--red);font-weight:820;margin:0 0 20px;letter-spacing:-.02em}.method-note{max-width:620px;color:#5c554c;font-size:1rem;font-weight:500;margin:18px 0 0;line-height:1.58}.hero-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:34px}.hero-text{min-width:0}.hero-text .lead{max-width:560px;font-size:clamp(1.05rem,1.45vw,1.18rem)}.hero-portrait{max-width:420px;width:100%;justify-self:center;margin:0}.hero-portrait img{width:100%;height:min(70vh,620px);aspect-ratio:3/4;object-fit:cover;object-position:center 15%;border-radius:18px;box-shadow:0 22px 74px rgba(20,19,17,.14)}.hero-portrait figcaption{text-align:center;font-size:.82rem;font-weight:800;color:#70685e;margin-top:12px}

/* Intro */
.intro-strip{max-width:var(--max);margin:0 auto 82px;padding:0 24px;display:grid;grid-template-columns:repeat(3,1fr);gap:30px}.intro-strip div{background:transparent;border:none;border-left:2px solid var(--accent);border-radius:0;padding:16px 24px;text-align:left}.intro-strip strong{display:block;font-size:.75rem;text-transform:uppercase;letter-spacing:.15em;color:var(--accent);margin-bottom:12px}.intro-strip span{display:block;font-size:1.05rem;line-height:1.45;font-weight:450;color:var(--ink)}

/* Work */
.section-head{display:grid;grid-template-columns:220px minmax(0,1fr);gap:40px;align-items:start;margin-bottom:42px}.section-head h2{font-size:clamp(1.85rem,3.5vw,3rem);line-height:1.05;letter-spacing:-.035em;margin:0 0 14px}.section-head p{margin:0;color:var(--muted);font-size:1.1rem;max-width:640px}
.filter-bar{max-width:var(--max);margin:0 auto 30px;padding:0;display:flex;gap:10px;flex-wrap:wrap}.filter-btn{border:1px solid var(--line);background:rgba(255,255,255,.62);color:var(--muted);border-radius:999px;padding:10px 14px;font-weight:780;cursor:pointer;transition:background .25s ease,color .25s ease,transform .25s ease}.filter-btn.active,.filter-btn:hover{background:var(--ink);color:#fff;border-color:var(--ink);transform:translateY(-1px)}
.projects-grid{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:30px}.project-card{grid-column:span 4;background:#fff;border:1px solid var(--line);border-radius:26px;overflow:hidden;box-shadow:0 18px 54px rgba(20,19,17,.06);transition:transform .42s cubic-bezier(.16,1,.3,1), box-shadow .42s ease}.project-card.featured{grid-column:span 6}.project-card:hover{transform:translateY(-8px) scale(1.01);box-shadow:0 32px 82px rgba(20,19,17,.13)}.project-card a{display:block;height:100%;cursor:pointer}.project-card figure{margin:0;background:#f2eee5;overflow:hidden;aspect-ratio:1/1;display:grid;place-items:center}.project-card img{width:100%;height:100%;object-fit:contain;background:#f2eee5;transition:transform .7s cubic-bezier(.16,1,.3,1),filter .5s ease}.project-card.featured figure{aspect-ratio:4/3}.project-card[data-category*="digital"] figure{aspect-ratio:4/3}.project-card:hover img{transform:scale(1.02)}.project-card-copy{padding:28px 28px 32px}.project-card-copy span{display:block;color:var(--accent-dark);text-transform:uppercase;letter-spacing:.12em;font-size:.72rem;font-weight:850;margin-bottom:12px}.project-card-copy h2{font-size:1.55rem;line-height:1.08;margin:0 0 12px;letter-spacing:-.035em;transition:color .25s ease}.project-card:hover h2{color:var(--accent-dark)}.project-card-copy p{margin:0;color:var(--muted);line-height:1.55;font-weight:500}

/* Footer */
.site-footer{background:var(--dark);color:white;margin-top:90px}.footer-inner{max-width:var(--max);margin:0 auto;padding:80px 24px;display:flex;flex-direction:column;align-items:center;text-align:center;gap:22px}.footer-inner img{width:200px;height:auto}.footer-inner p{color:#bdb8ad;max-width:620px;margin:0}.footer-links,.footer-contact{display:flex;gap:14px;flex-wrap:wrap;justify-content:center}.footer-links a,.footer-contact a{color:#f4f3ef;border:1px solid rgba(255,255,255,.18);padding:10px 13px;border-radius:999px;transition:background .25s ease}.footer-links a:hover,.footer-contact a:hover{background:rgba(255,255,255,.1)}.footer-contact a{background:rgba(255,255,255,.06)}

/* Pages */
.page-main{min-height:70vh}.about-hero{display:grid;grid-template-columns:330px 1fr;gap:64px;align-items:center}.about-hero figure{margin:0;max-width:330px;justify-self:center}.about-hero img{width:100%;aspect-ratio:3/4;object-fit:cover;object-position:50% 15%;border-radius:18px;box-shadow:0 25px 80px rgba(20,19,17,.12)}.about-hero h1,.contact-hero h1{font-size:clamp(2.8rem,5.5vw,5rem);line-height:1.03;letter-spacing:-.045em;margin:0 0 20px}.content-grid{display:grid;grid-template-columns:240px 1fr;gap:44px;border-top:1px solid var(--line)}.content-grid p{font-size:1.08rem;color:#3d3932;font-weight:500}.service-list{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.service-list article{background:#fff;border:1px solid var(--line);padding:26px;border-radius:24px}.service-list h2{margin:0 0 8px;font-size:1.25rem}.service-list p{margin:0;color:var(--muted)}.contact-actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:28px}

/* Case pages */
.case-main{background:var(--bg)}.case-hero h1{font-size:clamp(2.8rem,5.8vw,5.4rem);line-height:1.02;letter-spacing:-.045em;margin:0 0 20px}.case-hero h1::after{content:"";display:block;width:60px;height:2px;background:var(--accent);margin-top:24px}.back-link{display:inline-flex;margin-bottom:34px;color:var(--muted);font-weight:750}.case-cover{max-width:var(--max);margin:0 auto;padding:0 24px 66px;overflow:hidden}.case-cover img{width:100%;border-radius:30px;box-shadow:0 26px 80px rgba(20,19,17,.11);background:#eee}.project-meta-clean{max-width:var(--max);margin:0 auto 84px;padding:0 24px;display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.project-meta-clean div{background:#fff;border:1px solid var(--line);padding:18px;border-radius:18px}.project-meta-clean span{display:block;text-transform:uppercase;letter-spacing:.13em;font-size:.7rem;color:var(--muted);font-weight:850;margin-bottom:6px}.project-meta-clean strong{font-size:.98rem}.project-meta-clean a{text-decoration:underline;text-underline-offset:3px}.case-brief{max-width:var(--max);margin:0 auto;padding:54px 24px;border-bottom:1px solid var(--line)}.brief-content{max-width:780px}.brief-content h2{font-size:clamp(1.8rem,3.5vw,2.8rem);line-height:1.1;letter-spacing:-.03em;margin:0 0 16px}.brief-content p{font-size:1.1rem;color:var(--muted);font-weight:500;line-height:1.62}.case-text{max-width:var(--max);margin:0 auto 84px;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}.case-text h2{font-size:clamp(2rem,4vw,4rem);line-height:1;letter-spacing:-.045em;margin:0 0 18px}.case-text p{font-size:1.08rem;color:#3d3932;font-weight:500}.case-text figure{margin:0}.case-text figure img{border-radius:24px}.result-line{margin-top:24px;padding:18px 20px;background:var(--bg2);border-radius:12px;border-left:3px solid var(--accent);font-weight:500}.result-line strong{color:var(--ink);display:block;margin-bottom:4px}.case-process{max-width:var(--max);margin:0 auto 84px;padding:48px 24px}.process-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}.process-grid h3{font-size:1.1rem;margin:0 0 8px;color:var(--accent-dark)}.process-grid p{font-size:.96rem;color:var(--muted);margin:0;font-weight:500}.dark-block{background:var(--dark);color:white;max-width:calc(var(--max) - 48px);margin:0 auto 84px;border-radius:34px;padding:64px}.dark-block p{color:#d7d0c2}.dark-block figure{display:grid;place-items:center}.dark-block figure img{max-height:520px;object-fit:contain}.applications-grid{max-width:var(--max);margin:0 auto 96px;padding:0 24px;display:grid;gap:18px}.applications-grid.two{grid-template-columns:repeat(2,1fr)}.applications-grid.two-one{grid-template-columns:repeat(2,1fr)}.applications-grid.two-one .wide{grid-column:1/-1}.applications-grid.three{grid-template-columns:repeat(3,1fr)}.applications-grid.four{grid-template-columns:repeat(4,1fr)}.applications-grid figure{margin:0;background:#fff;border:1px solid var(--line);border-radius:28px;padding:16px;min-height:260px;display:flex;flex-direction:column;justify-content:center}.applications-grid img{width:100%;height:auto;object-fit:contain;max-height:620px;border-radius:18px}.applications-grid figcaption{font-size:.78rem;color:var(--muted);font-weight:750;text-transform:uppercase;letter-spacing:.11em;margin-top:12px}.project-nav-end{max-width:var(--max);margin:20px auto 0;padding:44px 24px;display:flex;justify-content:space-between;gap:16px;border-top:1px solid var(--line)}.project-nav-end a{font-weight:750;color:var(--muted)}
.laptop-live{background:#101010;border-radius:28px;padding:16px 16px 28px;box-shadow:0 28px 80px rgba(20,19,17,.18)}.browser-bar{height:38px;display:flex;gap:7px;align-items:center;color:#cfcac0;font-size:.78rem}.browser-bar span{width:10px;height:10px;border-radius:50%;background:#d9d9d9;opacity:.55}.browser-bar strong{font-weight:700;margin-left:8px}.laptop-live iframe{width:100%;height:600px;border:1px solid var(--line);border-radius:14px;background:#fff;box-shadow:0 10px 40px rgba(0,0,0,.1)}.phone-live{max-width:360px;margin:0 auto;background:#101010;border-radius:44px;padding:16px;box-shadow:0 30px 90px rgba(20,19,17,.16)}.phone-live iframe{width:100%;height:690px;border:1px solid var(--line);border-radius:34px;background:#fff;box-shadow:0 10px 40px rgba(0,0,0,.1)}
.beverage-layout{max-width:var(--max);margin:0 auto 88px;padding:0 24px;display:grid;grid-template-columns:1fr 1fr;gap:68px;align-items:center}.vending-machine{background:linear-gradient(145deg,#111,#26221d);border-radius:34px;padding:24px;box-shadow:0 30px 95px rgba(20,19,17,.24);color:white}.vending-screen{background:#050505;border:1px solid rgba(255,255,255,.14);border-radius:24px;padding:24px;min-height:560px;display:grid;grid-template-rows:auto 1fr auto;gap:18px}.screen-top{display:flex;justify-content:space-between;color:#d5c8aa;font-weight:800;font-size:.86rem;text-transform:uppercase;letter-spacing:.12em}.drink-stage{display:grid;place-items:center;min-height:330px}.drink-stage img{max-height:350px;width:auto;object-fit:contain}.drink-meta h2{font-size:clamp(1.8rem,4vw,3rem);margin:0;letter-spacing:-.05em}.drink-meta p{margin:8px 0 0;color:#cfc8be}.drink-controls{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-top:12px}.drink-arrow{width:46px;height:46px;border-radius:999px;border:1px solid rgba(255,255,255,.22);background:rgba(255,255,255,.06);color:white;font-size:1.5rem;cursor:pointer}.drink-thumbs{display:flex;gap:8px;overflow-x:auto;padding:4px 0 2px}.drink-thumbs button{border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.07);border-radius:14px;padding:4px;min-width:54px;height:54px;cursor:pointer}.drink-thumbs button.active{border-color:var(--accent);background:rgba(201,160,80,.22)}.drink-thumbs img{height:44px;width:44px;object-fit:contain}.drink-text h2{font-size:clamp(2rem,4vw,4rem);letter-spacing:-.05em;line-height:1;margin:0 0 18px}.drink-text p{font-size:1.08rem;color:#3d3932;font-weight:500}.drink-family{display:flex;gap:10px;flex-wrap:wrap;margin-top:18px}.drink-family span{border:1px solid var(--line);border-radius:999px;padding:8px 12px;font-size:.82rem;font-weight:780;background:rgba(255,255,255,.55)}
.reveal{opacity:0;transform:translateY(34px);transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}.reveal.is-visible{opacity:1;transform:translateY(0)}.project-card:nth-child(2){transition-delay:.06s}.project-card:nth-child(3){transition-delay:.12s}.project-card:nth-child(4){transition-delay:.18s}

@media (max-width:1200px){.projects-grid{grid-template-columns:repeat(12,minmax(0,1fr))}.project-card,.project-card.featured{grid-column:span 6}.hero-home{grid-template-columns:minmax(0,1fr) minmax(260px,360px);gap:44px}.hero-portrait{max-width:360px}.case-text,.beverage-layout{gap:44px}.process-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:980px){.nav-shell{min-height:68px}.nav-logo img{width:142px}.nav-links{gap:4px}.nav-links a{padding:8px 10px;font-size:.78rem}.hero-home,.about-hero,.content-grid,.case-text,.beverage-layout,.section-head{grid-template-columns:1fr}.hero-home{padding-top:64px;padding-bottom:74px}.hero-home h1{font-size:clamp(3rem,14vw,5rem)}.hero-portrait{max-width:320px}.intro-strip{grid-template-columns:1fr;gap:18px}.projects-grid{grid-template-columns:1fr}.project-card,.project-card.featured{grid-column:span 1}.project-card img,.project-card.featured figure{aspect-ratio:4/3}.project-meta-clean{grid-template-columns:repeat(2,1fr)}.applications-grid.two,.applications-grid.two-one,.applications-grid.three,.applications-grid.four{grid-template-columns:1fr}.applications-grid.two-one .wide{grid-column:auto}.dark-block{padding:36px 24px;border-radius:26px}.laptop-live iframe{height:460px}.phone-live iframe{height:620px}.process-grid{grid-template-columns:1fr}.footer-inner img{width:180px}}
@media (max-width:640px){.section-pad{padding:72px 18px}.section-pad.slim{padding:58px 18px}.site-header{position:sticky}.nav-shell{padding:12px 14px;gap:12px}.nav-logo img{width:122px}.nav-links a{font-size:.72rem;padding:7px 8px}.hero-home{padding:54px 18px 64px}.hero-home h1{font-size:clamp(3rem,17vw,4.7rem);line-height:.9}.role-line{font-size:1rem}.hero-actions{gap:8px}.button{width:100%}.hero-portrait{max-width:280px}.hero-portrait img{height:360px}.intro-strip{padding:0 18px;margin-bottom:54px}.section-head{gap:12px}.filter-bar{padding:0 18px}.projects-grid{gap:22px}.project-card{border-radius:22px}.project-card-copy{padding:22px}.project-card-copy h2{font-size:1.42rem}.project-meta-clean{grid-template-columns:1fr;margin-bottom:54px}.case-cover{padding-left:18px;padding-right:18px}.case-cover img{border-radius:22px}.case-text{padding-left:18px;padding-right:18px}.case-brief{padding-left:18px;padding-right:18px}.applications-grid{padding-left:18px;padding-right:18px}.project-nav-end{flex-direction:column}.beverage-layout{padding-left:18px;padding-right:18px}.vending-machine{padding:14px;border-radius:24px}.vending-screen{padding:16px;min-height:500px}.drink-stage{min-height:270px}.drink-stage img{max-height:290px}.footer-contact,.footer-links{flex-direction:column}.about-hero figure{max-width:280px}}
@media (prefers-reduced-motion:reduce){*,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.001ms!important}.reveal{opacity:1;transform:none}}
