/* 禾舍景觀 HESHE — 共用樣式（依 Figma 規格） */
:root{
  --green:#061B12; --footer:#0F201D; --footer-home:#034C2D;
  --cream:#FAF7F2; --tan:#F7E9D3; --tan2:#FEE9D5; --tan3:#FFF6E6;
  --clay:#C4876A; --clay-l:#E7C3A8; --brown:#311002;
  --ink:#030302; --cream-line:#D9D9D9;
  --serif:'Noto Serif HK',serif; --en:'Cormorant Garamond',serif; --sans:'Noto Sans TC',sans-serif;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{width:100%;max-width:100%;overflow-x:hidden}
html{scroll-behavior:smooth}
body{font-family:var(--serif);font-weight:200;line-height:1.8;background:var(--cream);color:var(--ink)}
body.theme-dark{background:var(--green);color:var(--cream)}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
.wrap{max-width:1510px;margin:0 auto;padding:0 clamp(24px,5.2vw,100px)}
.en{font-family:var(--en)}

/* placeholders */
.ph{position:relative;background:#D9D9D9;overflow:hidden}
.ph.garden{background:linear-gradient(135deg,#3c4a32,#27331f 55%,#15200f)}
.ph.olive{background:#454B3E}
.ph.dark{background:linear-gradient(135deg,#5b5f4e,#33362b)}
.ph::after{content:attr(data-label);position:absolute;left:12px;bottom:10px;font-family:var(--sans);font-size:10px;letter-spacing:.12em;color:rgba(80,80,80,.6)}
.ph.garden::after,.ph.olive::after,.ph.dark::after{color:rgba(255,255,255,.5)}

/* ===== header ===== */
header{position:fixed;top:0;left:0;width:100%;z-index:50;display:flex;align-items:center;justify-content:space-between;
  padding:16px clamp(20px,3vw,40px);transition:padding .4s,background .4s}
header.shrink{padding:8px clamp(20px,3vw,40px);backdrop-filter:blur(8px)}
body.theme-dark header.shrink{background:rgba(6,27,18,.92)}
body.theme-light header.shrink{background:rgba(250,247,242,.92)}
.brand{display:flex;align-items:center;gap:18px}
.logo{width:80px;height:80px;border-radius:50%;background:radial-gradient(circle at 50% 36%,#2f3a2c,#0f1810);
  border:1px solid #b89b5e;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#d9c79a;flex:none;
  transition:.4s;box-shadow:0 4px 8px rgba(0,0,0,.3)}
header.shrink .logo{width:58px;height:58px}
.logo b{font-family:var(--en);font-size:28px;font-weight:500;line-height:1}
.logo small{font-size:5.5px;letter-spacing:.14em;margin-top:3px;opacity:.85;font-family:var(--sans)}
.brand .name{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2vw,36px);letter-spacing:.15em}
body.theme-dark .brand .name{color:var(--cream)}
body.theme-light .brand .name{color:var(--ink)}
nav.main{display:flex;align-items:center;gap:clamp(24px,3vw,52px);
  background:linear-gradient(90deg,rgba(247,233,211,0),rgba(247,233,211,.85) 24%);
  padding:14px clamp(28px,3vw,56px) 14px 96px;margin-right:calc(-1*clamp(20px,3vw,40px));border-radius:2px}
nav.main a{font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.2vw,24px);letter-spacing:.15em;color:#000;position:relative;padding:4px 0;white-space:nowrap}
nav.main a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1.5px;background:#000;transition:width .35s}
nav.main a:hover::after,nav.main a.active::after{width:100%}
.menu-btn{display:none;flex-direction:column;gap:5px;cursor:pointer;background:none;border:0;z-index:61}
.menu-btn span{width:28px;height:2px;background:currentColor}
body.theme-dark .menu-btn{color:var(--cream)} body.theme-light .menu-btn{color:var(--ink)}

/* floating contact (聯絡我們 + 電話 + LINE) */
.fab{position:fixed;right:16px;top:46%;transform:translateY(-50%);z-index:40;display:flex;flex-direction:column;align-items:center;gap:12px}
.fab .lbl{writing-mode:vertical-rl;font-family:var(--serif);font-weight:600;font-size:13px;letter-spacing:.2em;margin-bottom:6px}
body.theme-dark .fab .lbl{color:var(--cream)} body.theme-light .fab .lbl{color:var(--ink)}
.fab a{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff;box-shadow:0 4px 12px rgba(0,0,0,.3);transition:transform .3s}
.fab a:hover{transform:scale(1.1)}
.fab .tel{background:#1a1a1a}.fab .line{background:#06C755}

/* ===== hero (dark home) ===== */
.hero{height:100vh;min-height:640px;position:relative;display:flex;align-items:center;overflow:hidden}
.hero .bg{position:absolute;inset:-6% 0}.hero .bg .ph{width:100%;height:112%}
.hero .veil{position:absolute;inset:0;background:linear-gradient(270deg,rgba(13,15,14,0) 0%,rgba(13,15,14,.72) 78%)}
.hero .inner{position:relative;z-index:2;width:100%}
.hero h1{font-family:var(--en);font-weight:400;font-size:clamp(46px,6.6vw,100px);line-height:1.16;letter-spacing:.03em;color:#fff}
.hero .sub{font-family:var(--serif);font-weight:600;font-size:clamp(18px,2.4vw,46px);letter-spacing:.15em;color:#fff;margin-top:26px}
.scrolld{position:absolute;left:clamp(24px,5vw,100px);bottom:40px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:14px}
.scrolld span{writing-mode:vertical-rl;font-family:var(--serif);font-weight:200;font-size:14px;letter-spacing:.2em;color:#fff}
.scrolld .line{width:2px;height:120px;background:var(--cream);position:relative;overflow:hidden}
.scrolld .line::after{content:"";position:absolute;top:-40%;left:0;width:100%;height:40%;background:var(--green);animation:drop 2.4s cubic-bezier(.6,0,.2,1) infinite}
@keyframes drop{0%{top:-40%}60%,100%{top:100%}}

/* ===== hero (light inner pages, leaf shadow) ===== */
.hero-l{min-height:clamp(520px,52vw,919px);position:relative;display:flex;align-items:center;background:var(--cream);overflow:hidden}
.hero-l .leaf{position:absolute;inset:0;z-index:0;
  background:
   radial-gradient(closest-side at 78% 8%,rgba(10,20,12,.16),transparent 70%),
   radial-gradient(closest-side at 92% 36%,rgba(10,20,12,.13),transparent 72%),
   radial-gradient(closest-side at 64% 0%,rgba(10,20,12,.10),transparent 70%);
  filter:blur(2px)}
.hero-l .leaf::after{content:"葉影 hero 圖待替換";position:absolute;right:18px;top:14px;font-family:var(--sans);font-size:11px;letter-spacing:.1em;color:rgba(80,80,80,.4)}
.hero-l .inner{position:relative;z-index:2}
.hero-l h1{font-family:var(--en);font-weight:400;font-size:clamp(48px,7vw,100px);line-height:1.1;letter-spacing:.03em;color:var(--ink)}
.hero-l .sub{font-family:var(--serif);font-weight:600;font-size:clamp(20px,2.6vw,46px);letter-spacing:.15em;color:var(--ink);margin-top:24px}

/* section common */
.sec{padding:clamp(64px,8vw,120px) 0}
.h2{font-family:var(--serif);font-weight:600;font-size:clamp(28px,3.4vw,46px);letter-spacing:.04em;display:flex;align-items:baseline;gap:16px;flex-wrap:wrap}
.h2 .zh{font-size:.66em}
.btn{display:inline-flex;align-items:center;gap:18px;background:var(--clay);color:#fff;font-family:var(--serif);font-weight:600;
  font-size:clamp(16px,1.2vw,24px);letter-spacing:.15em;padding:12px 24px;transition:.35s}
.btn:hover{filter:brightness(1.07);gap:26px}.btn .ar{font-size:.78em}
.reveal{opacity:0;transform:translateY(40px);transition:opacity 1s cubic-bezier(.2,.7,.2,1),transform 1s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}
.reveal.d1{transition-delay:.12s}.reveal.d2{transition-delay:.24s}.reveal.d3{transition-delay:.36s}

/* intro (text first) */
.hero h1 .w,.hero-l h1 .w{display:inline-block;overflow:hidden;vertical-align:bottom}
.hero h1 .w i,.hero-l h1 .w i{display:inline-block;font-style:normal;transform:translateY(115%);transition:transform 1.05s cubic-bezier(.19,1,.22,1)}
body.loaded .hero h1 .w i,body.loaded .hero-l h1 .w i{transform:none}
.hero h1 .w:nth-child(1) i,.hero-l h1 .w:nth-child(1) i{transition-delay:.12s}
.hero h1 .w:nth-child(2) i,.hero-l h1 .w:nth-child(2) i{transition-delay:.24s}
.hero h1 .w:nth-child(3) i,.hero-l h1 .w:nth-child(3) i{transition-delay:.36s}
.l2{display:block}
.hero h1 .l2 .w:nth-child(1) i{transition-delay:.5s}.hero h1 .l2 .w:nth-child(2) i{transition-delay:.62s}
.hero .sub,.hero-l .sub{opacity:0;transform:translateY(16px);transition:1s ease .85s}
body.loaded .hero .sub,body.loaded .hero-l .sub{opacity:1;transform:none}
.scrolld,.hdr-in{opacity:0}
.scrolld{transition:opacity 1s ease 1.4s}body.loaded .scrolld{opacity:1}
.hdr-in{transform:translateY(-12px);transition:opacity 1s ease 1.05s,transform 1s ease 1.05s}
body.loaded .hdr-in{opacity:1;transform:none}

/* ===== HOME: about(dark) ===== */
.h-about{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,90px);align-items:center}
.h-about .sub2{font-family:var(--serif);font-weight:600;font-size:clamp(22px,2vw,30px);letter-spacing:.15em;margin:32px 0 24px}
.h-about p{font-weight:200;font-size:clamp(15px,1.2vw,22px);line-height:2.2;letter-spacing:.1em;max-width:46ch}
.h-about .media{height:clamp(360px,42vw,640px)}.h-about .media .ph{width:100%;height:100%}

/* HOME: expertise */
.exp-grid{display:grid;grid-template-columns:repeat(4,1fr);margin-top:clamp(40px,5vw,72px);border-left:2px solid rgba(250,247,242,.25)}
.exp{position:relative;padding:28px clamp(16px,2vw,30px) 32px;border-right:2px solid rgba(250,247,242,.25);min-height:clamp(300px,30vw,453px);display:flex;flex-direction:column}
.exp.has-img{overflow:hidden}
.exp .imgbg{position:absolute;inset:0;z-index:0}.exp .imgbg .ph{width:100%;height:100%}
.exp .imgbg::before{content:"";position:absolute;inset:0;background:rgba(31,25,7,.58);z-index:1}
.exp .num{position:relative;z-index:2;font-family:var(--serif);font-weight:600;font-size:clamp(40px,4vw,64px);letter-spacing:.1em;color:var(--cream)}
.exp .num small{font-weight:200;opacity:.6}
.exp .zh{position:relative;z-index:2;font-family:var(--serif);font-weight:600;font-size:clamp(20px,1.8vw,30px);letter-spacing:.15em;margin-top:clamp(44px,7vw,110px);color:var(--cream)}
.exp .en2{position:relative;z-index:2;font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.3vw,22px);letter-spacing:.15em;margin-top:16px;color:var(--cream);opacity:.92}
.exp .arr{position:absolute;right:24px;bottom:24px;z-index:2;width:44px;height:44px}
.exp .arr::before{content:"";position:absolute;inset:0;border-right:2.5px solid var(--cream);border-bottom:2.5px solid var(--cream);transform:rotate(45deg) scale(.5);transform-origin:center;transition:.3s}
.exp:hover .arr::before{transform:rotate(45deg) scale(.62)}

/* portfolio grid (shared home + portfolio page) */
.port-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.2vw,40px);margin-top:clamp(36px,4vw,60px)}
.pcard{cursor:pointer}
.pcard .frame{overflow:hidden;height:clamp(200px,21vw,330px)}
.pcard .frame .ph,.pcard .frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.pcard:hover .frame .ph,.pcard:hover .frame img{transform:scale(1.07)}
.pcard .cap{font-family:var(--serif);font-weight:600;font-size:clamp(17px,1.5vw,30px);letter-spacing:.15em;margin-top:18px}
body.theme-dark .pcard .cap{color:var(--cream)} body.theme-light .pcard .cap{color:var(--ink)}

/* ===== ABOUT page ===== */
.our-story{background:var(--tan);display:grid;grid-template-columns:1fr 1fr;align-items:stretch}
.our-story .txt{padding:clamp(60px,8vw,150px) clamp(24px,6vw,110px)}
.our-story .lbl{font-family:var(--serif);font-weight:600;font-size:clamp(22px,2vw,30px);letter-spacing:.15em;margin:30px 0 24px;color:var(--ink)}
.our-story p{font-weight:200;font-size:clamp(15px,1.15vw,22px);line-height:2.1;letter-spacing:.12em;color:var(--ink);margin-bottom:22px;max-width:48ch}
.our-story .media{position:relative;min-height:420px}.our-story .media .ph{position:absolute;inset:0;width:100%;height:100%}
.core{background:var(--cream)}
.core-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(30px,4vw,70px);margin-top:clamp(40px,5vw,72px)}
.core-col .ico{width:44px;height:44px;border-radius:50%;background:#9bb089;opacity:.8;margin-bottom:26px}
.core-col .num{font-family:var(--serif);font-weight:600;font-size:clamp(34px,3.4vw,52px);letter-spacing:.1em;color:var(--ink)}
.core-col .num small{font-weight:200;opacity:.5}
.core-col h3{font-family:var(--serif);font-weight:600;font-size:clamp(18px,1.5vw,26px);letter-spacing:.12em;margin:18px 0 14px;color:var(--ink)}
.core-col .t{font-family:var(--serif);font-weight:600;font-size:clamp(16px,1.3vw,22px);letter-spacing:.06em;color:var(--ink);margin-bottom:12px}
.core-col p{font-weight:200;font-size:clamp(14px,1.05vw,18px);line-height:1.9;letter-spacing:.08em;color:var(--ink);margin-bottom:24px}
.core-col .media{height:clamp(150px,14vw,200px)}.core-col .media .ph{width:100%;height:100%}

/* CTA banner */
.cta-band{position:relative;min-height:clamp(280px,30vw,420px);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;overflow:hidden}
.cta-band .ph{position:absolute;inset:0;width:100%;height:100%}
.cta-band::after{content:"";position:absolute;inset:0;background:rgba(8,16,10,.55)}
.cta-band .c{position:relative;z-index:2;color:#fff}
.cta-band .c .ln{font-family:var(--serif);font-weight:600;font-size:clamp(18px,2vw,30px);letter-spacing:.15em}
.cta-band .btn{margin-top:26px}

/* ===== SERVICES page ===== */
.svc-hero .leaf{background:linear-gradient(180deg,rgba(196,135,106,.0),rgba(196,135,106,.0)),
  repeating-linear-gradient(125deg,#e7c3a8 0 60px,#dcb89c 60px 64px);opacity:.55;filter:none}
.svc-hero .leaf::after{content:"磚紋 hero 圖待替換"}
.svc-list{background:var(--tan2)}
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(24px,5vw,90px);align-items:center;padding:clamp(30px,4vw,54px) 0;position:relative}
.svc-row .left .num{font-family:var(--serif);font-weight:600;font-size:clamp(26px,2.4vw,38px);letter-spacing:.06em;color:var(--ink)}
.svc-row .left .en2{font-family:var(--en);font-weight:500;font-size:clamp(17px,1.5vw,24px);letter-spacing:.18em;color:var(--ink);margin-top:8px}
.svc-row .right p{font-weight:200;font-size:clamp(14px,1.1vw,20px);line-height:1.95;letter-spacing:.08em;color:var(--ink)}
.svc-row .right .btn{margin-top:22px;background:var(--clay)}
.svc-row.feat{overflow:hidden;border-radius:2px}
.svc-row.feat .ph{position:absolute;inset:0;width:100%;height:100%;z-index:0}
.svc-row.feat::after{content:"";position:absolute;inset:0;background:rgba(20,28,16,.62);z-index:1}
.svc-row.feat .left,.svc-row.feat .right{position:relative;z-index:2;padding:clamp(20px,3vw,40px) clamp(24px,4vw,50px)}
.svc-row.feat .num,.svc-row.feat .en2,.svc-row.feat .right p{color:#fff}
.svc-divline{border-top:1px solid rgba(3,3,2,.18)}
.how{background:var(--tan2)}
.steps{margin-top:clamp(36px,4vw,56px)}
.step{display:grid;grid-template-columns:130px 1fr 2fr;gap:clamp(20px,3vw,50px);align-items:center;padding:clamp(22px,2.4vw,30px) 0;border-bottom:1px solid rgba(3,3,2,.25)}
.step:first-child{border-top:1px solid rgba(3,3,2,.25)}
.step .no{font-family:var(--en);font-size:clamp(22px,2vw,30px);color:var(--ink);white-space:nowrap}
.step .no b{font-weight:500}
.step .ttl{display:flex;align-items:center;gap:14px}
.step .ttl::before{content:"●";font-size:10px;color:var(--ink)}
.step .ttl .zh{font-family:var(--serif);font-weight:600;font-size:clamp(18px,1.6vw,26px);letter-spacing:.1em;color:var(--ink)}
.step .ttl .en3{font-family:var(--en);font-size:clamp(14px,1.2vw,20px);letter-spacing:.15em;color:var(--ink);margin-left:6px}
.step .d{font-weight:200;font-size:clamp(13px,1vw,17px);line-height:1.9;letter-spacing:.06em;color:var(--ink)}

/* PORTFOLIO page gallery */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2vw,36px);margin-top:clamp(30px,3vw,50px)}
.gcard .frame{overflow:hidden;height:clamp(200px,18vw,280px)}
.gcard .frame .ph,.gcard .frame img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.gcard:hover .frame .ph,.gcard:hover .frame img{transform:scale(1.07)}
.gcard .cap{font-family:var(--serif);font-weight:600;font-size:clamp(16px,1.4vw,24px);letter-spacing:.12em;margin-top:14px;color:var(--ink)}
.pager{display:flex;justify-content:center;align-items:center;gap:18px;margin-top:clamp(40px,5vw,70px);font-family:var(--en);letter-spacing:.1em;font-size:18px;color:var(--ink)}
.pager a{color:var(--ink);opacity:.7}.pager a.active{color:var(--clay);opacity:1;font-weight:500}
.pager .nav{font-family:var(--serif);font-weight:600;font-size:15px;letter-spacing:.1em}
.center-h2{justify-content:center;text-align:center}

/* ===== footer ===== */
footer{background:var(--footer);padding:clamp(46px,5vw,70px) clamp(24px,8vw,151px)}
body.theme-dark footer{background:var(--footer-home)}
.foot-grid{display:grid;grid-template-columns:auto 1fr auto;gap:clamp(30px,5vw,80px);align-items:start}
.foot-co{font-family:var(--serif);font-weight:700;font-size:clamp(26px,2.6vw,40px);letter-spacing:.14em;color:#fff}
.foot-co .lbl{display:block;font-weight:500;font-size:.55em;margin-top:20px}
.foot-info{font-family:var(--sans);font-weight:400;font-size:14px;line-height:2.1;letter-spacing:.12em;color:#fff;margin-top:16px}
.foot-mid{padding-top:14px;border-top:1px solid rgba(255,255,255,.55)}
.foot-serv{font-family:var(--serif);font-weight:400;font-size:clamp(15px,1.4vw,24px);letter-spacing:.04em;color:#fff;line-height:1.8}
.foot-soc{display:flex;gap:14px;margin-top:24px}
.foot-soc a{width:50px;height:50px;border-radius:13px;display:flex;align-items:center;justify-content:center;font-size:22px;color:#fff}
.foot-soc .ig{background:linear-gradient(45deg,#f09433,#e6683c,#dc2743,#cc2366,#bc1888)}
.foot-soc .fb{background:#1877F2}.foot-soc .yt{background:#FF0000}

/* overlay menu */
.overlay{position:fixed;inset:0;background:var(--green);z-index:60;display:flex;flex-direction:column;justify-content:center;align-items:center;gap:30px;opacity:0;pointer-events:none;transition:opacity .5s}
.overlay.open{opacity:1;pointer-events:auto}
.overlay a{font-family:var(--serif);font-weight:600;font-size:30px;letter-spacing:.15em;color:var(--cream);opacity:0;transform:translateY(18px);transition:.5s}
.overlay.open a{opacity:1;transform:none}
.overlay.open a:nth-child(2){transition-delay:.1s}.overlay.open a:nth-child(3){transition-delay:.16s}.overlay.open a:nth-child(4){transition-delay:.22s}.overlay.open a:nth-child(5){transition-delay:.28s}
.overlay .close{position:absolute;top:24px;right:7vw;font-size:34px;color:var(--cream);background:none;border:0;cursor:pointer}

/* ===== responsive ===== */
@media(max-width:980px){
  nav.main{display:none}.menu-btn{display:flex}.brand .name{display:none}
  .h-about,.our-story,.svc-row{grid-template-columns:1fr}
  .our-story .media{min-height:300px}
  .exp-grid{grid-template-columns:repeat(2,1fr)}.exp{min-height:230px}
  .core-grid{grid-template-columns:1fr;gap:40px}
  .port-grid,.gallery{grid-template-columns:1fr 1fr}
  .step{grid-template-columns:90px 1fr}.step .d{grid-column:1/-1}
  .foot-grid{grid-template-columns:1fr}
  .svc-row.feat .ph{position:relative;height:220px}
  .pcard:hover .frame .ph,.pcard:hover .frame img,.gcard:hover .frame .ph,.gcard:hover .frame img{transform:none}
}
@media(max-width:560px){.exp-grid,.port-grid,.gallery{grid-template-columns:1fr}}

/* ---- WordPress 整合 ---- */
.page-body{font-weight:200;line-height:2.1;letter-spacing:.08em}
.page-body img{max-width:100%;height:auto}
.page-body a{color:var(--clay)}
.pagination .nav-links{display:flex;gap:14px;justify-content:center;font-family:var(--en);letter-spacing:.1em;margin-top:40px}
.pagination a,.pagination .current{color:var(--ink)} .pagination .current{color:var(--clay)}

/* How We Work — Step hover 浮動效果 */
.step{transition:background .4s ease,transform .45s cubic-bezier(.2,.7,.2,1),padding-left .4s ease,box-shadow .45s ease;border-radius:3px}
.step:hover{background:rgba(196,135,106,.12);transform:translateY(-4px);padding-left:22px;box-shadow:0 16px 34px rgba(49,16,2,.12)}
.step:hover .no,.step:hover .ttl .zh,.step:hover .ttl .en3{color:var(--clay)}
.step:hover .ttl::before{color:var(--clay)}
@media(max-width:980px){.step:hover{transform:none;padding-left:0;box-shadow:none}}

/* 按鈕：陶土底＋白色實心三角（依 Figma Frame 13） */
.btn{border-radius:0;font-weight:600;letter-spacing:.15em}
.btn .ar{width:0;height:0;border-top:7px solid transparent;border-bottom:7px solid transparent;border-left:11px solid currentColor;font-size:0;line-height:0;transition:transform .35s}
.btn:hover .ar{transform:translateX(4px)}
.btn.wide{width:265px;max-width:100%;height:50px;justify-content:space-between;gap:0;padding:0 22px 0 19.5px;font-size:clamp(18px,1.4vw,24px)}

/* 全站 clay 按鈕統一為 Figma Frame 13：265×50、文字靠左、白三角靠右 */
.btn{width:265px;max-width:100%;height:50px;justify-content:space-between;gap:0;padding:0 22px 0 19.5px;font-size:clamp(18px,1.4vw,24px)}
.btn:hover{gap:0}
.cta-band .btn{margin-left:auto;margin-right:auto}

/* EXPERTISE 卡片可點擊 + 斜向 ↘ 箭頭（依 Figma Arrow down-right） */
.exp{cursor:pointer;text-decoration:none}
.exp .arr{position:absolute;right:22px;bottom:22px;z-index:2;width:46px;height:46px;stroke:var(--cream);stroke-width:2;fill:none;transition:transform .35s}
.exp .arr::before{content:none!important}
.exp:hover .arr{transform:translate(5px,5px)}
.exp:hover .imgbg .ph{transform:scale(1.05);transition:transform 1.2s cubic-bezier(.2,.8,.2,1)}

/* EXPERTISE：hover 淡入顯示分類圖片 */
.exp{overflow:hidden}
.exp .imgbg{position:absolute;inset:0;z-index:0;opacity:0;transition:opacity .55s ease}
.exp:hover .imgbg{opacity:1}
.exp .imgbg .ph,.exp .imgbg img{width:100%;height:100%;object-fit:cover}
.exp .imgbg::before{content:"";position:absolute;inset:0;background:rgba(6,27,18,.5);z-index:1}
.exp:hover .imgbg .ph{transform:scale(1.05);transition:transform 4s ease}

/* 服務頁 Hero 有圖時隱藏磚紋佔位字 */
.svc-hero .leaf.has-img::after{content:none}

/* 頁尾社群 icon SVG 尺寸 */
.foot-soc a svg{width:24px;height:24px;display:block}

/* ===== 作品集 篩選列 + 清單版型（圖左 + 資訊面板右） ===== */
.cat-filter{display:flex;flex-wrap:wrap;justify-content:center;align-items:stretch;margin:30px 0 54px}
.cat-filter a{display:flex;flex-direction:column;align-items:center;gap:4px;padding:10px 24px;position:relative}
.cat-filter a+a{border-left:1px solid rgba(3,3,2,.18)}
.cat-filter a .en4{font-family:var(--en);font-size:clamp(13px,1.1vw,16px);letter-spacing:.1em;color:var(--ink)}
.cat-filter a .zh2{font-size:12px;letter-spacing:.08em;color:var(--ink);opacity:.65}
.cat-filter a.active{background:#6b7358;border-radius:4px;border-left:none}
.cat-filter a.active .en4,.cat-filter a.active .zh2{color:#fff;opacity:1}
.port-list{display:flex;flex-direction:column;gap:clamp(28px,3.5vw,52px)}
.port-row{display:grid;grid-template-columns:1.05fr .95fr;align-items:stretch;background:var(--tan3);overflow:hidden}
.port-row .img{height:clamp(280px,30vw,420px);overflow:hidden}
.port-row .img .ph,.port-row .img img{width:100%;height:100%;object-fit:cover;transition:transform 1.1s cubic-bezier(.2,.8,.2,1)}
.port-row:hover .img .ph,.port-row:hover .img img{transform:scale(1.05)}
.port-row .info{padding:clamp(26px,3vw,48px);display:flex;flex-direction:column;justify-content:center}
.port-row .info .pn{font-family:var(--en);font-size:13px;letter-spacing:.1em;color:var(--ink);opacity:.55}
.port-row .info .title{font-family:var(--en);font-weight:500;font-size:clamp(24px,2.4vw,34px);letter-spacing:.04em;color:var(--ink);margin:8px 0 22px}
.port-row .info dl{display:grid;grid-template-columns:96px 1fr;row-gap:13px;font-size:clamp(13px,1vw,15px)}
.port-row .info dt{font-family:var(--en);letter-spacing:.06em;color:var(--clay)}
.port-row .info dd{color:var(--ink);line-height:1.7}
.port-row .info .view{margin-top:26px;align-self:flex-end;font-family:var(--en);letter-spacing:.12em;color:var(--ink);font-size:14px;transition:color .3s}
.port-row:hover .info .view{color:var(--clay)}
.pf-meta{display:grid;grid-template-columns:110px 1fr;row-gap:15px;margin:26px 0 6px;max-width:560px}
.pf-meta dt{font-family:var(--en);letter-spacing:.06em;color:var(--clay)}
.pf-meta dd{color:var(--ink)}
@media(max-width:860px){.port-row{grid-template-columns:1fr}.port-row:hover .img .ph,.port-row:hover .img img{transform:none}}

/* 浮動鈕 icon SVG 尺寸 */
.fab a svg{width:24px;height:24px;display:block}

/* ===== 作品集列表：masonry 不規則排列 ===== */
.pf-masonry{columns:3;column-gap:clamp(16px,2vw,30px);margin-top:40px}
.pf-masonry .mcard{display:block;break-inside:avoid;margin:0 0 clamp(18px,2vw,30px);cursor:pointer;text-decoration:none}
.pf-masonry .mframe{overflow:hidden}
.pf-masonry .mframe img{width:100%;height:auto;display:block;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.pf-masonry .mframe .ph{width:100%;display:block}
.pf-masonry .mcard:nth-child(3n+1) .ph{height:300px}
.pf-masonry .mcard:nth-child(3n+2) .ph{height:380px}
.pf-masonry .mcard:nth-child(3n) .ph{height:250px}
.pf-masonry .mcard:hover .mframe img{transform:scale(1.05)}
.pf-masonry .cap{font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.3vw,20px);letter-spacing:.1em;margin-top:12px;color:var(--ink)}
@media(max-width:900px){.pf-masonry{columns:2}}
@media(max-width:560px){.pf-masonry{columns:1}}

/* ===== 單篇作品 gallery 圖層（內文圖庫區塊） ===== */
.pf-gallery{margin-top:clamp(40px,5vw,72px)}
.pf-gallery .wp-block-gallery,.pf-gallery .blocks-gallery-grid{display:grid !important;grid-template-columns:repeat(3,1fr);gap:clamp(12px,1.6vw,22px);list-style:none;margin:0;padding:0}
.pf-gallery figure{margin:0;overflow:hidden}
.pf-gallery img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.pf-gallery figure:hover img{transform:scale(1.05)}
.pf-gallery p img,.pf-gallery>img{width:100%;height:auto;margin:14px 0}
@media(max-width:780px){.pf-gallery .wp-block-gallery,.pf-gallery .blocks-gallery-grid{grid-template-columns:1fr 1fr}}

/* ===== 作品集列表：固定比例列（A=1:1:1, B=2:1:2 交替） ===== */
.pf-rows{margin-top:40px}
.prow{display:flex;gap:clamp(16px,2vw,30px);margin-bottom:clamp(18px,2vw,30px)}
.prow .mcard{flex:1;display:flex;flex-direction:column;text-decoration:none;cursor:pointer;min-width:0}
.prow.b .mcard:nth-child(1){flex:2}
.prow.b .mcard:nth-child(2){flex:1}
.prow.b .mcard:nth-child(3){flex:2}
.prow .mframe{overflow:hidden;height:clamp(180px,21vw,310px)}
.prow .mframe img,.prow .mframe .ph{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.prow .mcard:hover .mframe img{transform:scale(1.05)}
.prow .cap{font-family:var(--serif);font-weight:600;font-size:clamp(15px,1.3vw,20px);letter-spacing:.1em;margin-top:12px;color:var(--ink)}
@media(max-width:780px){
  .prow{flex-wrap:wrap}
  .prow .mcard,.prow.b .mcard:nth-child(1),.prow.b .mcard:nth-child(2),.prow.b .mcard:nth-child(3){flex:1 1 calc(50% - 10px)}
}
@media(max-width:480px){.prow .mcard,.prow.b .mcard{flex:1 1 100%}}

/* 單篇 gallery 漸出 */
.pf-gallery .g-reveal{opacity:0;transform:translateY(24px);transition:opacity .9s cubic-bezier(.2,.7,.2,1),transform .9s cubic-bezier(.2,.7,.2,1)}
.pf-gallery .g-reveal.in{opacity:1;transform:none}

/* ===== gallery 視覺化：大圖 2 欄填滿（覆寫先前小圖樣式） ===== */
.pf-gallery{margin-top:clamp(40px,5vw,72px);max-width:1200px;margin-left:auto;margin-right:auto}
.pf-gallery .wp-block-gallery,.pf-gallery .blocks-gallery-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;gap:clamp(14px,1.8vw,28px)!important;margin:0!important;padding:0!important;list-style:none}
.pf-gallery .wp-block-gallery>figure,.pf-gallery .wp-block-image,.pf-gallery .blocks-gallery-item,.pf-gallery>figure{margin:0!important;width:auto!important;max-width:none!important;flex:none!important}
.pf-gallery .wp-block-image,.pf-gallery .blocks-gallery-item,.pf-gallery>figure{position:relative;aspect-ratio:4/3;overflow:hidden;border-radius:2px}
.pf-gallery img{width:100%!important;height:100%!important;object-fit:cover!important;display:block;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.pf-gallery .wp-block-image:hover img,.pf-gallery>figure:hover img{transform:scale(1.05)}
.pf-gallery figcaption{display:none}
.pf-gallery p{font-weight:200;line-height:2;letter-spacing:.06em;margin:16px 0;color:var(--ink)}
@media(max-width:680px){.pf-gallery .wp-block-gallery,.pf-gallery .blocks-gallery-grid{grid-template-columns:1fr!important}}

/* ===== gallery 最終修正：固定列高、強制填滿、消除重疊 ===== */
.pf-gallery .wp-block-gallery,.pf-gallery .blocks-gallery-grid{display:grid!important;grid-template-columns:repeat(2,1fr)!important;grid-auto-rows:clamp(240px,28vw,380px)!important;gap:clamp(14px,1.8vw,26px)!important;margin:0 0 22px!important;padding:0!important;align-items:stretch!important}
.pf-gallery .wp-block-gallery>figure,.pf-gallery .wp-block-gallery .wp-block-image,.pf-gallery .blocks-gallery-item{margin:0!important;width:auto!important;max-width:none!important;height:100%!important;min-height:0!important;flex:none!important;aspect-ratio:auto!important;overflow:hidden;border-radius:2px;position:relative}
.pf-gallery .wp-block-gallery img,.pf-gallery .blocks-gallery-item img{width:100%!important;height:100%!important;object-fit:cover!important;display:block;position:static!important;inset:auto!important}
.pf-gallery > .wp-block-image{display:block;max-width:1100px;margin:0 auto 22px!important;aspect-ratio:auto!important;height:auto!important}
.pf-gallery > .wp-block-image img{width:100%!important;height:auto!important;object-fit:initial!important}
@media(max-width:680px){.pf-gallery .wp-block-gallery,.pf-gallery .blocks-gallery-grid{grid-template-columns:1fr!important;grid-auto-rows:clamp(220px,62vw,320px)!important}}
/* ===== gallery 自訂格線（JS 重建，完全可控、可正常往下捲） ===== */
.pf-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(14px,1.8vw,26px)}
.pf-item{margin:0;overflow:hidden;border-radius:2px;cursor:zoom-in;aspect-ratio:4/3;background:#e6e1d6}
.pf-item img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.pf-item:hover img{transform:scale(1.05)}
@media(max-width:680px){.pf-grid{grid-template-columns:1fr}}
/* 燈箱 lightbox */
.lb{position:fixed;inset:0;z-index:200;background:rgba(6,16,10,.93);display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .4s}
.lb.open{opacity:1;pointer-events:auto}
.lb img{max-width:88vw;max-height:84vh;object-fit:contain;box-shadow:0 24px 70px rgba(0,0,0,.55);transform:scale(.96);transition:transform .4s}
.lb.open img{transform:scale(1)}
.lb-close{position:fixed;top:22px;right:30px;width:50px;height:50px;border:0;background:rgba(255,255,255,.14);color:#fff;font-size:26px;line-height:1;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s;z-index:2}
.lb-close:hover{background:rgba(255,255,255,.28);transform:rotate(90deg)}
.lb-prev,.lb-next{position:fixed;top:50%;transform:translateY(-50%);width:54px;height:54px;border:0;background:rgba(255,255,255,.1);color:#fff;font-size:30px;line-height:1;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s}
.lb-prev:hover,.lb-next:hover{background:rgba(255,255,255,.24)}
.lb-prev{left:24px}.lb-next{right:24px}
@media(max-width:600px){.lb-prev,.lb-next{display:none}}
/* ===== 作品集鑲嵌：每 8 張一循環（第一排 3 等分，下方 5 不規則） ===== */
.pf-mosaic{display:grid;grid-template-columns:repeat(6,1fr);grid-auto-rows:clamp(100px,9vw,148px);gap:clamp(14px,1.6vw,24px);grid-auto-flow:dense;margin-top:40px}
.pf-mosaic .mcard{position:relative;display:flex;flex-direction:column;overflow:hidden;cursor:pointer;text-decoration:none;grid-column:span 2;grid-row:span 2}
.pf-mosaic .mframe{flex:1;overflow:hidden;min-height:0}
.pf-mosaic .mframe .ph,.pf-mosaic .mframe img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s cubic-bezier(.2,.8,.2,1)}
.pf-mosaic .mcard:hover .mframe .ph,.pf-mosaic .mcard:hover .mframe img{transform:scale(1.05)}
.pf-mosaic .cap{font-family:var(--serif);font-weight:600;font-size:clamp(14px,1.2vw,18px);letter-spacing:.1em;margin-top:10px;color:var(--ink);flex:none}
.pf-mosaic .mcard:nth-child(8n+4){grid-column:span 4;grid-row:span 4}
.pf-mosaic .mcard:nth-child(8n+5){grid-column:span 2;grid-row:span 2}
.pf-mosaic .mcard:nth-child(8n+6){grid-column:span 2;grid-row:span 2}
.pf-mosaic .mcard:nth-child(8n+7){grid-column:span 3;grid-row:span 2}
.pf-mosaic .mcard:nth-child(8n){grid-column:span 3;grid-row:span 2}
@media(max-width:900px){
  .pf-mosaic{grid-template-columns:repeat(2,1fr);grid-auto-rows:clamp(150px,40vw,220px)}
  .pf-mosaic .mcard,.pf-mosaic .mcard:nth-child(n){grid-column:span 1!important;grid-row:span 1!important}
}
@media(max-width:520px){.pf-mosaic{grid-template-columns:1fr}}

/* ===== 關於頁 OUR STORY：圖片裁切填滿、縮短留白、消除過高空白 ===== */
.our-story{align-items:stretch}
.our-story .txt{padding:clamp(46px,6vw,88px) clamp(24px,6vw,100px)!important}
.our-story .media{min-height:0!important;overflow:hidden;position:relative}
.our-story .media img,.our-story .media .ph{position:absolute!important;inset:0!important;width:100%!important;height:100%!important;object-fit:cover!important}
@media(max-width:980px){.our-story .media{min-height:340px!important}}

/* ===== Scroll down 指示：依版型調整，避免擋到標題 ===== */
@media(max-width:1024px){
  .scrolld{left:50%!important;right:auto;transform:translateX(-50%);bottom:20px;gap:10px}
  .scrolld .line{height:54px}
  .scrolld span{font-size:12px;letter-spacing:.18em}
}
@media(max-width:600px){ .scrolld{display:none} }

/* ===== 作品集頁底色 #FEE9D5 ===== */
body.post-type-archive-portfolio,body.tax-portfolio_cat,body.single-portfolio,body.page-portfolio{background:#FEE9D5!important}
body.post-type-archive-portfolio .hero-l,body.tax-portfolio_cat .hero-l,body.page-portfolio .hero-l{background:#FEE9D5!important}
/* ===== 頁尾版權列 ===== */
.foot-copy{text-align:center;font-family:var(--sans);font-size:13px;letter-spacing:.08em;color:rgba(255,255,255,.62);margin-top:clamp(30px,4vw,46px);padding-top:20px;border-top:1px solid rgba(255,255,255,.13)}
/* ===== Back to top ===== */
.totop{position:fixed;right:18px;bottom:22px;z-index:45;width:46px;height:46px;border:0;border-radius:50%;background:var(--clay);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;opacity:0;pointer-events:none;transform:translateY(12px);transition:opacity .35s,transform .35s,filter .3s;box-shadow:0 6px 16px rgba(0,0,0,.25)}
.totop.show{opacity:1;pointer-events:auto;transform:none}
.totop:hover{filter:brightness(1.08)}
.totop svg{width:22px;height:22px}
@media(max-width:600px){.totop{width:42px;height:42px;right:14px;bottom:16px}}
/* 後台自訂 LOGO：上傳圖檔時取代 CSS 徽章 */
.logo.has-img{background:none!important;border:none!important;box-shadow:none!important;overflow:hidden}
.logo.has-img img{width:100%;height:100%;object-fit:contain;display:block}

/* ===== 右下角 HS 浮水印（作品集/服務頁） ===== */
.pf-watermark{position:fixed;right:0;bottom:0;z-index:4;pointer-events:none;user-select:none;opacity:.06;line-height:0}
.pf-watermark img{width:clamp(180px,26vw,360px);height:auto;display:block;transform:translate(7%,9%)}
.pf-watermark .hs{display:block;font-family:var(--en);font-weight:600;font-size:clamp(150px,24vw,330px);color:var(--ink);line-height:.8;letter-spacing:-.04em;transform:translate(8%,12%)}
@media(max-width:700px){.pf-watermark{opacity:.05}.pf-watermark img{width:clamp(130px,42vw,200px)}.pf-watermark .hs{font-size:clamp(120px,40vw,190px)}}

/* 浮水印修正：完整顯示在右下角內側、提高可見度 */
.pf-watermark{position:fixed!important;right:clamp(12px,3vw,46px)!important;bottom:clamp(12px,3vw,46px)!important;z-index:6!important;opacity:.12!important;pointer-events:none;user-select:none;line-height:0}
.pf-watermark img{width:clamp(140px,20vw,260px)!important;height:auto!important;display:block;transform:none!important}
.pf-watermark .hs{transform:none!important}
@media(max-width:700px){.pf-watermark{opacity:.1!important}.pf-watermark img{width:clamp(110px,34vw,170px)!important}}

/* ===== 手機版優化：分類 chips 橫滑 + Hero 縮短 ===== */
@media(max-width:760px){
  /* 內頁 Hero 不要太高太空 */
  .hero-l{min-height:clamp(340px,64vw,440px)}
  .hero-l h1{font-size:clamp(40px,12vw,60px)}
  .hero-l .sub{font-size:clamp(15px,4vw,20px);margin-top:16px}
  /* 分類 bar 改成橫向滑動膠囊 */
  .cat-filter{flex-wrap:nowrap;justify-content:flex-start;overflow-x:auto;gap:9px;margin:18px 0 30px;padding:2px 2px 10px;-webkit-overflow-scrolling:touch;scrollbar-width:none}
  .cat-filter::-webkit-scrollbar{display:none}
  .cat-filter a{flex:0 0 auto;border:1px solid rgba(3,3,2,.22)!important;border-radius:999px;padding:7px 16px;gap:1px;background:#fff}
  .cat-filter a .en4{font-size:12.5px;letter-spacing:.05em}
  .cat-filter a .zh2{font-size:11px;opacity:.7}
  .cat-filter a.active{background:#6b7358;border-color:#6b7358!important}
  .cat-filter a.active .en4,.cat-filter a.active .zh2{color:#fff;opacity:1}
}
