:root{
  /* 精品優化：柔黑柔白，避開純黑純白（參考 Dior #f8f8f8 / #33383c） */
  --ink:#2b2b2b;          /* 石墨文字，非純黑 */
  --black:#1c1c1c;        /* 最深也只到深石墨 */
  --paper:#f7f6f4;        /* 柔白底，非純白 */
  --paper-2:#efece7;      /* 次層柔米白 */
  --terra:#2b2b2b;        /* accent 收斂為石墨 */
  --ochre:#7a766f;        /* 次要灰，較柔 */
  --forest:#26261f;       /* 深色區塊用柔石墨 */
  --plum:#262320;
  --muted:#76726b;        /* 柔次要灰 */
  --line:rgba(43,43,43,.10);
  --serif-en:'ABeeZee', sans-serif;
  --serif-tc:'ABeeZee','PingFang TC','Noto Sans TC', sans-serif;
  --sans:'ABeeZee','PingFang TC','Noto Sans TC', sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--paper);color:var(--ink);
  font-family:var(--sans);line-height:1.7;
  font-optical-sizing:auto;text-rendering:optimizeLegibility;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;width:100%;height:100%;object-fit:cover}
.wrap{max-width:1280px;margin:0 auto;padding:0 32px}
.ey{font-family:var(--sans);font-size:12px;letter-spacing:.32em;text-transform:uppercase;color:var(--terra);font-weight:500}

/* ---------- NAV ---------- */
header{position:fixed;top:0;left:0;right:0;z-index:50;
  transition:background .5s ease,padding .5s ease;padding:30px 0}
header.scrolled{background:rgba(247,246,244,.86);backdrop-filter:blur(14px) saturate(1.1);padding:15px 0;border-bottom:1px solid var(--line)}
.nav{display:flex;align-items:center;justify-content:space-between}
/* logo images must never be stretched/cropped by the global img rule */
img.logo{width:auto!important;height:auto;object-fit:contain!important}
.brand{display:flex;align-items:center;color:var(--ink)}
.brand .logo{height:42px;width:auto;transition:height .4s}
header.scrolled .brand .logo{height:34px}
.hero+*{}
nav ul{display:flex;gap:42px;list-style:none;align-items:center}
nav a{font-size:12.5px;letter-spacing:.18em;color:var(--ink);position:relative;padding:4px 0}
nav a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--ink);transition:width .45s cubic-bezier(.16,1,.3,1)}
nav a:hover::after{width:100%}
.nav-cta{border:1px solid var(--ink);padding:11px 24px;border-radius:0;font-size:11.5px;letter-spacing:.18em;transition:.4s}
.nav-cta:hover{background:var(--ink);color:var(--paper)}
.nav-cta::after{display:none}
/* dropdown for 作品 → 居家 / 商業 */
.has-sub{position:relative}
.has-sub .sub{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(10px);background:rgba(247,246,244,.97);backdrop-filter:blur(12px);border:1px solid var(--line);padding:16px 22px;display:flex;flex-direction:column;gap:13px;min-width:170px;opacity:0;visibility:hidden;transition:.38s cubic-bezier(.16,1,.3,1);white-space:nowrap;list-style:none}
.has-sub:hover .sub{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.has-sub .sub li{text-align:center}
.has-sub .sub a{font-size:12px;letter-spacing:.12em}
/* second level flyout：商業/居家 → 各案清單 */
.has-sub .sub li.has-sub2{text-align:left;position:relative}
.has-sub2 > a{display:flex;align-items:center;justify-content:space-between;gap:18px}
.has-sub2 .arr{font-style:normal;color:var(--muted);font-size:15px;line-height:1;transition:.3s}
.has-sub2:hover .arr{color:var(--ink)}
.sub2{position:absolute;top:-17px;left:100%;margin-left:1px;background:rgba(247,246,244,.98);backdrop-filter:blur(12px);border:1px solid var(--line);padding:16px 22px;display:flex;flex-direction:column;gap:12px;min-width:240px;opacity:0;visibility:hidden;transform:translateX(8px);transition:.32s cubic-bezier(.16,1,.3,1);list-style:none;white-space:nowrap}
.has-sub2:hover > .sub2{opacity:1;visibility:visible;transform:translateX(0)}
.sub2 li{text-align:left}
.sub2 a{font-size:12px;letter-spacing:.06em;color:var(--ink);display:block}
.sub2 a:hover{color:var(--muted)}
.burger{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0}
.burger span{width:26px;height:2px;background:var(--ink);transition:.3s}

/* ---------- HERO SLIDESHOW ---------- */
.hero{position:relative;height:100vh;min-height:640px;color:#fff;overflow:hidden;background:#1c1a18}
.slides{position:absolute;inset:0}
.slide{position:absolute;inset:0;display:flex;align-items:flex-end;opacity:0;z-index:1;transition:opacity 1.5s ease;pointer-events:none}
.slide.is-active{opacity:1;z-index:2;pointer-events:auto}
.slide-bg{position:absolute;inset:0;overflow:hidden}
.slide-bg::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(24,22,20,.24) 0%,rgba(24,22,20,.12) 45%,rgba(24,22,20,.66) 100%)}
.slide-bg img{width:100%;height:100%;object-fit:cover;transform:scale(1.02)}
.slide.is-active .slide-bg img{animation:kenburns 7s ease-out forwards}
@keyframes kenburns{from{transform:scale(1.02)}to{transform:scale(1.1)}}
.slide .wrap{width:100%;padding-bottom:13vh;position:relative;z-index:3}
.slide-content{opacity:0;transform:translateY(24px);transition:opacity 1s ease .35s,transform 1.2s cubic-bezier(.16,1,.3,1) .35s}
.slide.is-active .slide-content{opacity:1;transform:none}
.s-tag{font-size:11px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.82)}
.hero h1{font-family:var(--serif-tc);font-weight:400;font-size:clamp(36px,5vw,66px);line-height:1.14;letter-spacing:.03em;margin:18px 0 22px;text-shadow:0 1px 24px rgba(0,0,0,.22)}
.hero h1 .en{display:block;font-family:var(--serif-tc);font-weight:300;font-size:clamp(17px,1.9vw,24px);letter-spacing:.02em;color:rgba(255,255,255,.88);margin-top:12px}
.slide-link{display:inline-block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:#fff;padding-bottom:6px;border-bottom:1px solid rgba(255,255,255,.6);transition:.4s}
.slide-link:hover{border-color:#fff;letter-spacing:.26em}
.hero-brand{position:absolute;top:15vh;left:0;right:0;z-index:4}
.hero-brand .ey{color:rgba(255,255,255,.72);font-size:11px;letter-spacing:.26em}
.hero-dots{position:absolute;right:36px;bottom:40px;z-index:5;display:flex;gap:12px}
.hero-dots button{width:30px;height:2px;border:0;padding:0;background:rgba(255,255,255,.35);cursor:pointer;transition:.4s}
.hero-dots button.on{background:#fff;width:46px}
.scrollcue{position:absolute;bottom:34px;left:50%;transform:translateX(-50%);font-size:10px;letter-spacing:.3em;color:rgba(255,255,255,.7);writing-mode:vertical-rl;z-index:5}
.scrollcue::before{content:"";display:block;width:1px;height:46px;background:rgba(255,255,255,.6);margin:0 auto 12px;animation:cue 2s infinite}
@keyframes cue{0%,100%{opacity:.3;transform:scaleY(.6)}50%{opacity:1;transform:scaleY(1)}}

/* ---------- PAGE HEAD (inner pages) ---------- */
.page-head{padding:158px 0 0;}
.page-head .inner-head{max-width:760px}
.page-head .ey{display:block}
.page-head h1{font-family:var(--serif-tc);font-weight:400;font-size:clamp(34px,5vw,58px);line-height:1.16;margin:16px 0 0}
.page-head h1 .en{display:block;font-family:var(--serif-en);font-style:italic;color:var(--muted);font-size:.42em;letter-spacing:.04em;margin-top:14px}
.page-head p{color:var(--muted);font-size:15px;max-width:560px;line-height:1.75;margin-top:20px}
.page-head .rule{height:1px;background:var(--line);margin-top:46px}

/* ---------- reveal ---------- */
.rev{opacity:0;transform:translateY(42px);transition:opacity 1.5s ease,transform 1.6s cubic-bezier(.16,1,.3,1)}
.rev.in{opacity:1;transform:none}

/* ---------- PHILOSOPHY ---------- */
.philo{padding:185px 0 165px;position:relative}
.philo.inner{padding-top:80px}
.philo .grid{display:grid;grid-template-columns:1fr 1.1fr;gap:100px;align-items:center}
.philo h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(30px,3.8vw,52px);line-height:1.25;margin:20px 0 30px}
.philo h2 em{font-family:var(--serif-en);font-style:italic;color:var(--terra)}
.philo .body p{color:#4a423a;margin-bottom:18px;font-size:16px}
.philo .en{margin-top:26px;padding-top:24px;border-top:1px solid var(--line);font-family:var(--serif-en);font-size:17px;font-style:italic;color:var(--muted);line-height:1.6}
.philo-img{position:relative;aspect-ratio:4/5;border-radius:2px;overflow:hidden}
.philo-img::after{content:"";position:absolute;inset:0;box-shadow:inset 0 0 0 1px rgba(255,255,255,.25)}

/* ---------- PILLARS ---------- */
.pillars{background:var(--paper-2);color:var(--ink);padding:165px 0}
.pillars .head{text-align:center;max-width:640px;margin:0 auto 70px}
.pillars .head h2{font-family:var(--serif-en);font-style:italic;font-weight:400;font-size:clamp(28px,3.4vw,44px);margin-top:14px}
.pcols{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--line)}
.pcol{padding:54px 36px;border-right:1px solid var(--line);position:relative;transition:background .4s}
.pcol:last-child{border-right:0}
.pcol:hover{background:rgba(18,18,18,.02)}
/* poster-style block：照片 + 半透明色塊 + 大字（仿原官網 OUR EMOTION/VISION/MISSION） */
.pcol .pblock{position:relative;aspect-ratio:1/1;margin:-54px -36px 42px;overflow:hidden}
.pcol .pblock .pb-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.8s cubic-bezier(.16,1,.3,1)}
.pcol:hover .pblock .pb-img{transform:scale(1.06)}
.pcol .pblock .pb-tint{position:absolute;inset:20px;transition:opacity .5s}
.pcol .pblock .pb-word{position:absolute;inset:20px;display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;color:#fff;font-family:'Playfair Display',serif;font-weight:800;line-height:.9;letter-spacing:.01em;font-size:clamp(38px,4.6vw,64px);z-index:2;text-shadow:0 2px 18px rgba(0,0,0,.16)}
.pcol .pblock .pb-word span{display:block}
.pcol .no{font-family:var(--serif-en);font-size:15px;color:var(--muted);letter-spacing:.2em}
.pcol h3{font-family:var(--serif-en);font-size:30px;letter-spacing:.06em;margin:18px 0 6px;font-weight:500}
.pcol .zh{font-family:var(--serif-tc);font-size:15px;letter-spacing:.3em;color:var(--muted);margin-bottom:20px}
.pcol p{font-size:14.5px;color:#4a4a4a;line-height:1.75}
.pcol p.en{margin-top:14px;font-family:var(--serif-en);font-style:italic;font-size:15px;color:var(--muted)}

/* ---------- WORKS ---------- */
.works{padding:170px 0 150px}
.works.inner{padding-top:80px}
#about,#works,#residential,#commercial,#services,#contact{scroll-margin-top:96px}
.cat{margin-bottom:130px}
.cat:last-of-type{margin-bottom:0}
.cat-head{margin-bottom:56px;max-width:780px}
.cat-head h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(30px,4vw,52px);line-height:1.15;margin:14px 0 14px}
.cat-head p{color:var(--muted);font-size:15px;max-width:520px;line-height:1.7}
.works .top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:72px;flex-wrap:wrap;gap:20px}
.works h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(30px,4vw,54px);line-height:1.15}
.works h2 .en{font-family:var(--serif-en);font-style:italic;color:var(--muted);font-size:.6em;display:block;margin-top:6px}
.wgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px 40px}
.card{position:relative;overflow:hidden;border-radius:0;cursor:pointer;background:var(--paper-2)}
.card .ph{position:absolute;inset:0;overflow:hidden}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s cubic-bezier(.16,1,.3,1)}
.card:hover .ph img{transform:scale(1.05)}
.card .ph::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 45%,rgba(20,18,16,.55));opacity:.9;transition:opacity .5s}
.card .meta{position:absolute;left:34px;right:34px;bottom:30px;color:#fff;z-index:2}
.card .tag{font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:rgba(255,255,255,.82)}
.card .meta h3{font-family:var(--serif-en);font-weight:500;font-size:27px;margin:8px 0 2px;letter-spacing:.02em}
.card .meta .sub{font-size:12.5px;letter-spacing:.02em;color:rgba(255,255,255,.8);opacity:0;max-height:0;transition:.5s;overflow:hidden}
.card:hover .meta .sub{opacity:1;max-height:130px;margin-top:8px}
.c-full{grid-column:span 12;aspect-ratio:23/9}
.c-half{grid-column:span 6;aspect-ratio:4/5}
.c-wide{grid-column:span 6;aspect-ratio:16/11}
.works .more{text-align:center;margin-top:80px}
.btn-line{display:inline-block;font-size:12px;letter-spacing:.22em;text-transform:uppercase;padding-bottom:7px;border-bottom:1px solid var(--ink);transition:.4s}
.btn-line:hover{color:var(--muted);border-color:var(--muted)}

/* ---------- GALLERY (masonry) ---------- */
.gallery{padding:30px 0 150px}
.gallery .g-head{text-align:center;max-width:660px;margin:0 auto 64px}
.gallery .g-head h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(28px,3.4vw,46px);margin-top:12px}
.gallery .g-head p{color:var(--muted);margin-top:14px;font-size:15px}
.gstrip{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;max-width:1180px;margin:0 auto;padding:0 28px}
.gstrip a{display:block;margin:0;overflow:hidden;position:relative;aspect-ratio:4/5;background:var(--paper-2)}
.gstrip img{width:100%;height:100%!important;object-fit:cover!important;display:block;transition:transform 1.6s cubic-bezier(.16,1,.3,1)}
@media(max-width:900px){.gstrip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.gstrip{grid-template-columns:1fr}.gstrip a{aspect-ratio:4/3}}
.gstrip a::after{content:"";position:absolute;inset:0;background:rgba(20,18,16,0);transition:background .5s}
.gstrip a:hover img{transform:scale(1.04)}
.gstrip a:hover::after{background:rgba(20,18,16,.12)}

/* ---------- featured projects (home) ---------- */
.feat{padding:150px 0 40px}
.feat .f-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:60px;flex-wrap:wrap;gap:18px}
.feat .f-head h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(28px,3.6vw,48px);line-height:1.15;margin-top:12px}

/* ---------- social proof band ---------- */
.proof{border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:46px 0;text-align:center}
.proof .row{display:flex;justify-content:center;align-items:center;gap:54px;flex-wrap:wrap}
.proof .item{display:flex;flex-direction:column;gap:4px}
.proof .num{font-family:var(--serif-en);font-size:34px;font-weight:500;letter-spacing:.02em}
.proof .lab{font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--muted)}
.proof .ig{font-size:12.5px;letter-spacing:.14em;color:var(--muted)}
.proof .ig a{border-bottom:1px solid var(--line);padding-bottom:2px}
.proof .ig a:hover{color:var(--ink);border-color:var(--ink)}

/* ---------- COLOUR statement ---------- */
.colour{background:var(--paper-2);color:var(--ink);padding:165px 0;text-align:center;position:relative;overflow:hidden}
.colour .swatches{position:absolute;inset:0;display:flex;opacity:.0}
.colour blockquote{font-family:var(--serif-tc);font-weight:400;font-size:clamp(20px,2.7vw,32px);line-height:1.62;max-width:820px;margin:0 auto;position:relative}
.colour blockquote .en{display:block;font-family:var(--serif-en);font-style:italic;font-size:.5em;margin-top:24px;color:var(--muted)}
.colour .dots{display:flex;gap:12px;justify-content:center;margin-top:44px}
.colour .dots i{width:34px;height:34px;border-radius:50%;display:block;opacity:.78;box-shadow:0 0 0 1px rgba(18,18,18,.08)}

/* ---------- SERVICES / SHOP teaser ---------- */
.svc{padding:165px 0}
.svc.inner{padding-top:80px}
.svc .grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid var(--line)}
.svc .cell{padding:62px 44px;border-right:1px solid var(--line)}
.svc .cell:last-child{border-right:0;background:var(--paper-2)}
.svc .cell .ey{margin-bottom:18px}
.svc h3{font-family:var(--serif-tc);font-weight:400;font-size:28px;margin-bottom:16px}
.svc p{color:#4a423a;font-size:15px;margin-bottom:26px;max-width:420px}

/* ---------- CTA ---------- */
.cta{background:var(--paper-2);color:var(--ink);padding:170px 0;text-align:center}
.cta h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(30px,4.2vw,52px);line-height:1.35;margin-bottom:16px}
.cta h2 em{font-family:var(--serif-en);font-style:italic;color:var(--muted)}
.cta p{color:#5a5a56;max-width:480px;margin:0 auto 44px}
.cta .pill{display:inline-block;background:transparent;color:var(--ink);border:1px solid var(--ink);padding:16px 46px;border-radius:0;font-size:12px;letter-spacing:.2em;text-transform:uppercase;transition:.45s cubic-bezier(.16,1,.3,1)}
.cta .pill:hover{background:var(--ink);color:var(--paper)}

/* ---------- FOOTER ---------- */
footer{background:var(--ink);color:rgba(255,255,255,.7);padding:80px 0 40px;font-size:13.5px}
.fgrid{display:grid;grid-template-columns:1.4fr 1fr 1fr;gap:50px;padding-bottom:50px;border-bottom:1px solid rgba(255,255,255,.14)}
.fgrid .brand{color:var(--paper);font-size:30px}
.fgrid h4{color:var(--ochre);font-size:11px;letter-spacing:.24em;text-transform:uppercase;margin-bottom:18px}
.fgrid a{display:block;margin-bottom:10px;transition:.2s}
.fgrid a:hover{color:var(--paper)}
.fbot{display:flex;justify-content:space-between;padding-top:26px;font-size:12px;color:rgba(255,255,255,.45);flex-wrap:wrap;gap:10px}

/* ---------- RESPONSIVE ---------- */
@media(max-width:880px){
  .wrap{padding:0 22px}
  nav ul{position:fixed;inset:0;width:100%;max-width:none;background:var(--paper);flex-direction:column;justify-content:center;align-items:center;gap:26px;transform:translateX(100%);transition:transform .4s;z-index:55;padding:80px 40px 40px}
  header.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none}
  nav ul.open{transform:none}
  .burger{display:flex;z-index:60}
  .philo .grid{grid-template-columns:1fr;gap:40px}
  .pcols{grid-template-columns:1fr}
  .pcol{border-right:0;border-bottom:1px solid var(--line)}
  .hero-dots{right:18px;bottom:24px}
  .hero-dots button{width:22px}
  .hero-dots button.on{width:34px}
  .hero-brand{top:13vh}
  .scrollcue{display:none}
  .has-sub .sub{position:static;transform:none;opacity:1;visibility:visible;border:0!important;background:none!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;box-shadow:none!important;padding:12px 0 0;align-items:center;gap:16px;min-width:0}
  .has-sub .sub a{font-size:13px;color:var(--muted)}
  .sub2{display:none!important}
  .has-sub2 .arr{display:none}
  .has-sub2 > a{justify-content:center}
  .pcol .pblock{aspect-ratio:16/10}
  .pcol .pblock .pb-word{font-size:clamp(44px,16vw,80px)}
  .wgrid{display:flex;flex-direction:column;gap:18px}
  .c-full,.c-half,.c-wide{aspect-ratio:4/3}
  .svc .grid{grid-template-columns:1fr}
  .svc .cell{border-right:0;border-bottom:1px solid var(--line)}
  .gstrip{column-count:2;column-gap:12px;padding:0 18px}
  .gstrip a{margin-bottom:12px}
  .proof .row{gap:32px}
  .proof .num{font-size:28px}
  .fgrid{grid-template-columns:1fr;gap:34px}
  .feat .f-head{display:block}
  .page-head{padding-top:128px}
}

/* ---------- SHOP / 選物 ---------- */
.shop{padding:170px 0 150px}
.shop.inner{padding-top:80px}
#xuanwu{scroll-margin-top:96px}
.shop .top{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:72px;flex-wrap:wrap;gap:20px}
.shop .top h2{font-family:var(--serif-tc);font-weight:400;font-size:clamp(30px,4vw,54px);line-height:1.15}
.shop .top h2 .en{font-family:var(--serif-en);font-style:italic;color:var(--muted);font-size:.6em;display:block;margin-top:6px}
.shop .top p{color:var(--muted);font-size:15px;max-width:360px;text-align:right;line-height:1.7}
.sgrid{display:grid;grid-template-columns:repeat(12,1fr);gap:18px 40px}
.scard{display:flex;flex-direction:column;cursor:default}
.scard .ph{position:relative;overflow:hidden;background:var(--paper-2)}
.scard .ph img{width:100%;height:100%;object-fit:cover;transition:transform 1.6s cubic-bezier(.16,1,.3,1)}
.scard:hover .ph img{transform:scale(1.04)}
.scard .ph .badge{position:absolute;top:14px;left:14px;font-size:10px;letter-spacing:.22em;text-transform:uppercase;background:rgba(247,246,244,.92);color:var(--ink);padding:4px 10px;font-family:var(--sans)}
.scard .info{padding:20px 0 0}
.scard .stag{font-size:10.5px;letter-spacing:.28em;text-transform:uppercase;color:var(--muted);margin-bottom:8px;font-family:var(--sans)}
.scard .sname{font-family:var(--serif-tc);font-weight:400;font-size:19px;letter-spacing:.03em;margin-bottom:6px}
.scard .sprice{font-size:13.5px;color:var(--muted)}
.scard .srule{width:28px;height:1px;background:var(--line);margin:12px 0}
/* layout spans */
.s-full{grid-column:span 12;aspect-ratio:21/8}
.s-half{grid-column:span 6;aspect-ratio:4/5}
.s-third{grid-column:span 4;aspect-ratio:3/4}
.s-wide{grid-column:span 8;aspect-ratio:16/9}
@media(max-width:880px){
  .sgrid{display:flex;flex-direction:column;gap:30px}
  .s-full,.s-half,.s-third,.s-wide{aspect-ratio:4/3}
  .shop .top p{text-align:left}
}

.en2{display:block;font-family:var(--serif-en);font-style:italic;color:var(--muted);margin-top:9px;font-size:.92em;line-height:1.55;letter-spacing:.01em}
.meta .sub .en2{color:rgba(255,255,255,.7);margin-top:5px;font-size:12px}
.colour blockquote .lead2{display:block;font-size:.6em;margin-top:22px;color:var(--ink);font-family:var(--serif-tc);font-weight:400;letter-spacing:.02em}
