/* ============================================
   匠工房 TAKUMI KOBO — 工務店
   Theme: Monochrome Japanese Modern
   Black base, full-bleed photos, serif typography
   ============================================ */
:root{
  --pri:#111;--pri2:#222;--acc:#c9a96e;--acc2:#b08d57;
  --txt:#888;--heading:#111;
  --bg:#fff;--bg2:#f5f4f1;--bg3:#22201d;
  --ff:'Zen Old Mincho','Noto Serif JP',serif;
  --fb:'Noto Sans JP',sans-serif;
  --fe:'Cormorant Garamond',serif;
  --r:0;--rlg:0;
  --hh:80px;
  /* Override base.css vars */
  --color-primary:#111;--color-accent:#c9a96e;--color-text:#888;--color-heading:#111;
  --color-bg:#fff;--color-bg-alt:#f5f4f1;
  --color-header-bg:rgba(255,255,255,.95);
  --color-footer-bg:#22201d;--color-footer-text:rgba(255,255,255,.4);
  --font-heading:'Zen Old Mincho','Noto Serif JP',serif;
  --font-body:'Noto Sans JP',sans-serif;
  --font-en:'Cormorant Garamond',serif;
  --header-height:80px;--radius:0;--radius-lg:0;
  --hero-overlay:linear-gradient(to top,rgba(0,0,0,.8) 0%,transparent 50%);
}

/* --- Loading --- */
.loading-screen{background:var(--bg3)}
.loading-logo{font-family:var(--fe);color:var(--acc);font-size:clamp(1.5rem,3vw,2.5rem);font-weight:300;letter-spacing:.3em}

/* --- Header --- */
.header .logo{font-family:var(--ff);font-size:1rem;color:#fff !important;letter-spacing:.15em;font-weight:400;transition:color .3s ease}
.header.scrolled .logo{color:#111 !important}
.header .nav-link{font-size:.78rem;color:#fff !important;letter-spacing:.18em;font-weight:300;transition:color .3s ease,transform .45s cubic-bezier(.22,1,.36,1);display:inline-block;transform-origin:center}
.header.scrolled .nav-link{color:#111 !important}
/* Disable underline animation, use soft scale instead */
.header .nav-link::after{display:none}
.header .nav-link:hover{transform:scale(1.12);color:var(--acc) !important}
.header.scrolled .nav-link:hover{color:var(--acc) !important}
.header .hamburger span{background:#fff}
.header.scrolled .hamburger span{background:#111}

/* --- Hero --- */
.hero-build{min-height:100vh;position:relative;display:flex;align-items:flex-end;overflow:hidden}
.hero-build .hero-bg{filter:brightness(.35)}
.hero-build .hero-overlay{background:linear-gradient(to top,rgba(0,0,0,.85) 0%,rgba(0,0,0,.1) 60%)}
.hero-build .hero-inner{position:relative;z-index:1;padding:0 clamp(2rem,5vw,4rem) clamp(4rem,8vw,6rem);width:100%}
.hero-build .hero-tag{font-family:var(--fe);font-size:.65rem;letter-spacing:.3em;color:var(--acc);text-transform:uppercase;margin-bottom:1.5rem;display:flex;align-items:center;gap:.75rem}
.hero-build .hero-tag::before{content:'';width:40px;height:1px;background:var(--acc)}
.hero-build h1{font-family:var(--ff);font-size:clamp(2.5rem,6vw,5rem);color:#fff;font-weight:400;line-height:1.3;letter-spacing:.08em}
.hero-build .hero-sub{font-size:.85rem;color:rgba(255,255,255,.4);line-height:2.2;max-width:450px;margin-top:1.5rem}
.hero-scroll-v{position:absolute;bottom:2rem;right:clamp(2rem,5vw,4rem);writing-mode:vertical-rl;font-family:var(--fe);font-size:.6rem;letter-spacing:.2em;color:rgba(255,255,255,.25);display:flex;align-items:center;gap:.75rem}
.hero-scroll-v::after{content:'';width:1px;height:50px;background:rgba(255,255,255,.15)}

/* --- Works Gallery --- */
.works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(.5rem,1vw,.75rem);margin-top:2.5rem}
.works-item{position:relative;overflow:hidden;cursor:pointer}
.works-item img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1),filter .6s}
.works-item:hover img{transform:scale(1.06);filter:brightness(.65)}
.works-cap{position:absolute;bottom:0;left:0;right:0;padding:1.5rem;background:linear-gradient(to top,rgba(0,0,0,.75),transparent);opacity:0;transform:translateY(10px);transition:all .4s;color:#fff}
.works-item:hover .works-cap{opacity:1;transform:none}
.works-cap h3{font-family:var(--ff);font-size:.85rem;font-weight:400;letter-spacing:.08em}
.works-cap p{font-size:.6rem;color:rgba(255,255,255,.5);margin-top:.2rem}
.wi-tall{grid-row:span 2}
.wi-std{aspect-ratio:4/3}
@media(max-width:640px){.works-grid{grid-template-columns:1fr}.wi-tall{grid-row:auto}}

/* --- Works enriched (index page) --- */
.works-section{position:relative;isolation:isolate}
.works-section > .container{position:relative;z-index:2}

.works-head{display:grid;grid-template-columns:1fr auto;gap:1rem;align-items:end;margin-bottom:clamp(2.5rem,4vw,3.5rem)}
.works-lead{font-size:.85rem;line-height:2.1;color:var(--txt);margin-top:1.25rem;max-width:520px}
.works-viewall{font-family:var(--fe);font-size:.92rem;letter-spacing:.16em;color:var(--heading);text-transform:uppercase;display:inline-flex;align-items:center;gap:.55rem;padding:.55rem 0;border-bottom:1px solid var(--acc);transition:all .35s;align-self:end;font-weight:500}
.works-viewall span{transition:transform .35s;color:var(--acc);font-weight:400}
.works-viewall:hover{opacity:1;color:var(--acc);border-color:var(--acc)}
.works-viewall:hover span{transform:translateX(5px)}
@media(max-width:768px){.works-head{grid-template-columns:1fr}.works-viewall{justify-self:start;margin-top:1rem}}

/* Horizontal infinite marquee */
.works-marquee{position:relative;overflow:hidden;margin:0 calc(-1 * clamp(1.5rem,4vw,4rem));padding:.5rem 0 1rem}
.works-marquee::before,.works-marquee::after{content:'';position:absolute;top:0;bottom:0;width:clamp(40px,6vw,90px);z-index:3;pointer-events:none}
.works-marquee::before{left:0;background:linear-gradient(to right,var(--color-bg-alt) 10%,transparent)}
.works-marquee::after{right:0;background:linear-gradient(to left,var(--color-bg-alt) 10%,transparent)}
.works-track{display:flex;gap:clamp(1rem,1.8vw,1.75rem);width:max-content;padding:1rem clamp(1.5rem,4vw,4rem);animation:worksScroll 50s linear infinite;will-change:transform}
.works-marquee:hover .works-track{animation-play-state:paused}
@keyframes worksScroll{from{transform:translate3d(0,0,0)}to{transform:translate3d(-50%,0,0)}}
@media (prefers-reduced-motion:reduce){.works-track{animation:none}}

.work-card{position:relative;background:#fff;cursor:pointer}
.works-marquee .work-card{flex:0 0 auto;width:clamp(280px,26vw,360px)}
.work-cover{position:relative;overflow:hidden;background:var(--bg2)}
.works-marquee .work-cover{aspect-ratio:4/3}
.work-card-main .work-cover{aspect-ratio:3/4}
.work-card-sub .work-cover{aspect-ratio:16/10}
.work-cover img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.22,1,.36,1),filter .6s;display:block}
.work-card:hover .work-cover img{transform:scale(1.06);filter:brightness(.85)}
.work-cover::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.55),transparent 45%);opacity:0;transition:opacity .4s;pointer-events:none}
.work-card:hover .work-cover::after{opacity:1}

/* Number tag */
.work-tag{position:absolute;top:1rem;left:1rem;font-family:var(--fe);font-size:.85rem;letter-spacing:.15em;color:#fff;padding:.35rem .75rem;background:rgba(10,10,10,.45);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:2;font-weight:400}

/* Meta below card (centered) */
.work-meta{padding:1.1rem 0 0 0;position:relative;text-align:center}
.work-meta::before{content:'';position:absolute;top:.55rem;left:50%;width:24px;height:1px;background:var(--acc);transform:translateX(-50%);transition:width .5s cubic-bezier(.22,1,.36,1)}
.work-card:hover .work-meta::before{width:48px}
.work-meta-row{display:flex;justify-content:center;align-items:baseline;gap:.7rem;margin-bottom:.45rem;padding-top:.65rem}
.work-meta-row::after{content:'';position:absolute;display:none}
.work-loc{font-family:var(--ff);font-size:.85rem;font-weight:500;color:var(--heading);letter-spacing:.08em}
.work-year{font-family:var(--fe);font-size:.72rem;letter-spacing:.15em;color:var(--acc);font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums;position:relative;padding-left:.7rem}
.work-year::before{content:'';position:absolute;left:0;top:50%;width:1px;height:.7em;background:rgba(201,169,110,.45);transform:translateY(-50%)}
.work-title{font-size:.78rem;line-height:1.7;color:var(--txt);margin-bottom:.8rem}
.work-tags{display:flex;flex-wrap:wrap;gap:.4rem;justify-content:center}
.work-tags span{font-size:.6rem;letter-spacing:.1em;color:var(--txt);padding:.18rem .6rem;border:1px solid rgba(0,0,0,.1);background:rgba(255,255,255,.6)}

/* Architectural blueprint SVG decorative */
.works-blueprint{position:absolute;width:clamp(180px,16vw,280px);height:auto;color:var(--acc);opacity:.18;top:8%;right:5%;z-index:1;pointer-events:none}
.works-blueprint path{fill:none;stroke-dasharray:1000;stroke-dashoffset:1000;animation:wbDraw 2.5s cubic-bezier(.22,1,.36,1) forwards}
.works-blueprint .wb-roof{animation-delay:.2s}
.works-blueprint .wb-walls{animation-delay:.6s}
.works-blueprint .wb-door{animation-delay:1.2s}
.works-blueprint .wb-window-l{animation-delay:1.5s}
.works-blueprint .wb-window-r{animation-delay:1.7s}
.works-blueprint .wb-base{animation-delay:2s;stroke-dasharray:3 4}
@keyframes wbDraw{to{stroke-dashoffset:0}}
@media(max-width:768px){.works-blueprint{display:none}}
@media (prefers-reduced-motion:reduce){
  .works-blueprint path{animation:none;stroke-dashoffset:0}
  .work-cover img{transition:none}
}

/* Stat line (between grid and CTA) */
.works-statline{display:grid;grid-template-columns:1fr auto 1fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:center;margin-top:clamp(3rem,5vw,4.5rem)}
.works-statline-line{height:1px;background:linear-gradient(to right,transparent,rgba(201,169,110,.5))}
.works-statline:nth-child(n) .works-statline-line:last-child{background:linear-gradient(to left,transparent,rgba(201,169,110,.5))}
.works-statline-text{display:inline-flex;align-items:baseline;gap:.4rem}
.works-statline .counter{font-family:var(--fe);font-size:clamp(2rem,3.4vw,2.8rem);font-weight:400;color:var(--acc);line-height:1;font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums;letter-spacing:.02em}
.works-statline-plus{font-family:var(--fe);font-size:clamp(1.4rem,2.4vw,1.8rem);color:var(--acc);font-weight:400;line-height:1}
.works-statline-label{font-size:.7rem;color:var(--txt);letter-spacing:.15em;margin-left:.85rem}
@media(max-width:640px){.works-statline{grid-template-columns:1fr}.works-statline-line{display:none}}

/* --- Philosophy --- */
.phil-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,6rem);align-items:center}
.phil-img{position:relative;overflow:hidden}
.phil-img img{width:100%;aspect-ratio:3/4;object-fit:cover}
.phil-img::before{content:'';position:absolute;inset:12px;border:1px solid var(--acc);z-index:1;pointer-events:none;opacity:.25}
.phil-text h2{font-family:var(--ff);font-size:clamp(1.4rem,3vw,2.2rem);font-weight:400;color:var(--heading);line-height:1.8;letter-spacing:.08em;margin-bottom:1.5rem}
.phil-text p{font-size:.88rem;line-height:2.4;margin-bottom:1rem}
@media(max-width:768px){.phil-grid{grid-template-columns:1fr}}

/* --- Philosophy enriched (index.html top section) --- */
.phil-section{position:relative;isolation:isolate}
.phil-bg-tex{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.06;z-index:0;filter:grayscale(.4) sepia(.15);pointer-events:none;mix-blend-mode:multiply}
.phil-section > .container{position:relative;z-index:2}
.phil-grid-rich{display:grid;grid-template-columns:1.05fr 1fr;gap:clamp(3rem,6vw,7rem);align-items:center}
@media(max-width:900px){.phil-grid-rich{grid-template-columns:1fr;gap:clamp(2.5rem,5vw,4rem)}}

/* Layered visual (main + accent) */
.phil-visual{position:relative;aspect-ratio:3/4;max-width:560px}
.phil-photo{position:absolute;overflow:hidden;background:var(--bg2)}
.phil-photo img{width:100%;height:100%;object-fit:cover;display:block}
.phil-photo-main{inset:0;z-index:1}
.phil-photo-main img{animation:philKenburns 18s ease-in-out infinite alternate}
.phil-photo-accent{width:36%;aspect-ratio:4/5;right:-3%;bottom:-5%;z-index:3;box-shadow:0 22px 50px -28px rgba(0,0,0,.35),inset 0 0 60px 6px rgba(255,255,255,.18);border:none;background:#fff;opacity:.95;border-radius:0;overflow:hidden;mask-image:none;-webkit-mask-image:none}
.phil-photo-accent::after{content:'';position:absolute;inset:0;background:linear-gradient(140deg,rgba(255,253,247,.22) 0%,rgba(255,253,247,0) 35%,rgba(34,32,29,.18) 100%);z-index:1;pointer-events:none}
.phil-photo-accent img{animation:philKenburns 22s ease-in-out infinite alternate-reverse;filter:grayscale(.55) sepia(.18) brightness(1.02) contrast(.92)}
@media(max-width:900px){
  .phil-visual{margin:0 auto;max-width:480px}
  .phil-photo-accent{width:42%;right:-4%;bottom:-4%;border-width:5px}
}

/* Subtle gold corner-frames */
.phil-corner{position:absolute;width:46px;height:46px;border:1px solid var(--acc);opacity:.55;z-index:2;pointer-events:none}
.phil-corner-tl{top:-14px;left:-14px;border-right:none;border-bottom:none}
.phil-corner-br{bottom:-14px;right:-14px;border-left:none;border-top:none}
@media(max-width:900px){.phil-corner{width:36px;height:36px}}

/* Vertical gold line that draws in on visible */
.phil-vline{position:absolute;left:-2.4rem;top:0;width:1px;height:0;background:linear-gradient(to bottom,transparent,var(--acc) 25%,var(--acc) 75%,transparent);transition:height 1.4s cubic-bezier(.22,1,.36,1) .25s;z-index:1}
.phil-visual.visible .phil-vline{height:88%}
@media(max-width:900px){.phil-vline{left:-1.2rem}}

/* Ken-burns keyframes */
@keyframes philKenburns{
  0%  {transform:scale(1.02) translate(0%,0%)}
  100%{transform:scale(1.10) translate(-1.5%,1.2%)}
}

/* Decorative animated branch SVG */
.phil-branch{position:absolute;width:clamp(180px,16vw,260px);height:auto;color:var(--acc);opacity:.18;top:6%;right:4%;z-index:1;pointer-events:none;transform-origin:30px 460px;animation:philSway 9s ease-in-out infinite alternate}
.phil-branch-stem{stroke-dasharray:1200;stroke-dashoffset:1200;animation:philDraw 4s cubic-bezier(.22,1,.36,1) .4s forwards}
.phil-branch-leaf{opacity:0;transform-origin:center;animation:philLeaf 1.2s cubic-bezier(.22,1,.36,1) forwards}
.phil-branch-leaf:nth-of-type(1){animation-delay:2.4s}
.phil-branch-leaf:nth-of-type(2){animation-delay:2.8s}
.phil-branch-leaf:nth-of-type(3){animation-delay:3.2s}
@keyframes philDraw{to{stroke-dashoffset:0}}
@keyframes philLeaf{0%{opacity:0;transform:scale(.5) rotate(-8deg)}100%{opacity:1;transform:scale(1) rotate(0deg)}}
@keyframes philSway{0%{transform:rotate(-1.2deg)}100%{transform:rotate(1.2deg)}}
@media(max-width:900px){.phil-branch{display:none}}
@media (prefers-reduced-motion:reduce){
  .phil-photo-main img,.phil-photo-accent img,.phil-branch,.phil-branch-stem,.phil-branch-leaf{animation:none !important}
  .phil-branch-stem{stroke-dashoffset:0}
  .phil-branch-leaf{opacity:1}
}

/* ===========================================
   Gallery filters + cards (detail link)
   =========================================== */
.case-filter{display:flex;flex-wrap:wrap;gap:.7rem;justify-content:center;margin:clamp(1rem,2vw,1.5rem) auto clamp(2.75rem,4.5vw,4rem);max-width:1100px}
.cf-btn{font-family:var(--ff);font-size:.75rem;letter-spacing:.12em;color:var(--txt);background:transparent;border:1px solid rgba(0,0,0,.12);padding:.55rem 1.25rem;cursor:pointer;transition:all .35s cubic-bezier(.22,1,.36,1);font-weight:400}
.cf-btn:hover{border-color:var(--acc);color:var(--acc)}
.cf-btn.active{background:var(--heading);border-color:var(--heading);color:#fff}
.gallery-section .works-item{transition:opacity .4s,box-shadow .5s,transform .5s cubic-bezier(.22,1,.36,1)}
.gallery-section .works-item.is-hidden{display:none !important}
/* Always-visible card label (number + title) */
.gallery-section .works-item{text-decoration:none;color:inherit}
.gallery-section .works-item .case-tag{position:absolute;top:1rem;left:1rem;font-family:var(--fe);font-size:.78rem;letter-spacing:.18em;color:#fff;padding:.35rem .8rem;background:rgba(10,10,10,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);z-index:3;font-weight:400;font-feature-settings:"lnum" 1,"tnum" 1}
.gallery-section .works-item .case-label{position:absolute;left:0;right:0;bottom:0;padding:.85rem 1rem;color:#fff;background:linear-gradient(to top,rgba(10,10,10,.85),rgba(10,10,10,.4) 70%,transparent);z-index:2;display:flex;justify-content:space-between;align-items:flex-end;gap:.5rem;opacity:0;transform:translateY(8px);transition:all .4s cubic-bezier(.22,1,.36,1)}
.gallery-section .works-item:hover .case-label{opacity:1;transform:none}
.gallery-section .works-item .case-label-title{font-family:var(--ff);font-size:.85rem;font-weight:500;letter-spacing:.06em;line-height:1.4}
.gallery-section .works-item .case-label-link{font-family:var(--fe);font-size:.65rem;letter-spacing:.2em;color:var(--acc);text-transform:uppercase;white-space:nowrap}

/* ===========================================
   Case detail page
   =========================================== */
.case-hero{position:relative;height:clamp(380px,60vh,640px);overflow:hidden;display:flex;align-items:flex-end}
.case-hero-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}
.case-hero::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(10,10,10,.85) 0%,rgba(10,10,10,.2) 50%,rgba(10,10,10,.4) 100%);z-index:1;pointer-events:none}
.case-hero-text{position:relative;z-index:2;width:100%;padding:0 clamp(1.5rem,4vw,4rem) clamp(2rem,5vw,4rem);max-width:1200px;margin:0 auto}
.case-hero-text .case-num{font-family:var(--fe);font-size:.85rem;letter-spacing:.3em;color:var(--acc);display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}
.case-hero-text .case-num::before{content:'';width:30px;height:1px;background:var(--acc)}
.case-hero-text h1{font-family:var(--ff);color:#fff;font-size:clamp(2rem,4.5vw,3.6rem);font-weight:400;letter-spacing:.06em;line-height:1.4;margin-bottom:.85rem}
.case-hero-text .case-subtitle{font-family:var(--ff);color:rgba(255,255,255,.85);font-size:clamp(.9rem,1.4vw,1.05rem);letter-spacing:.05em;line-height:1.8;margin-bottom:1.25rem}
.case-hero-text .case-hero-tags{display:flex;flex-wrap:wrap;gap:.45rem}
.case-hero-text .case-hero-tags span{font-size:.65rem;letter-spacing:.15em;padding:.3rem .85rem;border:1px solid rgba(255,255,255,.4);color:rgba(255,255,255,.85);text-transform:uppercase;font-family:var(--fe)}

.case-bread{padding:clamp(1.75rem,3vw,2.5rem) 0;border-bottom:none;background:linear-gradient(135deg,#fafaf7 0%,#f3f1ec 60%,#f5f4f1 100%)}
.case-bread .container{font-size:.82rem;letter-spacing:.18em;color:var(--txt);font-family:var(--ff);font-weight:400;display:flex;align-items:center;flex-wrap:wrap;gap:.15rem}
.case-bread .container::before{content:'';display:inline-block;width:5px;height:5px;background:var(--acc);border-radius:50%;margin-right:1rem;flex-shrink:0;opacity:.8}
.case-bread a{color:var(--heading);font-weight:400;font-family:var(--ff);transition:color .4s cubic-bezier(.22,1,.36,1),transform .55s cubic-bezier(.22,1,.36,1);display:inline-block;will-change:transform}
.case-bread a:hover{color:var(--acc);opacity:1;transform:translateY(-3px)}
.case-bread .sep{margin:0 .85rem;color:var(--acc);opacity:.55;font-size:.78rem;font-weight:400}
.case-bread .cb-current{color:var(--heading);font-weight:400;font-family:var(--ff)}

/* Concept */
.case-concept{padding:clamp(4rem,7vw,6rem) 0;background:#fff}
.case-concept .container{max-width:780px}
.case-concept .sec-num{justify-content:flex-start;margin-bottom:1rem}
.case-concept h2{font-family:var(--ff);font-size:clamp(1.4rem,2.6vw,1.9rem);font-weight:400;letter-spacing:.08em;line-height:1.8;color:var(--heading);margin-bottom:1.75rem}
.case-concept p{font-size:.88rem;line-height:2.4;color:var(--txt);margin-bottom:1.1rem}

/* Photo gallery (case detail) */
.case-photos{padding:clamp(3rem,6vw,5rem) 0;background:var(--bg2)}
.case-photos .text-center{margin-bottom:clamp(2rem,4vw,3rem)}
.case-photos h2{font-family:var(--ff);font-size:clamp(1.4rem,2.6vw,1.9rem);font-weight:400;letter-spacing:.08em;color:var(--heading);margin-top:.6rem}
.case-photos-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-flow:row;gap:clamp(1rem,1.8vw,1.5rem)}
.case-photos-grid .cp-cell{position:relative;overflow:hidden;background:#22201d;margin:0;cursor:pointer;transition:box-shadow .5s cubic-bezier(.22,1,.36,1);aspect-ratio:4/3}
.case-photos-grid .cp-cell::before{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.18) 0%,rgba(0,0,0,.55) 100%);z-index:1;pointer-events:none;transition:opacity .4s}
.case-photos-grid .cp-cell:hover::before{opacity:.4}
.case-photos-grid .cp-cell img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 1s cubic-bezier(.22,1,.36,1),filter .55s;filter:saturate(.55) brightness(.7) contrast(.95);opacity:.78}
.case-photos-grid .cp-cell:hover img{transform:scale(1.03);filter:saturate(.7) brightness(.78);opacity:.9}
.case-photos-grid .cp-cell figcaption{position:absolute;bottom:.85rem;left:1rem;font-family:var(--fe);font-size:.72rem;letter-spacing:.22em;color:rgba(255,255,255,.72);text-transform:uppercase;z-index:2;font-weight:400;font-feature-settings:"lnum" 1,"tnum" 1;display:flex;align-items:center;gap:.5rem}
.case-photos-grid .cp-cell figcaption::before{content:'';width:18px;height:1px;background:var(--acc);opacity:.7}
.case-photos-grid .cp-cell::after{content:'\2295';position:absolute;top:.85rem;right:1rem;width:30px;height:30px;border-radius:50%;border:1px solid rgba(255,255,255,.35);color:rgba(255,255,255,.65);font-size:.95rem;display:flex;align-items:center;justify-content:center;line-height:1;z-index:2;backdrop-filter:blur(2px);transition:all .35s}
.case-photos-grid .cp-cell:hover::after{background:var(--acc);border-color:var(--acc);color:#fff}
.case-photos-grid > *:nth-child(n){grid-column:auto;grid-row:auto}
@media(max-width:768px){.case-photos-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.case-photos-grid{grid-template-columns:1fr}}

/* Spec table */
.case-spec{position:relative;isolation:isolate;overflow:hidden;padding:clamp(4rem,7vw,6rem) 0}
.case-spec-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none;filter:grayscale(.45) sepia(.08)}
.case-spec::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.93) 0%,rgba(248,247,243,.88) 50%,rgba(255,255,255,.95) 100%);z-index:1;pointer-events:none}
.case-spec > .container,.case-spec > .bg-letters{position:relative;z-index:2}
.case-spec .container{max-width:880px}
.case-spec h2{font-family:var(--ff);font-size:clamp(1.4rem,2.6vw,1.9rem);font-weight:400;letter-spacing:.08em;color:var(--heading);margin-top:.6rem;margin-bottom:1.5rem}
.case-spec-table{width:100%;border-collapse:collapse;background:#fff;border:1px solid rgba(0,0,0,.06);box-shadow:0 20px 40px -28px rgba(17,17,17,.12)}
.case-spec-table tr{border-bottom:1px solid rgba(0,0,0,.06)}
.case-spec-table tr:last-child{border-bottom:none}
.case-spec-table th{text-align:left;padding:1rem 1.25rem;font-family:var(--ff);font-size:.78rem;font-weight:500;letter-spacing:.08em;color:var(--heading);background:rgba(245,244,241,.5);width:170px;border-right:1px solid rgba(0,0,0,.06);vertical-align:top}
.case-spec-table td{padding:1rem 1.25rem;font-size:.82rem;line-height:1.85;color:var(--txt)}
@media(max-width:600px){.case-spec-table th{width:110px;padding:.85rem 1rem;font-size:.72rem}.case-spec-table td{padding:.85rem 1rem;font-size:.78rem}}

/* Highlights */
.case-highlights{padding:clamp(4rem,7vw,6rem) 0;background:var(--bg2)}
.case-highlights .text-center{margin-bottom:clamp(2rem,4vw,3rem)}
.case-highlights h2{font-family:var(--ff);font-size:clamp(1.4rem,2.6vw,1.9rem);font-weight:400;letter-spacing:.08em;color:var(--heading);margin-top:.6rem}
.case-hi-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(1.5rem,2.5vw,2rem)}
.case-hi-card{background:#fff;padding:clamp(1.75rem,3vw,2.5rem);border:1px solid rgba(0,0,0,.05);transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s}
.case-hi-card:hover{transform:translateY(-4px);box-shadow:0 30px 50px -28px rgba(17,17,17,.18)}
.case-hi-num{font-family:var(--fe);font-size:1.8rem;color:var(--acc);font-weight:300;line-height:1;display:block;margin-bottom:.75rem}
.case-hi-card h3{font-family:var(--ff);font-size:1rem;font-weight:500;letter-spacing:.06em;color:var(--heading);margin-bottom:.85rem}
.case-hi-card p{font-size:.78rem;line-height:2;color:var(--txt)}
@media(max-width:768px){.case-hi-grid{grid-template-columns:1fr}}

/* Voice block (compact) with property-related background */
.case-voice-block{position:relative;isolation:isolate;overflow:hidden;padding:clamp(3rem,5vw,4.5rem) 0}
.case-voice-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none;filter:grayscale(.55) sepia(.12) brightness(.95)}
.case-voice-block::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.94) 0%,rgba(248,247,243,.86) 50%,rgba(255,255,255,.94) 100%);z-index:1;pointer-events:none}
.case-voice-block > .container{position:relative;z-index:2}
.case-voice-block > .vert-label,.case-voice-block > .bg-letters{z-index:2}
.case-voice-block .container{max-width:640px}
.case-voice-block h2{font-family:var(--ff);font-size:clamp(1.3rem,2.3vw,1.7rem);font-weight:400;letter-spacing:.08em;color:var(--heading);margin-top:.6rem;margin-bottom:1.25rem}
.case-voice-card{position:relative;background:var(--bg2);padding:clamp(1.5rem,2.6vw,2rem) clamp(1.75rem,3vw,2.25rem);border-left:3px solid var(--acc)}
.case-voice-card::before{content:'\201C';position:absolute;top:-.35em;right:.9rem;font-family:var(--fe);font-size:5.5rem;line-height:1;color:rgba(201,169,110,.18);font-weight:400}
.case-voice-card blockquote{font-family:var(--ff);font-size:clamp(.85rem,1.1vw,.95rem);line-height:1.95;color:var(--heading);font-weight:400;margin-bottom:.85rem;letter-spacing:.03em;position:relative;z-index:1}
.case-voice-card cite{font-style:normal;font-size:.68rem;letter-spacing:.12em;color:var(--txt);font-family:var(--fe)}

/* Designer */
.case-designer{padding:clamp(4rem,7vw,6rem) 0;background:var(--bg2)}
.case-designer .container{max-width:780px}
.case-designer-card{display:grid;grid-template-columns:140px 1fr;gap:clamp(1.5rem,3vw,2.5rem);align-items:start;background:#fff;padding:clamp(1.75rem,3vw,2.5rem)}
.case-designer-photo{width:140px;height:140px;border-radius:50%;object-fit:cover;background:var(--bg2)}
.case-designer-info h3{font-family:var(--ff);font-size:1.15rem;font-weight:500;color:var(--heading);letter-spacing:.08em;margin-bottom:.4rem}
.case-designer-info .case-designer-role{font-family:var(--fe);font-size:.7rem;letter-spacing:.18em;color:var(--acc);text-transform:uppercase;margin-bottom:1rem}
.case-designer-info p{font-size:.82rem;line-height:2;color:var(--txt)}
@media(max-width:600px){.case-designer-card{grid-template-columns:1fr;text-align:center}.case-designer-photo{margin:0 auto}}

/* Related cases */
.case-related{padding:clamp(4rem,7vw,6rem) 0;background:#fff}
.case-related .text-center{margin-bottom:clamp(2rem,4vw,3rem)}
.case-related h2{font-family:var(--ff);font-size:clamp(1.4rem,2.6vw,1.9rem);font-weight:400;letter-spacing:.08em;color:var(--heading);margin-top:.6rem}
.case-related-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:clamp(1rem,2vw,1.5rem)}
.case-related-card{display:block;text-decoration:none;color:inherit;cursor:pointer}
.case-related-card .case-related-img{aspect-ratio:4/3;overflow:hidden;background:var(--bg2);margin-bottom:.85rem}
.case-related-card img{width:100%;height:100%;object-fit:cover;transition:transform 1s cubic-bezier(.22,1,.36,1)}
.case-related-card:hover img{transform:scale(1.05)}
.case-related-card h4{font-family:var(--ff);font-size:.85rem;font-weight:500;letter-spacing:.06em;color:var(--heading);margin-bottom:.2rem}
.case-related-card p{font-size:.66rem;letter-spacing:.06em;color:var(--txt);line-height:1.7}
.case-related-cta{text-align:center;margin-top:clamp(2rem,4vw,3rem)}
@media(max-width:768px){.case-related-grid{grid-template-columns:repeat(2,1fr)}}

/* ===========================================
   Lightbox (gallery photo modal)
   =========================================== */
.lightbox{position:fixed;inset:0;background:rgba(10,10,10,.92);display:flex;align-items:center;justify-content:center;padding:clamp(1rem,4vw,3rem);z-index:1000;opacity:0;visibility:hidden;transition:opacity .35s cubic-bezier(.22,1,.36,1),visibility 0s linear .35s;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}
.lightbox.open{opacity:1;visibility:visible;transition:opacity .35s cubic-bezier(.22,1,.36,1)}
.lb-content{position:relative;max-width:1100px;max-height:90vh;display:flex;flex-direction:column;gap:1rem;transform:scale(.96);transition:transform .45s cubic-bezier(.22,1,.36,1)}
.lightbox.open .lb-content{transform:scale(1)}
.lb-img-wrap{position:relative;overflow:hidden;background:#1a1a1a;flex:1;min-height:0}
.lb-img{display:block;width:100%;height:auto;max-height:78vh;object-fit:contain}
.lb-meta{color:#fff;text-align:center;padding:.5rem 0}
.lb-title{font-family:var(--ff);font-size:clamp(1.05rem,1.8vw,1.3rem);font-weight:500;letter-spacing:.08em;color:#fff;margin-bottom:.4rem}
.lb-desc{font-size:.78rem;letter-spacing:.06em;color:rgba(255,255,255,.55);line-height:1.8}
.lb-close{position:absolute;top:clamp(1rem,3vw,2rem);right:clamp(1rem,3vw,2rem);width:48px;height:48px;border-radius:50%;border:1px solid rgba(255,255,255,.25);background:rgba(0,0,0,.4);color:#fff;font-size:1.4rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .3s,border-color .3s,transform .3s;z-index:1}
.lb-close:hover{background:var(--acc);border-color:var(--acc);transform:rotate(90deg)}
.gallery-section .works-item{cursor:zoom-in}
.gallery-section .works-item::before{content:'\2295';position:absolute;top:1rem;right:1rem;font-family:var(--fe);font-size:1.4rem;color:#fff;opacity:0;transform:scale(.7);transition:all .35s cubic-bezier(.22,1,.36,1);z-index:3;line-height:1;background:rgba(10,10,10,.45);width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}
.gallery-section .works-item:hover::before{opacity:1;transform:scale(1)}

/* ===========================================
   Gallery page — decorative background + mosaic grid
   =========================================== */
.gallery-section{position:relative;background:linear-gradient(135deg,#fafaf7 0%,#f3f1ec 60%,#f5f4f1 100%);isolation:isolate;overflow:hidden;padding:clamp(2.5rem,4vw,3.75rem) 0 clamp(4rem,8vw,8rem) !important}

/* Uniform 3-column grid (3x4 = 12 items) */
.gallery-section .works-grid{display:grid !important;grid-template-columns:repeat(3,1fr);gap:clamp(2.25rem,4vw,3.5rem);max-width:1100px;margin:clamp(2rem,3.5vw,3rem) auto 0;column-count:auto !important;column-gap:clamp(2.25rem,4vw,3.5rem)}
.gallery-section .works-item{break-inside:auto !important;page-break-inside:auto !important;-webkit-column-break-inside:auto !important;display:block;margin-bottom:0 !important;cursor:zoom-in;position:relative;background:var(--bg2);overflow:hidden;width:auto;aspect-ratio:4/3;grid-column:span 1 !important;grid-row:span 1 !important;box-shadow:0 16px 32px -24px rgba(17,17,17,.18);transition:box-shadow .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1)}
.gallery-section .works-item:hover{box-shadow:0 28px 48px -22px rgba(17,17,17,.30)}
.gallery-section .works-item > img,.gallery-section .works-item img{width:100%;height:100%;display:block;object-fit:cover;transition:transform 1s cubic-bezier(.22,1,.36,1),filter .55s;box-shadow:none}
.gallery-section .works-item:hover img{transform:scale(1.04);filter:brightness(.92)}
/* Caption hidden — shown in lightbox on click only */
.gallery-section .works-item .works-cap{display:none}

@media(max-width:768px){.gallery-section .works-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.gallery-section .works-grid{grid-template-columns:1fr}}
.gallery-section::before{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(201,169,110,.18) 1px,transparent 1.2px);background-size:26px 26px;background-position:0 0;opacity:.55;z-index:0;pointer-events:none;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%);-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 80%)}
.gallery-section::after{content:'';position:absolute;left:-10%;top:-10%;width:55%;aspect-ratio:1/1;background:radial-gradient(circle at center,rgba(201,169,110,.10),transparent 65%);z-index:0;pointer-events:none}
.gallery-section > .container{position:relative;z-index:1}
.gallery-section > .vert-label,.gallery-section > .bg-letters{z-index:1}
.gallery-section .vert-label{color:var(--acc)}
.gallery-section .gal-corner{position:absolute;width:120px;height:120px;color:var(--acc);opacity:.18;z-index:1;pointer-events:none}
.gallery-section .gal-corner-tl{top:2rem;left:2rem}
.gallery-section .gal-corner-br{bottom:2rem;right:2rem;transform:rotate(180deg)}
.gallery-section .gal-corner path{fill:none;stroke:currentColor;stroke-width:1;stroke-linecap:round;stroke-dasharray:600;stroke-dashoffset:600;animation:galCornerDraw 2.4s cubic-bezier(.22,1,.36,1) .3s forwards}
@keyframes galCornerDraw{to{stroke-dashoffset:0}}
@media(max-width:768px){.gallery-section .gal-corner{display:none}}

/* ===========================================
   Voices page — featured pull-quote + stats
   =========================================== */
.voice-feature{position:relative;max-width:920px;margin:0 auto clamp(3rem,5vw,5rem);padding:clamp(2rem,4vw,4rem) clamp(1.5rem,3vw,3rem);text-align:center;isolation:isolate}
.voice-feature::before{content:'\201C';position:absolute;top:-.55em;left:50%;transform:translateX(-50%);font-family:var(--fe);font-size:clamp(10rem,22vw,20rem);line-height:1;color:rgba(201,169,110,.12);font-weight:400;pointer-events:none;z-index:-1}
.voice-feature blockquote{font-family:var(--ff);font-size:clamp(1.25rem,2.4vw,1.85rem);font-weight:400;line-height:2;letter-spacing:.04em;color:var(--heading);margin-bottom:1.5rem}
.voice-feature blockquote em{font-family:var(--fe);font-style:italic;color:var(--acc);font-weight:400}
.voice-feature .vf-line{display:block;width:48px;height:1px;background:var(--acc);margin:0 auto 1.25rem;opacity:.6}
.voice-feature .vf-cite{font-size:.7rem;letter-spacing:.18em;color:var(--txt);text-transform:uppercase;font-family:var(--fe)}

.voice-grid .voice-card:nth-child(even){grid-template-columns:1fr 280px}
.voice-grid .voice-card:nth-child(even) .voice-img{order:2}
.voice-grid .voice-card:nth-child(even) .voice-body{order:1;padding:clamp(2rem,3vw,2.5rem) 0 clamp(2rem,3vw,2.5rem) clamp(2rem,3vw,2.5rem)}
.voice-grid .voice-card:nth-child(even)::before{right:auto;left:1.5rem;transform:scaleX(-1)}
@media(max-width:768px){
  .voice-grid .voice-card:nth-child(even){grid-template-columns:1fr}
  .voice-grid .voice-card:nth-child(even) .voice-img{order:0}
  .voice-grid .voice-card:nth-child(even) .voice-body{order:0;padding:0 1.5rem 1.75rem}
}

.voice-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin:clamp(3rem,5vw,4.5rem) 0;border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08);background:linear-gradient(to bottom,rgba(255,255,255,.5),rgba(245,244,241,.5))}
.voice-stats .vs{padding:clamp(1.5rem,3vw,2.5rem) 1rem;text-align:center;position:relative}
.voice-stats .vs+.vs::before{content:'';position:absolute;left:0;top:25%;height:50%;width:1px;background:rgba(0,0,0,.08)}
.voice-stats .vs-v{font-family:var(--fe);font-size:clamp(2rem,3.6vw,2.6rem);font-weight:400;color:var(--acc);line-height:1;font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums;letter-spacing:.02em}
.voice-stats .vs-l{font-size:.65rem;color:var(--txt);letter-spacing:.15em;margin-top:.6rem}
@media(max-width:640px){.voice-stats{grid-template-columns:repeat(2,1fr)}.voice-stats .vs:nth-child(2)::before{display:none}.voice-stats .vs:nth-child(3),.voice-stats .vs:nth-child(4){border-top:1px solid rgba(0,0,0,.08)}}

/* ===========================================
   About page — Message + Values enrichments
   =========================================== */
/* Message section reuse phil-* but slightly different */
.about-message{position:relative;isolation:isolate}
.about-message > .container{position:relative;z-index:2}

/* Values redesign */
.values-rich{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:clamp(2.5rem,4vw,3.5rem);position:relative}
.values-rich::before{content:'';position:absolute;top:46px;left:8%;right:8%;height:1px;background:linear-gradient(to right,transparent,rgba(201,169,110,.4) 15%,rgba(201,169,110,.4) 85%,transparent);z-index:0;pointer-events:none}
.value-card{position:relative;padding:clamp(1.75rem,3vw,2.75rem) clamp(1.25rem,2.5vw,2rem);text-align:center;background:transparent;transition:background .4s,transform .5s cubic-bezier(.22,1,.36,1);z-index:1}
.value-card:hover{background:rgba(255,255,255,.5);transform:translateY(-4px)}
.value-card+.value-card{border-left:1px dashed rgba(201,169,110,.25)}
.value-circle{width:92px;height:92px;border-radius:50%;background:#fff;border:1px solid rgba(201,169,110,.4);display:flex;align-items:center;justify-content:center;margin:0 auto 1.25rem;font-family:var(--fe);font-size:1.6rem;color:var(--acc);font-weight:400;letter-spacing:.05em;position:relative;transition:all .45s cubic-bezier(.22,1,.36,1);font-feature-settings:"lnum" 1,"tnum" 1}
.value-circle::before{content:'';position:absolute;inset:6px;border:1px solid rgba(201,169,110,.25);border-radius:50%;transition:all .45s}
.value-card:hover .value-circle{background:var(--acc);color:#fff;border-color:var(--acc);transform:scale(1.06)}
.value-card:hover .value-circle::before{inset:10px;border-color:rgba(255,255,255,.4)}
.value-card h3{font-family:var(--ff);font-size:1rem;font-weight:500;color:var(--heading);letter-spacing:.08em;margin-bottom:.85rem}
.value-card p{font-size:.78rem;line-height:2;color:var(--txt)}
.value-card .value-tag{font-family:var(--fe);font-size:.62rem;letter-spacing:.3em;color:var(--acc);text-transform:uppercase;display:block;margin-bottom:.6rem}
@media(max-width:768px){
  .values-rich{grid-template-columns:1fr}
  .values-rich::before{display:none}
  .value-card+.value-card{border-left:none;border-top:1px dashed rgba(201,169,110,.25)}
}

/* Company section with background photo */
.about-company{position:relative;overflow:hidden;isolation:isolate}
.about-company .company-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}
.about-company::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(248,247,243,.92) 0%,rgba(245,244,241,.85) 50%,rgba(255,255,255,.9) 100%);z-index:1;pointer-events:none}
.about-company > .container{position:relative;z-index:2}
.about-company > .vert-label,.about-company > .bg-letters{z-index:2}
.about-company .company-card{background:#fff;border:1px solid rgba(0,0,0,.06);padding:clamp(1.75rem,3.5vw,2.75rem);position:relative;box-shadow:0 30px 60px -30px rgba(17,17,17,.12)}
.about-company .company-card::before{content:'';position:absolute;top:0;left:0;width:60px;height:1px;background:var(--acc)}
.about-company .company-card::after{content:'';position:absolute;bottom:0;right:0;width:60px;height:1px;background:var(--acc)}
.about-company .company-table{width:100%;border-collapse:collapse}
.about-company .company-table tr{border-bottom:1px solid rgba(0,0,0,.06)}
.about-company .company-table tr:last-child{border-bottom:none}
.about-company .company-table th{padding:.85rem 1rem;font-weight:500;width:160px;font-size:.78rem;color:var(--heading);background:rgba(245,244,241,.6);text-align:left;letter-spacing:.08em;font-family:var(--ff)}
.about-company .company-table td{padding:.85rem 1rem;font-size:.82rem;line-height:1.8;color:var(--txt)}
@media(max-width:600px){.about-company .company-table th{width:110px;font-size:.72rem}.about-company .company-table td{font-size:.76rem}}

/* ===========================================
   Contact page — form section background photo
   =========================================== */
.contact-form-section{position:relative;isolation:isolate;overflow:hidden}
.contact-form-section .form-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0;pointer-events:none}
.contact-form-section::before{content:'';position:absolute;inset:0;background:linear-gradient(135deg,rgba(248,247,243,.95) 0%,rgba(245,244,241,.90) 60%,rgba(255,255,255,.95) 100%);z-index:1;pointer-events:none}
.contact-form-section > .container{position:relative;z-index:2}
.contact-form-section > .vert-label,.contact-form-section > .bg-letters{z-index:2}
.contact-form-section .contact-form-card{box-shadow:0 30px 60px -30px rgba(17,17,17,.18)}
.contact-form-section .cs-card{box-shadow:0 20px 40px -25px rgba(17,17,17,.12);background:rgba(255,255,255,.78);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px)}

/* ===========================================
   Voices page — band wrapping pull-quote + stats
   =========================================== */
.voice-band{position:relative;isolation:isolate;padding:clamp(3rem,5vw,4.5rem) 0;margin:clamp(2.5rem,4vw,3.5rem) 0;background:linear-gradient(180deg,rgba(248,247,243,.65) 0%,rgba(245,244,241,.45) 100%)}
.voice-band::before{content:'\201C';position:absolute;top:-.42em;left:50%;transform:translateX(-50%);font-family:var(--fe);font-size:clamp(14rem,28vw,24rem);line-height:1;color:rgba(201,169,110,.07);font-weight:400;pointer-events:none;z-index:0}
.voice-band::after{content:'';position:absolute;inset:0;background-image:radial-gradient(circle,rgba(201,169,110,.10) 1px,transparent 1.2px);background-size:24px 24px;opacity:.5;mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);-webkit-mask-image:radial-gradient(ellipse at center,#000 30%,transparent 75%);pointer-events:none;z-index:0}
.voice-band > *{position:relative;z-index:1}
.voice-band .voice-feature{margin:0 auto}
.voice-band .voice-feature::before{display:none}
.voice-band .voice-stats{margin:clamp(2rem,3vw,2.5rem) 0 0;background:transparent;border-top:1px solid rgba(0,0,0,.08);border-bottom:none}

/* ===========================================
   Services page — enriched layout
   =========================================== */
.svc-section{position:relative;isolation:isolate;overflow:hidden}
.svc-row{display:grid;grid-template-columns:1fr 1fr;gap:clamp(3rem,6vw,5rem);align-items:center;position:relative;z-index:1}
.svc-row.svc-row-flip{direction:rtl}
.svc-row.svc-row-flip > *{direction:ltr}
@media(max-width:768px){.svc-row{grid-template-columns:1fr}.svc-row.svc-row-flip{direction:ltr}}

.svc-info{position:relative}
.svc-info .svc-tag{font-family:var(--fe);font-size:.65rem;letter-spacing:.28em;color:var(--acc);text-transform:uppercase;display:flex;align-items:center;gap:.6rem;margin-bottom:.85rem;font-weight:400}
.svc-info .svc-tag::before{content:'';width:28px;height:1px;background:var(--acc)}
.svc-info h2{font-family:var(--ff);font-size:clamp(1.6rem,3vw,2.2rem);font-weight:400;letter-spacing:.08em;margin-bottom:1.25rem;line-height:1.6;color:var(--heading)}
.svc-info p{font-size:.86rem;line-height:2.3;margin-bottom:1rem;color:var(--txt)}

.svc-highlights{display:grid;grid-template-columns:repeat(3,1fr);gap:0;margin-top:1.75rem;padding:1.1rem 0;border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08)}
.svc-highlights .sh{padding:0 .9rem;border-right:1px dashed rgba(201,169,110,.3);text-align:center}
.svc-highlights .sh:last-child{border-right:none}
.svc-highlights .sh-l{font-family:var(--fe);font-size:.58rem;letter-spacing:.2em;color:var(--acc);text-transform:uppercase;margin-bottom:.4rem;display:block;font-weight:400}
.svc-highlights .sh-v{font-family:var(--ff);font-size:.82rem;font-weight:500;color:var(--heading);letter-spacing:.04em;line-height:1.5}
@media(max-width:600px){.svc-highlights{grid-template-columns:1fr;gap:.75rem;padding:1rem 0}.svc-highlights .sh{border-right:none;border-bottom:1px dashed rgba(201,169,110,.3);padding:0 0 .55rem 0}.svc-highlights .sh:last-child{border-bottom:none;padding:0}}

/* Layered photo on services */
.svc-photo-layered{position:relative;width:100%;max-width:580px;margin:0 auto}
.svc-photo-layered .svc-photo-main{position:relative;width:100%;aspect-ratio:4/3;overflow:hidden;background:var(--bg2);transition:transform .55s cubic-bezier(.22,1,.36,1),box-shadow .55s cubic-bezier(.22,1,.36,1);z-index:1}
.svc-photo-layered .svc-photo-main img{width:100%;height:100%;object-fit:cover;transition:transform .85s cubic-bezier(.22,1,.36,1)}
.svc-photo-layered:hover .svc-photo-main{transform:translateY(-6px);box-shadow:0 30px 50px -20px rgba(17,17,17,.20)}
.svc-photo-layered:hover .svc-photo-main img{transform:scale(1.05)}
.svc-photo-layered .svc-photo-tag{position:absolute;top:1rem;left:1rem;padding:.4rem .85rem;background:rgba(10,10,10,.5);backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px);color:#fff;font-family:var(--fe);font-size:.78rem;letter-spacing:.15em;z-index:2;font-weight:400}
.svc-photo-layered .svc-photo-frame{position:absolute;top:-14px;left:-14px;width:55%;height:55%;border:1px solid var(--acc);opacity:.45;z-index:0;pointer-events:none;transition:transform .6s cubic-bezier(.22,1,.36,1)}
.svc-photo-layered:hover .svc-photo-frame{transform:translate(-5px,-5px)}

/* ===========================================
   Services page — image hover lift (legacy class kept)
   =========================================== */
.svc-photo{position:relative;overflow:visible;perspective:1000px;cursor:pointer}
.svc-photo .svc-photo-inner{position:relative;overflow:hidden;transform:translateY(0);transition:transform .55s cubic-bezier(.22,1,.36,1),box-shadow .55s cubic-bezier(.22,1,.36,1)}
.svc-photo .svc-photo-inner img{display:block;transition:transform .8s cubic-bezier(.22,1,.36,1),filter .55s}
.svc-photo:hover .svc-photo-inner{transform:translateY(-8px);box-shadow:0 30px 50px -20px rgba(17,17,17,.18)}
.svc-photo:hover .svc-photo-inner img{transform:scale(1.04)}
.svc-photo .svc-photo-frame{position:absolute;inset:14px;border:1px solid var(--acc);opacity:0;transform:translate(-12px,-12px);transition:opacity .5s cubic-bezier(.22,1,.36,1),transform .5s cubic-bezier(.22,1,.36,1);z-index:2;pointer-events:none}
.svc-photo:hover .svc-photo-frame{opacity:.55;transform:translate(0,0)}
@media (prefers-reduced-motion:reduce){.svc-photo .svc-photo-inner,.svc-photo:hover .svc-photo-inner,.svc-photo .svc-photo-inner img,.svc-photo:hover .svc-photo-inner img,.svc-photo .svc-photo-frame{transition:none;transform:none}}

/* Stat block in philosophy text */
.phil-stat{display:flex;align-items:baseline;gap:.5rem;margin:1.75rem 0 .5rem;padding:1rem 0;border-top:1px solid rgba(0,0,0,.08);border-bottom:1px solid rgba(0,0,0,.08)}
.phil-stat-num{font-family:var(--fe);font-size:clamp(2rem,3.6vw,2.8rem);font-weight:400;color:var(--acc);line-height:1;font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums;letter-spacing:.02em}
.phil-stat-plus{font-family:var(--fe);font-size:clamp(1.4rem,2.4vw,1.8rem);font-weight:400;color:var(--acc);line-height:1;margin-left:-.15rem}
.phil-stat-label{font-size:.72rem;color:var(--txt);letter-spacing:.08em;margin-left:.85rem}


/* --- Services --- */
.svc-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0;margin-top:2.5rem;border:1px solid rgba(0,0,0,.06)}
.svc{padding:clamp(1.5rem,3vw,2.5rem);border-bottom:1px solid rgba(0,0,0,.06);border-right:1px solid rgba(0,0,0,.06);transition:background .4s}
.svc:hover{background:var(--bg2)}
.svc:nth-child(even){border-right:none}
/* 数字も文字も同じ動きで素早くフェードイン (より速め) */
.svc.fade-in{transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1)}
.svc-num,.svc h3,.svc p{opacity:0;transform:translateY(12px);transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1)}
.svc.visible .svc-num,.svc.visible h3,.svc.visible p{opacity:1;transform:none}
/* 内側スタガー: 数字→見出し→本文 (短め) */
.svc.visible .svc-num{transition-delay:0s}
.svc.visible h3{transition-delay:.06s}
.svc.visible p{transition-delay:.12s}
.svc.delay-1.visible .svc-num{transition-delay:.07s}
.svc.delay-1.visible h3{transition-delay:.13s}
.svc.delay-1.visible p{transition-delay:.19s}
.svc.delay-2.visible .svc-num{transition-delay:.14s}
.svc.delay-2.visible h3{transition-delay:.20s}
.svc.delay-2.visible p{transition-delay:.26s}
.svc.delay-3.visible .svc-num{transition-delay:.21s}
.svc.delay-3.visible h3{transition-delay:.27s}
.svc.delay-3.visible p{transition-delay:.33s}
.svc-num{font-family:var(--fe);font-size:2.5rem;font-weight:300;color:var(--color-accent);margin-bottom:.75rem;line-height:1}
.svc h3{font-family:var(--ff);font-size:1rem;font-weight:500;color:var(--heading);letter-spacing:.06em;margin-bottom:.5rem}
.svc p{font-size:.78rem;line-height:1.9}
@media(max-width:640px){.svc-grid{grid-template-columns:1fr}.svc{border-right:none}}

/* --- Numbers --- */
.nums-bar{display:grid;grid-template-columns:repeat(4,1fr);background:linear-gradient(180deg,#2a2622 0%,#22201d 100%);color:#fff;position:relative}
.nums-bar::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at center top,rgba(201,169,110,.08),transparent 65%);pointer-events:none}
.nb{padding:clamp(2rem,4vw,3rem);text-align:center;position:relative;z-index:1}
.nb+.nb::before{content:'';position:absolute;left:0;top:20%;height:60%;width:1px;background:rgba(255,255,255,.08)}
.nb-v{font-family:var(--fe);font-size:clamp(2rem,4vw,2.8rem);font-weight:400;color:var(--acc);letter-spacing:.04em;font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums;line-height:1.1}
.nb-l{font-size:.65rem;color:rgba(255,255,255,.7);margin-top:.5rem;letter-spacing:.12em;font-weight:400}
@media(max-width:640px){.nums-bar{grid-template-columns:repeat(2,1fr)}.nb:nth-child(2)::before{display:none}}

/* --- Process --- */
.process{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:2.5rem;counter-reset:step}
.step{padding:1.5rem;text-align:center;border-right:1px solid rgba(0,0,0,.06);counter-increment:step}
.step:last-child{border-right:none}
.step.fade-in{transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1)}
.step::before{content:counter(step,decimal-leading-zero);font-family:var(--fe);font-size:clamp(2.6rem,4.5vw,3.4rem);font-weight:400;color:var(--color-accent);display:block;margin-bottom:.85rem;opacity:0;transform:translateY(12px);transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1);letter-spacing:.02em;line-height:1;font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums}
.step.visible::before{opacity:1;transform:translateY(0)}
.step h4,.step p{opacity:0;transform:translateY(12px);transition:opacity .45s cubic-bezier(.22,1,.36,1),transform .45s cubic-bezier(.22,1,.36,1)}
.step.visible h4,.step.visible p{opacity:1;transform:none}
.step.visible h4{transition-delay:.06s}
.step.visible p{transition-delay:.12s}
.step.delay-1::before{transition-delay:.07s}
.step.delay-1.visible h4{transition-delay:.13s}
.step.delay-1.visible p{transition-delay:.19s}
.step.delay-2::before{transition-delay:.14s}
.step.delay-2.visible h4{transition-delay:.20s}
.step.delay-2.visible p{transition-delay:.26s}
.step.delay-3::before{transition-delay:.21s}
.step.delay-3.visible h4{transition-delay:.27s}
.step.delay-3.visible p{transition-delay:.33s}
.step h4{font-family:var(--ff);font-size:clamp(.95rem,1.4vw,1.1rem);font-weight:500;color:var(--heading);letter-spacing:.06em;margin-bottom:.5rem;line-height:1.5}
.step p{font-size:clamp(.78rem,1.05vw,.85rem);line-height:1.9;color:var(--txt)}
@media(max-width:768px){.process{grid-template-columns:repeat(2,1fr)}.step:nth-child(2){border-right:none}}

/* --- CTA --- */
.cta-build{background:var(--bg3);padding:clamp(3rem,5vw,4.5rem) 0;text-align:center;position:relative;overflow:hidden}
.cta-build::before{content:'';position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:240px;height:240px;border:1px solid rgba(201,169,110,.06);border-radius:50%}
.cta-build h2{font-family:var(--ff);color:#fff;font-size:clamp(1.3rem,2.6vw,1.8rem);font-weight:400;letter-spacing:.1em;margin-bottom:.55rem}
.cta-build p{color:rgba(255,255,255,.35);font-size:.78rem;margin-bottom:1.25rem;line-height:1.9}
.btn-cta{display:inline-flex;align-items:center;gap:.75rem;padding:.7rem 2.2rem;border:1px solid var(--acc);color:var(--acc);font-family:var(--fe);font-size:.78rem;letter-spacing:.15em;transition:all .3s}
.btn-cta:hover{background:var(--acc);color:var(--bg3);opacity:1}

/* Natural gold-tinted hover for outline button (override base.css) */
.btn-outline{transition:background .35s,color .35s,transform .35s,box-shadow .35s,border-color .35s}
.btn-outline:hover{background:rgba(201,169,110,.10);color:var(--acc);border-color:var(--acc);transform:translateY(-2px);box-shadow:0 10px 25px -12px rgba(201,169,110,.35)}
.btn-outline:hover::after{color:var(--acc)}

/* --- Contact Form --- */
.form-input,.form-textarea,.form-select{background:var(--bg2);border:1px solid rgba(0,0,0,.06)}
.form-input:focus,.form-textarea:focus,.form-select:focus{border-color:var(--acc)}

/* --- SCALE Badge --- */
.scale-badge{background:var(--bg3)}
.scale-badge-dot{background:var(--acc)}

/* --- Footer compact override (all pages) --- */
.footer{padding:clamp(1.75rem,3vw,2.5rem) 0 0 !important}
.footer .footer-grid{gap:clamp(1.5rem,2.5vw,2rem) clamp(1.5rem,3vw,2.5rem) !important;margin-bottom:clamp(1.25rem,2vw,1.75rem) !important}
.footer .footer-logo{font-size:1rem !important;margin-bottom:.6rem !important;font-weight:400}
.footer .footer-desc{font-size:.72rem !important;line-height:1.85;opacity:.55}
.footer .footer-heading{font-size:.65rem !important;margin-bottom:.85rem !important;letter-spacing:.18em}
.footer .footer-links li{margin-bottom:.45rem !important}
.footer .footer-links a{font-size:.72rem !important;opacity:.55}
.footer .footer-bottom{padding:.95rem 0 1rem !important;border-top:1px solid rgba(255,255,255,.06) !important;font-size:.65rem !important;opacity:.5;letter-spacing:.06em}

/* Page Header */
.page-header{background:var(--bg3);padding:calc(var(--hh) + 3rem) 0 3rem;color:#fff}
.page-header .section-label{color:var(--acc)}
.page-header .section-label::before{background:var(--acc)}
.page-header h1{font-family:'Noto Serif JP','Zen Old Mincho',serif;color:#fff;font-size:clamp(2rem,4vw,3rem);font-weight:200;letter-spacing:.14em}
.page-header .page-subtitle{font-family:var(--fe);font-size:.7rem;color:rgba(255,255,255,.3);letter-spacing:.2em;margin-top:.4rem}
.breadcrumb a{color:var(--acc)}

/* Slow fade-in variant for staggered text reveals */
.fade-slow{transition-duration:1.8s !important;transition-timing-function:cubic-bezier(.22,1,.36,1) !important}

/* Values grid (三つの約束) — quick fade */
.values-grid .fade-in{transition:opacity .28s cubic-bezier(.22,1,.36,1),transform .28s cubic-bezier(.22,1,.36,1)}

/* ===========================================
   Decorative layout enhancements (和モダン × アシンメトリ)
   =========================================== */
/* Section relative wrapper */
.deco-sec{position:relative;overflow:hidden}

/* Giant background watermark letters (English) */
.bg-letters{position:absolute;font-family:var(--fe);font-weight:300;letter-spacing:.04em;color:rgba(17,17,17,.018);pointer-events:none;user-select:none;z-index:0;line-height:.9;white-space:nowrap;text-transform:uppercase}
.bg-letters.bl-tr{top:8%;right:-3%;font-size:clamp(4.5rem,11vw,10rem)}
.bg-letters.bl-bl{bottom:4%;left:-3%;font-size:clamp(4rem,9vw,8.5rem)}
.bg-letters.bl-mid{top:50%;left:50%;transform:translate(-50%,-50%);font-size:clamp(5.5rem,14vw,12rem);color:rgba(17,17,17,.012)}
/* On dark backgrounds, lighten the watermark */
.deco-sec.on-dark .bg-letters{color:rgba(255,255,255,.025)}

/* Vertical English label (writing-mode rl) */
.vert-label{position:absolute;writing-mode:vertical-rl;font-family:var(--fe);font-size:.65rem;letter-spacing:.3em;color:var(--acc);text-transform:uppercase;display:flex;align-items:center;gap:.75rem;z-index:2;font-weight:400}
.vert-label::after{content:'';width:1px;height:50px;background:var(--acc);display:block}
.vert-label.vl-l{left:1.5rem;top:3rem}
.vert-label.vl-r{right:1.5rem;top:3rem}
@media(max-width:900px){.vert-label{display:none}}

/* Section number badge (small gold-bordered) */
.sec-num{font-family:var(--fe);font-size:.7rem;letter-spacing:.3em;color:var(--acc);display:inline-flex;align-items:center;gap:.6rem;font-weight:400}
.sec-num::before{content:'';width:24px;height:1px;background:var(--acc)}

/* Corner gold L-frame */
.corner-frame{position:absolute;width:60px;height:60px;border:1px solid var(--acc);opacity:.4;z-index:1;pointer-events:none}
.corner-frame.cf-tl{top:1.5rem;left:1.5rem;border-right:none;border-bottom:none}
.corner-frame.cf-br{bottom:1.5rem;right:1.5rem;border-left:none;border-top:none}

/* Ensure container content sits above watermarks */
.deco-sec > .container{position:relative;z-index:1}

/* Process gold connector line */
.process{position:relative}
.process::before{content:'';position:absolute;top:calc(1.5rem + 1.25rem);left:12.5%;right:12.5%;height:1px;background:linear-gradient(to right,transparent,var(--acc) 20%,var(--acc) 80%,transparent);opacity:.35;z-index:0;pointer-events:none}
.step{position:relative;z-index:1;background:transparent}
@media(max-width:768px){.process::before{display:none}}

/* Asymmetric heading offset for Philosophy text column */
.phil-text{position:relative}
.phil-text .sec-num{margin-bottom:1.25rem}

/* Subtle bleed for works grid (left edge) on desktop */
@media(min-width:1024px){
  .works-bleed-left .works-grid{margin-left:-3vw}
}

/* ===========================================
   Voices (お客様の声) — refined card design
   =========================================== */
.voice-intro{max-width:640px;margin:0 auto 4rem;text-align:center}
.voice-intro .sec-num{justify-content:center;margin-bottom:1rem}
.voice-intro h2{font-family:var(--ff);font-size:clamp(1.4rem,3vw,2.1rem);font-weight:400;letter-spacing:.08em;line-height:1.7;color:var(--heading);margin-bottom:1.25rem}
.voice-intro p{font-size:.85rem;line-height:2.2;color:var(--txt)}

.voice-grid{display:grid;grid-template-columns:1fr;gap:clamp(1.5rem,3vw,2.5rem)}
/* Softer, more natural fade-in for voice cards */
.voice-card.fade-in{opacity:0;transform:translateY(18px);transition:opacity 1.05s cubic-bezier(.22,1,.36,1),transform 1.05s cubic-bezier(.22,1,.36,1)}
.voice-card.fade-in.visible{opacity:1;transform:none}
.voice-card.fade-in .voice-img img{opacity:0;transform:scale(1.04);transition:opacity 1.2s cubic-bezier(.22,1,.36,1),transform 1.4s cubic-bezier(.22,1,.36,1)}
.voice-card.fade-in.visible .voice-img img{opacity:1;transform:scale(1);transition-delay:.1s}
.voice-card.fade-in .voice-tag,.voice-card.fade-in .voice-stars,.voice-card.fade-in h3,.voice-card.fade-in .voice-text,.voice-card.fade-in .voice-meta{opacity:0;transform:translateY(10px);transition:opacity .85s cubic-bezier(.22,1,.36,1),transform .85s cubic-bezier(.22,1,.36,1)}
.voice-card.fade-in.visible .voice-tag{opacity:1;transform:none;transition-delay:.18s}
.voice-card.fade-in.visible .voice-stars{opacity:1;transform:none;transition-delay:.24s}
.voice-card.fade-in.visible h3{opacity:1;transform:none;transition-delay:.30s}
.voice-card.fade-in.visible .voice-text{opacity:1;transform:none;transition-delay:.36s}
.voice-card.fade-in.visible .voice-meta{opacity:1;transform:none;transition-delay:.44s}
@media (prefers-reduced-motion:reduce){.voice-card.fade-in,.voice-card.fade-in *{transition:none !important;transform:none !important;opacity:1 !important}}
.voice-card{position:relative;display:grid;grid-template-columns:280px 1fr;gap:clamp(1.5rem,3vw,2.5rem);background:#fff;border:1px solid rgba(0,0,0,.06);overflow:hidden;transition:transform .5s cubic-bezier(.22,1,.36,1),box-shadow .5s}
.voice-card:hover{transform:translateY(-4px);box-shadow:0 30px 60px -30px rgba(17,17,17,.18)}
.voice-card::before{content:'\201C';position:absolute;top:-.4em;right:1.5rem;font-family:var(--fe);font-size:11rem;line-height:1;color:rgba(201,169,110,.10);font-weight:400;pointer-events:none;z-index:0}
.voice-img{position:relative;overflow:hidden;background:var(--bg2);min-height:260px}
.voice-img img{width:100%;height:100%;object-fit:cover;transition:transform .8s cubic-bezier(.22,1,.36,1)}
.voice-card:hover .voice-img img{transform:scale(1.06)}
.voice-img::after{content:'';position:absolute;inset:10px;border:1px solid rgba(201,169,110,.35);pointer-events:none}
.voice-body{padding:clamp(2rem,3vw,2.5rem) clamp(2rem,3vw,2.5rem) clamp(2rem,3vw,2.5rem) 0;position:relative;z-index:1;display:flex;flex-direction:column;justify-content:center}
.voice-tag{font-family:var(--fe);font-size:.65rem;letter-spacing:.25em;color:var(--acc);text-transform:uppercase;margin-bottom:.85rem;display:flex;align-items:center;gap:.6rem}
.voice-tag::before{content:'';width:24px;height:1px;background:var(--acc)}
.voice-stars{display:inline-flex;gap:.15rem;color:var(--acc);font-size:.7rem;letter-spacing:.15em;margin-bottom:.85rem}
.voice-card h3{font-family:var(--ff);font-size:clamp(1rem,1.6vw,1.2rem);font-weight:500;color:var(--heading);letter-spacing:.05em;line-height:1.7;margin-bottom:1rem}
.voice-card .voice-text{font-size:.82rem;line-height:2.2;margin-bottom:1.25rem;color:#555}
.voice-meta{display:flex;flex-wrap:wrap;gap:.5rem 1.25rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.06);font-size:.7rem;color:var(--txt);letter-spacing:.06em}
.voice-meta span{display:inline-flex;align-items:center;gap:.4rem}
.voice-meta span::before{content:'';width:4px;height:4px;background:var(--acc);border-radius:50%;display:inline-block;opacity:.6}
@media(max-width:768px){
  .voice-card{grid-template-columns:1fr}
  .voice-img{min-height:220px;aspect-ratio:16/9}
  .voice-body{padding:0 1.5rem 1.75rem}
  .voice-card::before{font-size:7rem;top:.2em}
}

/* ===========================================
   Contact (お問い合わせ) — refined layout
   =========================================== */
.contact-channels{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border:1px solid rgba(0,0,0,.06);margin-top:2.5rem}
.cc{padding:clamp(1.75rem,3vw,2.5rem);text-align:center;border-right:1px solid rgba(0,0,0,.06);position:relative;transition:background .4s}
.cc:last-child{border-right:none}
.cc:hover{background:var(--bg2)}
.cc-icon{font-family:var(--fe);font-size:1.6rem;color:var(--acc);letter-spacing:.18em;margin-bottom:.75rem;font-weight:300;display:flex;align-items:center;justify-content:center;gap:.4rem}
.cc-icon::before,.cc-icon::after{content:'';width:18px;height:1px;background:var(--acc);opacity:.5}
.cc-label{font-size:.65rem;letter-spacing:.2em;color:var(--txt);text-transform:uppercase;margin-bottom:.6rem}
.cc h3{font-family:var(--fe);font-size:1.6rem;font-weight:400;color:var(--heading);letter-spacing:.04em;margin-bottom:.4rem;font-feature-settings:"lnum" 1,"tnum" 1;font-variant-numeric:lining-nums tabular-nums}
.cc-en{font-family:var(--fe);font-size:1.6rem;font-weight:300;color:var(--heading);letter-spacing:.05em;margin-bottom:.4rem}
.cc-note{font-size:.65rem;color:var(--txt);line-height:1.7;letter-spacing:.04em}
@media(max-width:768px){
  .contact-channels{grid-template-columns:1fr}
  .cc{border-right:none;border-bottom:1px solid rgba(0,0,0,.06)}
  .cc:last-child{border-bottom:none}
}

/* Flow steps */
.flow-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:0;margin-top:1rem;position:relative;counter-reset:flow}
.flow-steps::before{content:'';position:absolute;top:clamp(44px,4.5vw,54px);left:12.5%;right:12.5%;height:1px;background:linear-gradient(to right,transparent,rgba(201,169,110,.5) 15%,rgba(201,169,110,.5) 85%,transparent);z-index:0}
.fs{padding:0 .5rem;text-align:center;counter-increment:flow;position:relative;z-index:1}
.fs-circle{width:clamp(88px,9vw,108px);height:clamp(88px,9vw,108px);border:1px solid rgba(201,169,110,.45);background:#fff;border-radius:50%;margin:0 auto 1.1rem;display:flex;align-items:center;justify-content:center;font-family:var(--fe);font-size:clamp(1.6rem,2.2vw,1.95rem);color:var(--acc);font-weight:400;letter-spacing:.05em;position:relative;transition:all .4s;box-shadow:0 8px 20px -16px rgba(201,169,110,.45);font-feature-settings:"lnum" 1,"tnum" 1}
.fs-circle::before{content:counter(flow,decimal-leading-zero)}
.fs:hover .fs-circle{background:var(--acc);color:#fff;border-color:var(--acc);transform:scale(1.06)}
.fs h4{font-family:var(--ff);font-size:.82rem;font-weight:500;color:var(--heading);letter-spacing:.06em;margin-bottom:.35rem}
.fs p{font-size:.68rem;line-height:1.7;color:var(--txt)}
@media(max-width:768px){
  .flow-steps{grid-template-columns:repeat(2,1fr);gap:1.5rem 0}
  .flow-steps::before{display:none}
}

/* Refined form (used on contact page) */
.contact-form-wrap{display:grid;grid-template-columns:1.3fr 1fr;gap:clamp(2rem,4vw,4rem);align-items:start}
.contact-form-card{background:#fff;border:1px solid rgba(0,0,0,.08);padding:clamp(2rem,3.5vw,3rem);position:relative}
.contact-form-card::before{content:'';position:absolute;top:0;left:0;width:60px;height:1px;background:var(--acc)}
.contact-form-card h2{font-family:var(--ff);font-size:1.2rem;font-weight:500;letter-spacing:.06em;color:var(--heading);margin-bottom:.4rem}
.contact-form-card .form-lead{font-size:.74rem;color:var(--txt);margin-bottom:1.75rem;letter-spacing:.04em}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}
.cf{margin-bottom:1.1rem;position:relative}
.cf label{display:block;font-size:.7rem;font-weight:500;letter-spacing:.08em;color:var(--heading);margin-bottom:.4rem}
.cf label .req{color:var(--acc);font-size:.6rem;margin-left:.3rem;letter-spacing:.1em}
.cf input,.cf select,.cf textarea{width:100%;padding:.8rem .9rem;border:1px solid rgba(0,0,0,.12);background:#fff;font-size:.82rem;font-family:var(--fb);color:var(--heading);transition:border-color .3s,background .3s,box-shadow .3s;outline:none}
.cf input:focus,.cf select:focus,.cf textarea:focus{border-color:var(--acc);background:#fffefa;box-shadow:0 0 0 3px rgba(201,169,110,.08)}
.cf textarea{height:130px;resize:vertical;line-height:1.8}
.btn-submit{width:100%;padding:1rem 1.25rem;background:var(--heading);color:#fff;border:none;font-size:.78rem;font-weight:500;letter-spacing:.2em;cursor:pointer;font-family:var(--ff);transition:all .35s;position:relative;overflow:hidden;margin-top:.5rem}
.btn-submit::after{content:'\2192';position:absolute;right:1.4rem;top:50%;transform:translateY(-50%);transition:transform .35s}
.btn-submit:hover{background:var(--acc);letter-spacing:.25em}
.btn-submit:hover::after{transform:translate(4px,-50%)}

.contact-side{display:flex;flex-direction:column;gap:1rem}
.cs-card{background:var(--bg2);padding:1.5rem;position:relative;border-left:2px solid var(--acc);transition:background .35s}
.cs-card:hover{background:#efeee9}
.cs-card .cs-tag{font-family:var(--fe);font-size:.6rem;letter-spacing:.25em;color:var(--acc);text-transform:uppercase;margin-bottom:.5rem}
.cs-card h3{font-family:var(--ff);font-size:.95rem;font-weight:500;letter-spacing:.06em;color:var(--heading);margin-bottom:.55rem}
.cs-card p{font-size:.74rem;line-height:1.95;color:var(--txt)}
@media(max-width:900px){.contact-form-wrap{grid-template-columns:1fr}.cf-row{grid-template-columns:1fr}}

