/* =========================================================
   BARD COMMUNICATIONS — visual communications agency
   B2B editorial · black / white / grey · sans-led
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Archivo:wght@400;500;600;700;800&family=Newsreader:ital,opsz,wght@1,6..72,300;1,6..72,400&family=Noto+Sans+TC:wght@400;500;600&family=Spline+Sans+Mono:wght@400;500&display=swap');

:root{
  /* neutral monochrome palette */
  --paper:#f4f4f3;
  --paper-2:#e7e7e5;
  --panel:#ddddda;
  --ink:#0d0d0d;
  --ink-2:#3d3d3c;
  --grey:#6c6c6a;
  --grey-2:#9a9a97;
  --hair:rgba(13,13,13,.14);
  --hair-soft:rgba(13,13,13,.07);
  --noir:#0a0a0a;
  --noir-2:#161615;
  --on-noir:#f4f4f3;
  --on-noir-soft:rgba(244,244,243,.58);

  --sans:'Archivo','Helvetica Neue',Helvetica,Arial,sans-serif;
  --serif:'Newsreader',Georgia,serif;
  --mono:'Spline Sans Mono',ui-monospace,monospace;
  --cjk:'Noto Sans TC','Archivo','Helvetica Neue',sans-serif;

  --maxw:1560px;
  --gutter:clamp(20px,4vw,76px);
  --nav-h:72px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;}
body{
  margin:0;background:var(--paper);color:var(--ink);
  font-family:var(--sans);font-weight:400;line-height:1.5;font-size:17px;
  overflow-x:hidden;
}
::selection{background:var(--ink);color:var(--paper);}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit;}

/* ---------- layout ---------- */
.wrap{max-width:var(--maxw);margin:0 auto;padding-inline:var(--gutter);}
.section{padding-block:clamp(76px,11vw,170px);position:relative;}
.rule{height:1px;background:var(--hair);border:0;margin:0;}

/* labels */
.eyebrow{font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--grey);display:inline-flex;align-items:center;gap:.8em;}
.eyebrow::before{content:"";width:22px;height:1px;background:currentColor;opacity:.7;}
.eyebrow.bare::before{display:none;}

.sec-head{display:flex;justify-content:space-between;align-items:baseline;gap:24px;flex-wrap:wrap;margin-bottom:clamp(38px,5vw,72px);}
.sec-num{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;color:var(--grey-2);text-transform:uppercase;}

/* display type — sharp grotesque */
.display{font-family:var(--sans);font-weight:700;line-height:.96;letter-spacing:-.028em;margin:0;text-wrap:balance;}
.h-xl{font-size:clamp(46px,8.8vw,142px);}
.h-lg{font-size:clamp(36px,5.6vw,82px);}
.h-md{font-size:clamp(28px,3.6vw,50px);}
.it{font-family:var(--serif);font-style:italic;font-weight:300;letter-spacing:-.01em;}

.lede{font-size:clamp(17px,1.45vw,21px);line-height:1.55;color:var(--ink-2);max-width:54ch;font-weight:400;}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:.8em;font-family:var(--mono);font-size:11.5px;font-weight:500;letter-spacing:.16em;text-transform:uppercase;padding:15px 24px;border-radius:2px;border:1px solid var(--ink);background:var(--ink);color:var(--paper);transition:background .4s cubic-bezier(.2,.7,.2,1),color .4s,gap .4s;}
.btn .arw{transition:transform .4s cubic-bezier(.2,.7,.2,1);}
.btn:hover{background:transparent;color:var(--ink);gap:1.3em;}
.btn:hover .arw{transform:translateX(4px);}
.btn.ghost{background:transparent;color:var(--ink);}
.btn.ghost:hover{background:var(--ink);color:var(--paper);}
.btn.on-dark{border-color:var(--on-noir);background:var(--on-noir);color:var(--noir);}
.btn.on-dark:hover{background:transparent;color:var(--on-noir);}

.tlink{position:relative;display:inline-block;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;padding-bottom:3px;}
.tlink::after{content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;background:currentColor;transform:scaleX(0);transform-origin:left;transition:transform .45s cubic-bezier(.2,.7,.2,1);}
.tlink:hover::after{transform:scaleX(1);}

/* ============ NAV ============ */
.nav{position:fixed;top:0;left:0;right:0;z-index:80;height:var(--nav-h);display:flex;align-items:center;background:color-mix(in srgb,var(--paper) 80%,transparent);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:border-color .4s,background .4s;}
.nav.scrolled{border-bottom-color:var(--hair);}
.nav .wrap{display:flex;align-items:center;justify-content:flex-end;gap:32px;width:100%;}
.brand{display:flex;align-items:center;gap:14px;}
.badge{display:block;width:auto;}
.logo{position:relative;display:inline-block;line-height:0;}
.logo .cn{position:absolute;top:0;left:0;opacity:0;}
.logo .en,.logo .cn{transition:opacity 1.1s ease;}
.logo.show-cn .en{opacity:0;}
.logo.show-cn .cn{opacity:1;}
.nav .badge{height:56px;}
.hero-badge{height:clamp(150px,17vw,230px);}
.footer .badge{height:80px;}
.brand .wordmark{font-weight:800;font-size:23px;letter-spacing:-.02em;line-height:1;}
.brand .divider{width:1px;height:20px;background:var(--hair);}
.brand .tag{font-family:var(--mono);font-size:10px;letter-spacing:.2em;text-transform:uppercase;color:var(--grey);line-height:1.3;}
.nav-links{display:flex;align-items:center;gap:32px;}
.nav-links a{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-2);transition:color .3s;}
.nav-links a:hover{color:var(--ink);}
.nav-cta{font-family:var(--mono);font-size:11.5px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--ink);border-radius:2px;padding:9px 17px;transition:background .4s,color .4s;}
.nav-cta:hover{background:var(--ink);color:var(--paper);}
.nav-burger{display:none;flex-direction:column;gap:5px;padding:8px;}
.nav-burger span{width:24px;height:1.5px;background:var(--ink);}

.mobile-menu{position:fixed;inset:0;z-index:75;background:var(--paper);transform:translateY(-100%);transition:transform .6s cubic-bezier(.7,0,.2,1);display:flex;flex-direction:column;justify-content:center;padding:var(--gutter);}
.mobile-menu.open{transform:translateY(0);}
.mobile-menu a{font-weight:700;letter-spacing:-.02em;font-size:clamp(34px,11vw,60px);padding:12px 0;border-bottom:1px solid var(--hair);display:flex;justify-content:space-between;align-items:baseline;}
.mobile-menu a .mi{font-family:var(--mono);font-size:13px;color:var(--grey);font-weight:400;}

/* ============ HERO ============ */
.hero{padding-top:calc(var(--nav-h) + clamp(26px,4vw,52px));padding-bottom:clamp(28px,4vw,52px);}
.hero-top{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;flex-wrap:wrap;padding-bottom:clamp(26px,3.5vw,46px);border-bottom:1px solid var(--hair);}
.hero-grid{display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(28px,4vw,64px);align-items:end;margin-top:clamp(30px,4vw,52px);}
.hero h1{font-size:clamp(50px,8.4vw,150px);line-height:.92;letter-spacing:-.035em;}
.hero h1 .it{display:inline;}
.hero-coords{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;color:var(--grey);text-align:right;line-height:1.9;padding-top:6px;}
.hero-left{display:flex;flex-direction:column;gap:clamp(20px,2.4vw,30px);}
.hero-intro{display:flex;flex-direction:column;gap:24px;max-width:46ch;}
.hero-actions{display:flex;gap:16px;flex-wrap:wrap;align-items:center;}
.hero-figure{margin:0;position:relative;}
.hero-figure .slot{width:100%;height:clamp(340px,42vw,560px);}
.hero-fig-cap{position:absolute;left:0;bottom:0;padding:14px 16px;display:flex;justify-content:space-between;width:100%;font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--on-noir);mix-blend-mode:difference;}
.hero-fig-tag{position:absolute;top:16px;left:16px;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--on-noir);background:rgba(10,10,10,.55);padding:6px 11px;border-radius:2px;backdrop-filter:blur(4px);}

/* ============ FEATURED WORK BAND ============ */
.feat{padding-block:clamp(14px,2vw,26px);}
.feat-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin-bottom:22px;}
.feat-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:clamp(14px,1.4vw,22px);}
.feat-grid .feat-sub{display:grid;grid-template-rows:1fr 1fr;gap:clamp(14px,1.4vw,22px);}
.feat-card{position:relative;overflow:hidden;cursor:default;background:var(--panel);}
.feat-card.big{aspect-ratio:16/12;}
.feat-card.small{aspect-ratio:16/9;}
.feat-card .slot{width:100%;height:100%;transition:transform .9s cubic-bezier(.2,.7,.2,1);pointer-events:none;}
.feat-card:hover .slot{transform:scale(1.04);}
.feat-card::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(10,10,10,.6));opacity:.85;transition:opacity .5s;}
.feat-card:hover::after{opacity:1;}
.feat-card .fc-meta{position:absolute;left:0;bottom:0;z-index:2;padding:clamp(16px,1.8vw,26px);display:flex;justify-content:space-between;align-items:flex-end;width:100%;gap:14px;color:var(--on-noir);}
.feat-card .fc-name{font-weight:700;letter-spacing:-.02em;font-size:clamp(19px,1.7vw,28px);}
.feat-card .fc-cat{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:rgba(244,244,243,.78);white-space:nowrap;}
.feat-card .fc-view{position:absolute;right:clamp(16px,1.8vw,26px);top:clamp(16px,1.8vw,26px);z-index:2;font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--on-noir);border:1px solid rgba(244,244,243,.5);border-radius:2px;padding:7px 12px;opacity:0;transform:translateY(-6px);transition:opacity .4s,transform .4s,background .4s,color .4s;}
.feat-card:hover .fc-view{opacity:1;transform:none;}
.feat-card:hover .fc-view{background:var(--on-noir);color:var(--noir);border-color:var(--on-noir);}
@media(max-width:860px){.feat-grid{grid-template-columns:1fr;}.feat-card.big{aspect-ratio:16/10;}}

/* ============ ABOUT ============ */
.about-grid{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(36px,6vw,92px);}
.about-statement{font-weight:600;font-size:clamp(25px,3vw,44px);line-height:1.16;letter-spacing:-.025em;text-wrap:pretty;}
.about-statement .it{font-weight:300;}
.about-meta{display:flex;flex-direction:column;gap:0;}
.about-meta .lede{margin-bottom:28px;}
.region{display:flex;flex-direction:column;gap:6px;padding:22px 0;border-top:1px solid var(--hair);}
.region:last-child{border-bottom:1px solid var(--hair);}
.region h4{margin:0;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;display:flex;justify-content:space-between;}
.region h4 span{color:var(--grey-2);}
.region p{margin:0;color:var(--ink-2);font-size:15px;max-width:44ch;}

.stat-row{display:flex;gap:clamp(34px,6vw,104px);flex-wrap:wrap;margin-top:clamp(46px,6vw,88px);padding-top:clamp(34px,4vw,52px);border-top:1px solid var(--ink);}
.stat{display:flex;flex-direction:column;gap:8px;}
.stat .n{font-weight:700;letter-spacing:-.03em;font-size:clamp(54px,7.5vw,108px);line-height:1;perspective:760px;}
.stat .l{font-family:var(--mono);font-size:clamp(10.5px,0.85vw,12.5px);letter-spacing:.14em;text-transform:uppercase;color:var(--grey);}

/* ============ SERVICES ============ */
.svc-list{border-top:1px solid var(--ink);}
.svc{display:grid;grid-template-columns:74px 1fr auto;gap:24px;align-items:center;padding:clamp(24px,3.2vw,42px) 0;border-bottom:1px solid var(--hair);position:relative;transition:padding-left .5s cubic-bezier(.2,.7,.2,1);overflow:hidden;}
.svc::before{content:"";position:absolute;inset:0;background:var(--ink);transform:translateY(101%);transition:transform .5s cubic-bezier(.2,.7,.2,1);z-index:0;}
.svc > *{position:relative;z-index:1;}
.svc:hover{padding-left:28px;color:var(--paper);}
.svc:hover::before{transform:translateY(0);}
.svc:hover .svc-num,.svc:hover .svc-desc{color:rgba(244,244,243,.6);}
.svc-num{font-family:var(--mono);font-size:12px;color:var(--grey-2);letter-spacing:.08em;}
.svc-name{font-weight:700;letter-spacing:-.025em;font-size:clamp(24px,3.2vw,46px);line-height:1.02;}
.svc-desc{font-size:14px;color:var(--grey);max-width:32ch;text-align:right;transition:color .4s;padding-right:clamp(20px,2.4vw,42px);}
@media(max-width:760px){.svc{grid-template-columns:44px 1fr;}.svc-desc{display:none;}}

/* ============ WORK ============ */
.work-bar{display:flex;justify-content:space-between;align-items:flex-end;gap:24px;flex-wrap:wrap;margin-bottom:clamp(26px,3vw,42px);}
.filters{display:flex;flex-wrap:wrap;gap:7px;}
.filter{font-family:var(--mono);font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;padding:9px 15px;border-radius:2px;border:1px solid var(--hair);color:var(--ink-2);transition:all .3s;}
.filter:hover{border-color:var(--ink);}
.filter.active{background:var(--ink);color:var(--paper);border-color:var(--ink);}
.work-count{font-family:var(--mono);font-size:11.5px;letter-spacing:.1em;color:var(--grey-2);}

.work-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:clamp(14px,1.5vw,26px);}
.work-card{position:relative;cursor:pointer;grid-column:span 6;}
.work-card.wide{grid-column:span 12;}
.work-card.third{grid-column:span 4;}
.work-media{position:relative;overflow:hidden;background:var(--panel);}
.work-media .slot{width:100%;height:100%;transition:transform .9s cubic-bezier(.2,.7,.2,1);pointer-events:none;}
.work-card .work-media{aspect-ratio:4/3;}
.work-card.wide .work-media{aspect-ratio:16/7;}
.work-card.third .work-media{aspect-ratio:3/4;}
.work-card:hover .work-media .slot{transform:scale(1.035);}
.work-media::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 52%,rgba(10,10,10,.55));opacity:0;transition:opacity .5s;}
.work-card:hover .work-media::after{opacity:1;}
.work-hover{position:absolute;left:0;bottom:0;width:100%;z-index:2;padding:clamp(14px,1.6vw,22px);display:flex;justify-content:space-between;align-items:flex-end;gap:14px;color:var(--on-noir);opacity:0;transform:translateY(8px);transition:opacity .45s,transform .45s;}
.work-card:hover .work-hover{opacity:1;transform:none;}
.work-hover .wh-view{font-family:var(--mono);font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;border:1px solid rgba(244,244,243,.55);border-radius:2px;padding:7px 11px;white-space:nowrap;}
.work-hover .wh-view-name{font-weight:700;letter-spacing:-.02em;font-size:clamp(17px,1.5vw,24px);}
.work-meta{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding-top:13px;}
.work-meta .wt{font-weight:700;letter-spacing:-.02em;font-size:clamp(18px,1.5vw,25px);}
.work-meta .wc{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey);white-space:nowrap;}
.work-card.is-hidden{display:none;}
@media(max-width:760px){.work-card,.work-card.third{grid-column:span 12 !important;}.work-card.wide{grid-column:span 12;}}

/* ============ PROCESS ============ */
.process{background:var(--noir);color:var(--on-noir);}
.process .eyebrow,.process .sec-num{color:var(--on-noir-soft);}
.proc-list{display:grid;grid-template-columns:repeat(5,1fr);border-top:1px solid rgba(244,244,243,.2);}
.proc-step{padding:clamp(26px,3vw,46px) clamp(15px,1.5vw,26px) clamp(34px,4vw,58px);border-right:1px solid rgba(244,244,243,.2);position:relative;min-height:clamp(220px,23vw,320px);display:flex;flex-direction:column;}
.proc-step:last-child{border-right:0;}
.proc-step .pn{font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;color:var(--on-noir-soft);}
.proc-step .pt{font-weight:700;letter-spacing:-.025em;font-size:clamp(21px,1.9vw,29px);line-height:1.04;margin-top:auto;}
.proc-step .pd{font-size:13.5px;color:var(--on-noir-soft);margin-top:13px;max-width:25ch;line-height:1.5;min-height:6em;}
.proc-step .pbar{position:absolute;left:0;bottom:0;height:2px;width:0;background:var(--on-noir);transition:width 1.1s cubic-bezier(.2,.7,.2,1) .1s;}
.proc-step.in .pbar{width:100%;}
@media(max-width:860px){.proc-list{grid-template-columns:1fr;}.proc-step{border-right:0;border-bottom:1px solid rgba(244,244,243,.2);min-height:0;}.proc-step .pt{margin-top:16px;}}

/* ============ CONTACT ============ */
.contact{padding-bottom:clamp(40px,5vw,70px);}
.contact-head{font-size:clamp(40px,8vw,140px);line-height:.92;letter-spacing:-.035em;}
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(32px,5vw,72px);margin-top:clamp(40px,5vw,72px);align-items:start;}
.contact-mail{font-weight:700;letter-spacing:-.02em;font-size:clamp(24px,3vw,44px);display:inline-flex;align-items:center;gap:.35em;}
.contact-mail .arw{font-size:.5em;transition:transform .45s;}
.contact-mail:hover .arw{transform:translate(5px,-5px);}
.offices{display:grid;grid-template-columns:1fr 1fr;gap:clamp(28px,3vw,46px);}
.office h4{margin:0 0 14px;font-weight:600;font-size:clamp(16px,1.35vw,19px);letter-spacing:-.01em;line-height:1.32;}
.cn{font-family:var(--cjk);}
.office p{margin:0 0 9px;color:var(--ink-2);font-size:14.5px;line-height:1.62;max-width:36ch;}
.office .addr{color:var(--ink);}
.office .tel{font-family:var(--mono);font-size:12.5px;letter-spacing:.01em;color:var(--ink-2);}
.office .pin{font-size:13px;color:var(--grey);margin-top:2px;}
.office a{text-decoration:none;color:inherit;transition:color .3s;}
.office a:hover{color:var(--ink);}

/* ============ FOOTER ============ */
.footer{border-top:1px solid var(--hair);padding-block:38px;}
.footer .wrap{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;}
.footer .fmark{font-weight:800;font-size:20px;letter-spacing:-.02em;}
.footer .fmeta{font-family:var(--mono);font-size:10.5px;letter-spacing:.1em;color:var(--grey);text-transform:uppercase;}

/* ============ FULL-SCREEN CASE STUDY ============ */
.cs{position:fixed;inset:0;z-index:120;background:var(--paper);opacity:0;visibility:hidden;overflow-y:auto;overflow-x:hidden;}
.cs.open{opacity:1;visibility:visible;}
.cs-bar{position:sticky;top:0;z-index:5;display:flex;justify-content:space-between;align-items:center;padding:18px var(--gutter);background:color-mix(in srgb,var(--paper) 82%,transparent);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);border-bottom:1px solid var(--hair);}
.cs-bar .cb-id{font-family:var(--mono);font-size:11.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);}
.cs-bar .cb-id b{color:var(--ink);font-weight:500;}
.cs-close{display:inline-flex;align-items:center;gap:.7em;font-family:var(--mono);font-size:11.5px;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--ink);border-radius:2px;padding:9px 16px;transition:background .4s,color .4s;}
.cs-close:hover{background:var(--ink);color:var(--paper);}
.cs-body{max-width:var(--maxw);margin:0 auto;padding:clamp(28px,4vw,64px) var(--gutter) clamp(60px,7vw,110px);transform:translateY(26px);transition:transform .6s cubic-bezier(.2,.7,.2,1);}
.cs.open .cs-body{transform:none;}
.cs-titlewrap{display:grid;grid-template-columns:1.4fr .6fr;gap:clamp(24px,4vw,56px);align-items:end;margin-bottom:clamp(28px,3.5vw,48px);}
.cs-title{font-weight:700;letter-spacing:-.035em;font-size:clamp(44px,7vw,122px);line-height:.9;margin:0;}
.cs-rolewrap{display:flex;flex-direction:column;gap:14px;padding-bottom:10px;}
.cs-role{font-size:clamp(15px,1.2vw,18px);color:var(--ink-2);line-height:1.5;}
.cs-cover .slot{width:100%;height:clamp(320px,52vw,720px);}
.cs-info{display:grid;grid-template-columns:1.2fr .8fr;gap:clamp(28px,4vw,72px);margin-top:clamp(36px,4.5vw,68px);}
.cs-desc{font-size:clamp(17px,1.4vw,22px);line-height:1.62;color:var(--ink);max-width:48ch;}
.cs-facts{display:flex;flex-direction:column;}
.cs-facts .fh{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);padding:0 0 12px;border-bottom:1px solid var(--ink);}
.cs-fact{display:flex;justify-content:space-between;gap:16px;padding:13px 0;border-bottom:1px solid var(--hair);font-size:15px;}
.cs-fact span{color:var(--grey);font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;padding-top:3px;white-space:nowrap;}
.cs-deliver{display:flex;flex-wrap:wrap;gap:8px;margin-top:18px;}
.cs-deliver li{list-style:none;font-family:var(--mono);font-size:11px;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--hair);border-radius:2px;padding:8px 13px;color:var(--ink-2);}
.cs-deliver ul{display:contents;margin:0;padding:0;}
.cs-gallery{margin-top:clamp(40px,5vw,80px);}
.cs-gallery .gh{display:flex;justify-content:space-between;align-items:baseline;border-top:1px solid var(--ink);padding-top:18px;margin-bottom:22px;}
.cs-gallery-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(14px,1.5vw,24px);}
.cs-gallery-grid .slot{width:100%;height:clamp(240px,30vw,460px);}
.cs-gallery-grid .g-wide{grid-column:span 2;}
.cs-gallery-grid .g-wide .slot{height:clamp(300px,40vw,620px);}
.cs-next{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:clamp(48px,5vw,84px);padding-top:30px;border-top:1px solid var(--ink);flex-wrap:wrap;cursor:pointer;}
.cs-next .nx-label{font-family:var(--mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--grey);}
.cs-next .nx-name{font-weight:700;letter-spacing:-.03em;font-size:clamp(28px,4vw,64px);display:inline-flex;align-items:center;gap:.4em;line-height:1;}
.cs-next .nx-name .arw{transition:transform .45s;}
.cs-next:hover .nx-name .arw{transform:translateX(8px);}
@media(max-width:820px){.cs-titlewrap,.cs-info{grid-template-columns:1fr;}.cs-gallery-grid{grid-template-columns:1fr;}.cs-gallery-grid .g-wide{grid-column:span 1;}}

/* ============ BILINGUAL SECTION LABEL (small CN supporting subtitle) ============ */
.eyebrow-cn{font-family:var(--cjk);font-size:12.5px;font-weight:400;letter-spacing:.06em;text-transform:none;color:var(--grey-2);}
.process .eyebrow-cn{color:var(--on-noir-soft);}

/* ============ SELECTED WORK — gliding reel ============ */
.reel{position:relative;overflow:hidden;}
.reel-track{display:flex;width:max-content;animation:reelGlide 40s linear infinite;will-change:transform;}
.reel:hover .reel-track,.reel:focus-within .reel-track{animation-play-state:paused;}
@keyframes reelGlide{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.reel-card{flex:0 0 auto;width:clamp(340px,40vw,560px);margin-right:clamp(20px,2.2vw,36px);}
.rc-media{position:relative;overflow:hidden;aspect-ratio:4/3;background:var(--panel);}
.rc-media .slot{width:100%;height:100%;transition:transform 1s cubic-bezier(.2,.7,.2,1);}
.rc-cap{padding-top:16px;display:flex;flex-direction:column;gap:10px;}
.rc-meta{display:flex;justify-content:space-between;align-items:baseline;gap:14px;}
.rc-name{font-weight:700;letter-spacing:-.02em;font-size:clamp(18px,1.5vw,26px);line-height:1.15;}
.rc-cat{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);white-space:nowrap;}
.rc-summary{margin:0;font-size:13px;line-height:1.5;color:var(--grey);max-width:42ch;max-height:0;opacity:0;transform:translateY(6px);overflow:hidden;transition:max-height .55s cubic-bezier(.2,.7,.2,1),opacity .45s ease,transform .55s cubic-bezier(.2,.7,.2,1);}
/* hover: pause the reel, focus the one under the cursor */
.reel:hover .reel-card{opacity:.38;transition:opacity .5s ease;}
.reel .reel-card:hover{opacity:1;}
.reel-card:hover .rc-media .slot{transform:scale(1.05);}
.reel-card:hover .rc-summary{max-height:8em;opacity:1;transform:none;}
@media(prefers-reduced-motion:reduce){.reel-track{animation:none;}.reel{overflow-x:auto;}}
@media(max-width:860px){.reel-card{width:78vw;}}

/* ============ OTHER SELECTED WORKS — compact cards ============ */
.other-head{display:flex;justify-content:space-between;align-items:flex-end;gap:20px;flex-wrap:wrap;margin:clamp(56px,7vw,112px) 0 clamp(22px,2.6vw,36px);padding-top:clamp(26px,3vw,40px);border-top:1px solid var(--ink);}
.other-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(14px,1.6vw,26px);}
.other-card{cursor:default;}
.other-media{position:relative;overflow:hidden;background:var(--panel);aspect-ratio:4/3;}
.other-media .slot{width:100%;height:100%;pointer-events:auto;}
.other-meta{display:flex;justify-content:space-between;align-items:baseline;gap:12px;padding-top:11px;}
.other-meta .ot{font-weight:700;letter-spacing:-.02em;font-size:clamp(15px,1.1vw,18px);line-height:1.15;}
.other-meta .oc{font-family:var(--mono);font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--grey);white-space:nowrap;}
.o-summary{margin:7px 0 0;font-size:12px;line-height:1.5;color:var(--grey);max-width:34ch;text-wrap:pretty;}
@media(max-width:1040px){.other-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:680px){.other-grid{grid-template-columns:repeat(2,1fr);}}

/* ============ AI + EDM CAPABILITY ============ */
.cap-figure{margin:clamp(40px,5vw,84px) 0 0;position:relative;}
.cap-figure .slot{width:100%;height:clamp(300px,38vw,520px);}
.cap-cap{display:flex;justify-content:space-between;gap:16px;margin-top:14px;padding-top:13px;border-top:1px solid var(--hair);font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--grey);}

/* ============ CREATIVE LEAD ============ */
.lead-grid{display:grid;grid-template-columns:.5fr 1.5fr;gap:clamp(34px,5vw,84px);align-items:center;}
.lead-portrait{margin:0;display:flex;justify-content:center;}
.lead-portrait .slot{width:clamp(200px,22vw,280px);height:clamp(200px,22vw,280px);}
.lead-body{display:flex;flex-direction:column;gap:clamp(16px,1.9vw,24px);}
.lead-body .eyebrow{margin-bottom:2px;}
.lead-name{font-size:clamp(46px,5.4vw,92px);line-height:.94;}
.lead-quote{font-size:clamp(22px,2.4vw,38px);line-height:1.24;letter-spacing:-.02em;color:var(--ink);max-width:22ch;margin:0;}
.lead-actions{margin-top:6px;}
@media(max-width:1040px){.lead-grid{grid-template-columns:1fr;}.lead-portrait .slot{width:clamp(190px,40vw,240px);height:clamp(190px,40vw,240px);}}

/* ---------- reveal (transform-only — never hides content if the timeline is frozen) ---------- */
.reveal{transform:translateY(20px);transition:transform .85s cubic-bezier(.2,.7,.2,1);}
.reveal.in{transform:none;}
.reveal.d1{transition-delay:.07s;}
.reveal.d2{transition-delay:.14s;}
.reveal.d3{transition-delay:.21s;}
.reveal.d4{transition-delay:.28s;}

/* ============ INTERACTION ENHANCEMENTS (additive — transform-only entrances) ============ */

/* Featured work — split-screen converging reveal */
.feat-quad .feat-card{transform:translateY(22px);transition:transform 1.05s cubic-bezier(.2,.7,.2,1);}
.feat-quad .feat-card.rx-l{transform:translate(-46px,0);}
.feat-quad .feat-card.rx-r{transform:translate(46px,0);}
.feat-quad .feat-card.in{transform:none;}

/* Featured hover — refined crop + on-hover summary */
.feat-card .slot{transition:transform 1.05s cubic-bezier(.2,.7,.2,1);}
.feat-card:hover .slot,.feat-card:focus-visible .slot{transform:scale(1.06);}
.feat-card:focus-visible{outline:none;}
.feat-card:focus-visible .fc-view{opacity:1;transform:none;background:var(--on-noir);color:var(--noir);border-color:var(--on-noir);}
.feat-card .fc-foot{position:absolute;left:0;bottom:0;width:100%;z-index:2;padding:clamp(13px,1.4vw,20px) clamp(16px,1.8vw,26px);display:flex;flex-direction:column;color:var(--on-noir);background:var(--noir);}
.feat-card .fc-foot .fc-meta{position:static;padding:0;}
.feat-card .fc-summary{margin:0 0 9px;max-width:40ch;font-size:clamp(13px,1vw,15px);line-height:1.4;color:rgba(244,244,243,.85);max-height:0;opacity:0;transform:translateY(10px);overflow:hidden;transition:max-height .6s cubic-bezier(.2,.7,.2,1),opacity .5s ease,transform .6s cubic-bezier(.2,.7,.2,1);}
.feat-card:hover .fc-summary,.feat-card:focus-visible .fc-summary{max-height:7em;opacity:1;transform:none;}

/* Case study — staggered editorial entrance (body itself stays put; children carry the motion) */
.cs-body{transform:none;}
.cs-rise{transform:translateY(28px);transition:transform .82s cubic-bezier(.2,.7,.2,1);}
.cs-rise.in{transform:none;}

/* Contact — drawn hairline + line-by-line type reveal */
.contact-head .cl{display:block;}
.contact-rule{height:1px;background:var(--hair);margin-top:clamp(30px,4vw,54px);}
.line-reveal{transform:scaleX(0);transform-origin:left;transition:transform 1.15s cubic-bezier(.2,.7,.2,1);}
.line-reveal.in{transform:scaleX(1);}

/* Italic accent — Solari split-flap title reveal; the word then sits static (transform-only) */
.it-move{display:inline-block;white-space:nowrap;cursor:default;}
.it-move .ch{display:inline-block;}
/* split-flap cells */
[data-flap]{perspective:760px;}
.fl{display:inline-block;}
.fl-word{display:inline-block;white-space:nowrap;}
.fl.flapping{animation:flFlip .2s cubic-bezier(.3,.05,.2,1);transform-origin:50% 0;}
@keyframes flFlip{0%{transform:rotateX(-85deg);}100%{transform:rotateX(0);}}

/* Process — sleek line icons (geometric, echoing the monogram's dot/diamond) */
.proc-step .pi{display:block;width:clamp(31px,2.64vw,37px);height:clamp(31px,2.64vw,37px);margin-top:18px;color:var(--on-noir-soft);transition:color .6s ease,transform .9s cubic-bezier(.2,.7,.2,1);transform:translateY(8px);}
.proc-step .pi svg{display:block;width:100%;height:100%;}
.proc-step.in .pi{color:var(--on-noir);transform:none;}
/* Process icons — meaningful micro-loops, begin once the step is revealed (transform-only) */
.proc-step .pi .ic-write,.proc-step .pi .ic-pulse,.proc-step .pi .ic-needle,.proc-step .pi .ic-lift,.proc-step .pi .ic-send{transform-box:fill-box;transform-origin:center;}
.proc-step .pi .ic-write{stroke-dasharray:17;}
.proc-step.in .pi .ic-write{animation:icWrite 4.4s ease-in-out infinite;}
.proc-step.in .pi .ic-pulse{animation:icPulse 4.4s ease-in-out infinite .3s;}
.proc-step.in .pi .ic-needle{animation:icNeedle 4.4s cubic-bezier(.5,.05,.2,1) infinite .6s;}
.proc-step.in .pi .ic-lift{animation:icLift 4.4s ease-in-out infinite .9s;}
.proc-step.in .pi .ic-send{animation:icSend 4.4s ease-in-out infinite 1.2s;}
@keyframes icWrite{0%,38%{stroke-dashoffset:17;}66%,100%{stroke-dashoffset:0;}}
@keyframes icPulse{0%,50%,100%{transform:scale(1);}70%{transform:scale(1.16);}}
@keyframes icNeedle{0%,40%,100%{transform:rotate(0deg);}66%{transform:rotate(135deg);}}
@keyframes icLift{0%,45%,100%{transform:translateY(0);}66%{transform:translateY(-2.5px);}}
@keyframes icSend{0%,45%,100%{transform:translateY(0);}66%{transform:translateY(-3.5px);}}

/* ---------- responsive ---------- */
@media(max-width:1040px){
  .nav-links,.nav-cta{display:none;}
  .nav-burger{display:flex;}
  .hero-grid{grid-template-columns:1fr;align-items:stretch;}
  .about-grid{grid-template-columns:1fr;}
  .contact-grid{grid-template-columns:1fr;}
}
@media(max-width:560px){
  .offices{grid-template-columns:1fr;}
  .brand .tag,.brand .divider{display:none;}
  .hero-top{flex-direction:column;align-items:center;text-align:center;}
  .hero-logo{justify-content:center;}
  .hero-coords{text-align:center;}
}
@media(prefers-reduced-motion:reduce){
  *{animation-duration:.001ms !important;animation-iteration-count:1 !important;}
  .reveal{transform:none !important;}
  .cs-body{transform:none !important;}
  .cs-rise,.line-reveal,.feat-quad .feat-card{transform:none !important;}
  .it-move .ch{animation:none !important;transform:none !important;}
  .fl.flapping{animation:none !important;transform:none !important;}
  .proc-step .pi{transform:none !important;}
  .proc-step .pi svg *{animation:none !important;transform:none !important;}
  .proc-step .pi .ic-write{stroke-dashoffset:0 !important;}
  html{scroll-behavior:auto;}
}


/* ---- static <img> slots (replaces the editor image-slot component) ---- */
.slot{display:block;object-fit:cover;background:var(--panel);}
.lead-portrait .slot{border-radius:50%;width:100%;height:100%;}

/* ================================================================
   MOBILE-ONLY FIXES (desktop > 1040px is untouched / locked)
   ================================================================ */

/* (1) Founder portrait — was filling the full column on small screens;
       restore a sensible responsive size (~half width on a phone). */
@media(max-width:1040px){
  .lead-portrait .slot{
    width:clamp(150px,40vw,220px) !important;
    height:clamp(150px,40vw,220px) !important;
  }
}

/* (3) Hero featured image — lift the tag + caption OUT of the image so
       they no longer overlap the artwork on phones. */
@media(max-width:760px){
  .hero-figure{display:flex;flex-direction:column;}
  .hero-fig-tag{
    position:static;order:-1;align-self:flex-start;
    background:transparent;color:var(--grey);padding:0 0 10px;
  }
  .hero-fig-cap{
    position:static;width:auto;padding:12px 0 0;
    background:none;color:var(--ink-2);
  }
}

/* (2) Other Selected Works — stack name above category so long titles
       (e.g. "LKY School of Public Policy") stop wrapping one word per line. */
@media(max-width:680px){
  .other-meta{flex-direction:column;align-items:flex-start;gap:3px;}
  .other-meta .oc{white-space:normal;}
}
