:root{
  --cream:#F4F1EC;--cream2:#EAE6DF;--grn:#1E3528;--grn2:#2A4A38;
  --slv:#6B7280;--slv2:#9AA3AE;--slv3:#C8CDD3;
  --white:#FFFFFF;--dust:#6E6861;--dust2:#A09890;
  --border:rgba(30,53,40,.08);
  --serif:'Playfair Display',Georgia,serif;--sans:'Outfit',sans-serif;
  --nav-h:68px;--ease:cubic-bezier(.4,0,.2,1);--max:940px;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--cream);color:var(--grn);-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
img{display:block;max-width:100%}

@keyframes fadeUp{from{opacity:0;transform:translateY(24px)}to{opacity:1;transform:none}}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@keyframes pulse{0%,100%{transform:scale(1)}50%{transform:scale(1.15)}}
.reveal{opacity:0;transform:translateY(22px);transition:opacity .8s var(--ease),transform .8s var(--ease);pointer-events:none}
.reveal.on{opacity:1;transform:none;pointer-events:auto}
.d1{transition-delay:.12s}.d2{transition-delay:.24s}.d3{transition-delay:.36s}

/* NAV */
nav{position:fixed;top:0;left:0;right:0;z-index:300;display:flex;align-items:center;justify-content:space-between;padding:0 52px;height:var(--nav-h);transition:height .4s var(--ease),background .4s,box-shadow .4s}
nav.scrolled{height:56px;background:rgba(244,241,236,.96);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);box-shadow:0 1px 0 var(--border)}
.nav-logo{font-family:var(--serif);font-size:1.05rem;letter-spacing:.06em;color:var(--grn);flex-shrink:0;transition:opacity .3s}
.nav-logo:hover{opacity:.6}
.nav-logo span{font-style:italic}
.nav-links{display:flex;gap:34px;align-items:center}
.nav-links a{font-size:.62rem;font-weight:500;letter-spacing:.17em;text-transform:uppercase;color:var(--dust);transition:color .25s;position:relative}
.nav-links a:not(.nav-cta)::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:var(--slv2);transition:width .32s var(--ease)}
.nav-links a:not(.nav-cta):hover{color:var(--grn)}
.nav-links a:not(.nav-cta):hover::after{width:100%}
.nav-cta{font-size:.61rem!important;letter-spacing:.16em!important;color:var(--white)!important;background:var(--grn);padding:9px 20px;border:1px solid var(--grn);transition:background .3s!important;border-radius:1px}
.nav-cta:hover{background:var(--grn2)!important}
.burger{display:none;flex-direction:column;gap:5px;background:none;border:none;cursor:pointer;padding:8px;-webkit-tap-highlight-color:transparent}
.burger span{width:22px;height:1.5px;background:var(--grn);display:block;transition:all .3s}
.burger.open span:nth-child(1){transform:rotate(45deg) translate(4px,5px)}
.burger.open span:nth-child(2){opacity:0}
.burger.open span:nth-child(3){transform:rotate(-45deg) translate(4px,-5px)}
.mob{display:none;position:fixed;inset:0;z-index:290;background:var(--cream);flex-direction:column;justify-content:center;align-items:center;gap:10px;padding:24px}
.mob.open{display:flex}
.mob a{font-family:var(--serif);font-size:1.7rem;font-style:italic;color:var(--grn);transition:color .2s;padding:6px 0;-webkit-tap-highlight-color:transparent}
.mob a:hover,.mob a:active{color:var(--slv)}
.mob .mob-cta{margin-top:14px;font-family:var(--sans)!important;font-size:.7rem!important;font-style:normal!important;letter-spacing:.18em;text-transform:uppercase;background:var(--grn);color:var(--white)!important;padding:14px 36px;border-radius:1px}

/* HERO */
.hero{min-height:100vh;padding-top:var(--nav-h);display:flex;flex-direction:column;position:relative;overflow:hidden;background:var(--cream)}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 65% 50% at 12% 20%,rgba(30,53,40,.04) 0%,transparent 55%),radial-gradient(ellipse 55% 60% at 88% 75%,rgba(107,114,128,.03) 0%,transparent 55%)}
.hero-wm{position:absolute;right:-2vw;top:46%;transform:translateY(-50%);font-family:var(--serif);font-size:clamp(12rem,26vw,38rem);font-weight:500;font-style:italic;color:transparent;-webkit-text-stroke:1px rgba(30,53,40,.04);line-height:1;pointer-events:none;user-select:none}
.hero-top{text-align:center;padding:88px 24px 40px;animation:fadeUp .9s .1s both;position:relative;z-index:2}
.hero-eyebrow{display:inline-flex;align-items:center;gap:14px;font-size:.56rem;font-weight:500;letter-spacing:.36em;text-transform:uppercase;color:var(--slv);margin-bottom:24px}
.eyebrow-line{width:24px;height:1px;background:var(--slv2);opacity:.6}
.hero-h{font-family:var(--serif);font-size:clamp(1.9rem,5.2vw,3.4rem);font-weight:400;line-height:1.25;color:var(--grn);margin-bottom:22px}
.hero-h em{font-style:italic;color:var(--slv)}
.hero-sub{font-size:.84rem;line-height:2;color:var(--dust);max-width:520px;margin:0 auto 32px}
.hero-ctas{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-dark{display:inline-flex;align-items:center;font-size:.62rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;background:var(--grn);color:var(--white);padding:14px 32px;border:1px solid var(--grn);transition:background .3s;border-radius:1px;-webkit-tap-highlight-color:transparent}
.btn-dark:hover,.btn-dark:active{background:var(--grn2)}
.btn-ghost{display:inline-flex;align-items:center;font-size:.62rem;font-weight:500;letter-spacing:.17em;text-transform:uppercase;color:var(--grn);padding:14px 32px;border:1px solid rgba(30,53,40,.2);transition:border-color .3s,color .3s;border-radius:1px;-webkit-tap-highlight-color:transparent}
.btn-ghost:hover,.btn-ghost:active{border-color:var(--slv2);color:var(--slv)}

/* SERVICE PANELS */
.panels{display:flex;gap:1px;background:rgba(30,53,40,.07);margin:32px 24px 0;flex:1;animation:fadeUp .9s .45s both;position:relative;z-index:2;min-height:260px}
.panel{flex:1;background:var(--cream);padding:28px 22px;cursor:pointer;display:flex;flex-direction:column;transition:flex .7s cubic-bezier(.25,.46,.45,.94),background .3s;position:relative;overflow:hidden}
.panel::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--slv2);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease)}
.panel:hover::after,.panel.active::after{transform:scaleX(1)}
.panel:hover{background:var(--white)}
.panel.active{flex:3.8;background:var(--grn);cursor:default}
.panel.active:hover{background:var(--grn)}
.panel.active::after{background:var(--slv3)}
.p-num{font-family:var(--serif);font-size:3.4rem;font-weight:400;color:var(--slv2);opacity:.45;line-height:1;margin-bottom:auto;transition:font-size .5s,opacity .4s}
.panel.active .p-num{font-size:2rem;opacity:.25;color:var(--slv3)}
.p-title{font-family:var(--serif);font-size:.97rem;line-height:1.3;margin-bottom:8px;color:var(--grn);transition:font-size .4s,color .3s}
.panel.active .p-title{font-size:1.35rem;color:var(--white);margin-bottom:14px}
.p-hint{font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;color:var(--dust2);display:flex;align-items:center;gap:7px}
.p-arr{display:inline-block;width:12px;height:1px;background:var(--slv2);position:relative;transition:width .3s}
.p-arr::after{content:'';position:absolute;right:0;top:-3px;border:3px solid transparent;border-left:4px solid var(--slv2)}
.panel:hover .p-arr{width:20px}
.panel.active .p-hint{display:none}
.p-body{max-height:0;opacity:0;overflow:hidden;transition:max-height .75s cubic-bezier(.25,.46,.45,.94),opacity .4s .1s}
.panel.active .p-body{max-height:900px;opacity:1}
.p-desc{font-size:.78rem;line-height:2;color:rgba(255,255,255,.52);margin-bottom:16px;max-width:420px}
.p-tags{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:18px}
.p-tag{font-size:.5rem;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border:1px solid rgba(200,205,211,.2);color:var(--slv3)}
.p-tl{margin-bottom:18px}
.p-tl-line{height:1px;background:linear-gradient(to right,rgba(200,205,211,.35),rgba(200,205,211,.03))}
.p-tl-steps{display:flex;flex-wrap:wrap}
.p-tl-step{flex:1;min-width:0;padding-top:13px;text-align:center;position:relative;padding-bottom:4px}
.p-tl-dot{width:7px;height:7px;border-radius:50%;border:1px solid rgba(200,205,211,.4);background:var(--grn);position:absolute;top:-4px;left:50%;transform:translateX(-50%);z-index:1}
.p-tl-dot::after{content:'';width:3px;height:3px;background:var(--slv3);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.p-tl-name{font-size:.48rem;line-height:1.4;color:rgba(255,255,255,.55);padding:0 2px}
.p-tl-days{font-size:.43rem;color:var(--slv3);margin-top:3px;font-weight:600;letter-spacing:.06em;opacity:.7}
.p-cta{display:inline-flex;align-items:center;gap:8px;font-size:.58rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--slv3);transition:gap .3s,color .25s;cursor:pointer;-webkit-tap-highlight-color:transparent}
.p-cta:hover,.p-cta:active{gap:14px;color:var(--white)}
.p-cta-line{width:18px;height:1px;background:var(--slv3);transition:width .3s}
.p-cta:hover .p-cta-line{width:28px}
.p-close{position:absolute;top:12px;right:12px;width:28px;height:28px;border:1px solid rgba(255,255,255,.12);background:none;color:rgba(255,255,255,.38);font-size:.85rem;cursor:pointer;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s;-webkit-tap-highlight-color:transparent}
.panel.active .p-close{opacity:1;pointer-events:auto}
.p-close:hover{color:rgba(255,255,255,.8);background:rgba(255,255,255,.07)}
.panel-consult.active{background:var(--grn2)}
.panel-consult.active:hover{background:var(--grn2)}
.consult-form{display:flex;flex-direction:column;gap:10px;margin-top:12px}
.consult-label{font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(255,255,255,.42);margin-bottom:2px}
.consult-textarea{background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.13);color:var(--white);font-family:var(--sans);font-size:.76rem;line-height:1.7;padding:12px 14px;resize:none;min-height:84px;outline:none;transition:border-color .25s}
.consult-textarea::placeholder{color:rgba(255,255,255,.22)}
.consult-textarea:focus{border-color:rgba(200,205,211,.3)}
.consult-send{display:inline-flex;align-items:center;justify-content:center;font-size:.59rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;background:var(--white);color:var(--grn);padding:10px 22px;border:none;cursor:pointer;transition:opacity .3s;align-self:flex-start;border-radius:1px;-webkit-tap-highlight-color:transparent}
.consult-send:hover,.consult-send:active{opacity:.8}

/* MARQUEE */
.marquee-wrap{overflow:hidden;border-top:1px solid var(--border);background:rgba(244,241,236,.86);backdrop-filter:blur(14px);margin-top:24px;animation:fadeUp .9s .8s both;position:relative;z-index:2}
.marquee-track{display:flex;width:max-content;animation:marq 36s linear infinite}
.marquee-track:hover{animation-play-state:paused}
.mq-row{display:flex;align-items:center;padding:13px 0;flex-shrink:0}
.mq-item{font-size:.52rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--dust);padding:0 14px;white-space:nowrap}
.mq-dot{width:3px;height:3px;background:var(--slv2);border-radius:50%;opacity:.5;margin:0 5px}

/* VALUE STRIP */
.value-strip{background:var(--grn);padding:72px 24px}
.value-inner{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.07)}
.val-box{background:var(--grn);padding:44px 28px;text-align:center;transition:background .3s}
.val-box:hover{background:rgba(255,255,255,.04)}
.val-icon{font-size:1.2rem;color:var(--slv3);opacity:.4;margin-bottom:16px}
.val-title{font-family:var(--serif);font-size:1.1rem;color:var(--white);margin-bottom:12px}
.val-desc{font-size:.74rem;line-height:1.9;color:rgba(255,255,255,.42);max-width:200px;margin:0 auto}

/* INTRO */
.intro-sec{padding:96px 24px;display:flex;justify-content:center}
.intro-in{max-width:820px;text-align:center;width:100%}
.intro-q{font-family:var(--serif);font-style:italic;font-size:clamp(1.25rem,2.8vw,1.9rem);line-height:1.65;color:var(--grn);margin-bottom:36px}
.pillars{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.pillar{background:var(--cream);padding:32px 24px;transition:background .25s;text-align:left}
.pillar:hover{background:var(--white)}
.pillar-icon{font-size:1.2rem;color:var(--slv2);opacity:.6;margin-bottom:12px}
.pillar-title{font-family:var(--serif);font-size:.95rem;color:var(--grn);margin-bottom:10px}
.pillar-desc{font-size:.73rem;line-height:1.85;color:var(--dust)}

/* CTA STRIPS */
.cta-strip{padding:80px 24px;text-align:center}
.cta-strip.light{background:var(--cream2)}
.cta-strip.dark{background:var(--grn)}
.cta-inner{max-width:600px;margin:0 auto}
.cta-strip h2{font-family:var(--serif);font-size:clamp(1.5rem,3vw,2.2rem);font-weight:400;line-height:1.3;margin-bottom:16px}
.cta-strip.light h2{color:var(--grn)}
.cta-strip.dark h2{color:var(--white)}
.cta-strip h2 em{font-style:italic;color:var(--slv)}
.cta-strip.dark h2 em{color:var(--slv3)}
.cta-strip p{font-size:.82rem;line-height:2;margin-bottom:30px}
.cta-strip.light p{color:var(--dust)}
.cta-strip.dark p{color:rgba(255,255,255,.48)}
.cta-btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}
.btn-light{display:inline-flex;align-items:center;font-size:.62rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;background:var(--white);color:var(--grn);padding:14px 30px;border:1px solid var(--white);transition:opacity .3s;border-radius:1px;-webkit-tap-highlight-color:transparent}
.btn-light:hover{opacity:.82}
.btn-ghost-light{display:inline-flex;align-items:center;font-size:.62rem;font-weight:500;letter-spacing:.17em;text-transform:uppercase;color:rgba(255,255,255,.7);padding:14px 30px;border:1px solid rgba(255,255,255,.22);transition:border-color .3s,color .3s;border-radius:1px;-webkit-tap-highlight-color:transparent}
.btn-ghost-light:hover{border-color:rgba(255,255,255,.5);color:var(--white)}

/* SECTION HEADERS */
.sec-eye{font-size:.56rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--slv);text-align:center;margin-bottom:12px;display:flex;align-items:center;justify-content:center;gap:14px}
.sec-eye.on-dark{color:var(--slv3)}
.sec-eye::before,.sec-eye::after{content:'';width:20px;height:1px;background:currentColor;opacity:.4}
.sec-h{font-family:var(--serif);font-size:clamp(1.7rem,4vw,2.8rem);font-weight:400;text-align:center;line-height:1.2;margin-bottom:64px}
.sec-h.light{color:var(--white)}
.sec-h.dark{color:var(--grn)}
.sec-h em{font-style:italic;color:var(--slv)}
.sec-h.light em{color:var(--slv3)}

/* IDENTITY */
.identity-sec{background:var(--grn);padding:96px 24px;color:var(--white)}
.identity-inner{max-width:var(--max);margin:0 auto}
.id-grid{display:grid;grid-template-columns:1.2fr 1fr;gap:64px;align-items:start;margin-top:52px}
.id-h{font-family:var(--serif);font-size:clamp(1.4rem,2.8vw,2rem);line-height:1.3;margin-bottom:18px;font-weight:400}
.id-h em{font-style:italic;color:var(--slv3)}
.id-p{font-size:.81rem;line-height:2;color:rgba(255,255,255,.5);margin-bottom:14px}
.id-photo-col{display:flex;flex-direction:column;gap:12px;padding-top:4px}
.id-photo-box{width:72%;margin:0 auto;aspect-ratio:3/4;background:var(--grn2);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:4rem;font-style:italic;color:rgba(200,205,211,.15);border:1px solid rgba(255,255,255,.07)}
.id-stats{display:flex;gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06)}
.id-stat{flex:1;background:var(--grn);padding:18px 10px;text-align:center;transition:background .25s}
.id-stat:hover{background:rgba(255,255,255,.04)}
.id-stat-n{font-family:var(--serif);font-size:1.5rem;font-weight:400;color:var(--slv3);line-height:1;margin-bottom:4px}
.id-stat-l{font-size:.47rem;letter-spacing:.13em;text-transform:uppercase;color:rgba(255,255,255,.3);line-height:1.5}

/* PROCESS */
.process-sec{background:var(--grn2);color:var(--white);padding:96px 24px 80px}
.svc-list{max-width:var(--max);margin:0 auto}
.svc{border-top:1px solid rgba(255,255,255,.07);position:relative;overflow:hidden}
.svc:last-child{border-bottom:1px solid rgba(255,255,255,.07)}
.svc-trigger{width:100%;background:none;border:none;color:inherit;cursor:pointer;padding:36px 0;display:grid;grid-template-columns:72px 1fr auto;gap:24px;align-items:center;text-align:left;-webkit-tap-highlight-color:transparent;transition:opacity .25s}
.svc-trigger:hover{opacity:.85}
.svc-num{font-family:var(--serif);font-size:3.2rem;color:var(--slv3);opacity:.4;line-height:1;transition:opacity .3s}
.svc.open .svc-num{opacity:.6}
.svc-name-wrap{}
.svc-name{font-family:var(--serif);font-size:clamp(1.15rem,2.4vw,1.55rem);color:var(--white);line-height:1.25}
.svc-name-sub{font-size:.73rem;color:rgba(255,255,255,.42);line-height:1.7;margin-top:6px;max-width:520px}
.svc-arrow{width:32px;height:32px;border:1px solid rgba(255,255,255,.15);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:transform .4s var(--ease),background .25s}
.svc-arrow svg{width:12px;height:12px;stroke:var(--slv3);fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.svc.open .svc-arrow{transform:rotate(180deg);background:rgba(255,255,255,.06)}
.svc-body{max-height:0;overflow:hidden;transition:max-height .6s cubic-bezier(.25,.46,.45,.94)}
.svc.open .svc-body{max-height:600px}
.svc-body-in{padding:0 0 36px 96px}
.svc-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}
.svc-tag{font-size:.5rem;letter-spacing:.08em;text-transform:uppercase;padding:4px 9px;border:1px solid rgba(200,205,211,.15);color:rgba(200,205,211,.6)}
.tl{margin-bottom:24px}
.tl-line{height:1px;background:linear-gradient(to right,var(--slv2),rgba(154,163,174,.06))}
.tl-steps{display:flex;flex-wrap:wrap}
.tl-step{flex:1;min-width:0;padding-top:16px;text-align:center;position:relative}
.tl-dot{width:9px;height:9px;border-radius:50%;border:1px solid var(--slv2);background:var(--grn2);position:absolute;top:-5px;left:50%;transform:translateX(-50%);z-index:1}
.tl-dot::after{content:'';width:3px;height:3px;background:var(--slv3);border-radius:50%;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%)}
.tl-name{font-size:.53rem;line-height:1.5;color:rgba(255,255,255,.55);margin-bottom:4px;padding:0 2px}
.tl-days{font-size:.46rem;font-weight:600;letter-spacing:.08em;color:var(--slv2);opacity:.8}
.svc-cta{display:inline-flex;align-items:center;gap:9px;font-size:.58rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--slv3);cursor:pointer;transition:gap .3s,color .25s;-webkit-tap-highlight-color:transparent}
.svc-cta:hover,.svc-cta:active{gap:14px;color:var(--white)}
.svc-cta-line{width:18px;height:1px;background:var(--slv2);transition:width .3s}
.svc-cta:hover .svc-cta-line{width:30px}

/* B2B SECTION */
.b2b-sec{padding:96px 24px;background:var(--cream2)}
.b2b-inner{max-width:1100px;margin:0 auto}
.b2b-intro{max-width:800px;margin:0 auto 48px;text-align:center}
.b2b-lead{font-size:.84rem;line-height:2;color:var(--dust);margin-bottom:20px}
.b2b-tags{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}
.b2b-tags span{font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv);border:1px solid var(--border);background:var(--cream);padding:7px 11px}
.b2b-index{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:64px}
.b2b-index-item{background:var(--cream);padding:24px 22px;transition:background .25s var(--ease);display:block}
.b2b-index-item:hover{background:var(--white)}
.b2b-index-item strong{display:block;font-family:var(--serif);font-size:1rem;font-weight:400;color:var(--grn);margin-bottom:7px}
.b2b-index-item span{display:block;font-size:.7rem;line-height:1.7;color:var(--dust)}
.b2b-block{margin-bottom:72px;scroll-margin-top:80px}
.b2b-block-head{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:end;margin-bottom:20px}
.b2b-kicker{font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;color:var(--slv);margin-bottom:10px}
.b2b-block-head h3{font-family:var(--serif);font-size:clamp(1.3rem,2.3vw,1.9rem);font-weight:400;line-height:1.3;color:var(--grn)}
.b2b-block-head p{font-size:.79rem;line-height:1.95;color:var(--dust);margin-top:10px;max-width:760px}
.b2b-head-cta{align-self:start;white-space:nowrap;font-size:.58rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--white);background:var(--grn);padding:12px 18px;border:1px solid var(--grn);transition:background .25s var(--ease);flex-shrink:0}
.b2b-head-cta:hover{background:var(--grn2)}
.b2b-subcats{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:24px}
.b2b-subcats span{font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv);background:var(--cream);border:1px solid var(--border);padding:6px 10px}
.b2b-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.b2b-card{background:var(--cream);display:flex;flex-direction:column;transition:background .25s var(--ease)}
.b2b-card:hover{background:var(--white)}
.b2b-card-media{aspect-ratio:4/3;background:linear-gradient(135deg,#ede8e0,#e2dbd0);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:2.4rem;color:var(--slv2);opacity:.7;border-bottom:1px solid var(--border)}
.b2b-card-body{padding:22px 20px 24px;flex:1;display:flex;flex-direction:column}
.b2b-card-cat{font-size:.5rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv);margin-bottom:8px}
.b2b-card h4{font-family:var(--serif);font-size:1rem;font-weight:400;line-height:1.35;color:var(--grn);margin-bottom:10px}
.b2b-card p{font-size:.74rem;line-height:1.85;color:var(--dust);margin-bottom:12px}
.b2b-card ul{list-style:none;display:flex;flex-direction:column;gap:6px;margin-bottom:16px;flex:1}
.b2b-card li{position:relative;padding-left:12px;font-size:.68rem;line-height:1.65;color:var(--dust)}
.b2b-card li::before{content:'';position:absolute;left:0;top:9px;width:4px;height:1px;background:var(--slv2)}
.b2b-card-link{display:inline-flex;align-items:center;gap:8px;font-size:.56rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;color:var(--grn);margin-top:auto}
.b2b-card-link::after{content:'';width:18px;height:1px;background:currentColor;transition:width .25s var(--ease)}
.b2b-card-link:hover::after{width:28px}
.b2b-details{margin-top:80px;padding:44px;background:var(--cream);border:1px solid var(--border)}
.b2b-details-title{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:400;text-align:center;color:var(--grn);margin-bottom:28px}
.b2b-details-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.b2b-detail{background:var(--cream);padding:24px 20px}
.b2b-detail h4{font-family:var(--serif);font-size:.96rem;font-weight:400;color:var(--grn);margin-bottom:10px}
.b2b-detail p{font-size:.73rem;line-height:1.85;color:var(--dust)}
.b2b-target{margin-top:64px;background:var(--grn);padding:40px;display:grid;grid-template-columns:1.2fr .8fr;gap:30px;align-items:center}
.b2b-target h3{font-family:var(--serif);font-size:clamp(1.3rem,2.3vw,2rem);font-weight:400;color:var(--white);line-height:1.3;margin-bottom:10px}
.b2b-target p{font-size:.79rem;line-height:1.95;color:rgba(255,255,255,.52)}
.b2b-target-points{display:flex;flex-wrap:wrap;gap:8px}
.b2b-target-points span{font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv3);padding:8px 10px;border:1px solid rgba(255,255,255,.15)}
.b2b-final{margin-top:64px;padding:38px 40px;display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center;border:1px solid var(--border);background:var(--cream)}
.b2b-final h3{font-family:var(--serif);font-size:clamp(1.3rem,2.2vw,1.9rem);font-weight:400;line-height:1.3;color:var(--grn);margin-bottom:10px}
.b2b-final p{font-size:.79rem;line-height:1.9;color:var(--dust);max-width:700px}

/* MARKETS */
.market-sec{background:var(--grn);color:var(--white);padding:96px 24px}
.market-inner{max-width:var(--max);margin:0 auto}
.market-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.06);margin-top:52px}
.mkt-card{background:var(--grn);padding:40px 30px;transition:background .25s;position:relative}
.mkt-card::after{content:'';position:absolute;bottom:0;left:30px;right:30px;height:1px;background:var(--slv2);opacity:0;transition:opacity .35s}
.mkt-card:hover{background:rgba(255,255,255,.03)}
.mkt-card:hover::after{opacity:.4}
.mkt-region{font-size:.52rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--slv3);opacity:.55;margin-bottom:12px}
.mkt-title{font-family:var(--serif);font-size:1.15rem;color:var(--white);margin-bottom:12px}
.mkt-desc{font-size:.74rem;line-height:1.95;color:rgba(255,255,255,.4)}

/* CONTACT */
.contact-sec{padding:104px 24px;text-align:center;background:var(--cream);position:relative;overflow:hidden}
.contact-sec::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 70% 60% at 50% 50%,rgba(107,114,128,.04) 0%,transparent 65%)}
.contact-inner{max-width:540px;margin:0 auto;position:relative}
.contact-p{font-size:.82rem;line-height:2;color:var(--dust);margin-bottom:40px}
.contact-btn{display:inline-flex;align-items:center;font-size:.62rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;color:var(--white);background:var(--grn);padding:16px 44px;border:1px solid var(--grn);transition:background .3s;border-radius:1px;-webkit-tap-highlight-color:transparent}
.contact-btn:hover,.contact-btn:active{background:var(--grn2)}
.contact-det{margin-top:52px;display:flex;justify-content:center;gap:48px;flex-wrap:wrap}
.det-l{font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dust2);margin-bottom:7px}
.det-v{font-family:var(--serif);font-size:.9rem;color:var(--grn)}
.det-v a{transition:color .25s}
.det-v a:hover,.det-v a:active{color:var(--slv)}

/* FOOTER */
footer{padding:30px 52px;border-top:1px solid var(--border);display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;background:var(--cream2)}
.f-logo{font-family:var(--serif);font-size:.82rem;letter-spacing:.12em;text-transform:uppercase;color:var(--grn);opacity:.35}
.f-copy{font-size:.57rem;color:var(--dust2)}
.f-links{display:flex;gap:20px;flex-wrap:wrap}
.f-links a{font-size:.57rem;letter-spacing:.1em;text-transform:uppercase;color:var(--dust);transition:color .25s}
.f-links a:hover{color:var(--grn)}

/* CHATBOT */
#chat-trigger{position:fixed;bottom:28px;right:28px;z-index:800;width:54px;height:54px;border-radius:50%;background:var(--grn);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 20px rgba(30,53,40,.22);transition:background .3s,transform .2s;-webkit-tap-highlight-color:transparent}
#chat-trigger:hover{background:var(--grn2);transform:scale(1.05)}
#chat-trigger svg{width:22px;height:22px;fill:none;stroke:var(--white);stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.chat-badge{position:absolute;top:-2px;right:-2px;width:17px;height:17px;border-radius:50%;background:var(--slv2);font-size:.45rem;font-weight:700;color:var(--grn);display:flex;align-items:center;justify-content:center;animation:pulse 2.5s ease-in-out infinite}
#chat-window{position:fixed;bottom:94px;right:28px;z-index:799;width:360px;max-width:calc(100vw - 40px);background:var(--white);border:1px solid rgba(30,53,40,.1);box-shadow:0 8px 40px rgba(30,53,40,.16);display:none;flex-direction:column;max-height:78vh;overflow:hidden}
#chat-window.open{display:flex}
.chat-head{background:var(--grn);color:var(--white);padding:16px;display:flex;align-items:center;gap:12px;flex-shrink:0}
.chat-head-av{width:36px;height:36px;border-radius:50%;background:var(--grn2);display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:.95rem;font-style:italic;color:var(--slv3);border:1.5px solid rgba(255,255,255,.18);flex-shrink:0}
.chat-head-info{flex:1;min-width:0}
.chat-head-name{font-family:var(--serif);font-size:.88rem;font-style:italic}
.chat-head-status{font-size:.48rem;letter-spacing:.12em;text-transform:uppercase;color:rgba(255,255,255,.45);margin-top:2px}
.chat-head-dot{width:6px;height:6px;border-radius:50%;background:#5cb85c;flex-shrink:0}
.chat-x{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.45);font-size:1.1rem;padding:4px;transition:color .2s}
.chat-x:hover{color:var(--white)}
.chat-msgs{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:10px}
.chat-msg{max-width:88%;padding:10px 13px;font-size:.76rem;line-height:1.65}
.chat-msg.bot{background:var(--cream2);color:var(--grn);align-self:flex-start}
.chat-msg.user{background:var(--grn);color:var(--white);align-self:flex-end}
.typing-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:var(--slv);margin:0 2px;animation:pulse .9s ease-in-out infinite}
.typing-dot:nth-child(2){animation-delay:.15s}
.typing-dot:nth-child(3){animation-delay:.3s}
.chat-opts{padding:0 16px 10px;display:flex;flex-direction:column;gap:5px}
.chat-opt{background:var(--cream2);border:1px solid var(--border);color:var(--grn);font-size:.71rem;padding:9px 12px;cursor:pointer;text-align:left;transition:background .2s,border-color .2s;-webkit-tap-highlight-color:transparent;border-radius:1px;line-height:1.4}
.chat-opt:hover,.chat-opt:active{background:var(--cream);border-color:rgba(154,163,174,.35)}
.chat-foot{padding:10px 12px;border-top:1px solid var(--border);display:flex;gap:7px;flex-shrink:0}
.chat-inp{flex:1;border:1px solid var(--border);background:var(--cream);color:var(--grn);font-family:var(--sans);font-size:.75rem;padding:9px 12px;outline:none;transition:border-color .25s}
.chat-inp:focus{border-color:rgba(30,53,40,.25)}
.chat-inp::placeholder{color:var(--dust2)}
.chat-snd{background:var(--grn);border:none;cursor:pointer;color:var(--white);width:36px;height:36px;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .2s;-webkit-tap-highlight-color:transparent}
.chat-snd:hover{background:var(--grn2)}
.chat-snd svg{width:15px;height:15px;fill:none;stroke:currentColor;stroke-width:2;stroke-linecap:round;stroke-linejoin:round}
.chat-restart{background:none;border:none;cursor:pointer;color:rgba(255,255,255,.35);font-size:.48rem;letter-spacing:.1em;text-transform:uppercase;padding:4px;transition:color .2s}
.chat-restart:hover{color:rgba(255,255,255,.65)}


/* ── CONTACT FORM ── */
.contact-form-wrap{max-width:640px;margin:0 auto 40px}
.site-contact-form{display:flex;flex-direction:column;gap:16px}
.cf-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.cf-field{display:flex;flex-direction:column;gap:6px}
.cf-full{width:100%}
.cf-label{font-size:.5rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv)}
.cf-input,.cf-textarea,.cf-select{width:100%;padding:13px 14px;border:1px solid var(--border);
  background:var(--white);font-family:var(--sans);font-size:.76rem;color:var(--grn);
  outline:none;transition:border-color .25s;border-radius:1px;-webkit-appearance:none}
.cf-input:focus,.cf-textarea:focus,.cf-select:focus{border-color:rgba(30,53,40,.3)}
.cf-input::placeholder,.cf-textarea::placeholder{color:var(--dust2)}
.cf-select{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%236B7280'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:34px}
.cf-textarea{resize:vertical;min-height:120px;line-height:1.7}
.cf-submit{display:inline-flex;align-items:center;justify-content:center;
  font-size:.62rem;font-weight:600;letter-spacing:.17em;text-transform:uppercase;
  background:var(--grn);color:var(--white);padding:15px 36px;border:1px solid var(--grn);
  cursor:pointer;transition:background .3s;border-radius:1px;align-self:flex-start;
  -webkit-tap-highlight-color:transparent;margin-top:4px}
.cf-submit:hover{background:var(--grn2)}
.contact-confirm{max-width:520px;margin:0 auto 40px;text-align:center;padding:44px 28px;
  border:1px solid var(--border);background:var(--white)}
.confirm-icon{width:52px;height:52px;border-radius:50%;background:var(--grn);color:var(--white);
  font-size:1.3rem;display:flex;align-items:center;justify-content:center;margin:0 auto 18px}
.confirm-h{font-family:var(--serif);font-size:1.4rem;color:var(--grn);margin-bottom:12px;font-weight:400}
.confirm-p{font-size:.78rem;line-height:1.9;color:var(--dust);margin-bottom:22px}
.cf-reset{font-size:.56rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  color:var(--grn);background:none;border:1px solid rgba(30,53,40,.2);padding:10px 22px;
  cursor:pointer;transition:border-color .3s;border-radius:1px}
.cf-reset:hover{border-color:var(--slv2)}
@media(max-width:600px){.cf-row{grid-template-columns:1fr}}

/* RESPONSIVE */
@media(max-width:1024px){.b2b-grid,.b2b-details-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:900px){.b2b-index,.b2b-target{grid-template-columns:1fr 1fr}.b2b-target{grid-template-columns:1fr}}
@media(max-width:768px){
  :root{--nav-h:56px}
  nav{padding:0 18px}
  .nav-links{display:none}
  .burger{display:flex}
  .hero-top{padding:56px 20px 32px}
  .hero-wm{display:none}
  .panels{flex-direction:column;margin:18px 14px 0;background:transparent;gap:0}
  .panel{margin-bottom:1px;padding:20px 18px}
  .panel.active{flex:none}
  .p-num{font-size:2.8rem;margin-bottom:6px}
  .p-tl-steps{flex-wrap:wrap}
  .p-tl-step{min-width:40%;text-align:left;padding-top:0;border-left:1px solid rgba(200,205,211,.22);padding-left:8px;margin-bottom:10px}
  .p-tl-line,.p-tl-dot{display:none}
  .svc-trigger{grid-template-columns:52px 1fr auto;gap:14px;padding:28px 0}
  .svc-body-in{padding:0 0 28px 66px}
  .svc-num{font-size:2.5rem}
  .tl-steps{flex-wrap:wrap}
  .tl-step{min-width:45%;text-align:left;padding-top:0;border-left:1px solid rgba(154,163,174,.25);padding-left:8px;margin-bottom:12px}
  .tl-line,.tl-dot{display:none}
  .pillars{grid-template-columns:1fr}
  .value-inner{grid-template-columns:1fr 1fr}
  .b2b-index,.b2b-grid,.b2b-details-grid{grid-template-columns:1fr}
  .b2b-block-head,.b2b-final{grid-template-columns:1fr}
  .b2b-details,.b2b-target,.b2b-final{padding:26px 20px}
  .b2b-target{grid-template-columns:1fr}
  .contact-det{gap:24px}
  footer{flex-direction:column;text-align:center;padding:22px 18px}
  .f-links{justify-content:center}
  .sec-h{margin-bottom:44px;font-size:clamp(1.5rem,6vw,2.2rem)}
  .value-strip,.intro-sec,.identity-sec,.process-sec,.b2b-sec,.market-sec,.contact-sec,.cta-strip{padding-top:68px;padding-bottom:68px}
  #chat-window{width:calc(100vw - 32px);right:16px;bottom:80px}
  #chat-trigger{bottom:18px;right:18px;width:50px;height:50px}
  .id-photo-box{width:65%}
  .id-grid{grid-template-columns:1fr}
  .market-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
  .value-inner{grid-template-columns:1fr}
  .tl-step{min-width:48%}
  .mkt-card{padding:28px 18px}
  .b2b-target-points{flex-direction:column}
}

/* Photo */
.id-photo-img{width:72%;margin:0 auto;display:block;aspect-ratio:3/4;
  object-fit:cover;object-position:center top;
  border:1px solid rgba(255,255,255,.07);filter:grayscale(5%) contrast(1.03);}

/* ── COLLECTIONS ── */
.coll-sec{padding:88px 24px 96px;background:var(--cream)}
.coll-inner{max-width:1100px;margin:0 auto}
.coll-intro{max-width:760px;margin:0 auto 44px;text-align:center}
.coll-intro-p{font-size:.84rem;line-height:2;color:var(--dust)}

.coll-block{margin-bottom:68px}
.coll-block-head{display:grid;grid-template-columns:1fr auto;gap:24px;
  align-items:end;margin-bottom:20px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.coll-season{font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;color:var(--slv);margin-bottom:8px}
.coll-name{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:400;color:var(--grn)}
.coll-name em{font-style:italic;color:var(--slv)}
.coll-desc{font-size:.8rem;line-height:2;color:var(--dust);max-width:700px;margin-bottom:24px}
.coll-cats{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:44px}
.coll-cat{font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;
  color:var(--slv);border:1px solid var(--border);padding:5px 10px;background:var(--cream2)}

/* Category sub-heading */
.coll-subhead{display:flex;align-items:center;gap:16px;margin-bottom:20px;margin-top:52px}
.coll-subhead-label{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--grn)}
.coll-subhead-line{flex:1;height:1px;background:var(--border)}
.coll-subhead-count{font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv2)}

/* Price tier badges */
.price-tier{display:inline-flex;align-items:center;gap:6px;font-size:.48rem;
  letter-spacing:.16em;text-transform:uppercase;padding:4px 8px;margin-bottom:10px}
.tier-entry{color:var(--slv);border:1px solid var(--border);background:var(--cream2)}
.tier-fine{color:var(--grn2);border:1px solid rgba(30,53,40,.15);background:rgba(30,53,40,.04)}
.tier-high{color:var(--grn);border:1px solid rgba(30,53,40,.25);background:rgba(30,53,40,.07)}
.tier-hj{color:var(--white);background:var(--grn);border:1px solid var(--grn)}

/* Product grid */
.coll-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border)}
.coll-grid-3{grid-template-columns:repeat(3,1fr)}
.coll-card{background:var(--cream);display:flex;flex-direction:column;transition:background .25s}
.coll-card:hover{background:var(--white)}
.coll-card-img{width:100%;aspect-ratio:1/1;background:var(--cream2);
  overflow:hidden;border-bottom:1px solid var(--border);position:relative}
.coll-card-img img{width:100%;height:100%;object-fit:contain;object-position:center;
  padding:12px;transition:transform .55s var(--ease);display:block}
.coll-card:hover .coll-card-img img{transform:scale(1.06)}
.coll-card-body{padding:18px 16px 22px;flex:1;display:flex;flex-direction:column}
.coll-card-cat{font-size:.48rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv);margin-bottom:6px}
.coll-card-name{font-family:var(--serif);font-size:.92rem;color:var(--grn);margin-bottom:8px;line-height:1.3}
.coll-card-note{font-size:.7rem;line-height:1.75;color:var(--dust);margin-bottom:12px;flex:1}
.coll-card-price{font-size:.62rem;font-weight:500;letter-spacing:.04em;color:var(--grn);
  border-top:1px solid var(--border);padding-top:10px;margin-top:auto}
.coll-card-price span{font-size:.5rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--slv);font-weight:400;display:block;margin-bottom:2px}

/* Line 01 */
.coll-block.line01{background:var(--cream2);padding:42px 36px;margin-bottom:0}
.coll-block.line01 .coll-card{background:var(--cream2)}
.coll-block.line01 .coll-card:hover{background:var(--white)}
.coll-block.line01 .coll-grid{background:rgba(30,53,40,.06);border-color:rgba(30,53,40,.06)}


.collection-nav{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 34px;max-width:920px}
.collection-nav a{font-size:.54rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grn);padding:10px 14px;border:1px solid var(--border);background:var(--white);transition:background .25s var(--ease),border-color .25s var(--ease)}
.collection-nav a:hover{background:var(--cream2);border-color:rgba(30,53,40,.14)}
.collection-split-label{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--slv);margin:34px 0 14px;text-align:center}
#collections .coll-desc{max-width:760px}
#collections .product-aesthetic{font-size:.68rem;line-height:1.75;color:var(--dust2);margin:-2px 0 12px}
#collections .product-specs{display:grid;grid-template-columns:1fr 1fr;gap:8px 12px;margin-bottom:12px}
#collections .product-spec{display:flex;flex-direction:column;gap:2px;padding:8px 9px;background:rgba(255,255,255,.55);border:1px solid var(--border)}
#collections .product-spec-k{font-size:.46rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv)}
#collections .product-spec-v{font-size:.67rem;line-height:1.55;color:var(--grn)}
#line01-block .line01-group{background:rgba(255,255,255,.56);border:1px solid var(--border)}
#line01-block .line01-item{padding:10px 0}
#line01-block .line01-item-note{max-width:34ch}
@media(max-width:768px){
  .collection-nav{gap:8px;margin-bottom:24px}
  .collection-nav a{font-size:.5rem;padding:9px 10px}
  #collections .product-specs{grid-template-columns:1fr}
  .collection-split-label{margin:24px 0 10px}
  .coll-block.line01{padding:26px 18px}
  .rhythm-hero-text{left:24px;right:24px;bottom:24px}
}

/* Price legend */
.price-legend{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:36px;align-items:center}
.price-legend-label{font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--dust2);margin-right:4px}

/* Optimised collections */
.coll-sec.optimized{padding:88px 24px 80px}
.coll-sec.optimized .coll-intro{margin-bottom:56px}
.coll-sec.optimized .coll-block{margin-bottom:72px}
.coll-sec.optimized .coll-desc{max-width:860px;margin-bottom:18px}
.coll-sec.optimized .coll-cats{margin-bottom:28px}
.coll-sec.optimized .price-legend{margin-bottom:28px}
.coll-sec.optimized .coll-subhead{margin-top:34px;margin-bottom:14px}
.coll-sec.optimized .coll-card-body{padding:15px 14px 18px}
.coll-sec.optimized .coll-card-note{font-size:.68rem;line-height:1.65}

.line01-compact{background:linear-gradient(180deg,var(--cream2),#eee8df);padding:34px;border:1px solid rgba(30,53,40,.08)}
.line01-head{display:grid;grid-template-columns:1.2fr .8fr;gap:24px;align-items:start;margin-bottom:24px}
.line01-lead{font-size:.76rem;line-height:1.85;color:var(--dust);max-width:760px}
.line01-meta{display:flex;flex-wrap:wrap;gap:8px;justify-content:flex-end;align-content:flex-start}
.line01-meta span{font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv);border:1px solid rgba(30,53,40,.08);padding:7px 10px;background:rgba(255,255,255,.55)}
.line01-groups{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:12px}
.line01-group{background:rgba(255,255,255,.5);border:1px solid rgba(30,53,40,.08);padding:16px 16px 14px}
.line01-group h4{font-family:var(--serif);font-size:1rem;font-weight:400;color:var(--grn);margin-bottom:4px}
.line01-group-top{display:flex;align-items:end;justify-content:space-between;gap:10px;margin-bottom:12px}
.line01-count{font-size:.48rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv2)}
.line01-list{display:flex;flex-direction:column;gap:10px}
.line01-item{display:grid;grid-template-columns:30px 1fr;gap:10px;padding:10px 0;border-top:1px solid rgba(30,53,40,.07)}
.line01-item:first-child{border-top:none;padding-top:0}
.line01-icon{width:30px;height:30px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,255,.72);border:1px solid rgba(30,53,40,.08);font-family:var(--serif);font-style:italic;color:var(--slv2)}
.line01-item-main{min-width:0}
.line01-tier{display:inline-flex;align-items:center;gap:6px;font-size:.43rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv);margin-bottom:4px}
.line01-tier::before{content:'';width:10px;height:1px;background:currentColor;opacity:.55}
.line01-item-name{font-family:var(--serif);font-size:.82rem;color:var(--grn);line-height:1.25;margin-bottom:5px}
.line01-item-note{font-size:.63rem;line-height:1.6;color:var(--dust)}
.line01-item-price{margin-top:7px;font-size:.58rem;color:var(--grn)}
.line01-actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:22px;padding-top:18px;border-top:1px solid rgba(30,53,40,.08)}
.line01-note{font-size:.64rem;line-height:1.75;color:var(--dust2);margin-top:2px;max-width:720px}
.line01-btn{display:inline-flex;align-items:center;justify-content:center;font-size:.56rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;background:var(--grn);color:var(--white);padding:11px 18px;border:none;cursor:pointer;transition:background .2s}
.line01-btn:hover{background:var(--grn2)}
.line01-btn.ghost{background:transparent;color:var(--grn);border:1px solid rgba(30,53,40,.14)}
.line01-btn.ghost:hover{background:rgba(255,255,255,.6)}

@media(max-width:1024px){.line01-groups{grid-template-columns:1fr 1fr}}
@media(max-width:768px){.coll-sec.optimized{padding-top:68px;padding-bottom:68px}.line01-compact{padding:22px 18px}.line01-head{grid-template-columns:1fr}.line01-meta{justify-content:flex-start}.line01-groups{grid-template-columns:1fr}}

@media(max-width:1024px){.coll-grid{grid-template-columns:repeat(3,1fr)}.coll-grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
  .coll-grid,.coll-grid-3{grid-template-columns:repeat(2,1fr)}
  .coll-block-head{grid-template-columns:1fr}
  .coll-block.line01{padding:28px 18px}
  .coll-sec{padding-top:68px;padding-bottom:68px}
}
@media(max-width:480px){.coll-grid,.coll-grid-3{grid-template-columns:1fr}}

/* ── CART ── */
.cart-btn-wrap{position:fixed;bottom:96px;right:24px;z-index:3000}
.cart-fab{width:52px;height:52px;border-radius:50%;background:var(--grn);
  color:var(--white);border:none;cursor:pointer;display:flex;align-items:center;
  justify-content:center;box-shadow:0 4px 20px rgba(0,0,0,.18);
  transition:transform .2s,background .2s;font-size:1.3rem}
.cart-fab:hover{transform:scale(1.08);background:var(--grn2)}
.cart-badge{position:absolute;top:-4px;right:-4px;width:18px;height:18px;
  border-radius:50%;background:#c8a96e;color:var(--white);font-size:.55rem;
  font-weight:700;display:flex;align-items:center;justify-content:center;
  opacity:0;transform:scale(0);transition:all .25s}
.cart-badge.visible{opacity:1;transform:scale(1)}

.cart-drawer{position:fixed;top:0;right:-420px;width:420px;max-width:100vw;
  height:100vh;background:var(--white);z-index:4000;
  box-shadow:-4px 0 32px rgba(0,0,0,.12);transition:right .35s var(--ease);
  display:flex;flex-direction:column}
.cart-drawer.open{right:0}
.cart-overlay{position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:3999;
  opacity:0;pointer-events:none;transition:opacity .35s}
.cart-overlay.open{opacity:1;pointer-events:all}

.cart-head{padding:24px 20px 18px;border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between}
.cart-head-title{font-family:var(--serif);font-size:1.1rem;color:var(--grn)}
.cart-close{background:none;border:none;cursor:pointer;font-size:1.4rem;
  color:var(--slv);padding:4px 8px;transition:color .2s}
.cart-close:hover{color:var(--grn)}
.cart-empty{flex:1;display:flex;flex-direction:column;align-items:center;
  justify-content:center;gap:12px;color:var(--slv2);font-size:.78rem;
  letter-spacing:.04em}
.cart-empty-icon{font-size:2.4rem;opacity:.3}
.cart-items{flex:1;overflow-y:auto;padding:0 20px}
.cart-item{display:grid;grid-template-columns:1fr auto;gap:8px;
  padding:16px 0;border-bottom:1px solid var(--border)}
.cart-item-name{font-family:var(--serif);font-size:.88rem;color:var(--grn);margin-bottom:3px}
.cart-item-price{font-size:.7rem;color:var(--slv);letter-spacing:.04em}
.cart-item-remove{background:none;border:none;cursor:pointer;color:var(--slv2);
  font-size:.9rem;padding:2px 6px;transition:color .2s;align-self:start;margin-top:2px}
.cart-item-remove:hover{color:#b04040}
.cart-footer{padding:20px;border-top:1px solid var(--border)}
.cart-note{font-size:.68rem;line-height:1.8;color:var(--dust);margin-bottom:16px}
.cart-checkout-btn{width:100%;padding:14px;background:var(--grn);color:var(--white);
  border:none;cursor:pointer;font-size:.58rem;font-weight:600;letter-spacing:.2em;
  text-transform:uppercase;transition:background .25s}
.cart-checkout-btn:hover{background:var(--grn2)}
.cart-checkout-btn:disabled{opacity:.4;cursor:not-allowed}

/* Add to cart button on product cards */
.v-card-add,.coll-card-add{
  display:inline-flex;align-items:center;gap:6px;margin-top:8px;
  font-size:.5rem;font-weight:600;letter-spacing:.16em;text-transform:uppercase;
  color:var(--white);background:var(--grn);border:none;cursor:pointer;
  padding:8px 14px;transition:background .2s,transform .15s}
.v-card-add:hover,.coll-card-add:hover{background:var(--grn2)}
.v-card-add:active,.coll-card-add:active{transform:scale(.96)}
.v-card-add.added,.coll-card-add.added{background:#5a7a60}

/* ── RHYTHM COLLECTION ── */
.rhythm-hero{position:relative;width:100%;height:480px;overflow:hidden;background:#1a1a1a}
.rhythm-hero video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:50% 50%;opacity:.88}
.rhythm-hero-overlay{position:absolute;inset:0;background:linear-gradient(to bottom,transparent 40%,rgba(26,26,26,.7))}
.rhythm-hero-text{position:absolute;bottom:40px;left:40px;right:40px;color:#f4f1ec;max-width:640px;margin:0 auto;text-align:left}
.rhythm-hero-eye{font-size:.5rem;letter-spacing:.28em;text-transform:uppercase;opacity:.6;margin-bottom:10px}
.rhythm-hero-h{font-family:var(--serif);font-size:clamp(2rem,4vw,3.2rem);font-weight:400;line-height:1.1}
.rhythm-hero-sub{font-size:.78rem;line-height:1.9;opacity:.7;max-width:480px;margin-top:10px}

.rhythm-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);margin-bottom:40px}
.rhythm-img{overflow:hidden;aspect-ratio:1/1}
.rhythm-img img{width:100%;height:100%;object-fit:cover;object-position:center;
  transition:transform .6s var(--ease)}
.rhythm-img:hover img{transform:scale(1.04)}

.rhythm-card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border)}
.rhythm-card{background:var(--cream);padding:28px 22px;border-top:none}
.rhythm-card-name{font-family:var(--serif);font-size:.95rem;color:var(--grn);margin-bottom:6px}
.rhythm-card-note{font-size:.74rem;line-height:1.85;color:var(--dust);margin-bottom:14px}
.rhythm-card-price{font-size:.62rem;font-weight:600;color:var(--grn);opacity:.6;
  border-top:1px solid var(--border);padding-top:10px;margin-bottom:10px}
.rhythm-mat{display:flex;flex-wrap:wrap;gap:5px;margin-bottom:12px}
.rhythm-mat span{font-size:.44rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--slv);border:1px solid var(--border);padding:4px 8px;background:var(--cream2)}

@media(max-width:768px){
  .rhythm-grid,.rhythm-card-grid{grid-template-columns:1fr 1fr}
  .rhythm-hero{height:320px}
  .rhythm-hero-text{left:24px;bottom:28px}
}
@media(max-width:480px){
  .rhythm-grid,.rhythm-card-grid{grid-template-columns:1fr}
}

/* ---- V25 compact layout + product intelligence ---- */
:root{--section-tight:72px}
.hero-top{padding-bottom:28px}
.panels{margin-top:24px;min-height:220px}
.value-strip,.intro-sec,.identity-sec,.process-sec,.b2b-sec,.market-sec,.contact-sec,.cta-strip{padding-top:var(--section-tight);padding-bottom:var(--section-tight)}
.coll-sec.optimized{padding:72px 20px 60px}
.coll-sec.optimized .coll-intro{margin-bottom:42px}
.coll-sec.optimized .coll-block{margin-bottom:56px}
.coll-sec.optimized .coll-desc{margin-bottom:14px}
.coll-sec.optimized .coll-cats{margin-bottom:20px}
.coll-sec.optimized .price-legend{margin-bottom:20px}
.coll-sec.optimized .coll-subhead{margin-top:24px;margin-bottom:12px}
.coll-block.line01{padding:28px 18px 32px}
.v-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.v-card,.coll-card,.rhythm-card{background:var(--cream);display:flex;flex-direction:column}
.v-card:hover,.coll-card:hover,.rhythm-card:hover{background:var(--white)}
.v-card-img,.coll-card-img,.rhythm-img{aspect-ratio:1/1}
.v-card-body,.coll-card-body,.rhythm-card{padding:14px 14px 16px}
.v-card-tier,.coll-card-cat,.rhythm-mat{margin-bottom:6px}
.v-card-name,.coll-card-name,.rhythm-card-name{font-family:var(--serif);font-size:.93rem;line-height:1.3;color:var(--grn);margin-bottom:8px}
.v-card-note,.coll-card-note,.rhythm-card-note{font-size:.69rem;line-height:1.65;color:var(--dust);margin-bottom:8px}
.product-aesthetic{font-size:.66rem;line-height:1.6;color:var(--grn2);padding-top:8px;margin-top:8px;border-top:1px solid var(--border)}
.product-specs{display:grid;grid-template-columns:1fr 1fr;gap:6px 10px;margin-top:10px;padding-top:10px;border-top:1px dashed rgba(30,53,40,.14)}
.product-spec{display:flex;flex-direction:column;gap:2px}
.product-spec-k{font-size:.46rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv)}
.product-spec-v{font-size:.64rem;line-height:1.45;color:var(--grn)}
.v-card-price,.coll-card-price,.rhythm-card-price{font-size:.68rem;font-weight:600;letter-spacing:.02em;color:var(--grn);border-top:1px solid var(--border);padding-top:10px;margin-top:10px}
.v-card-price span,.coll-card-price span,.rhythm-card-price span{display:block;font-size:.47rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv);font-weight:500;margin-bottom:3px}
.v-card-add,.coll-card-add{margin-top:10px}
.v-card-enquire{display:block;margin-top:6px;font-size:.54rem;letter-spacing:.16em;text-transform:uppercase;color:var(--grn)}
.rhythm-card .product-specs{margin-bottom:2px}
@media(max-width:1100px){.v-grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:768px){
  :root{--section-tight:60px}
  .coll-sec.optimized{padding:60px 14px 52px}
  .coll-block.line01{padding:22px 14px 26px}
  .v-grid,.coll-grid,.rhythm-card-grid{grid-template-columns:repeat(2,1fr)}
  .product-specs{grid-template-columns:1fr}
}
@media(max-width:480px){
  .v-grid,.coll-grid,.rhythm-card-grid{grid-template-columns:1fr}
  .product-specs{grid-template-columns:1fr}
}

/* v30 collection cleanup */
.collection-nav.clean{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin:0 auto 30px;max-width:860px}.collection-nav.clean a{font-size:.56rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grn);padding:10px 14px;border:1px solid var(--border);background:var(--cream2)}
.collection-kicker{text-align:center;font-size:.56rem;letter-spacing:.28em;text-transform:uppercase;color:var(--slv);margin-bottom:12px}.collection-intro-note{max-width:760px;margin:0 auto 28px;text-align:center;font-size:.82rem;line-height:1.95;color:var(--dust)}
.collection-band{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin:0 0 32px}.collection-band .summary-item{background:var(--cream);padding:18px 16px}.collection-band .summary-k{display:block;font-size:.48rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv);margin-bottom:6px}.collection-band .summary-v{font-family:var(--serif);font-size:.95rem;color:var(--grn)}
.rhythm-showcase{display:grid;grid-template-columns:1.05fr .95fr;gap:24px;align-items:start}.rhythm-copy-panel{border:1px solid var(--border);background:var(--cream2);padding:26px 24px}.rhythm-copy-panel h4{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--grn);margin-bottom:10px}.rhythm-copy-panel p{font-size:.76rem;line-height:1.85;color:var(--dust);margin-bottom:12px}.rhythm-offer-points{display:flex;flex-wrap:wrap;gap:8px;margin-top:10px}.rhythm-offer-points span{font-size:.48rem;letter-spacing:.14em;text-transform:uppercase;border:1px solid var(--border);padding:6px 8px;background:var(--cream)}
.offer-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-top:22px}.offer-card{background:var(--cream);padding:24px 22px}.offer-card h4{font-family:var(--serif);font-size:1rem;font-weight:400;color:var(--grn);margin-bottom:10px}.offer-card p{font-size:.74rem;line-height:1.8;color:var(--dust);margin-bottom:12px}.offer-card span{font-size:.48rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv)}
.line-offer-head{max-width:820px;margin:0 0 22px}.line-offer-head p{font-size:.8rem;line-height:1.95;color:var(--dust)}
@media(max-width:768px){.collection-band,.offer-grid,.rhythm-showcase{grid-template-columns:1fr}}

/* --- FINAL CLEAN SHOWROOM OVERRIDES --- */
.coll-sec.optimized{padding-top:88px;padding-bottom:88px}
.collection-kicker{font-size:.58rem;letter-spacing:.32em;text-transform:uppercase;color:var(--slv);text-align:center;margin-bottom:14px}
.collection-intro-note{max-width:760px;margin:0 auto 24px;text-align:center;font-size:.84rem;line-height:1.95;color:var(--dust)}
.collection-nav.clean{display:flex;flex-wrap:wrap;gap:10px;justify-content:center;margin:0 auto 52px;max-width:980px}
.collection-nav.clean a{font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;padding:10px 14px;border:1px solid var(--border);background:var(--white);color:var(--grn)}
.clean-block{margin-bottom:72px;padding:34px;border:1px solid var(--border);background:rgba(255,255,255,.55)}
.clean-head{display:grid;grid-template-columns:1fr auto;gap:20px;align-items:end;margin-bottom:12px}
.clean-kicker{font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;color:var(--slv);margin-bottom:10px}
.clean-title{font-family:var(--serif);font-size:clamp(1.4rem,2.6vw,2rem);font-weight:400;color:var(--grn);line-height:1.25}
.clean-desc{font-size:.8rem;line-height:1.9;color:var(--dust);max-width:820px;margin-bottom:26px}
.section-rail{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border);margin-bottom:28px}
.section-rail .summary-item{background:var(--cream);padding:18px 16px}
.summary-k{display:block;font-size:.5rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv);margin-bottom:7px}
.summary-v{display:block;font-family:var(--serif);font-size:.95rem;color:var(--grn);line-height:1.35}
.clean-subhead{display:flex;align-items:center;gap:16px;margin:30px 0 16px}
.clean-subhead h4{font-family:var(--serif);font-size:1.05rem;font-weight:400;color:var(--grn)}
.clean-subhead .line{flex:1;height:1px;background:var(--border)}
.clean-subhead .count{font-size:.52rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv2)}
.duet-grid-clean{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--border);border:1px solid var(--border)}
.duet-grid-clean.four{grid-template-columns:repeat(4,1fr)}
.duet-grid-clean.five{grid-template-columns:repeat(5,1fr)}
.system-card{background:var(--cream);padding:22px 20px 20px;display:flex;flex-direction:column;min-height:270px}
.system-tag{font-size:.5rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv);margin-bottom:10px}
.system-card h5{font-family:var(--serif);font-size:1rem;font-weight:400;line-height:1.35;color:var(--grn);margin-bottom:10px}
.system-card p{font-size:.73rem;line-height:1.8;color:var(--dust);margin-bottom:12px}
.system-meta{margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}
.system-meta div{display:flex;justify-content:space-between;gap:10px;font-size:.64rem;line-height:1.6;color:var(--dust)}
.system-meta span:first-child{text-transform:uppercase;letter-spacing:.08em;color:var(--slv)}
.price-selector{margin-top:12px}
.price-selector label{display:block;font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;color:var(--slv);margin-bottom:6px}
.price-selector select{width:100%;padding:11px 12px;border:1px solid var(--border);background:var(--white);font-family:var(--sans);font-size:.72rem;color:var(--grn);outline:none}
.price-output{margin-top:8px;font-size:.72rem;color:var(--grn);font-weight:500}
.ear-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.ear-summary,.ear-cards{background:var(--cream)}
.ear-summary{padding:24px}
.ear-summary p{font-size:.76rem;line-height:1.9;color:var(--dust);margin-bottom:18px}
.ear-list{display:grid;gap:1px;background:var(--border);border:1px solid var(--border)}
.ear-list div{background:var(--cream);padding:14px 16px}
.ear-list strong{display:block;font-family:var(--serif);font-size:.95rem;font-weight:400;color:var(--grn);margin-bottom:4px}
.ear-list span{font-size:.67rem;color:var(--dust);line-height:1.6}
.ear-cards{display:grid;grid-template-columns:1fr 1fr;gap:1px}
.mini-card{background:var(--cream);padding:22px 18px}
.mini-card h5{font-family:var(--serif);font-size:1rem;font-weight:400;color:var(--grn);margin-bottom:8px}
.mini-card p{font-size:.72rem;line-height:1.8;color:var(--dust);margin-bottom:10px}
.rhythm-shell{display:grid;grid-template-columns:1.2fr .8fr;gap:28px;align-items:start}
.rhythm-hero-clean{position:relative;background:#e7e0d6;border:1px solid var(--border);aspect-ratio:16/10;overflow:hidden}
.rhythm-hero-clean video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;object-position:center center;transform:scale(1.02)}
.rhythm-hero-clean .overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(0,0,0,.48),rgba(0,0,0,.08) 45%,rgba(0,0,0,.02))}
.rhythm-hero-caption{position:absolute;left:26px;right:26px;bottom:22px;color:#fff}
.rhythm-hero-caption .eye{font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;opacity:.7;margin-bottom:8px}
.rhythm-hero-caption h4{font-family:var(--serif);font-size:clamp(1.5rem,2.4vw,2rem);font-weight:400;line-height:1.15;margin-bottom:8px}
.rhythm-hero-caption p{font-size:.75rem;line-height:1.8;opacity:.82;max-width:420px}
.rhythm-note{padding:26px;border:1px solid var(--border);background:var(--white)}
.rhythm-note h4{font-family:var(--serif);font-size:1.1rem;font-weight:400;color:var(--grn);margin-bottom:12px}
.rhythm-note p{font-size:.75rem;line-height:1.85;color:var(--dust);margin-bottom:14px}
.rhythm-points{display:flex;flex-wrap:wrap;gap:8px}
.rhythm-points span{font-size:.5rem;letter-spacing:.14em;text-transform:uppercase;padding:7px 10px;border:1px solid var(--border);background:var(--cream)}
.rhythm-products-clean{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin-top:22px}
.line01-framework{display:grid;grid-template-columns:1.1fr .9fr;gap:1px;background:var(--border);border:1px solid var(--border)}
.framework-left,.framework-right{background:var(--cream);padding:24px}
.framework-left p,.framework-right p{font-size:.76rem;line-height:1.9;color:var(--dust)}
.offer-pillars{display:grid;grid-template-columns:1fr 1fr;gap:1px;background:var(--border);border:1px solid var(--border);margin-top:18px}
.offer-pillars div{background:var(--cream);padding:16px}
.offer-pillars strong{display:block;font-family:var(--serif);font-size:.96rem;font-weight:400;color:var(--grn);margin-bottom:6px}
.offer-pillars span{font-size:.67rem;line-height:1.7;color:var(--dust)}
.range-stack{display:grid;gap:1px;background:var(--border);border:1px solid var(--border);margin-top:18px}
.range-stack div{background:var(--cream);padding:15px 16px}
.range-stack strong{display:block;font-size:.56rem;letter-spacing:.16em;text-transform:uppercase;color:var(--slv);margin-bottom:5px}
.range-stack span{display:block;font-family:var(--serif);font-size:.94rem;color:var(--grn)}
@media(max-width:1024px){
  .duet-grid-clean.five{grid-template-columns:repeat(3,1fr)}
  .ear-grid,.rhythm-shell,.line01-framework{grid-template-columns:1fr}
}
@media(max-width:768px){
  .clean-block{padding:24px 18px}
  .section-rail,.duet-grid-clean,.duet-grid-clean.four,.duet-grid-clean.five,.rhythm-products-clean,.ear-cards,.offer-pillars{grid-template-columns:1fr}
  .clean-head{grid-template-columns:1fr}
}


.system-media,.mini-media{
  aspect-ratio:1/1;
  background:var(--cream2);
  border:1px solid var(--border);
  margin:-2px -2px 16px;
  overflow:hidden;
}
.system-media img,.mini-media img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center;
  display:block;
  transition:transform .35s var(--ease);
}
.system-card:hover .system-media img,.mini-card:hover .mini-media img{transform:scale(1.04)}
.mini-card{display:flex;flex-direction:column}
.mini-card .system-meta{margin-top:auto}

/* ══════════════════════════════════════
   COLLECTIONS REBUILT v36
══════════════════════════════════════ */
#collections{background:var(--cream);padding:96px 0 0}
.coll-wrap{max-width:1100px;margin:0 auto;padding:0 28px}

/* Section header */
.coll-eyebrow-row{display:flex;align-items:center;gap:14px;margin-bottom:10px}
.coll-section-eye{font-size:.5rem;letter-spacing:.3em;text-transform:uppercase;color:var(--slv)}
.coll-section-title{font-family:var(--serif);font-size:clamp(1.8rem,3.5vw,2.8rem);
  font-weight:400;color:var(--grn);margin-bottom:16px;line-height:1.15}
.coll-section-intro{font-size:.8rem;line-height:2;color:var(--dust);max-width:680px;margin-bottom:48px}

/* Collection nav pills */
.coll-pills{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:72px}
.coll-pill{font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--slv);border:1px solid var(--border);padding:8px 16px;
  background:var(--cream2);cursor:pointer;transition:all .2s;text-decoration:none;display:inline-block}
.coll-pill:hover,.coll-pill.active{background:var(--grn);color:var(--white);border-color:var(--grn)}

/* Block divider */
.coll-block-new{border-top:1px solid var(--border);padding:72px 0 80px;scroll-margin-top:80px}
.coll-block-new:first-of-type{border-top:none;padding-top:0}
.coll-block-head-row{display:flex;align-items:flex-end;justify-content:space-between;
  margin-bottom:8px;padding-bottom:20px;border-bottom:1px solid var(--border)}
.coll-block-kicker{font-size:.48rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--slv2);margin-bottom:6px}
.coll-block-title{font-family:var(--serif);font-size:clamp(1.4rem,2.5vw,2rem);
  font-weight:400;color:var(--grn)}
.coll-block-title em{font-style:italic;color:var(--slv)}
.coll-block-desc{font-size:.78rem;line-height:1.95;color:var(--dust);
  max-width:700px;margin:16px 0 32px}

/* Tier separator */
.tier-label-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;
  gap:14px;margin:40px 0 24px}
.tier-label-row .tl-line{height:1px;background:var(--border)}
.tier-label-row .tl-text{font-size:.47rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--slv);border:1px solid var(--border);padding:5px 12px;
  background:var(--cream2);white-space:nowrap}

/* Product card grid */
.prod-grid{display:grid;gap:1px;background:var(--border);border:1px solid var(--border)}
.prod-grid.col3{grid-template-columns:repeat(3,1fr)}
.prod-grid.col4{grid-template-columns:repeat(4,1fr)}
.prod-grid.col2{grid-template-columns:repeat(2,1fr)}
.prod-grid.col5{grid-template-columns:repeat(5,1fr)}

/* Product card */
.prod-card{background:var(--cream);display:flex;flex-direction:column;
  transition:background .25s;position:relative}
.prod-card:hover{background:var(--white)}
.prod-card-media{width:100%;aspect-ratio:1/1;overflow:hidden;
  background:var(--cream2);border-bottom:1px solid var(--border);position:relative}
.prod-card-media img{width:100%;height:100%;object-fit:contain;
  object-position:center;padding:10px;transition:transform .5s var(--ease,cubic-bezier(.4,0,.2,1))}
.prod-card:hover .prod-card-media img{transform:scale(1.05)}
.prod-card-media .img-placeholder{width:100%;height:100%}

.prod-card-body{padding:18px 16px 20px;flex:1;display:flex;flex-direction:column;gap:4px}
.prod-card-tier{font-size:.44rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--slv2);margin-bottom:2px}
.prod-card-name{font-family:var(--serif);font-size:.9rem;color:var(--grn);line-height:1.3}
.prod-card-note{font-size:.69rem;line-height:1.8;color:var(--dust);flex:1;margin-top:4px}

/* Spec pills row */
.prod-card-specs{display:flex;flex-wrap:wrap;gap:5px;margin:8px 0}
.spec-pill{font-size:.44rem;letter-spacing:.1em;padding:3px 7px;
  border:1px solid var(--border);color:var(--slv);background:var(--cream2)}

/* Price row */
.prod-card-price-row{display:flex;align-items:center;justify-content:space-between;
  margin-top:10px;padding-top:10px;border-top:1px solid var(--border)}
.prod-card-price{font-size:.65rem;font-weight:600;color:var(--grn);opacity:.65}
.prod-card-add{font-size:.46rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--white);background:var(--grn);border:none;cursor:pointer;
  padding:6px 11px;transition:background .2s}
.prod-card-add:hover{background:var(--grn2,#2a4a38)}
.prod-card-add.added{background:#5a7a60}

/* Alloy selector */
.alloy-selector{display:flex;gap:5px;margin:6px 0 2px;flex-wrap:wrap}
.alloy-btn{font-size:.42rem;letter-spacing:.1em;padding:3px 8px;
  border:1px solid var(--border);background:transparent;cursor:pointer;
  color:var(--slv);transition:all .2s}
.alloy-btn.sel{border-color:var(--grn);background:var(--grn);color:var(--white)}
.alloy-btn:hover:not(.sel){border-color:var(--slv)}

/* ── EAR SECTION ── */
.ear-grid-new{display:grid;grid-template-columns:1fr 1fr;gap:1px;
  background:var(--border);border:1px solid var(--border)}

/4;
  overflow:hidden;background:var(--cream2)}
.img-scroll-item img{width:100%;height:100%;object-fit:cover;object-position:center top}








/* Ear product cards */
.ear-prod-col{background:var(--cream);padding:0}
.ear-prod-list{display:flex;flex-direction:column;gap:0}
.ear-prod-item{padding:20px 20px 18px;border-bottom:1px solid var(--border);
  display:flex;flex-direction:column;gap:5px}
.ear-prod-item:last-child{border-bottom:none}
.ear-prod-tier{font-size:.44rem;letter-spacing:.18em;text-transform:uppercase;
  color:var(--slv2)}
.ear-prod-name{font-family:var(--serif);font-size:.88rem;color:var(--grn)}
.ear-prod-note{font-size:.68rem;line-height:1.8;color:var(--dust)}
.ear-prod-specs{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}
.ear-prod-price-row{display:flex;align-items:center;justify-content:space-between;
  margin-top:8px;padding-top:8px;border-top:1px solid var(--border)}
.ear-prod-price{font-size:.62rem;font-weight:600;color:var(--grn);opacity:.65}
.ear-prod-add{font-size:.44rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;
  color:var(--white);background:var(--grn);border:none;cursor:pointer;
  padding:5px 10px;transition:background .2s}
.ear-prod-add:hover{background:var(--grn2,#2a4a38)}

/* ── RHYTHM ── */
.rhythm-wrap{display:grid;grid-template-columns:1fr 1fr;gap:0;
  background:var(--border);border:1px solid var(--border)}
.rhythm-video-col{aspect-ratio:4/5;overflow:hidden;position:relative;background:#111}
.rhythm-video-col video{width:100%;height:100%;object-fit:cover;opacity:.9}
.rhythm-video-overlay{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(20,20,20,.7) 0%,transparent 60%)}
.rhythm-video-caption{position:absolute;bottom:28px;left:24px;right:24px;color:#f4f1ec}
.rhythm-video-caption .rv-eye{font-size:.46rem;letter-spacing:.24em;text-transform:uppercase;opacity:.6;margin-bottom:8px}
.rhythm-video-caption .rv-h{font-family:var(--serif);font-size:clamp(1.2rem,2vw,1.6rem);font-weight:400;line-height:1.2}
.rhythm-cards-col{display:flex;flex-direction:column;background:var(--cream)}
.rhythm-card-new{padding:24px 22px;border-bottom:1px solid var(--border);flex:1;display:flex;flex-direction:column;gap:5px}
.rhythm-card-new:last-child{border-bottom:none}
.rhythm-photo-strip{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;
  background:var(--border);border:1px solid var(--border);border-top:none;margin-top:-1px}
.rhythm-photo-strip .rps-img{aspect-ratio:4/3;overflow:hidden;background:var(--cream2)}
.rhythm-photo-strip .rps-img img{width:100%;height:100%;object-fit:cover}

/* ── LINE 01 ── */
.line01-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.line01-chapter{padding:24px 0}
.line01-ch-label{font-size:.48rem;letter-spacing:.2em;text-transform:uppercase;
  color:var(--slv);border-bottom:1px solid var(--border);padding-bottom:10px;margin-bottom:16px}
.line01-ch-desc{font-size:.75rem;line-height:1.9;color:var(--dust);margin-bottom:12px}
.line01-items{display:flex;flex-direction:column;gap:10px}
.line01-item{display:flex;align-items:center;gap:12px;padding:10px 0;
  border-bottom:1px dashed var(--border)}
.line01-item:last-child{border-bottom:none}
.line01-item-name{font-family:var(--serif);font-size:.82rem;color:var(--grn);flex:1}
.line01-item-price{font-size:.6rem;color:var(--slv);letter-spacing:.04em;white-space:nowrap}

/* Responsive */
@media(max-width:1024px){
  .prod-grid.col5{grid-template-columns:repeat(3,1fr)}
  .prod-grid.col4{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:768px){
  .prod-grid.col3,.prod-grid.col4,.prod-grid.col5{grid-template-columns:repeat(3,1fr)}
  .ear-grid-new,.rhythm-wrap,.line01-grid{grid-template-columns:1fr}
  #collections{padding-top:64px}
  .coll-block-new{padding:52px 0 60px}
}
@media(max-width:480px){
  .prod-grid.col3,.prod-grid.col2{grid-template-columns:1fr}
  .prod-grid.col5{grid-template-columns:repeat(3,1fr)}
}


/* ── EAR STATIC GALLERY (replaces scroll) ── */
.ear-static-grid{display:grid;gap:1px;background:var(--border);border:1px solid var(--border)}
.ear-static-grid.cols2{grid-template-columns:1fr 1fr}
.ear-static-grid.cols3{grid-template-columns:1fr 1fr 1fr}
.ear-static-img{aspect-ratio:3/4;overflow:hidden;background:var(--cream2)}
.ear-static-img img{width:100%;height:100%;object-fit:cover;
  object-position:center top;transition:transform .5s var(--ease)}
.ear-static-img:hover img{transform:scale(1.04)}
@media(max-width:600px){
  .ear-static-grid.cols3{grid-template-columns:1fr 1fr}
}

/* ── RHYTHM rebuilt ── */
.rhythm-elegant{margin:0}
.rhythm-full-video{width:100%;aspect-ratio:16/9;overflow:hidden;
  position:relative;background:#111;margin-bottom:1px}
.rhythm-full-video video{width:100%;height:100%;object-fit:cover;opacity:.9}
.rhythm-full-video-overlay{position:absolute;inset:0;
  background:linear-gradient(to top,rgba(10,10,10,.65) 0%,transparent 55%)}
.rhythm-full-video-caption{position:absolute;bottom:40px;left:48px;right:48px;
  color:#f4f1ec;display:flex;align-items:flex-end;justify-content:space-between}
.rv-left .rv-eye{font-size:.48rem;letter-spacing:.26em;text-transform:uppercase;opacity:.55;margin-bottom:10px}
.rv-left .rv-h{font-family:var(--serif);font-size:clamp(1.6rem,3vw,2.4rem);
  font-weight:400;line-height:1.2}
.rv-right{text-align:right;opacity:.65;font-size:.72rem;line-height:1.9;
  max-width:260px}
.rhythm-three-img{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;
  background:var(--border);border:1px solid var(--border);margin-bottom:1px}
.rhythm-three-img .rimg{overflow:hidden}
.rhythm-three-img .rimg img{width:100%;height:100%;object-fit:cover;
  object-position:center;transition:transform .6s var(--ease)}
.rhythm-three-img .rimg:hover img{transform:scale(1.04)}
.rhythm-three-img .rimg:first-child{aspect-ratio:3/4}
.rhythm-three-img .rimg:nth-child(2){aspect-ratio:3/4}
.rhythm-three-img .rimg:last-child{aspect-ratio:3/4}
.rhythm-cards-elegant{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1px;
  background:var(--border);border:1px solid var(--border);border-top:none}
.rhythm-card-el{background:var(--cream);padding:28px 24px;display:flex;flex-direction:column;gap:6px}
.rhythm-card-el .rc-kicker{font-size:.46rem;letter-spacing:.2em;text-transform:uppercase;color:var(--slv2)}
.rhythm-card-el .rc-name{font-family:var(--serif);font-size:.96rem;color:var(--grn);line-height:1.25}
.rhythm-card-el .rc-note{font-size:.72rem;line-height:1.9;color:var(--dust);flex:1}
.rhythm-card-el .rc-specs{display:flex;flex-wrap:wrap;gap:5px;margin-top:6px}
.rhythm-card-el .rc-price-row{display:flex;align-items:center;justify-content:space-between;
  margin-top:12px;padding-top:12px;border-top:1px solid var(--border)}
.rhythm-card-el .rc-price{font-size:.64rem;font-weight:600;color:var(--grn);opacity:.65}
.rhythm-card-el .rc-add{font-size:.45rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--white);background:var(--grn);border:none;cursor:pointer;
  padding:6px 12px;transition:background .2s}
.rhythm-card-el .rc-add:hover{background:var(--grn2,#2a4a38)}
.rhythm-card-el .rc-enquire{font-size:.48rem;letter-spacing:.12em;color:var(--slv);
  text-decoration:none;display:inline-flex;align-items:center;gap:5px;margin-top:4px;
  transition:color .2s}
.rhythm-card-el .rc-enquire::after{content:'';width:12px;height:1px;background:currentColor}
.rhythm-card-el .rc-enquire:hover{color:var(--grn)}
@media(max-width:768px){
  .rhythm-three-img,.rhythm-cards-elegant{grid-template-columns:1fr 1fr}
  .rhythm-full-video{aspect-ratio:4/3}
  .rhythm-full-video-caption{left:24px;bottom:24px}
  .rv-right{display:none}
}
@media(max-width:480px){
  .rhythm-three-img,.rhythm-cards-elegant{grid-template-columns:1fr}
}

/* ── PILLARS (Line 01 renamed) ── */
.pillars-intro{font-size:.78rem;line-height:2;color:var(--dust);max-width:680px;margin-bottom:32px}
.pillars-accord{border:1px solid var(--border);border-bottom:none}
.pillars-accord-item{border-bottom:1px solid var(--border)}
.pillars-accord-head{display:flex;align-items:center;justify-content:space-between;
  padding:18px 22px;cursor:pointer;background:var(--cream);transition:background .2s;
  user-select:none}
.pillars-accord-head:hover{background:var(--cream2)}
.pillars-accord-head.open{background:var(--grn);color:var(--white)}
.pillars-accord-label{font-family:var(--serif);font-size:.88rem;color:inherit}
.pillars-accord-head.open .pillars-accord-label{color:var(--white)}
.pillars-accord-sub{font-size:.56rem;letter-spacing:.12em;text-transform:uppercase;
  color:var(--slv);margin-top:2px}
.pillars-accord-head.open .pillars-accord-sub{color:rgba(255,255,255,.6)}
.pillars-accord-icon{font-size:.9rem;transition:transform .25s;color:var(--slv)}
.pillars-accord-head.open .pillars-accord-icon{transform:rotate(45deg);color:var(--white)}
.pillars-accord-body{display:none;padding:0 22px 22px;background:var(--cream)}
.pillars-accord-body.open{display:block}
.pillars-items{display:flex;flex-direction:column;gap:0;margin-top:16px}
.pillars-item{display:flex;align-items:baseline;justify-content:space-between;
  padding:9px 0;border-bottom:1px dashed var(--border)}
.pillars-item:last-child{border-bottom:none}
.pillars-item-name{font-size:.78rem;color:var(--grn)}
.pillars-item-price{font-size:.6rem;color:var(--slv);letter-spacing:.04em;white-space:nowrap;margin-left:12px}
.pillars-note{font-size:.7rem;line-height:1.9;color:var(--dust);margin-bottom:12px}



/* ── Rhythm two-cards layout ── */
.rhythm-two-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-top: none;
}
.rhythm-card-main {
  background: var(--cream);
  display: flex;
  flex-direction: column;
  transition: background .25s;
}
.rhythm-card-main:hover { background: var(--white); }
.rcm-img {
  width: 100%;
  aspect-ratio: 4/3;
  overflow: hidden;
  background: var(--cream2);
  border-bottom: 1px solid var(--border);
}
.rcm-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform .5s var(--ease);
}
.rhythm-card-main:hover .rcm-img img { transform: scale(1.04); }
.rcm-body {
  padding: 24px 22px;
  display: flex;
  flex-direction: column;
  gap: 6px;
  flex: 1;
}
.rcm-kicker { font-size: .46rem; letter-spacing: .2em; text-transform: uppercase; color: var(--slv2); }
.rcm-name { font-family: var(--serif); font-size: .96rem; color: var(--grn); line-height: 1.25; }
.rcm-note { font-size: .72rem; line-height: 1.9; color: var(--dust); flex: 1; }
.rcm-specs { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 6px; }
.rcm-price-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--border);
}
.rcm-price { font-size: .64rem; font-weight: 600; color: var(--grn); opacity: .65; }
.rcm-discover {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 10px;
  font-size: .52rem;
  font-weight: 600;
  letter-spacing: .14em;
  text-transform: uppercase;
  color: var(--grn);
  text-decoration: none;
  transition: gap .2s, color .2s;
}
.rcm-discover::after { content: ''; width: 16px; height: 1px; background: currentColor; transition: width .2s; }
.rcm-discover:hover { gap: 11px; }
.rcm-discover:hover::after { width: 24px; }

@media(max-width:600px){
  .rhythm-two-cards { grid-template-columns: 1fr; }
}


/* Video never hidden by reveal */
.rhythm-full-video { opacity: 1 !important; transform: none !important; }
.rhythm-full-video video { opacity: 1 !important; }

/* ── B2B CATEGORIES restored ── */
.b2b-cat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;
  background:var(--border);border:1px solid var(--border);margin:32px 0 48px}
.b2b-cat-card{background:var(--cream);padding:24px 20px;
  transition:background .25s;display:flex;flex-direction:column;gap:8px}
.b2b-cat-card:hover{background:var(--white)}
.b2b-cat-num{font-size:.44rem;letter-spacing:.22em;text-transform:uppercase;
  color:var(--slv2)}
.b2b-cat-name{font-family:var(--serif);font-size:.98rem;color:var(--grn);
  font-weight:400;line-height:1.2}
.b2b-cat-types{font-size:.65rem;line-height:1.85;color:var(--dust);flex:1}
.b2b-cat-enquire{display:inline-flex;align-items:center;gap:5px;margin-top:8px;
  font-size:.48rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;
  color:var(--slv);text-decoration:none;transition:color .2s}
.b2b-cat-enquire::after{content:'';width:12px;height:1px;background:currentColor;
  transition:width .2s}
.b2b-cat-enquire:hover{color:var(--grn)}
.b2b-cat-enquire:hover::after{width:20px}
@media(max-width:1024px){.b2b-cat-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.b2b-cat-grid{grid-template-columns:1fr 1fr}}

/* ══════════════════════════════════════════════════════════
   MOBILE → DESKTOP STRUCTURE OVERRIDE
   Keeps desktop-like layout on phone screens
   ══════════════════════════════════════════════════════════ */

@media(max-width:768px){
  /* NAV: keep links visible, compact style */
  .nav-links{display:none !important}
  .burger{display:flex !important}
  nav{padding:0 14px !important}

  /* HERO: keep watermark, reduce padding */
  .hero-wm{display:none !important}
  .hero-top{padding:48px 16px 24px !important}
  .hero-h{font-size:clamp(1.4rem,4.5vw,2.4rem) !important}
  .hero-sub{font-size:.72rem !important;max-width:90% !important}

  /* SERVICE PANELS: keep horizontal, not vertical */
  .panels{flex-direction:row !important;margin:14px 10px 0 !important;
    background:rgba(30,53,40,.07) !important;gap:1px !important;min-height:200px !important}
  .panel{margin-bottom:0 !important;padding:16px 12px !important}
  .panel.active{flex:3.8 !important}
  .p-num{font-size:2rem !important}
  .p-title{font-size:.78rem !important}
  .panel.active .p-title{font-size:1rem !important}
  .p-desc{font-size:.64rem !important;line-height:1.7 !important}
  .p-hint{font-size:.42rem !important}
  .p-tag{font-size:.38rem !important;padding:2px 5px !important}
  .p-tl-steps{flex-wrap:wrap !important}
  .p-tl-step{min-width:30% !important}
  .p-tl-name{font-size:.38rem !important}
  .p-tl-days{font-size:.34rem !important}
  .p-cta{font-size:.44rem !important}
  .consult-textarea{font-size:.64rem !important;min-height:60px !important}
  .consult-send{font-size:.46rem !important;padding:8px 14px !important}

  /* VALUE STRIP: keep 4-column → 2×2 */
  .value-inner{grid-template-columns:1fr 1fr !important}
  .val-title{font-size:.88rem !important}
  .val-desc{font-size:.62rem !important}

  /* PILLARS: keep 3 columns */
  .pillars{grid-template-columns:repeat(3,1fr) !important}
  .pillar{padding:20px 14px !important}
  .pillar-title{font-size:.78rem !important}
  .pillar-desc{font-size:.6rem !important}

  /* IDENTITY: keep 2-column grid */
  .id-grid{grid-template-columns:1.2fr 1fr !important;gap:28px !important}
  .id-h{font-size:clamp(1.1rem,2.2vw,1.6rem) !important}
  .id-p{font-size:.68rem !important}
  .id-photo-img{width:90% !important}
  .id-photo-box{width:90% !important}

  /* PROCESS ACCORDION */
  .svc-trigger{grid-template-columns:44px 1fr auto !important;gap:10px !important;padding:20px 0 !important}
  .svc-num{font-size:2rem !important}
  .svc-name{font-size:clamp(.9rem,2vw,1.2rem) !important}
  .svc-body-in{padding:0 0 20px 54px !important}

  /* MARKET: keep 3-column */
  .market-grid{grid-template-columns:repeat(3,1fr) !important}
  .mkt-card{padding:24px 14px !important}
  .mkt-title{font-size:.82rem !important}
  .mkt-desc{font-size:.6rem !important;line-height:1.7 !important}

  /* CTA STRIPS */
  .cta-strip h2{font-size:clamp(1.1rem,2.5vw,1.6rem) !important}
  .cta-strip p{font-size:.68rem !important}

  /* COLLECTIONS: keep 2+ columns */
  .coll-grid,.coll-grid-3,.v-grid,.rhythm-card-grid{grid-template-columns:repeat(2,1fr) !important}
  .coll-sec.optimized{padding:60px 14px 60px !important}
  .coll-card-body{padding:12px 10px 14px !important}
  .coll-card-name{font-size:.78rem !important}
  .coll-card-note{font-size:.58rem !important}
  .collection-nav.clean a{font-size:.44rem !important;padding:7px 8px !important}

  /* PRODUCT GRIDS: keep 2 columns minimum */
  .prod-grid.col3,.prod-grid.col4,.prod-grid.col5{grid-template-columns:repeat(3,1fr) !important}
  .prod-card-body{padding:12px 10px 14px !important}
  .prod-card-name{font-size:.76rem !important}
  .prod-card-note{font-size:.58rem !important}
  .prod-card-price{font-size:.54rem !important}
  .spec-pill{font-size:.38rem !important}
  .product-specs{grid-template-columns:1fr 1fr !important}
  .product-spec-v{font-size:.54rem !important}

  /* EAR: keep 2 columns */
  .ear-grid-new{grid-template-columns:1.15fr .85fr !important}
  .ear-static-grid.cols3{grid-template-columns:1fr 1fr 1fr !important}

  /* RHYTHM: keep 2-column layout */
  .rhythm-wrap{grid-template-columns:1fr 1fr !important}
  .rhythm-three-img,.rhythm-cards-elegant{grid-template-columns:repeat(2,1fr) !important}
  .rhythm-two-cards{grid-template-columns:1fr 1fr !important}
  .rhythm-full-video{aspect-ratio:16/9 !important}
  .rhythm-full-video-caption{left:16px !important;bottom:16px !important}
  .rv-right{display:block !important;font-size:.58rem !important}

  /* LINE 01 */
  .line01-grid{grid-template-columns:1fr 1fr !important;gap:18px !important}
  .line01-framework{grid-template-columns:1.1fr .9fr !important}

  /* B2B: keep 2+ columns */
  .b2b-cat-grid{grid-template-columns:repeat(2,1fr) !important}
  .b2b-details-grid{grid-template-columns:repeat(2,1fr) !important}
  .b2b-block-head{grid-template-columns:1fr auto !important}
  .b2b-target{grid-template-columns:1fr !important}
  .b2b-final{grid-template-columns:1fr auto !important}
  .b2b-details,.b2b-target,.b2b-final{padding:22px 16px !important}

  /* SECTION RAILS, BANDS */
  .section-rail{grid-template-columns:repeat(3,1fr) !important}
  .collection-band{grid-template-columns:repeat(3,1fr) !important}
  .duet-grid-clean,.duet-grid-clean.four{grid-template-columns:repeat(2,1fr) !important}
  .duet-grid-clean.five{grid-template-columns:repeat(3,1fr) !important}
  .offer-grid{grid-template-columns:repeat(2,1fr) !important}
  .offer-pillars{grid-template-columns:1fr 1fr !important}
  .rhythm-showcase{grid-template-columns:1.05fr .95fr !important}
  .clean-block{padding:20px 14px !important}
  .clean-head{grid-template-columns:1fr auto !important}

  /* CONTACT FORM */
  .cf-row{grid-template-columns:1fr 1fr !important}
  .contact-form-wrap{max-width:100% !important}
  .contact-det{gap:24px !important;flex-wrap:wrap !important}

  /* FOOTER: keep horizontal */
  footer{flex-direction:row !important;text-align:left !important;padding:22px 14px !important;gap:10px !important}
  .f-logo{font-size:.7rem !important}
  .f-copy{font-size:.48rem !important}
  .f-links{gap:12px !important}
  .f-links a{font-size:.46rem !important}

  /* SECTION SPACING */
  .sec-h{margin-bottom:36px !important;font-size:clamp(1.3rem,3.5vw,2rem) !important}
  .value-strip,.intro-sec,.identity-sec,.process-sec,.b2b-sec,.market-sec,.contact-sec,.cta-strip{padding-top:52px !important;padding-bottom:52px !important}

  /* CHATBOT */
  #chat-window{width:320px !important;right:12px !important;bottom:76px !important}
  #chat-trigger{bottom:14px !important;right:14px !important;width:44px !important;height:44px !important}
  #chat-trigger svg{width:18px !important;height:18px !important}

  /* CART */
  .cart-btn-wrap{bottom:72px !important;right:12px !important}
  .cart-fab{width:44px !important;height:44px !important;font-size:1rem !important}
}

@media(max-width:480px){
  /* Keep 2-column grids, never collapse to 1 */
  .value-inner{grid-template-columns:1fr 1fr !important}
  .coll-grid,.coll-grid-3,.v-grid{grid-template-columns:repeat(2,1fr) !important}
  .rhythm-grid,.rhythm-card-grid,.rhythm-three-img,.rhythm-cards-elegant{grid-template-columns:repeat(2,1fr) !important}
  .prod-grid.col3,.prod-grid.col5{grid-template-columns:repeat(3,1fr) !important}.prod-grid.col2{grid-template-columns:repeat(2,1fr) !important}
  .rhythm-two-cards{grid-template-columns:1fr 1fr !important}
  .b2b-target-points{flex-direction:row !important;flex-wrap:wrap !important}

  /* Smaller type for very small screens */
  .nav-links a{font-size:.4rem !important;letter-spacing:.06em !important}
  .nav-links{gap:8px !important}
  .nav-cta{padding:5px 8px !important;font-size:.38rem !important}
  .hero-h{font-size:clamp(1.2rem,4vw,1.8rem) !important}
  .hero-sub{font-size:.64rem !important}
  .p-title{font-size:.68rem !important}
  .panel.active .p-title{font-size:.88rem !important}
  .p-num{font-size:1.6rem !important}

  /* Pillars: keep 3 col but smaller */
  .pillars{grid-template-columns:repeat(3,1fr) !important}
  .pillar{padding:14px 10px !important}
  .pillar-title{font-size:.68rem !important}
  .pillar-desc{font-size:.52rem !important}

  /* Market: keep 3 col */
  .market-grid{grid-template-columns:repeat(3,1fr) !important}
  .mkt-desc{font-size:.52rem !important}

  /* Footer */
  footer{flex-direction:row !important;flex-wrap:wrap !important}
}

/* Allow pinch zoom on mobile for accessibility */
@media(max-width:768px){
  html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
}



/* ── MOBILE POLISH / PHONE-FIRST OVERRIDES ───────────────────────── */
html,body{max-width:100%;overflow-x:hidden}
@media (max-width: 768px){
  body{font-size:16px}
  nav{padding:0 14px}
  .nav-logo{font-size:.88rem;max-width:70vw;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
  .burger{padding:10px;margin-right:-6px}
  .burger span{width:24px;height:2px}
  .mob{justify-content:flex-start;padding:88px 24px 28px;overflow-y:auto}
  .mob a{font-size:1.35rem;line-height:1.2;text-align:center}
  .mob .mob-cta{width:100%;max-width:320px;text-align:center}

  .hero{min-height:auto}
  .hero-top{padding:42px 18px 22px}
  .hero-eyebrow{margin-bottom:16px;gap:10px;letter-spacing:.22em}
  .hero-h{font-size:clamp(1.7rem,8vw,2.25rem);line-height:1.18;margin-bottom:14px}
  .hero-sub{font-size:.82rem;line-height:1.8;max-width:34ch;margin-bottom:22px}
  .hero-ctas,.cta-btns{display:grid;grid-template-columns:1fr;gap:10px}
  .hero-ctas > *, .cta-btns > *, .contact-btn, .b2b-head-cta, .line01-btn, .cf-submit{width:100%;justify-content:center}
  .btn-dark,.btn-ghost,.btn-light,.btn-ghost-light,.contact-btn,.cf-submit{padding:15px 18px}

  .panels{margin:14px 12px 0;border:1px solid var(--border);background:var(--border)}
  .panel{padding:18px 16px}
  .panel.active{padding-bottom:20px}
  .p-title{font-size:.9rem}
  .panel.active .p-title{font-size:1.1rem}
  .p-desc{font-size:.74rem;line-height:1.8}
  .p-tags{gap:6px}
  .p-tag{font-size:.46rem}
  .p-close{top:10px;right:10px}

  .sec-eye{gap:10px;letter-spacing:.22em}
  .sec-h{margin-bottom:30px;line-height:1.12}
  .intro-q{margin-bottom:24px;line-height:1.45}
  .pillar,.val-box,.b2b-index-item,.b2b-card-body,.b2b-detail,.mkt-card{padding:22px 18px}
  .id-grid{gap:28px}
  .id-photo-img,.id-photo-box{width:100%;max-width:320px}
  .id-stats{display:grid;grid-template-columns:1fr 1fr}
  .id-stat{padding:16px 8px}

  .svc-trigger{grid-template-columns:42px 1fr 28px;gap:12px;padding:22px 0}
  .svc-num{font-size:2rem}
  .svc-name{font-size:1.05rem}
  .svc-name-sub,.b2b-block-head p,.b2b-lead,.coll-intro-p,.contact-p{font-size:.76rem;line-height:1.75}
  .svc-body-in{padding:0 0 22px 54px}

  .collection-nav{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;padding-bottom:6px;scrollbar-width:none}
  .collection-nav::-webkit-scrollbar{display:none}
  .collection-nav a{flex:0 0 auto}

  .prod-grid,.coll-grid,.coll-grid-3,.rhythm-grid,.rhythm-card-grid,.market-grid,.b2b-grid,.b2b-details-grid,.b2b-cat-grid{grid-template-columns:1fr !important}
  .prod-card,.coll-card,.rhythm-card,.b2b-card{min-width:0}
  .prod-card-body,.coll-card-body{padding:16px 14px 18px}
  .prod-card-name,.coll-card-name{font-size:.92rem}
  .prod-card-note,.coll-card-note,.rhythm-card-note{font-size:.72rem;line-height:1.7}
  .prod-card-specs,#collections .product-specs{grid-template-columns:1fr !important}
  .prod-card-add,.coll-card-add{width:100%;justify-content:center;padding:10px 14px}

  .line01-compact,.coll-block.line01,.b2b-details,.b2b-target,.b2b-final{padding:22px 16px}
  .line01-groups{grid-template-columns:1fr;gap:10px}
  .line01-group{padding:14px 14px 12px}
  .line01-item{grid-template-columns:26px 1fr;gap:8px}
  .line01-icon{width:26px;height:26px}

  .contact-form-wrap{margin-bottom:28px}
  .site-contact-form{gap:12px}
  .cf-row{grid-template-columns:1fr;gap:12px}
  .cf-input,.cf-textarea,.cf-select{font-size:16px;padding:14px 13px}

  #chat-trigger{bottom:16px;right:16px;width:52px;height:52px}
  #chat-window{right:8px;left:8px;bottom:74px;width:auto;max-width:none;max-height:60vh;height:auto;border:1px solid rgba(30,53,40,.1);box-shadow:0 8px 40px rgba(30,53,40,.16)}
  .chat-head{padding:14px 16px}
  .chat-msgs{padding:14px}
  .chat-msg{max-width:92%;font-size:.78rem}
  .chat-foot{padding:10px 12px calc(10px + env(safe-area-inset-bottom))}
  .chat-inp{font-size:16px}

  .cart-btn-wrap{right:16px;bottom:78px}
  .cart-drawer{width:100vw;right:-100vw}
  .cart-head{padding:18px 16px 16px}
  .cart-items{padding:0 16px}
  .cart-footer{padding:16px 16px calc(16px + env(safe-area-inset-bottom))}

  footer{padding-bottom:calc(24px + env(safe-area-inset-bottom))}
}

@media (max-width: 480px){
  :root{--section-tight:56px}
  .hero-top,.coll-sec.optimized,.coll-sec,.value-strip,.intro-sec,.identity-sec,.process-sec,.b2b-sec,.market-sec,.contact-sec,.cta-strip{padding-left:14px;padding-right:14px}
  .hero-h{font-size:1.56rem}
  .hero-sub{font-size:.78rem}
  .hero-eyebrow,.sec-eye{font-size:.5rem}
  .panel,.pillar,.val-box,.b2b-index-item,.b2b-card-body,.b2b-detail,.mkt-card,.line01-group{padding-left:14px;padding-right:14px}
  .contact-det{display:grid;grid-template-columns:1fr;gap:16px}
  .id-stats{grid-template-columns:1fr}
  .cart-btn-wrap{bottom:74px}
}



/* ── RHYTHM PENDANT ── */
.rhythm-pendant-row {
  display: grid;
  grid-template-columns: 1.1fr 0.9fr;
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-top: none;
  margin-top: 0;
}
.rp-images {
  display: flex;
  flex-direction: column;
  gap: 1px;
  background: var(--border);
}
.rp-img-main {
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--cream2);
}
.rp-img-main img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  transition: transform .5s var(--ease);
}
.rhythm-pendant-row:hover .rp-img-main img { transform: scale(1.03); }
.rp-img-sub {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1px;
  background: var(--border);
}
.rp-img-s {
  aspect-ratio: 1/1;
  overflow: hidden;
  background: var(--cream2);
}
.rp-img-s img {
  width: 100%; height: 100%;
  object-fit: cover; object-position: center;
  transition: transform .5s var(--ease);
}
.rp-body {
  background: var(--cream);
  padding: 28px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  justify-content: center;
}
@media(max-width:768px){
  .rhythm-pendant-row{
    grid-template-columns: 1fr;
  }
  .rp-img-main{ aspect-ratio: 4/3; }
}
@media(max-width:480px){
  .rp-body{ padding: 18px 14px; }
}

/* ========== */

@media (max-width: 480px){
  html, body{
    overflow-x:hidden !important;
    -webkit-text-size-adjust:100%;
  }

  /* cart stays top-right */
  .cart-btn-wrap{
    position:fixed !important;
    top:10px !important;
    right:10px !important;
    bottom:auto !important;
    left:auto !important;
    z-index:4100 !important;
  }
  .cart-fab{
    width:44px !important;
    height:44px !important;
    font-size:1rem !important;
  }

  /* chatbot stays bottom-right */
  #chat-trigger{
    position:fixed !important;
    right:12px !important;
    left:auto !important;
    bottom:12px !important;
    top:auto !important;
    z-index:3200 !important;
    width:46px !important;
    height:46px !important;
  }
  #chat-window{
    position:fixed !important;
    right:8px !important;
    left:8px !important;
    bottom:66px !important;
    top:auto !important;
    width:auto !important;
    max-width:none !important;
    max-height:54vh !important;
    height:auto !important;
    z-index:3199 !important;
  }
  .chat-head{padding:12px !important}
  .chat-msgs{
    max-height:30vh !important;
    overflow-y:auto !important;
    -webkit-overflow-scrolling:touch;
    padding:12px !important;
  }
  .chat-foot{
    position:sticky;
    bottom:0;
    background:var(--white);
    padding:10px !important;
  }
  .chat-inp{
    font-size:16px !important; /* prevents iPhone zoom */
    min-height:38px !important;
  }

  /* mobile text optimisation without changing structure */
  .hero-sub,
  .coll-desc,
  .coll-card-note,
  .b2b-card p,
  .contact-p,
  .id-p,
  .rhythm-card-note{
    font-size:.72rem !important;
    line-height:1.7 !important;
  }

  .coll-name,
  .rhythm-card-name,
  .coll-card-name,
  .id-h{
    line-height:1.2 !important;
  }

  .coll-block-head,
  .clean-head,
  .b2b-block-head{
    grid-template-columns:1fr !important;
    gap:12px !important;
    align-items:start !important;
  }

  .b2b-head-cta,
  .nav-cta,
  .btn-dark,
  .btn-ghost,
  .contact-btn{
    white-space:normal !important;
    text-align:center !important;
    justify-content:center !important;
    padding:10px 14px !important;
    font-size:.56rem !important;
  }

  /* profile readability + slightly smaller photo */
  .id-grid{
    grid-template-columns:1fr !important;
    gap:22px !important;
  }
  .id-photo-img,
  .id-photo-box{
    width:48% !important;
    max-width:170px !important;
    margin:0 auto !important;
  }

  /* a bit tighter vertical rhythm */
  .identity-sec,
  .process-sec,
  .coll-sec,
  .b2b-sec,
  .market-sec,
  .contact-sec,
  .intro-sec,
  .value-strip,
  .cta-strip{
    padding-top:56px !important;
    padding-bottom:56px !important;
  }
}

/* ========== */

/* SERVICES CLICKABLE ANIMATION */

/* subtle idle animation */
@keyframes serviceHint{
  0%{transform:translateY(0)}
  50%{transform:translateY(-4px)}
  100%{transform:translateY(0)}
}

/* pulse border */
@keyframes servicePulse{
  0%{box-shadow:0 0 0 0 rgba(30,53,40,.12)}
  70%{box-shadow:0 0 0 10px rgba(30,53,40,0)}
  100%{box-shadow:0 0 0 0 rgba(30,53,40,0)}
}

/* apply on desktop */
@media (min-width:769px){
  .panel{
    position:relative;
    transition:transform .25s ease, box-shadow .25s ease;
  }

  .panel::before{
    content:"click";
    position:absolute;
    top:14px;
    right:14px;
    font-size:.5rem;
    letter-spacing:.2em;
    text-transform:uppercase;
    opacity:.35;
    pointer-events:none;
  }

  .panel:hover{
    transform:translateY(-6px);
    box-shadow:0 10px 30px rgba(0,0,0,.08);
  }

  .panel:not(.active){
    animation:servicePulse 2.5s infinite;
  }
}

/* mobile scroll hint */
@media (max-width:768px){
  .panel{
    animation:serviceHint 2.2s ease-in-out infinite;
  }

  .panel::after{
    content:"tap to explore";
    display:block;
    font-size:.5rem;
    letter-spacing:.16em;
    text-transform:uppercase;
    opacity:.4;
    margin-top:6px;
  }

  .panel.active{
    animation:none;
  }
}

/* ========== */

/* 1) NAV FIX MOBILE: ONLY FULL NAME + BURGER */
@media (max-width:768px){

  .nav-links{
    display:none !important;
  }

  .nav-logo{
    font-size:.9rem !important;
    letter-spacing:.06em !important;
    white-space:nowrap !important;
    overflow:visible !important;
    text-overflow:unset !important;
    max-width:none !important;
  }

}

/* 2) STRONGER SERVICE INTERACTION (DESKTOP) */

@media (min-width:769px){

  .panel{
    transition:transform .3s ease, box-shadow .3s ease, background .3s;
    cursor:pointer;
  }

  .panel:hover{
    transform:translateY(-10px) scale(1.02);
    box-shadow:0 18px 50px rgba(0,0,0,.12);
  }

  .panel:not(.active){
    animation:none !important;
  }

  /* strong visual hint */
  .panel::after{
    content:"";
    position:absolute;
    inset:0;
    border:1px solid rgba(30,53,40,.08);
    transition:border .3s;
  }

  .panel:hover::after{
    border:1px solid rgba(30,53,40,.3);
  }

}

/* mobile: clearer tap affordance */
@media (max-width:768px){

  .panel{
    border:1px solid rgba(30,53,40,.1);
    background:var(--white);
  }

  .panel::after{
    content:"tap";
    position:absolute;
    top:10px;
    right:10px;
    font-size:.5rem;
    letter-spacing:.2em;
    opacity:.35;
  }

}

/* ========== */

/* language selector */
.chat-lang-sel{background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);color:var(--white);font-size:.75rem;padding:3px 5px;cursor:pointer;border-radius:2px;outline:none;-webkit-appearance:none;appearance:none;transition:background .2s}
.chat-lang-sel:hover{background:rgba(255,255,255,.22)}
.chat-lang-sel option{background:var(--grn);color:var(--white)}

/* progress bar */
.chat-progress-wrap{height:3px;background:rgba(30,53,40,.08);flex-shrink:0}
.chat-progress-bar{height:100%;width:0%;background:linear-gradient(90deg,var(--grn),var(--slv2));transition:width .6s cubic-bezier(.4,0,.2,1)}

/* summary card */
.chat-summary{background:var(--cream);border:1px solid var(--border);padding:14px;border-radius:1px;font-size:.72rem;line-height:1.6;width:100%}
.cs-title{font-family:var(--serif);font-size:.85rem;color:var(--grn);margin-bottom:10px;font-weight:500}
.cs-row{display:flex;gap:8px;padding:5px 0;border-bottom:1px solid var(--border)}
.cs-row:last-child{border-bottom:none}
.cs-k{font-size:.52rem;letter-spacing:.12em;text-transform:uppercase;color:var(--slv);flex-shrink:0;width:60px;padding-top:1px}
.cs-v{color:var(--grn);flex:1;word-break:break-word}

/* card message — takes full width */
.chat-msg.chat-card{max-width:100%;background:transparent;padding:0}

/* input error shake */
@keyframes chatShake{0%,100%{transform:translateX(0)}25%{transform:translateX(-4px)}75%{transform:translateX(4px)}}
.chat-inp-error{border-color:rgba(180,60,60,.5)!important;animation:chatShake .3s ease}
.chat-inp-error::placeholder{color:rgba(180,60,60,.7)!important}

/* typing bubble */
.typing-bubble{display:flex;align-items:center;gap:3px;padding:10px 14px!important}

/* link inside chat messages */
.chat-msg a{color:var(--grn);text-decoration:underline}
.chat-msg.user a{color:rgba(255,255,255,.85)}

/* ========== */

@media (max-width:768px){
  .burger{display:flex !important}
  .nav-links{display:none !important}
}
@media (min-width:769px){
  .burger{display:none !important}
  .nav-links{display:flex !important}
}

/* ========== */

@media (max-width:480px){

  /* ── SERVICES PANELS: 2×2 grid, not 4-in-a-row ── */
  .panels{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:1px !important;
    flex-direction:unset !important;
    margin:16px 0 0 !important;
    min-height:0 !important;
    background:rgba(30,53,40,.07) !important;
  }
  .panel{
    flex:none !important;
    padding:18px 14px !important;
    min-height:130px !important;
  }
  .panel.active{
    grid-column:1 / -1 !important;
    flex:none !important;
  }
  .p-num{
    font-size:1.8rem !important;
    opacity:.18 !important;
    margin-bottom:4px !important;
  }
  .p-title{
    font-size:.82rem !important;
    line-height:1.2 !important;
  }
  .panel.active .p-title{
    font-size:.95rem !important;
  }
  .p-hint{font-size:.44rem !important}
  .p-desc{font-size:.68rem !important;line-height:1.6 !important}
  .p-tag{font-size:.42rem !important;padding:3px 6px !important}
  .p-cta{font-size:.48rem !important}

  /* ── COLLECTION BLOCK HEADER: stack vertically ── */
  .coll-block-head-row{
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:14px !important;
  }
  .coll-block-head-row .b2b-head-cta{
    align-self:flex-start !important;
    width:auto !important;
    padding:9px 16px !important;
    font-size:.52rem !important;
  }
  .coll-block-kicker{
    font-size:.44rem !important;
    letter-spacing:.16em !important;
  }
  .coll-block-title{
    font-size:1.4rem !important;
    line-height:1.2 !important;
  }
  .coll-block-desc{
    font-size:.72rem !important;
    line-height:1.75 !important;
  }

  /* ── SECTION SPACING: more compact ── */
  .identity-sec,
  .process-sec,
  .coll-sec,
  .b2b-sec,
  .market-sec,
  .contact-sec,
  .intro-sec,
  .value-strip,
  .cta-strip{
    padding-top:48px !important;
    padding-bottom:48px !important;
    padding-left:16px !important;
    padding-right:16px !important;
  }
  .coll-sec.optimized{
    padding:48px 16px !important;
  }

  /* ── HERO: less top space ── */
  .hero-top{
    padding:14px 16px 20px !important;
  }
  .hero-h{
    font-size:1.55rem !important;
    line-height:1.18 !important;
    margin-bottom:12px !important;
  }
  .hero-sub{
    font-size:.72rem !important;
    line-height:1.7 !important;
    margin-bottom:18px !important;
  }
  .hero-eyebrow{
    margin-bottom:12px !important;
    font-size:.5rem !important;
  }

  /* ── SEC HEADERS ── */
  .sec-h{
    font-size:1.35rem !important;
    margin-bottom:28px !important;
    line-height:1.2 !important;
  }

  /* ── IDENTITY: photo sizing ── */
  .id-grid{
    grid-template-columns:1fr !important;
    gap:20px !important;
  }
  .id-photo-img,
  .id-photo-box{
    width:52% !important;
    max-width:180px !important;
    margin:0 auto !important;
  }
  .id-stats{
    flex-direction:row !important;
  }

  /* ── COLLECTION NAV TABS ── */
  .collection-nav{
    gap:6px !important;
    margin-bottom:20px !important;
  }
  .collection-nav a{
    font-size:.48rem !important;
    padding:8px 10px !important;
  }

  /* ── BUTTONS ── */
  .btn-dark,
  .btn-ghost,
  .contact-btn{
    font-size:.56rem !important;
    padding:11px 18px !important;
    width:100% !important;
    justify-content:center !important;
    box-sizing:border-box !important;
  }
  .hero-ctas{
    flex-direction:column !important;
    gap:8px !important;
    align-items:stretch !important;
  }

  /* ── CHAT & CART ── */
  #chat-trigger{
    bottom:14px !important;
    right:14px !important;
    width:46px !important;
    height:46px !important;
  }
  #chat-window{
    left:8px !important;
    right:8px !important;
    bottom:68px !important;
    max-height:56vh !important;
  }
  .cart-btn-wrap{
    top:10px !important;
    right:62px !important;
    bottom:auto !important;
    left:auto !important;
    transform:none !important;
  }

}

/* ========== */

/* ── FINAL MOBILE OVERRIDES - highest priority ── */
@media (max-width:480px){

  /* 1. PRODUCT GRIDS: col3 stays 3 columns */
  .prod-grid.col3{
    grid-template-columns:repeat(3,1fr) !important;
    gap:1px !important;
  }
  .prod-card-body{padding:8px 7px 10px !important}
  .prod-card-name{font-size:.62rem !important;line-height:1.2 !important}
  .prod-card-note{font-size:.52rem !important;line-height:1.5 !important}
  .prod-card-tier{font-size:.38rem !important}
  .prod-card-price{font-size:.46rem !important}
  .prod-card-specs{display:none !important}
  .prod-card-add{font-size:.38rem !important;padding:5px 6px !important}

  /* 2. ENQUIRE / COLLECTION BLOCK HEAD: force stack */
  /* 2. ENQUIRE / COLLECTION BLOCK HEAD: force stack */
  .coll-block-head-row{
    display:flex !important;
    flex-direction:column !important;
    align-items:flex-start !important;
    gap:12px !important;
    margin-bottom:16px !important;
  }
  .coll-block-head-row .b2b-head-cta{
    align-self:flex-start !important;
    width:auto !important;
    max-width:max-content !important;
    padding:9px 16px !important;
    font-size:.52rem !important;
    white-space:nowrap !important;
  }
  .coll-block-kicker{
    font-size:.44rem !important;
    letter-spacing:.14em !important;
    line-height:1.4 !important;
  }
  .coll-block-title{
    font-size:1.3rem !important;
    line-height:1.2 !important;
    margin-top:4px !important;
  }

  /* 3. SERVICES: vertical accordion strips */
  .panels{
    display:flex !important;
    flex-direction:column !important;
    gap:1px !important;
    margin:14px 0 0 !important;
    min-height:0 !important;
    background:rgba(30,53,40,.07) !important;
  }
  .panel{
    flex:none !important;
    width:100% !important;
    padding:18px 16px !important;
    min-height:0 !important;
    cursor:pointer !important;
  }
  .panel.active{
    flex:none !important;
    width:100% !important;
  }
  .p-num{
    font-size:1.5rem !important;
    opacity:.15 !important;
    margin-bottom:2px !important;
    display:inline-block !important;
  }
  .p-title{
    font-size:.92rem !important;
    line-height:1.25 !important;
  }
  .panel.active .p-title{
    font-size:1rem !important;
  }
  /* show a small chevron hint */
  .p-hint{
    font-size:.5rem !important;
    letter-spacing:.14em !important;
  }

  /* 4. CHATBOT: always anchored bottom-right, never drifts left */
  #chat-trigger{
    position:fixed !important;
    bottom:14px !important;
    right:14px !important;
    left:auto !important;
    top:auto !important;
    transform:none !important;
    z-index:3200 !important;
    width:46px !important;
    height:46px !important;
  }
  #chat-window{
    position:fixed !important;
    right:8px !important;
    left:8px !important;
    bottom:68px !important;
    top:auto !important;
    width:auto !important;
    max-width:none !important;
    max-height:58vh !important;
    transform:none !important;
    z-index:3199 !important;
  }

  /* 4b. IDENTITY: side-by-side even on mobile */
  .id-grid{
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:14px !important;
    align-items:start !important;
    margin-top:24px !important;
  }
  .id-text{
    min-width:0 !important;
  }
  .id-h{
    font-size:.95rem !important;
    line-height:1.2 !important;
    margin-bottom:8px !important;
  }
  .id-p{
    font-size:.62rem !important;
    line-height:1.6 !important;
    margin-bottom:8px !important;
  }
  .id-photo-col{
    min-width:0 !important;
  }
  .id-photo-img,
  .id-photo-box{
    width:100% !important;
    max-width:none !important;
    margin:0 !important;
  }
  .id-stats{
    display:flex !important;
    flex-direction:column !important;
    gap:1px !important;
    margin-top:8px !important;
  }
  .id-stat-n{
    font-size:1.2rem !important;
  }
  .id-stat-l{
    font-size:.46rem !important;
  }

  /* 5. SECTION SPACING */
  .value-strip,.intro-sec,.identity-sec,.process-sec,
  .b2b-sec,.market-sec,.contact-sec,.cta-strip,
  .coll-sec,.coll-sec.optimized{
    padding-top:44px !important;
    padding-bottom:44px !important;
    padding-left:14px !important;
    padding-right:14px !important;
  }

  /* 6. CART button — clear of chatbot */
  .cart-btn-wrap{
    position:fixed !important;
    top:10px !important;
    right:60px !important;
    left:auto !important;
    bottom:auto !important;
    transform:none !important;
    z-index:4100 !important;
  }

  /* 7. Force all reveal elements visible — no invisible boxes on mobile */
  .reveal{
    opacity:1 !important;
    transform:none !important;
    pointer-events:auto !important;
  }

  /* 8. b2b-final: stack vertically */
  .b2b-final{
    grid-template-columns:1fr !important;
    padding:22px 16px !important;
    gap:16px !important;
  }
  .b2b-final h3{
    font-size:1.1rem !important;
    line-height:1.3 !important;
  }
  .b2b-final p{
    font-size:.68rem !important;
    line-height:1.65 !important;
  }
  .b2b-final .btn-dark{
    width:100% !important;
    justify-content:center !important;
  }

  /* 9. b2b-details-grid: 1 column */
  .b2b-details-grid{
    grid-template-columns:1fr !important;
  }
  .b2b-detail{
    padding:16px !important;
  }
  .b2b-detail h4{
    font-size:.82rem !important;
    margin-bottom:5px !important;
  }
  .b2b-detail p{
    font-size:.65rem !important;
    line-height:1.6 !important;
  }

  /* 10. Rhythm card notes - truncate to avoid wall of text */
  .rcm-note,.rhythm-card-note,.rhythm-card .v-card-note{
    display:-webkit-box !important;
    -webkit-line-clamp:3 !important;
    -webkit-box-orient:vertical !important;
    overflow:hidden !important;
    font-size:.6rem !important;
    line-height:1.5 !important;
  }

  /* 11. b2b-cat-card: single column list */
  .b2b-cat-grid{
    grid-template-columns:1fr !important;
  }

  /* 12. panels min-height reset */
  .panels{
    min-height:0 !important;
  }
}

/* ========== */

/* ═══════════════════════════════════════════════════════════════
   V70 – DEFINITIVE MOBILE OVERRIDES
   Single source of truth for ≤768px and ≤480px.
   This block sits last, so all rules here win.
   ═══════════════════════════════════════════════════════════════ */

/* ── TABLET  ≤768 ────────────────────────────────────────────── */
@media (max-width:768px){

  /* GLOBAL SPACING — much tighter to reduce boredom-scroll */
  .value-strip,.intro-sec,.identity-sec,.process-sec,
  .b2b-sec,.market-sec,.contact-sec,.cta-strip,
  .coll-sec,.coll-sec.optimized{
    padding-top:40px !important;
    padding-bottom:40px !important;
    padding-left:16px !important;
    padding-right:16px !important;
  }
  .sec-h{margin-bottom:22px !important;font-size:1.35rem !important;line-height:1.2 !important}
  .sec-eye{margin-bottom:6px !important}

  /* HERO — compact, breathable */
  .hero{min-height:auto !important}
  .hero-top{padding:36px 16px 18px !important}
  .hero-h{font-size:1.6rem !important;line-height:1.15 !important;margin-bottom:10px !important}
  .hero-sub{font-size:.78rem !important;line-height:1.7 !important;max-width:38ch !important;margin-bottom:16px !important}
  .hero-eyebrow{margin-bottom:10px !important;font-size:.5rem !important}
  .hero-ctas{display:flex !important;flex-direction:column !important;gap:8px !important}
  .btn-dark,.btn-ghost,.btn-light,.btn-ghost-light,.contact-btn,.cf-submit{
    width:100% !important;justify-content:center !important;padding:13px 18px !important;font-size:.58rem !important}

  /* SERVICES PANELS — vertical accordion, readable */
  .panels{
    display:flex !important;
    flex-direction:column !important;
    gap:1px !important;
    margin:12px 0 0 !important;
    min-height:0 !important;
    background:rgba(30,53,40,.08) !important;
    border:none !important;
  }
  .panel{
    flex:none !important;width:100% !important;
    padding:16px 16px !important;min-height:0 !important;
  }
  .panel.active{flex:none !important;padding-bottom:18px !important}
  .p-num{font-size:1.4rem !important;opacity:.15 !important;margin-bottom:2px !important;display:inline-block !important}
  .p-title{font-size:.88rem !important;line-height:1.2 !important}
  .panel.active .p-title{font-size:1rem !important;color:var(--white) !important}
  .p-hint{font-size:.48rem !important}
  .p-desc{font-size:.72rem !important;line-height:1.7 !important}
  .p-tag{font-size:.44rem !important;padding:3px 7px !important}
  .p-cta{font-size:.5rem !important}
  .p-tl-steps{flex-wrap:wrap !important}
  .p-tl-step{min-width:45% !important;text-align:left !important;padding-top:0 !important;
    border-left:1px solid rgba(200,205,211,.22) !important;padding-left:8px !important;margin-bottom:8px !important}
  .p-tl-line,.p-tl-dot{display:none !important}
  .p-tl-name{font-size:.44rem !important}
  .p-tl-days{font-size:.38rem !important}
  .consult-textarea{font-size:.72rem !important;min-height:64px !important}
  .consult-send{font-size:.5rem !important;padding:9px 16px !important}

  /* VALUE STRIP — stack 1 column on phone for readability */
  .value-inner{grid-template-columns:1fr 1fr !important}
  .val-box{padding:22px 16px !important}
  .val-title{font-size:.92rem !important}
  .val-desc{font-size:.68rem !important;line-height:1.7 !important;max-width:none !important}

  /* PILLARS — SINGLE COLUMN for readability */
  .pillars{grid-template-columns:1fr !important;gap:1px !important}
  .pillar{padding:18px 16px !important}
  .pillar-title{font-size:.88rem !important}
  .pillar-desc{font-size:.72rem !important;line-height:1.7 !important}
  .intro-q{font-size:1.1rem !important;line-height:1.4 !important;margin-bottom:20px !important}

  /* CTA STRIPS — tighter */
  .cta-strip h2{font-size:1.2rem !important;margin-bottom:10px !important}
  .cta-strip p{font-size:.74rem !important;line-height:1.7 !important;margin-bottom:18px !important}

  /* IDENTITY — single column, controlled photo */
  .id-grid{grid-template-columns:1fr !important;gap:20px !important}
  .id-h{font-size:1.1rem !important;line-height:1.25 !important;margin-bottom:10px !important}
  .id-p{font-size:.74rem !important;line-height:1.7 !important;margin-bottom:10px !important}
  .id-photo-img,.id-photo-box{width:55% !important;max-width:200px !important;margin:0 auto !important}
  .id-stats{
    display:grid !important;
    grid-template-columns:1fr 1fr 1fr !important;
    gap:1px !important;
    margin-top:6px !important;
  }
  .id-stat{padding:14px 8px !important}
  .id-stat-n{font-size:1.2rem !important}
  .id-stat-l{font-size:.44rem !important}

  /* PROCESS ACCORDION — readable */
  .svc-trigger{grid-template-columns:40px 1fr 28px !important;gap:10px !important;padding:18px 0 !important}
  .svc-num{font-size:1.8rem !important}
  .svc-name{font-size:1rem !important}
  .svc-name-sub{font-size:.72rem !important;line-height:1.65 !important}
  .svc-body-in{padding:0 0 18px 50px !important}
  .svc-tag{font-size:.44rem !important}
  .tl-steps{flex-wrap:wrap !important}
  .tl-step{min-width:45% !important;text-align:left !important;padding-top:0 !important;
    border-left:1px solid rgba(154,163,174,.25) !important;padding-left:8px !important;margin-bottom:8px !important}
  .tl-line,.tl-dot{display:none !important}

  /* COLLECTIONS — product grids */
  .coll-sec.optimized{padding:40px 14px !important}
  /* Duet prod grids: 3 columns always */
  .prod-grid.col3{grid-template-columns:repeat(3,1fr) !important}
  .prod-grid.col5{grid-template-columns:repeat(3,1fr) !important}
  .prod-grid.col4{grid-template-columns:repeat(2,1fr) !important}
  .prod-grid.col2{grid-template-columns:repeat(2,1fr) !important}
  /* Other grids: 2 columns */
  .coll-grid,.coll-grid-3,.v-grid{grid-template-columns:repeat(2,1fr) !important}
  /* Rhythm: DO NOT TOUCH — stays 2 col */
  .rhythm-card-grid,.rhythm-three-img,.rhythm-cards-elegant{
    grid-template-columns:repeat(2,1fr) !important}
  /* Smaller card styling for 3-col fit */
  .prod-card-body{padding:10px 8px 12px !important}
  .prod-card-name{font-size:.72rem !important;line-height:1.2 !important}
  .prod-card-note{font-size:.58rem !important;line-height:1.5 !important}
  .prod-card-price{font-size:.54rem !important}
  .prod-card-add{font-size:.42rem !important;padding:5px 8px !important;width:100% !important;justify-content:center !important}
  .prod-card-tier{font-size:.38rem !important}
  .spec-pill{font-size:.36rem !important;padding:2px 5px !important}
  .coll-card-body{padding:14px 12px 16px !important}
  .coll-card-name{font-size:.86rem !important}
  .coll-card-note{font-size:.68rem !important;line-height:1.6 !important}
  .coll-card-add{width:100% !important;justify-content:center !important;padding:8px 12px !important}
  .collection-nav{flex-wrap:nowrap !important;overflow-x:auto !important;justify-content:flex-start !important;
    scrollbar-width:none !important;padding-bottom:4px !important;margin-bottom:16px !important}
  .collection-nav::-webkit-scrollbar{display:none !important}
  .collection-nav a{flex:0 0 auto !important;font-size:.5rem !important;padding:8px 10px !important}
  .coll-block-head-row{display:flex !important;flex-direction:column !important;align-items:flex-start !important;gap:10px !important;margin-bottom:14px !important}
  .coll-block-head-row .b2b-head-cta{align-self:flex-start !important;width:auto !important;padding:9px 16px !important;font-size:.52rem !important}
  .coll-block-kicker{font-size:.46rem !important}
  .coll-block-title{font-size:1.3rem !important;line-height:1.2 !important}
  .coll-block-desc{font-size:.74rem !important;line-height:1.7 !important}
  .rhythm-two-cards{grid-template-columns:1fr 1fr !important}
  .rhythm-pendant-row{grid-template-columns:1fr !important}
  .ear-grid-new{grid-template-columns:1fr !important}
  .line01-grid{grid-template-columns:1fr !important;gap:16px !important}
  .line01-compact{padding:18px 14px !important}
  .line01-groups{grid-template-columns:1fr !important;gap:8px !important}

  /* MARKETS — single column for readability */
  .market-grid{grid-template-columns:1fr !important}
  .mkt-card{padding:20px 16px !important}
  .mkt-title{font-size:.95rem !important}
  .mkt-desc{font-size:.72rem !important;line-height:1.7 !important}

  /* B2B */
  .b2b-cat-grid{grid-template-columns:1fr 1fr !important}
  .b2b-cat-card{padding:16px 14px !important}
  .b2b-cat-name{font-size:.9rem !important}
  .b2b-cat-types{font-size:.64rem !important}
  .b2b-details-grid{grid-template-columns:1fr !important}
  .b2b-detail{padding:16px !important}
  .b2b-detail h4{font-size:.88rem !important}
  .b2b-detail p{font-size:.68rem !important;line-height:1.7 !important}
  .b2b-block-head{grid-template-columns:1fr !important;gap:10px !important}
  .b2b-target{grid-template-columns:1fr !important;padding:20px 16px !important}
  .b2b-final{grid-template-columns:1fr !important;padding:20px 16px !important;gap:14px !important}
  .b2b-final h3{font-size:1.05rem !important}
  .b2b-final p{font-size:.72rem !important;line-height:1.7 !important}
  .b2b-lead{font-size:.74rem !important;line-height:1.7 !important}

  /* CONTACT */
  .contact-form-wrap{margin-bottom:24px !important}
  .cf-row{grid-template-columns:1fr !important;gap:10px !important}
  .cf-input,.cf-textarea,.cf-select{font-size:16px !important;padding:12px !important}
  .contact-det{display:grid !important;grid-template-columns:1fr !important;gap:14px !important}
  .contact-p{font-size:.76rem !important;line-height:1.7 !important;margin-bottom:24px !important}

  /* FOOTER */
  footer{flex-direction:column !important;text-align:center !important;padding:18px 14px !important;gap:8px !important}
  .f-links{justify-content:center !important;gap:12px !important}
  .f-links a{font-size:.48rem !important}
  .f-logo{font-size:.72rem !important}
  .f-copy{font-size:.48rem !important}

  /* SECTION RAILS */
  .section-rail,.collection-band{grid-template-columns:1fr 1fr 1fr !important}
  .duet-grid-clean,.duet-grid-clean.four{grid-template-columns:repeat(2,1fr) !important}
  .offer-grid{grid-template-columns:1fr !important}
  .clean-block{padding:18px 14px !important}
  .clean-head{grid-template-columns:1fr !important;gap:10px !important}

  /* CHAT & CART */
  #chat-trigger{bottom:14px !important;right:14px !important;width:48px !important;height:48px !important;z-index:3200 !important}
  #chat-window{right:8px !important;left:8px !important;bottom:70px !important;width:auto !important;max-width:none !important;max-height:58vh !important;z-index:3199 !important}
  .chat-inp{font-size:16px !important}
  .cart-btn-wrap{top:10px !important;right:58px !important;bottom:auto !important;z-index:4100 !important}
  .cart-fab{width:42px !important;height:42px !important;font-size:.95rem !important}

  /* REVEAL — force visible on mobile */
  .reveal{opacity:1 !important;transform:none !important;pointer-events:auto !important}

  /* MARQUEE — smaller */
  .marquee-wrap{margin-top:12px !important}
  .mq-item{font-size:.46rem !important;padding:0 10px !important}
  .mq-row{padding:10px 0 !important}

  /* Mobile menu */
  .mob{justify-content:flex-start !important;padding:80px 24px 28px !important}
  .mob a{font-size:1.25rem !important;line-height:1.2 !important;text-align:center !important}
  .mob .mob-cta{width:100% !important;max-width:300px !important;text-align:center !important}
}

/* ── PHONE ≤480 ──────────────────────────────────────────────── */
@media (max-width:480px){
  /* Even tighter spacing */
  .value-strip,.intro-sec,.identity-sec,.process-sec,
  .b2b-sec,.market-sec,.contact-sec,.cta-strip,
  .coll-sec,.coll-sec.optimized{
    padding-top:32px !important;
    padding-bottom:32px !important;
    padding-left:12px !important;
    padding-right:12px !important;
  }
  .sec-h{font-size:1.2rem !important;margin-bottom:18px !important}

  /* Hero even tighter */
  .hero-top{padding:28px 12px 14px !important}
  .hero-h{font-size:1.45rem !important}
  .hero-sub{font-size:.74rem !important}

  /* Value strip: 1 column on phone */
  .value-inner{grid-template-columns:1fr !important}
  .val-box{padding:18px 14px !important}

  /* Stats row stays 3-col */
  .id-stats{grid-template-columns:1fr 1fr 1fr !important}

  /* Product grids: Duet stays 3 cols, rhythm stays as-is */
  .prod-grid.col3{grid-template-columns:repeat(3,1fr) !important}
  .prod-grid.col5{grid-template-columns:repeat(3,1fr) !important}
  .coll-grid,.coll-grid-3,.v-grid,.prod-grid.col4,
  .prod-grid.col2,.rhythm-card-grid{
    grid-template-columns:repeat(2,1fr) !important}
  .prod-card-body{padding:8px 6px 10px !important}
  .prod-card-name{font-size:.62rem !important;line-height:1.2 !important}
  .prod-card-note{font-size:.5rem !important;line-height:1.45 !important;
    display:-webkit-box !important;-webkit-line-clamp:2 !important;-webkit-box-orient:vertical !important;overflow:hidden !important}
  .prod-card-price{font-size:.48rem !important}
  .prod-card-add{font-size:.38rem !important;padding:4px 6px !important}
  .prod-card-tier{font-size:.34rem !important}
  .prod-card-specs{display:none !important}
  .spec-pill{font-size:.32rem !important;padding:2px 4px !important}

  /* B2B cat still 2-col */
  .b2b-cat-grid{grid-template-columns:1fr 1fr !important}

  /* Contact */
  .contact-det{grid-template-columns:1fr !important}

  /* Rhythm two cards: 1 col on very small */
  .rhythm-two-cards{grid-template-columns:1fr !important}
}

/* ========== */

/* ════════════════════════════════════════════════════════════
   PRODUCT SECTION · v3
   - Horizontal scrolling bands per design line
   - Inline detail expansion below the clicked band
   - Prominent metal/alloy selectors with live price
   ════════════════════════════════════════════════════════════ */

#collections{padding:90px 0 110px;background:var(--cream);min-height:600px}
.coll-shell{max-width:1240px;margin:0 auto;padding:0 28px}

/* ── HERO ──────────────────────────────────────────────── */
.coll-hero{text-align:center;max-width:720px;margin:0 auto 56px}
.coll-hero-eye{font-size:.62rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dust);margin-bottom:18px;font-weight:500}
.coll-hero-h{font-family:var(--serif);font-size:clamp(2rem,4.4vw,3.2rem);font-weight:400;line-height:1.15;color:var(--grn);margin-bottom:18px}
.coll-hero-h em{font-style:italic;color:var(--dust)}
.coll-hero-sub{font-size:.95rem;line-height:1.65;color:var(--dust);font-weight:300}

/* ── COLLECTION TABS ───────────────────────────────────── */
.coll-tabs{display:flex;justify-content:center;gap:6px;margin:0 auto 48px;flex-wrap:wrap;padding:6px;background:rgba(255,255,255,.55);border:1px solid var(--border);border-radius:2px;width:fit-content}
.coll-tab{font-family:var(--sans);font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dust);padding:13px 24px;border:none;background:transparent;cursor:pointer;border-radius:1px;transition:all .3s;font-weight:500;white-space:nowrap}
.coll-tab:hover{color:var(--grn)}
.coll-tab.active{background:var(--grn);color:#fff}

.coll-meta{max-width:920px;margin:0 auto 52px;text-align:center}
.coll-meta-eye{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dust);margin-bottom:12px;font-weight:500}
.coll-meta-h{font-family:var(--serif);font-size:clamp(1.6rem,3.2vw,2.4rem);font-weight:400;color:var(--grn);margin-bottom:12px;line-height:1.2}
.coll-meta-h em{font-style:italic;color:var(--dust)}
.coll-meta-desc{font-size:.92rem;line-height:1.65;color:var(--dust);font-weight:300;max-width:680px;margin:0 auto}

.coll-pane{display:none}
.coll-pane.active{display:block;animation:fadeIn .4s ease}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ── LINE SECTION ──────────────────────────────────────── */
.line-sec{margin-bottom:64px;padding-top:36px;border-top:1px solid var(--border)}
.line-sec:first-of-type{padding-top:0;border-top:none}

.line-head{display:flex;align-items:flex-end;justify-content:space-between;gap:24px;margin-bottom:24px;flex-wrap:wrap}
.line-head-l{flex:1;min-width:0}
.line-head-label{font-size:.6rem;letter-spacing:.24em;text-transform:uppercase;color:var(--grn);font-weight:500;margin-bottom:6px}
.line-head-title{font-family:var(--serif);font-size:1.4rem;color:var(--grn);font-weight:400;line-height:1.25;margin-bottom:6px}
.line-head-title em{font-style:italic;color:var(--dust)}
.line-head-desc{font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--dust);line-height:1.5;font-weight:400;max-width:560px}

.line-head-r{display:flex;align-items:center;gap:8px}
.line-head-count{font-size:.65rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dust);font-weight:500}
.line-arrows{display:none}
.line-arrow{width:36px;height:36px;border-radius:50%;background:#fff;border:1px solid var(--border);cursor:pointer;color:var(--grn);font-size:1rem;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}
.line-arrow:hover:not(:disabled){border-color:var(--grn);background:var(--grn);color:#fff}
.line-arrow:disabled{opacity:.3;cursor:default}

/* Product grid — 4 columns, no scroll */
.line-band{position:relative}
.line-track{display:grid;grid-template-columns:repeat(4,1fr);gap:18px;padding:6px 0 22px}

/* Cards in the grid */
.pc{background:#fff;border:1px solid var(--border);cursor:pointer;transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .25s;display:flex;flex-direction:column;overflow:hidden;position:relative;text-decoration:none;color:inherit;min-width:0}
.pc:hover{transform:translateY(-3px);box-shadow:0 12px 30px -10px rgba(30,53,40,.18)}
.pc.selected{border-color:var(--grn);border-width:1.5px}
.pc-img{aspect-ratio:1/1;background:#f6f4ee;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;padding:14px}
.pc-img img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transition:transform .5s var(--ease)}
.pc:hover .pc-img img{transform:scale(1.04)}
.pc-tier{position:absolute;top:12px;left:12px;background:rgba(255,255,255,.94);font-size:.52rem;letter-spacing:.18em;text-transform:uppercase;padding:5px 9px;color:var(--grn);font-weight:500;border:1px solid var(--border)}
.pc-tier.high{background:var(--grn);color:#fff;border-color:var(--grn)}
.pc-tier.preview{background:#c8a96e;color:#fff;border-color:#c8a96e}
.pc-tier.signature{background:#1e3528;color:#fff;border-color:#1e3528}
.pc-body{padding:18px 18px 20px;display:flex;flex-direction:column;flex:1}
.pc-code{font-size:.52rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dust);margin-bottom:7px;font-weight:500}
.pc-name{font-family:var(--serif);font-size:1.1rem;color:var(--grn);margin-bottom:8px;line-height:1.25;font-weight:400;display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.pc-name em{font-style:italic;color:var(--dust)}
.pc-sw-inline{width:14px;height:14px;border-radius:50%;display:inline-block;border:1px solid rgba(30,53,40,.25);flex:0 0 auto}
.pc-sub{font-size:.78rem;line-height:1.5;color:var(--dust);margin-bottom:14px;font-weight:300;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.pc-foot{display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--border);padding-top:12px;margin-top:auto;gap:8px}
.pc-price{font-family:var(--serif);font-size:.95rem;color:var(--grn)}
.pc-price-from{font-size:.5rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dust);margin-right:4px;font-weight:500}
.pc-cta{font-size:.55rem;letter-spacing:.2em;text-transform:uppercase;color:var(--grn);font-weight:500;white-space:nowrap;display:flex;align-items:center;gap:4px}
.pc-swatches{display:flex;gap:4px;margin-top:10px;flex-wrap:wrap;align-items:center}
.pc-sw{width:12px;height:12px;border-radius:50%;border:1px solid rgba(30,53,40,.2);display:inline-block}
.pc-sw-more{font-size:.55rem;color:var(--dust);margin-left:3px}

/* ── INLINE DETAIL PANEL ──────────────────────────────── */
.line-detail{margin-top:0;max-height:0;overflow:hidden;transition:max-height .5s var(--ease),margin-top .4s var(--ease),opacity .3s ease;opacity:0}
.line-detail.expanded{max-height:2400px;margin-top:24px;opacity:1}

.detail-card{background:#fff;border:1px solid var(--grn);position:relative;overflow:hidden}
.detail-close{position:absolute;top:18px;right:18px;width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.95);border:1px solid var(--border);cursor:pointer;color:var(--grn);font-size:.95rem;display:flex;align-items:center;justify-content:center;z-index:5;transition:all .2s}
.detail-close:hover{background:var(--grn);color:#fff;border-color:var(--grn)}

.detail-grid{display:grid;grid-template-columns:1fr 1fr;align-items:stretch;min-height:540px}
@media(max-width:880px){.detail-grid{grid-template-columns:1fr;min-height:auto}}

/* LEFT — image */
.detail-img{background:#f6f4ee;display:flex;align-items:center;justify-content:center;padding:50px 40px;position:relative;min-height:480px}
@media(max-width:880px){.detail-img{padding:36px 24px;min-height:380px}}
.detail-img img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transition:opacity .25s}
.detail-img img.swap{opacity:0}
.detail-kicker{position:absolute;top:18px;left:18px;background:#fff;font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;padding:7px 12px;color:var(--grn);font-weight:500;border:1px solid var(--border)}

/* Multi-angle thumbnails inside image area */
.detail-thumbs{position:absolute;bottom:18px;left:50%;transform:translateX(-50%);display:flex;gap:8px;background:rgba(255,255,255,.92);padding:8px;border:1px solid var(--border);backdrop-filter:blur(4px)}
.detail-thumb{width:54px;height:54px;background:#fff;border:1px solid var(--border);cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;transition:border-color .2s}
.detail-thumb img{max-width:100%;max-height:100%;object-fit:contain}
.detail-thumb.active{border-color:var(--grn);border-width:1.5px}

/* RIGHT — configurator */
.detail-config{padding:44px 44px 40px;display:flex;flex-direction:column;gap:0;overflow-y:auto}
@media(max-width:880px){.detail-config{padding:32px 24px 28px}}

.detail-tier{display:inline-block;font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;padding:5px 10px;color:var(--grn);font-weight:500;background:rgba(255,255,255,.55);border:1px solid var(--border);margin-bottom:10px;align-self:flex-start}
.detail-tier.high{background:var(--grn);color:#fff;border-color:var(--grn)}
.detail-tier.preview{background:#c8a96e;color:#fff;border-color:#c8a96e}
.detail-tier.signature{background:#1e3528;color:#fff;border-color:#1e3528}
.detail-code{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dust);font-weight:500;margin-bottom:10px}
.detail-h{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.1rem);font-weight:400;color:var(--grn);line-height:1.15;margin-bottom:8px}
.detail-h em{font-style:italic;color:var(--dust)}
.detail-sub{font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--dust);margin-bottom:14px;line-height:1.5}
.detail-desc{font-size:.85rem;line-height:1.65;color:var(--grn);font-weight:300;margin-bottom:22px}

.detail-divider{height:1px;background:var(--border);margin:0 0 22px}

/* LIVE PRICE — large and prominent */
.detail-price-row{display:flex;align-items:baseline;justify-content:space-between;gap:14px;margin-bottom:24px;flex-wrap:wrap}
.detail-price-l{display:flex;align-items:baseline;gap:14px}
.detail-price-eye{font-size:.55rem;letter-spacing:.22em;text-transform:uppercase;color:var(--dust);font-weight:500}
.detail-price{font-family:var(--serif);font-size:2.1rem;color:var(--grn);transition:color .3s,transform .3s}
.detail-price.flash{color:#c8a96e;transform:scale(1.04)}
.detail-price-note{font-family:var(--serif);font-style:italic;font-size:.74rem;color:var(--dust);max-width:200px;text-align:right}

/* Selector sections */
.detail-sec{margin-bottom:22px}
.detail-sec-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:10px;gap:14px;flex-wrap:wrap}
.detail-sec-label{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--grn);font-weight:600}
.detail-sec-val{font-family:var(--serif);font-style:italic;font-size:.85rem;color:var(--dust);text-align:right}

/* ── PROMINENT METAL PILLS — clear and clickable ── */
.detail-metals{display:flex;gap:8px;flex-wrap:wrap}
.metal-pill{display:flex;align-items:center;gap:9px;background:#fff;border:1.5px solid var(--border);padding:11px 14px;cursor:pointer;transition:all .2s;font-family:var(--sans);font-size:.72rem;letter-spacing:.06em;color:var(--grn);font-weight:500}
.metal-pill:hover{border-color:rgba(30,53,40,.55)}
.metal-pill.active{border-color:var(--grn);background:rgba(30,53,40,.04)}
.metal-pill .dot{width:18px;height:18px;border-radius:50%;background:var(--c);border:1px solid rgba(30,53,40,.2);flex:0 0 auto}

/* Toggle groups */
.detail-toggle{display:grid;gap:6px}
.detail-toggle.col4{grid-template-columns:repeat(4,1fr)}
.detail-toggle.col3{grid-template-columns:repeat(3,1fr)}
.detail-toggle.col2{grid-template-columns:repeat(2,1fr)}
.detail-toggle.col1{grid-template-columns:1fr}

.detail-tog-btn{background:#fff;border:1.5px solid var(--border);padding:13px 8px;font-family:var(--sans);font-size:.72rem;letter-spacing:.14em;text-transform:uppercase;color:var(--grn);cursor:pointer;transition:all .2s;text-align:center;font-weight:500}
.detail-tog-btn:hover:not(.disabled):not(:disabled){border-color:rgba(30,53,40,.55)}
.detail-tog-btn.active{background:var(--grn);color:#fff;border-color:var(--grn)}
.detail-tog-btn.disabled,.detail-tog-btn:disabled{opacity:.3;cursor:not-allowed;text-decoration:line-through}

.detail-prop-btn{background:#fff;border:1.5px solid var(--border);padding:13px 6px;cursor:pointer;transition:all .2s;display:flex;flex-direction:column;align-items:center;gap:3px;text-align:center}
.detail-prop-btn:hover{border-color:rgba(30,53,40,.55)}
.detail-prop-btn.active{border-color:var(--grn);background:rgba(30,53,40,.04)}
.detail-prop-letter{font-family:var(--serif);font-style:italic;font-size:1.25rem;color:var(--grn);line-height:1}
.detail-prop-name{font-size:.55rem;letter-spacing:.18em;text-transform:uppercase;color:var(--grn);font-weight:500}
.detail-prop-mm{font-family:var(--serif);font-style:italic;font-size:.7rem;color:var(--dust)}

.detail-size-wrap{position:relative}
.detail-size{width:100%;background:#fff;border:1.5px solid var(--border);padding:13px 16px;font-family:var(--sans);font-size:.8rem;color:var(--grn);appearance:none;cursor:pointer;letter-spacing:.04em;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%231E3528' stroke-width='1.5'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 14px center;background-size:18px;padding-right:42px}
.detail-size-guide{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--grn);text-decoration:underline;text-underline-offset:3px;cursor:pointer;background:none;border:none;padding:0;font-family:var(--sans);font-weight:500}

/* CTAs */
.detail-cta-row{display:grid;grid-template-columns:1fr;gap:8px;margin-top:14px}
.detail-add{background:var(--grn);color:#fff;border:none;padding:17px;font-family:var(--sans);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;width:100%;display:flex;align-items:center;justify-content:center;gap:10px;font-weight:600;transition:background .25s}
.detail-add:hover{background:#15281d}
.detail-add .arr{transition:transform .25s}
.detail-add:hover .arr{transform:translateX(4px)}
.detail-consult{background:transparent;border:1.5px solid var(--border);padding:15px;font-family:var(--sans);font-size:.65rem;letter-spacing:.22em;text-transform:uppercase;cursor:pointer;width:100%;color:var(--grn);transition:border-color .25s;font-weight:500}
.detail-consult:hover{border-color:var(--grn)}

/* ── MOBILE RESPONSIVE ─────────────────────────────────── */
@media(max-width:1100px){
  .line-track{grid-template-columns:repeat(4,1fr);gap:12px}
}
@media(max-width:880px){
  .line-track{grid-template-columns:repeat(3,1fr);gap:8px}
}
@media(max-width:560px){
  #collections{padding:60px 0 80px}
  .coll-shell{padding:0 12px}
  .line-track{grid-template-columns:repeat(3,1fr);gap:6px}
  .line-sec{margin-bottom:50px;padding-top:30px}
  .line-head{flex-direction:column;align-items:stretch}
  .pc-img{padding:8px}
  .pc-body{padding:9px 8px 11px}
  .pc-code{font-size:.46rem;letter-spacing:.16em;margin-bottom:5px}
  .pc-name{font-size:.74rem;margin-bottom:5px;gap:5px}
  .pc-sw-inline{width:11px;height:11px}
  .pc-sub{display:none}
  .pc-foot{padding-top:8px;flex-direction:column;align-items:flex-start;gap:5px}
  .pc-price{font-size:.74rem}
  .pc-price-from{font-size:.42rem;letter-spacing:.13em;margin-right:3px}
  .pc-cta{font-size:.46rem;letter-spacing:.16em}
  .pc-tier{font-size:.42rem;letter-spacing:.13em;padding:3px 6px;top:6px;left:6px}
}

/* ── PRODUCT DETAIL — mobile-optimized layout ─────────── */
/* Desktop default unchanged: image left, config right */
.detail-config-header,.detail-config-desc,.detail-config-quick,.detail-config-options{display:contents}
@media(min-width:881px){
  .detail-config-header,.detail-config-desc,.detail-config-quick,.detail-config-options{display:block}
  .detail-config-header,.detail-config-desc,.detail-config-options{margin:0}
}

/* Mobile: STACKED layout — large image on top, compact pill bar below */
@media(max-width:880px){
  .detail-grid{
    grid-template-columns:1fr !important;
    grid-template-areas:"img" "quick" "header" "desc" "options" "cta";
    min-height:auto;
  }
  .detail-img{
    grid-area:img;min-height:auto;padding:14px;
    height:48vh;
    background:#f6f4ee;
  }
  .detail-img .detail-kicker{font-size:.42rem;padding:4px 7px;letter-spacing:.16em;top:8px;left:8px}
  .detail-config{display:contents}

  /* COMPACT BAR DIRECTLY BELOW IMAGE — price (left) + pills (right, wrap if needed) */
  .detail-config-quick{
    grid-area:quick;display:flex;align-items:flex-start;gap:12px;
    padding:10px 14px;background:var(--cream);border-top:1px solid var(--border);border-bottom:1px solid var(--border)
  }
  .detail-config-quick .detail-price-row{flex:0 0 auto;flex-direction:column;align-items:flex-start;gap:1px;margin:0;flex-wrap:nowrap;border-right:1px solid var(--border);padding-right:12px}
  .detail-config-quick .detail-price-l{flex-direction:column;align-items:flex-start;gap:0}
  .detail-config-quick .detail-price-eye{font-size:.4rem;letter-spacing:.14em}
  .detail-config-quick .detail-price{font-size:1.05rem;line-height:1.1}
  .detail-config-quick .detail-price-note{display:none}
  .detail-config-quick .detail-sec{margin:0;flex:1;min-width:0}
  .detail-config-quick .detail-sec-head{margin-bottom:4px;gap:6px;flex-wrap:wrap}
  .detail-config-quick .detail-sec-label{font-size:.42rem;letter-spacing:.12em}
  .detail-config-quick .detail-sec-val{font-size:.58rem;font-style:italic;color:var(--dust);text-align:right}
  .detail-config-quick .detail-metals{display:flex;flex-wrap:wrap;gap:4px}
  .detail-config-quick .metal-pill{padding:5px 8px;font-size:.54rem;gap:5px;letter-spacing:.02em;border-width:1px}
  .detail-config-quick .metal-pill .dot{width:10px;height:10px}

  .detail-config-header{grid-area:header;display:block;padding:16px 16px 6px}
  .detail-config-header .detail-tier{font-size:.45rem;padding:3px 7px;margin-bottom:6px}
  .detail-config-header .detail-code{font-size:.5rem;margin-bottom:4px}
  .detail-config-header .detail-h{font-size:1.4rem;margin-bottom:4px}
  .detail-config-header .detail-sub{font-size:.76rem;margin-bottom:0;line-height:1.4}

  .detail-config-desc{grid-area:desc;display:block;padding:0 16px 12px}
  .detail-config-desc .detail-desc{margin-bottom:0;font-size:.78rem;line-height:1.55}
  .detail-divider{display:none}

  .detail-config-options{grid-area:options;display:block;padding:0 16px 4px}
  .detail-config-options .detail-sec{margin-bottom:18px}

  .detail-cta-row{grid-area:cta;padding:0 16px 18px;margin:0}

  .detail-thumbs{padding:5px;gap:5px;bottom:8px}
  .detail-thumb{width:38px;height:38px;padding:2px}
}

/* Phones: image slightly shorter, smaller padding */
@media(max-width:560px){
  .detail-img{height:44vh;padding:10px}
}

/* ── SIMILAR PRODUCTS BAR (below detail-grid) ─────────── */
.detail-similar{padding:32px 36px 40px;border-top:1px solid var(--border);background:var(--cream2)}
.detail-similar-head{font-family:var(--serif);font-size:1rem;color:var(--grn);margin-bottom:16px;font-weight:400}
.detail-similar-head em{font-style:italic;color:var(--dust)}
.detail-similar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}

.sim-pc{background:#fff;border:1px solid var(--border);cursor:pointer;transition:border-color .2s,transform .2s,box-shadow .2s;display:flex;flex-direction:column;overflow:hidden;min-width:0;text-decoration:none;color:inherit}
.sim-pc:hover{border-color:var(--grn);transform:translateY(-2px);box-shadow:0 8px 18px -8px rgba(30,53,40,.18)}
.sim-pc-img{aspect-ratio:1/1;background:#f6f4ee;padding:10px;display:flex;align-items:center;justify-content:center;overflow:hidden}
.sim-pc-img img{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;transition:transform .35s var(--ease)}
.sim-pc:hover .sim-pc-img img{transform:scale(1.05)}
.sim-pc-body{padding:9px 11px 11px;display:flex;flex-direction:column;gap:3px}
.sim-pc-code{font-size:.42rem;letter-spacing:.18em;text-transform:uppercase;color:var(--dust);font-weight:500}
.sim-pc-name{font-family:var(--serif);font-size:.78rem;color:var(--grn);line-height:1.2;font-weight:400}
.sim-pc-name em{font-style:italic;color:var(--dust)}
.sim-pc-price{font-size:.58rem;color:var(--grn);font-weight:500;margin-top:4px;letter-spacing:.04em}

@media(max-width:1100px){.detail-similar-grid{grid-template-columns:repeat(4,1fr);gap:8px}}
@media(max-width:880px){
  .detail-similar{padding:24px 16px 30px}
  .detail-similar-head{font-size:.92rem;margin-bottom:14px}
  .detail-similar-grid{grid-template-columns:repeat(3,1fr);gap:7px}
  .sim-pc-img{padding:6px}
  .sim-pc-body{padding:7px 8px 9px;gap:3px}
  .sim-pc-code{font-size:.4rem;letter-spacing:.12em}
  .sim-pc-name{font-size:.66rem;line-height:1.2}
  .sim-pc-price{font-size:.56rem;margin-top:3px;letter-spacing:.03em}
}
@media(max-width:560px){
  .detail-similar{padding:20px 12px 24px}
  .detail-similar-head{font-size:.82rem;margin-bottom:11px}
  .detail-similar-grid{grid-template-columns:repeat(3,1fr);gap:5px}
  .sim-pc-img{padding:5px}
  .sim-pc-body{padding:6px 6px 8px;gap:2px}
  .sim-pc-code{font-size:.38rem;letter-spacing:.1em}
  .sim-pc-name{font-size:.6rem;line-height:1.18}
  .sim-pc-price{font-size:.52rem;margin-top:2px;letter-spacing:.02em}
}

/* ==========  LOGO IMAGE (added)  ========== */
.nav-logo{display:flex;align-items:center}
.nav-logo img{height:22px;width:auto;display:block;transition:height .3s var(--ease)}
nav.scrolled .nav-logo img{height:19px}
@media (max-width:768px){
  .nav-logo img{height:18px}
  nav.scrolled .nav-logo img{height:16px}
}
