/* PDP shared component styles.
 *
 * Extracted from per-shell inline <style> blocks during the theme
 * pivot Phase 1 (architectural plumbing). Source of truth for color
 * tokens is assets/css/site.css :root.
 *
 * Architecture:
 *   site.css  — base reset + tokens (:root) + base typography + nav/footer
 *   pdp.css   — shared PDP component styles (this file). Color values
 *               via var(--ink), var(--t1), etc. — resolved from site.css :root.
 *
 * Per-shell inline <style> blocks should now contain ONLY genuine
 * per-shell overrides (e.g. legacy size grid columns) or nothing.
 *
 * Originally extracted from products/hustle-harder.html as the canonical
 * cluster-2 (post-b19deb6) PDP template variant. 38 PDP shells in the
 * codebase share this base. Waypoint shells (the-coastline, the-pacific,
 * the-sierra, the-mojave) need additional watch-specific styles +
 * cross-sell variant overrides which remain inline.
 */

body{cursor:none;font-family:var(--sans);background:var(--bg);color:var(--t1);overflow-x:hidden;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}img{display:block;max-width:100%}
/* Grain */

/* ── GSAP reveal targets ── */
.rv{opacity:0;transform:translateY(40px);will-change:transform,opacity}
.rv-l{opacity:0;transform:translateX(-40px);will-change:transform,opacity}
.rv-r{opacity:0;transform:translateX(40px);will-change:transform,opacity}

/* ═══════════ ANNOUNCE ═══════════ */
/* Phase 4.1D: .ann scrolling marquee retired in favor of unified
   .ed-masthead static treatment (defined in site.css line 180+).
   PDP markup now uses <div class="ed-masthead"> matching homepage
   so the announcement reads as a single coherent header across
   the site. .ann/.ann-t/@keyframes marq rules removed — no live
   markup references them anywhere. */

/* ═══════════ NAV ═══════════ */
/* .nav.has-masthead positioning lives in site.css; .has-ann
   variant retired with the marquee. */
.nav-a{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.18em;text-transform:uppercase;color:var(--t2);transition:color .3s}.nav-icon{color:var(--t2);transition:color .3s;position:relative}.cart-dot{position:absolute;top:-2px;right:-6px;width:6px;height:6px;background:rgba(201,191,168,.3);border-radius:50%}
.ham{color:var(--t1)}

/* ═══════════ MOBILE MENU ═══════════ */
.mm .mm-sub{font-family:var(--sans);font-size:.7rem;color:var(--t3);letter-spacing:.15em;text-transform:uppercase;margin-top:32px}

/* ═══════════ HERO ═══════════ */
.hero{position:relative;height:100vh;height:100svh;min-height:700px;display:flex;overflow:hidden;background:var(--bg)}
.hero-img{position:absolute;inset:0;overflow:hidden}
.hero-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:brightness(.65) saturate(.8) sepia(.02)}
.hero-fade{position:absolute;inset:0;background:linear-gradient(to bottom,rgba(41,39,40,.05) 0%,rgba(41,39,40,.05) 35%,rgba(41,39,40,.35) 55%,rgba(41,39,40,.82) 80%,rgba(41,39,40,.95) 100%);z-index:1}
.hero-fade-b{position:absolute;bottom:0;left:0;right:0;height:15%;background:linear-gradient(to top,var(--bg),transparent);z-index:1}
/* Ambient glow */
.hero-glow{position:absolute;width:500px;height:500px;border-radius:50%;filter:blur(120px);z-index:0;pointer-events:none;opacity:.12}
.hero-glow-1{background:rgba(201,191,168,.3);top:30%;left:15%;animation:glowDrift1 12s ease-in-out infinite alternate}
.hero-glow-2{background:var(--olive);top:50%;right:20%;animation:glowDrift2 15s ease-in-out infinite alternate}
@keyframes glowDrift1{0%{transform:translate(0,0)}100%{transform:translate(40px,-30px)}}
@keyframes glowDrift2{0%{transform:translate(0,0)}100%{transform:translate(-30px,40px)}}
.hero-body{position:relative;z-index:2;display:flex;flex-direction:column;justify-content:flex-end;align-items:flex-start;text-align:left;padding:0 56px 56px;height:100%;max-width:100%;margin:0;width:100%}
.hero-tag{font-family:var(--condensed);font-size:.6rem;font-weight:600;letter-spacing:.5em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:14px;margin-bottom:14px}
.hero-tag-line{width:28px;height:.5px;background:rgba(201,191,168,.3)}
.hero-tag-dim{font-weight:400;color:var(--t3)}
.hero-h{font-family:var(--display);font-weight:700;font-size:clamp(4rem,12vw,9rem);text-transform:uppercase;color:var(--t1);line-height:.85;letter-spacing:.01em}
.hero-h em{font-weight:200;color:var(--accent)}
.hero-p{font-family:var(--serif);font-size:1.1rem;font-weight:400;font-style:italic;color:var(--t1);margin-top:14px;line-height:1.7;max-width:34ch;opacity:.8}
.hero-ctas{display:flex;gap:12px;margin-top:24px}

/* Buttons */
.btn{font-family:var(--sans);font-size:.65rem;font-weight:600;letter-spacing:.2em;text-transform:uppercase;padding:16px 40px;transition:all .35s var(--ease);display:inline-flex;align-items:center;gap:8px}
.btn-a{background:rgba(201,191,168,.3);color:var(--bg);border:1px solid rgba(201,191,168,.35)}.btn-a:hover{background:var(--accent-h)}
.btn-o{background:transparent;color:var(--t1);border:1px solid var(--bd)}.btn-o:hover{border-color:var(--t2)}

/* Scroll cue */
.scroll-cue{position:absolute;bottom:28px;right:56px;z-index:3;display:flex;flex-direction:column;align-items:center;gap:6px}
.scroll-cue span{font-family:var(--condensed);font-size:.45rem;letter-spacing:.35em;text-transform:uppercase;color:var(--t3);writing-mode:vertical-lr}
.scroll-cue div{width:1px;height:36px;background:linear-gradient(to bottom,var(--accent),transparent);animation:sPulse 2s ease-in-out infinite}
@keyframes sPulse{0%,100%{opacity:1;transform:scaleY(1)}50%{opacity:.3;transform:scaleY(.4)}}

/* ═══════════ MANIFESTO STRIP ═══════════ */
.manifesto{padding:56px;border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);display:flex;align-items:center;gap:40px}
.manifesto-line{width:40px;height:1px;background:rgba(201,191,168,.3);flex-shrink:0}
.manifesto-text{font-family:var(--display);font-size:clamp(1.1rem,2.2vw,1.6rem);font-weight:400;text-transform:uppercase;letter-spacing:.06em;line-height:1.4;color:var(--t2);max-width:700px}
.manifesto-text em{font-style:normal;color:var(--t1);font-weight:600}
.manifesto-closer{opacity:0;display:inline}

/* ═══════════ SECTION UTILS ═══════════ */
.sec{padding:100px 56px}
.sec-label{font-family:var(--condensed);font-size:.55rem;font-weight:600;letter-spacing:.45em;text-transform:uppercase;color:var(--accent);margin-bottom:12px}
.sec-title{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.6rem);font-weight:400;text-transform:uppercase;line-height:.94;letter-spacing:.04em}
.sec-hdr{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:48px}
.sec-link{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--t3);transition:color .3s}.sec-link:hover{color:var(--accent)}

/* ═══════════ PRODUCT GRID ═══════════ */
.pgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px}
.pcard{position:relative;overflow:hidden;display:block;background:var(--el);height:620px}
.pcard img,.pcard .pf,.pcard .pb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1) saturate(.88) sepia(.03);transition:filter .5s,transform .7s var(--ease),opacity .4s;transform:scale(1.01)}
.pcard:hover img{filter:brightness(1.05) saturate(.95);transform:scale(1)}
.pcard .pf{z-index:1}.pcard .pb{z-index:1;opacity:0}
.pcard:hover .pf{opacity:0}
.pcard:hover .pb{opacity:1}
.pcard-badge{position:absolute;top:10px;left:10px;font-family:var(--condensed);font-size:.45rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;padding:3px 10px;z-index:4;background:rgba(201,191,168,.3);color:var(--bg)}
.pcard-info{position:absolute;bottom:0;left:0;right:0;padding:20px 22px 22px;background:linear-gradient(to top,rgba(21,20,19,.95) 0%,rgba(21,20,19,.72) 55%,rgba(21,20,19,.15) 88%,transparent 100%);color:var(--t1);transform:translateY(100%);transition:transform .55s cubic-bezier(.16,1,.3,1);z-index:3;will-change:transform}
.pcard:hover .pcard-info{transform:translateY(0)}
.pcard-name{font-family:var(--display);font-size:1.05rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;color:var(--t1);line-height:1;margin-bottom:6px}
.pcard-price{font-family:var(--display);font-size:.85rem;font-weight:700;color:var(--t1);letter-spacing:.02em}

/* ═══════════ STORY  -  ROARK-INSPIRED NARRATIVE ═══════════ */
.story{position:relative;overflow:hidden}
.story-ch{position:relative;min-height:90vh;display:flex;align-items:center;overflow:hidden}
.story-ch-img{position:absolute;inset:0}
.story-ch-img img{width:100%;height:120%;object-fit:cover;will-change:transform}
.story-ch-ov{position:absolute;inset:0;z-index:1}
.story-ch-body{position:relative;z-index:2;width:100%}

/* Chapter 1: Origin */
.story-origin .story-ch-img img{filter:brightness(.25) saturate(.35) sepia(.15)}
.story-origin .story-ch-ov{background:linear-gradient(to right,rgba(41,39,40,.9) 0%,rgba(41,39,40,.6) 50%,transparent 100%)}
.story-origin .story-ch-body{padding:80px 56px;max-width:560px}

/* Chapter 2: Return */
.story-return{min-height:60vh;background:var(--green);display:flex;align-items:center}
.story-return-body{padding:80px 56px;max-width:600px;margin:0 auto;text-align:center}

/* Chapter 3: Now */
.story-now .story-ch-img img{filter:brightness(.5) saturate(.5) sepia(.08)}
.story-now .story-ch-ov{background:linear-gradient(to left,rgba(41,39,40,.9) 0%,rgba(41,39,40,.5) 50%,transparent 100%)}
.story-now .story-ch-body{padding:80px 56px;max-width:520px;margin-left:auto}

.story-num{font-family:var(--display);font-size:6rem;font-weight:200;color:rgba(201,191,168,.06);line-height:1;margin-bottom:-20px;position:relative;z-index:0}
.story-tag{font-family:var(--condensed);font-size:.5rem;font-weight:600;letter-spacing:.5em;text-transform:uppercase;color:var(--accent);margin-bottom:16px}
.story-h{font-family:var(--display);font-size:clamp(1.8rem,3.5vw,2.8rem);font-weight:400;text-transform:uppercase;line-height:.94;margin-bottom:20px;letter-spacing:.04em}
.story-h em{font-style:normal;color:var(--accent)}
.story-p{font-family:var(--serif);font-size:1rem;font-weight:300;color:var(--t2);line-height:1.9;margin-bottom:14px;font-style:italic}
.story-p strong{color:var(--t1);font-weight:500;font-style:normal}
.story-link{font-family:var(--condensed);font-size:.55rem;font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--accent);display:inline-flex;align-items:center;gap:8px;margin-top:10px;transition:gap .3s}.story-link:hover{gap:14px}

/* ═══════════ COLLECTIONS ═══════════ */
.cols{display:grid;grid-template-columns:1fr 1fr}
.col{position:relative;min-height:580px;overflow:hidden;cursor:pointer}
.col img{width:100%;height:100%;object-fit:cover;filter:brightness(.5) saturate(.5) sepia(.08);transition:all 1.2s var(--ease);transform:scale(1.04)}
.col:hover img{filter:brightness(.7) saturate(.6);transform:scale(1)}
.col-in{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;padding:44px;z-index:2}
.col-name{font-family:var(--display);font-size:clamp(2.8rem,5.5vw,4.5rem);font-weight:400;text-transform:uppercase;line-height:.88;margin-bottom:8px;letter-spacing:.05em}
.col-link{font-family:var(--condensed);font-size:.5rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t2);opacity:0;transform:translateY(6px);transition:all .4s}
.col:hover .col-link{opacity:1;transform:none;color:var(--accent)}
.col-div{position:absolute;top:0;bottom:0;right:0;width:1px;background:var(--bd);z-index:3}

/* ═══════════ COLLAB ═══════════ */
.collab{position:relative;min-height:500px;overflow:hidden}
.collab-bg{position:absolute;inset:0}.collab-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(.28) saturate(.4) sepia(.1)}
.collab-ov{position:absolute;inset:0;background:linear-gradient(105deg,rgba(41,39,40,.95) 0%,rgba(41,39,40,.65) 40%,transparent 100%)}
.collab-body{position:relative;z-index:2;padding:80px 56px;max-width:480px;display:flex;flex-direction:column;justify-content:center;min-height:500px}

/* ═══════════ TRUST ═══════════ */
.trust{display:grid;grid-template-columns:repeat(3,1fr);border-top:1px solid var(--bd);border-bottom:1px solid var(--bd);background:var(--green)}
.trust-i{padding:40px 32px;text-align:center;border-right:1px solid var(--bd)}.trust-i:last-child{border-right:none}
.trust-h{font-family:var(--display);font-size:.85rem;font-weight:400;letter-spacing:.08em;text-transform:uppercase;margin-bottom:6px}
.trust-p{font-family:var(--serif);font-size:.8rem;color:var(--t2);font-weight:300;font-style:italic}

/* ═══════════ COMMUNITY ═══════════ */
.comm{padding:100px 56px;text-align:center;position:relative;overflow:hidden}
.comm::before{content:"STY";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--display);font-size:clamp(14rem,30vw,28rem);color:rgba(201,191,168,.015);pointer-events:none;line-height:.8}
.comm-h{font-family:var(--display);font-size:clamp(1.6rem,3vw,2.4rem);font-weight:300;text-transform:uppercase;letter-spacing:.08em;line-height:.94;margin-bottom:48px}.comm-h .a{color:var(--accent);font-weight:400}
.comm-row{display:flex;justify-content:center;gap:72px}
.comm-n{font-family:var(--display);font-size:3.2rem;font-weight:300;letter-spacing:.04em}
.comm-l{font-family:var(--condensed);font-size:.4rem;font-weight:500;letter-spacing:.35em;text-transform:uppercase;color:var(--t3);margin-top:6px}

/* ═══════════ EMAIL ═══════════ */
.email{padding:80px 56px;background:var(--sf);text-align:center;border-top:1px solid var(--bd)}
.email-h{font-family:var(--display);font-size:1.6rem;font-weight:300;text-transform:uppercase;letter-spacing:.08em;margin-bottom:8px}
.email-sub{font-family:var(--serif);font-size:.9rem;color:var(--t3);margin-bottom:28px;font-weight:300;font-style:italic}
.email-form{display:flex;max-width:440px;margin:0 auto}
.email-in{flex:1;padding:14px 18px;background:var(--bg);border:1px solid var(--bd);border-right:0;color:var(--t1);font-family:var(--sans);font-size:.85rem;outline:none}.email-in:focus{border-color:var(--accent)}
.email-in::placeholder{color:var(--t3)}
.email-btn{font-family:var(--display);font-size:.8rem;letter-spacing:.1em;padding:14px 28px;background:rgba(201,191,168,.3);color:var(--bg);border:1px solid rgba(201,191,168,.35);transition:all .3s}.email-btn:hover{background:var(--accent-h)}

/* ═══════════ FOOTER v2 ═══════════ */
.ft-logo{font-family:var(--display);font-weight:700;font-size:3rem;letter-spacing:.02em;color:var(--t1);line-height:.9}
.ft-tag{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t2);margin-top:6px}
@media(max-width:960px){.ft-top{grid-template-columns:1fr;gap:40px}.ft-cols{grid-template-columns:repeat(2,1fr);gap:32px}}
@media(max-width:600px){.ft{padding:56px 24px 32px}.ft-cols{grid-template-columns:1fr 1fr;gap:24px}.ft-btm{flex-direction:column;align-items:flex-start}.ft-logo img{height:30px}}
@media(max-width:400px){.ft-cols{grid-template-columns:1fr}}

/* ═══════════ WAYPOINT WATCHES ═══════════ */
.waypoint{position:relative;min-height:600px;overflow:hidden;background:var(--sf);background:var(--wp-bg-alt)}
.waypoint-split{display:grid;grid-template-columns:1fr 1fr;min-height:600px}
.waypoint-img{position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}
.waypoint-img-inner{position:absolute;inset:-10%;display:flex;align-items:center;justify-content:center;will-change:transform}
.waypoint-img-placeholder{width:100%;height:100%;background:var(--el);display:flex;align-items:center;justify-content:center;font-family:var(--condensed);font-weight:400;font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(201,191,168,.06)}
.waypoint-body{padding:80px 56px;display:flex;flex-direction:column;justify-content:center;border-left:1px solid var(--bd)}
.waypoint-tag{font-family:var(--condensed);font-size:.55rem;font-weight:600;letter-spacing:.45em;text-transform:uppercase;color:var(--accent);display:flex;align-items:center;gap:10px;margin-bottom:14px}
.waypoint-tag-line{width:20px;height:.5px;background:rgba(201,191,168,.3)}
.waypoint-name{font-family:var(--display);font-size:clamp(2.8rem,6vw,4.5rem);font-weight:700;text-transform:uppercase;letter-spacing:.02em;line-height:.9;margin-bottom:8px}
.waypoint-sub{font-family:var(--sans);font-size:.65rem;font-weight:400;text-transform:uppercase;letter-spacing:.2em;color:var(--t3);margin-bottom:22px}
.waypoint-desc{font-family:var(--serif);font-size:1rem;font-weight:300;font-style:italic;color:var(--t2);line-height:1.85;margin-bottom:28px;max-width:380px}
.waypoint-desc strong{font-weight:500;color:var(--t1);font-style:normal}
.waypoint-specs{display:flex;gap:28px;margin-bottom:32px}
.waypoint-spec{text-align:center}
.waypoint-spec-val{font-family:var(--display);font-size:1.4rem;font-weight:700;letter-spacing:.02em;text-transform:uppercase;margin-bottom:4px}
.waypoint-spec-label{font-family:var(--sans);font-size:.55rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--t3)}

/* ═══════════ FOUNDER NOTE ═══════════ */
.fn{position:relative;padding:20px 24px;border-left:2px solid var(--accent);background:rgba(147,148,116,.06)}
.fn-label{position:absolute;top:-8px;left:16px;font-family:var(--condensed);font-weight:600;font-size:.5rem;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);background:var(--wp-tag-bg);padding:0 8px}
.fn-text{font-family:var(--serif);font-size:1rem;font-weight:400;font-style:italic;line-height:1.65;color:var(--t2)}
.fn-sig{font-family:var(--display);font-weight:500;font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--accent);margin-top:10px}

.pgrid 
.pgrid-2 

/* ═══════════ CART DRAWER ═══════════ */
.cart-drawer{position:fixed;top:0;right:0;width:420px;max-width:90vw;height:100%;background:var(--sf);z-index:10001;transform:translateX(100%);transition:transform .5s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;border-left:1px solid var(--bd)}
.cart-drawer.open{transform:translateX(0)}
.cart-backdrop{position:fixed;inset:0;background:rgba(0,0,0,.5);z-index:10000;opacity:0;visibility:hidden;transition:all .4s}
.cart-backdrop.open{opacity:1;visibility:visible}
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:24px 28px;border-bottom:1px solid var(--bd)}
.cart-title{font-family:var(--display);font-weight:700;font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--t1)}
.cart-close{width:44px;height:44px;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--t3);transition:color .3s;background:none;border:none;font-size:1.2rem}
.cart-close:hover{color:var(--t1)}
.cart-body{flex:1;padding:28px;overflow-y:auto;display:flex;flex-direction:column;align-items:center;justify-content:center}
.cart-empty{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--t3)}
.cart-empty-cta{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-top:16px;text-decoration:none;transition:color .3s}
.cart-empty-cta:hover{color:var(--t1)}
.cart-footer{padding:24px 28px;border-top:1px solid var(--bd)}
.cart-checkout{width:100%;padding:16px;background:rgba(201,191,168,.3);color:var(--bg);font-family:var(--sans);font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s}
.cart-checkout:hover{background:var(--olive)}

/* ═══════════ SOCIAL PROOF BAR ═══════════ */
.sp-bar{background:var(--sf);border-top:0.5px solid var(--bd);border-bottom:0.5px solid var(--bd);padding:28px 56px;display:flex;align-items:center;justify-content:center;gap:72px;flex-wrap:wrap}
.sp-item{display:flex;align-items:center;gap:12px}
.sp-stars{display:flex;gap:2px;color:var(--t1)}
.sp-stars svg{width:14px;height:14px}
.sp-n{font-family:var(--display);font-weight:700;font-size:1.3rem;color:var(--t1);letter-spacing:.01em;line-height:1}
.sp-l{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--t2)}
.sp-div{width:1px;height:28px;background:var(--bd)}
@media(max-width:768px){.sp-bar{padding:20px 20px;gap:24px}.sp-div{display:none}}
@media(max-width:480px){.sp-bar{flex-direction:column;gap:16px;padding:24px 20px}}

/* ═══════════ PRODUCT CARD RATINGS ═══════════ */
.pcard-rating{display:flex;align-items:center;gap:6px;margin-top:8px;font-family:var(--sans);font-size:.58rem;color:rgba(201,191,168,.7);letter-spacing:.04em}
.pcard-rating .stars{display:flex;gap:1px;color:var(--t1)}
.pcard-rating .stars svg{width:10px;height:10px}
.pcard-rating .count{color:var(--t3);font-size:.55rem}

/* ═══════════ WHY STY ═══════════ */
.why{padding:100px 56px 40px;background:var(--bg);text-align:center}
.why-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:56px;max-width:1180px;margin:48px auto 0}
.why-card{text-align:left}
.why-num{font-family:var(--display);font-size:.7rem;font-weight:500;letter-spacing:.2em;color:var(--t3);margin-bottom:16px}
.why-h{font-family:var(--display);font-weight:700;font-size:clamp(1.3rem,2vw,1.7rem);text-transform:uppercase;letter-spacing:.01em;line-height:1;margin-bottom:14px;color:var(--t1)}
.why-p{font-family:var(--sans);font-size:.8rem;line-height:1.7;color:var(--t2);font-weight:400;max-width:30ch}
.why-intro{font-family:var(--serif);font-style:italic;font-size:1rem;color:var(--t2);max-width:50ch;margin:0 auto}
@media(max-width:768px){.why{padding:60px 24px 20px}.why-grid{grid-template-columns:1fr;gap:40px;margin-top:32px}}

/* ═══════════ MODAL SYSTEM ═══════════ */
.modal-backdrop{position:fixed;inset:0;z-index:10050;background:rgba(21,20,19,.88);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);opacity:0;visibility:hidden;transition:opacity .4s var(--ease),visibility .4s var(--ease);display:flex;align-items:center;justify-content:center;padding:20px}
.modal-backdrop.open{opacity:1;visibility:visible}
.modal{background:var(--sf);border:0.5px solid var(--bd);max-width:960px;width:100%;max-height:90vh;overflow:hidden;position:relative;transform:translateY(20px);opacity:0;transition:all .5s var(--ease)}
.modal-backdrop.open .modal{transform:translateY(0);opacity:1}
.modal-close{position:absolute;top:16px;right:16px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(21,20,19,.6);backdrop-filter:blur(8px);border:0.5px solid rgba(201,191,168,.1);color:var(--t1);cursor:pointer;z-index:10;transition:all .3s;font-size:1.4rem;line-height:1;border-radius:0}
.modal-close:hover{background:rgba(21,20,19,.9);border-color:rgba(201,191,168,.25)}
body.modal-open{overflow:hidden}

/* Quick-view modal */
.qv-grid{display:grid;grid-template-columns:1.1fr 1fr;max-height:90vh}
.qv-img{position:relative;overflow:hidden;background:var(--el)}
.qv-img img{width:100%;height:100%;object-fit:cover;object-position:center;display:block}
.qv-thumbs{position:absolute;bottom:16px;left:16px;display:flex;gap:8px;z-index:2}
.qv-thumb{width:52px;height:64px;border:0.5px solid var(--bone-dim);background:var(--el);cursor:pointer;opacity:.6;transition:opacity .3s,border-color .3s}
.qv-thumb.active,.qv-thumb:hover{opacity:1;border-color:var(--t1)}
.qv-body{padding:56px 48px;overflow-y:auto;display:flex;flex-direction:column}
.qv-eyebrow{font-family:var(--sans);font-size:.5rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t3);margin-bottom:12px}
.qv-name{font-family:var(--display);font-weight:700;font-size:clamp(1.8rem,3.5vw,2.6rem);text-transform:uppercase;letter-spacing:.01em;line-height:.95;color:var(--t1);margin-bottom:10px}
.qv-price{font-family:var(--display);font-size:1.1rem;font-weight:700;color:var(--t1);margin-bottom:12px}
.qv-rating{display:flex;align-items:center;gap:8px;margin-bottom:24px;font-family:var(--sans);font-size:.65rem;color:var(--t2);letter-spacing:.04em;padding-bottom:24px;border-bottom:0.5px solid var(--bd)}
.qv-rating .stars{display:flex;gap:1px;color:var(--t1)}
.qv-rating .stars svg{width:12px;height:12px}
.qv-rating .count{color:var(--t3);font-size:.6rem}
.qv-desc{font-family:var(--sans);font-weight:400;font-size:.82rem;line-height:1.75;color:var(--t2);margin-bottom:24px;letter-spacing:.01em}
.qv-section{margin-bottom:24px}
.qv-section-h{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--t2);margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}
.qv-size-guide-link{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--t1);text-decoration:underline;text-underline-offset:3px;background:none;border:none;cursor:pointer;padding:0}
.qv-size-guide-link:hover{color:var(--t2)}
.qv-sizes{display:flex;gap:8px;flex-wrap:wrap}
.qv-sz{min-width:48px;height:42px;padding:0 14px;display:flex;align-items:center;justify-content:center;border:0.5px solid var(--bd);background:transparent;font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--t1);cursor:pointer;transition:all .3s}
.qv-sz:hover{border-color:var(--t2)}
.qv-sz.selected{background:var(--t1);color:var(--bg);border-color:var(--t1)}
.qv-sz.unavailable{opacity:.25;cursor:not-allowed;text-decoration:line-through}
.qv-cta{display:flex;gap:12px;margin-top:auto;padding-top:12px}
.qv-cta-main{flex:1;padding:18px;background:var(--t1);color:var(--bg);font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s}
.qv-cta-main:hover{background:var(--t2);letter-spacing:.28em}
.qv-cta-main:disabled{opacity:.4;cursor:not-allowed;background:var(--t3)}
.qv-details-link{display:block;margin-top:16px;font-family:var(--sans);font-size:.58rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--t2);text-align:center}
.qv-details-link:hover{color:var(--t1)}

@media(max-width:768px){
.modal-backdrop{padding:0;align-items:stretch}
.modal{max-height:100vh;height:100vh;max-width:100vw;border:none}
.qv-grid{grid-template-columns:1fr;overflow-y:auto}
.qv-img{height:55vh}
.qv-body{padding:32px 24px}
.qv-name{font-size:1.8rem}
}

/* Size guide modal */
.sg-modal{max-width:780px}
.sg-header{padding:40px 48px 24px;border-bottom:0.5px solid var(--bd)}
.sg-title{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,3vw,2.2rem);text-transform:uppercase;letter-spacing:.01em;color:var(--t1);margin-bottom:8px}
.sg-intro{font-family:var(--serif);font-style:italic;font-size:.9rem;color:var(--t2);line-height:1.5}
.sg-tabs{display:flex;gap:4px;padding:16px 48px 0;border-bottom:0.5px solid var(--bd);flex-wrap:wrap}
.sg-tab{padding:12px 16px;background:none;border:none;font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.16em;text-transform:uppercase;color:var(--t3);cursor:pointer;transition:color .3s;border-bottom:2px solid transparent;margin-bottom:-1px}
.sg-tab:hover{color:var(--t2)}
.sg-tab.active{color:var(--t1);border-color:var(--t1)}
.sg-content{padding:32px 48px 40px;overflow-y:auto;max-height:calc(90vh - 200px)}
.sg-unit{display:flex;justify-content:flex-end;margin-bottom:16px;gap:8px}
.sg-unit button{padding:6px 12px;background:none;border:0.5px solid var(--bd);font-family:var(--sans);font-size:.55rem;letter-spacing:.15em;text-transform:uppercase;color:var(--t2);cursor:pointer;transition:all .3s}
.sg-unit button.active{background:var(--t1);color:var(--bg);border-color:var(--t1)}
.sg-table{width:100%;border-collapse:collapse;font-family:var(--sans);font-size:.75rem}
.sg-table th{text-align:left;padding:14px 12px;font-weight:500;letter-spacing:.15em;text-transform:uppercase;font-size:.55rem;color:var(--t2);border-bottom:0.5px solid var(--bd);background:transparent}
.sg-table td{padding:14px 12px;border-bottom:0.5px solid var(--bd);color:var(--t1);font-weight:400}
.sg-table tbody tr{transition:background .3s}
.sg-table tbody tr:hover{background:rgba(201,191,168,.02)}
.sg-how-title{font-family:var(--display);font-weight:700;font-size:1rem;text-transform:uppercase;letter-spacing:.06em;color:var(--t1);margin-top:32px;margin-bottom:16px}
.sg-how-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.sg-how-item{padding:16px;border:0.5px solid var(--bd)}
.sg-how-n{font-family:var(--display);font-weight:700;font-size:.8rem;color:var(--t2);margin-bottom:6px}
.sg-how-h{font-family:var(--sans);font-size:.65rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;color:var(--t1);margin-bottom:8px}
.sg-how-p{font-family:var(--serif);font-style:italic;font-size:.75rem;line-height:1.5;color:var(--t2)}
@media(max-width:768px){
.sg-header,.sg-tabs,.sg-content{padding-left:24px;padding-right:24px}
.sg-how-grid{grid-template-columns:1fr}
.sg-tabs{overflow-x:auto;padding-top:8px}
.sg-tab{flex-shrink:0}
}


/* ═══════════ CUSTOM CURSOR ═══════════ */
.cursor{position:fixed;width:14px;height:14px;border:1px solid rgba(201,191,168,.35);border-radius:50%;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:width .4s cubic-bezier(.16,1,.3,1),height .4s cubic-bezier(.16,1,.3,1),border-color .3s,background .3s,opacity .3s;opacity:0}
.cursor.visible{opacity:1}
.cursor.hover{width:52px;height:52px;border-color:rgba(201,191,168,.5);background:rgba(201,191,168,.03)}
@media(max-width:768px){.cursor{display:none}}
@media(pointer:coarse){.cursor{display:none}}

/* ═══════════ STAGGERED REVEALS ═══════════ */
.rv1{transition-delay:.1s}
.rv2{transition-delay:.2s}
.rv3{transition-delay:.3s}
.rv4{transition-delay:.4s}

/* ═══════════ BUTTON HOVER UPGRADE ═══════════ */
.btn:hover{letter-spacing:.24em;border-color:var(--bone-dim);background:rgba(201,191,168,.03)}
.btn-a:hover{background:rgba(201,191,168,.08);letter-spacing:.24em}

/* ═══════════ NAV HOVER UPGRADE ═══════════ */
.nav-c a:hover{color:var(--t1)}

/* ═══════════ CHAPTER BREAKS ═══════════ */
.ch-break{display:flex;align-items:center;justify-content:center;padding:40px 56px;gap:20px}
.ch-line{flex:1;height:0.5px;background:var(--bd)}
.ch-dot{width:4px;height:4px;border-radius:50%;background:rgba(201,191,168,.25)}
@media(max-width:768px){.ch-break{padding:28px 20px}}

/* ═══════════ PRODUCT CARD HOVER UPGRADE ═══════════ */
.pcard:hover{transform:translateY(-2px)}
.pcard:hover .pcard-name{color:var(--t1)}
.pcard{transition:transform .4s cubic-bezier(.16,1,.3,1)}

/* ═══════════ COLOPHON ═══════════ */
.colophon{font-family:var(--sans);font-size:.5rem;font-weight:400;letter-spacing:.2em;text-transform:uppercase;color:var(--t3);line-height:1.8}

/* Hide default cursor on desktop when custom cursor active */
@media(pointer:fine){a,button,.pcard{cursor:none}}

/* ═══════════ WAYPOINT WARM PALETTE ═══════════ */
.waypoint .waypoint-tag{color:var(--wp-meta)}
.waypoint .waypoint-tag-line{background:var(--wp-tag)}
.waypoint .waypoint-name{color:var(--wp-text)}
.waypoint .waypoint-sub{color:var(--wp-tag)}
.waypoint .waypoint-desc{color:var(--wp-text-muted)}
.waypoint .waypoint-desc strong{color:var(--wp-text)}
.waypoint .sec-label{color:var(--wp-meta)}
.waypoint .waypoint-body{border-left:1px solid rgba(21,20,19,.06);padding:80px 64px}
.waypoint .waypoint-spec{text-align:left}
.waypoint .waypoint-spec-val{color:var(--wp-text);font-weight:700}
.waypoint .waypoint-spec-label{color:var(--wp-tag)}
.waypoint .waypoint-specs{gap:32px}
.waypoint .btn{color:var(--wp-text);border-color:rgba(41,39,40,.15)}
.waypoint .btn:hover{border-color:var(--wp-meta);background:rgba(107,108,78,.05);letter-spacing:.24em}
.waypoint .waypoint-img{background:var(--wp-bg)}
.waypoint .waypoint-img-placeholder{color:rgba(21,20,19,.06)}

/* ═══════════ PAGE LOADER ═══════════ */
.loader{position:fixed;inset:0;z-index:99999;display:flex;align-items:center;justify-content:center;background:var(--bg);flex-direction:column;gap:.8rem;transition:opacity .6s var(--ease),visibility .6s}
.loader.done{opacity:0;visibility:hidden;pointer-events:none}
.loader-word{font-family:var(--display);font-weight:700;font-size:clamp(1.2rem,4vw,2.2rem);letter-spacing:.3em;text-transform:uppercase;color:var(--t1);overflow:hidden;display:flex}
.loader-word span{display:inline-block;opacity:0;transform:translateY(100%);animation:lci .5s var(--ease) forwards}
.loader-line{width:0;height:2px;background:rgba(201,191,168,.3);animation:lli 1.6s var(--ease) .4s forwards}
.loader-sub{font-family:var(--condensed);font-weight:500;font-size:.6rem;letter-spacing:.35em;text-transform:uppercase;color:var(--t3);opacity:0;animation:lfi .8s var(--ease) .8s forwards}
@keyframes lci{to{opacity:1;transform:translateY(0)}}
@keyframes lli{to{width:120px}}
@keyframes lfi{to{opacity:1}}

/* ═══════════ SCROLL PROGRESS ═══════════ */
.scroll-progress{position:fixed;top:0;left:0;width:0;height:2px;background:rgba(201,191,168,.3);z-index:9998;pointer-events:none}

/* ═══════════ BACK TO TOP ═══════════ */
.btt{position:fixed;bottom:24px;right:24px;width:44px;height:44px;background:var(--ink);border:0;border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:100;opacity:0;visibility:hidden;transform:translateY(12px);transition:opacity .35s var(--ease),visibility .35s var(--ease),transform .35s var(--ease),background .25s var(--ease);cursor:pointer;padding:0;box-shadow:0 6px 18px rgba(29,29,27,.18)}
.btt.show{opacity:1;visibility:visible;transform:translateY(0)}
.btt:hover,.btt:focus-visible{background:var(--accent);outline:none}
.btt svg{width:16px;height:16px;stroke:var(--bone);fill:none;stroke-width:2}

/* ═══════════ TOUCH TARGETS ═══════════ */
.nav-icon{min-width:44px;min-height:44px;display:inline-flex;align-items:center;justify-content:center}
.ham{min-width:44px;min-height:44px;display:none;align-items:center;justify-content:center;padding:0}
.mm .mm-x{min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;top:12px;right:12px}

/* ═══════════ SAFE AREA ═══════════ */
.ed-masthead{padding-top:max(9px, env(safe-area-inset-top, 0px))}
.ft-btm{padding-bottom:env(safe-area-inset-bottom, 0px)}

/* ═══════════ RESPONSIVE  -  TABLET ═══════════ */
@media(max-width:1024px){
.waypoint-specs{gap:20px;flex-wrap:wrap}
.cols .col{min-height:400px}
}

/* ═══════════ RESPONSIVE  -  MOBILE ═══════════ */
@media(max-width:768px){
.ed-masthead{padding:6px 16px;padding-top:max(6px, env(safe-area-inset-top, 0px))}
.nav{padding:0 16px;height:50px}.nav-c{display:none}.ham{display:flex}
.nav.scrolled{backdrop-filter:none;-webkit-backdrop-filter:none;background:rgba(41,39,40,.97)}
.hero{min-height:100vh;min-height:100svh}
.hero-img img{width:100%;height:100%;position:absolute;inset:0;object-fit:cover;object-position:35% center;filter:brightness(.6) saturate(.75) sepia(.02)}
.hero-fade{background:linear-gradient(to bottom,rgba(41,39,40,.08) 0%,rgba(41,39,40,.08) 30%,rgba(41,39,40,.4) 50%,rgba(41,39,40,.88) 78%,rgba(41,39,40,.97) 100%)}
.hero-body{padding:0 20px 44px;max-width:100%;text-align:left;align-items:flex-start}
.hero-h{font-size:clamp(3.5rem,16vw,5.5rem)}
.hero-glow{display:none}
.hero-ctas{flex-direction:column;width:100%;max-width:320px;gap:8px}
.btn{width:100%;justify-content:center;padding:16px 24px;font-size:.7rem}
.scroll-cue{display:none}
.manifesto{padding:40px 20px;flex-direction:column;gap:16px}.manifesto-line{width:24px}
.manifesto-text{font-size:clamp(1rem,4vw,1.3rem)}
.sec{padding:48px 20px}
.sec-label{font-size:.6rem;letter-spacing:.35em}
.sec-title{font-size:clamp(1.3rem,5vw,2rem)}

.sec-hdr{flex-direction:column;gap:10px;align-items:flex-start}
.fn-label{background:var(--sf)}
.pgrid{grid-template-columns:1fr 1fr;gap:2px}
.pgrid .pcard:first-child{grid-column:span 2}
.pgrid-2{grid-template-columns:1fr 1fr;gap:2px}
.pgrid-2 .pcard:last-child{grid-column:span 2}

.pcard-info{padding:10px 12px 14px}
.pcard-name{font-size:.72rem}
.story-origin .story-ch-body,.story-now .story-ch-body{padding:40px 20px;max-width:100%}
.story-return-body{padding:40px 20px}
.story-origin .story-ch-ov,.story-now .story-ch-ov{background:rgba(41,39,40,.88)}
.story-ch{min-height:auto}
.story-num{font-size:3.5rem}
.story-h{font-size:clamp(1.4rem,5vw,2rem)}
.cols{grid-template-columns:1fr}.col{min-height:320px}.col-div{display:none}.col-link{opacity:1;transform:none}
.collab-body{padding:36px 20px;min-height:360px}.collab-ov{background:linear-gradient(to bottom,rgba(41,39,40,.95),rgba(41,39,40,.5))}
.waypoint-split{grid-template-columns:1fr}.waypoint-img{height:50vh;height:50svh}.waypoint-body{padding:36px 20px;border-left:none;border-top:1px solid var(--bd)}.waypoint-specs{gap:16px}
.waypoint-name{font-size:clamp(2.2rem,8vw,3.2rem)}
.waypoint-spec-label{font-size:.5rem;letter-spacing:.2em}
.trust{grid-template-columns:1fr}.trust-i{border-right:none;border-bottom:1px solid var(--bd);padding:24px 20px}.trust-i:last-child{border-bottom:none}
.comm{padding:56px 20px}.comm-row{flex-wrap:wrap;gap:24px;justify-content:space-around}.comm-n{font-size:2.2rem}
.email{padding:44px 20px}.email-form{flex-direction:column}.email-in{border-right:1px solid var(--bd);border-bottom:none}
.email-btn{border-top:0}
.ft{padding:28px 20px;flex-direction:column;gap:20px;padding-bottom:max(28px, calc(20px + env(safe-area-inset-bottom, 0px)))}.ft-cols{flex-direction:column;gap:16px}.ft-btm{flex-direction:column;gap:4px}
.btt{bottom:max(20px, calc(12px + env(safe-area-inset-bottom, 0px)));right:16px;width:40px;height:40px;background:var(--ink)}
.loader-word{font-size:clamp(.85rem,5vw,1.4rem);letter-spacing:.35em}
}

/* ═══════════ RESPONSIVE  -  LARGE PHONE ═══════════ */
@media(max-width:480px){
.hero-img img{object-position:30% center}
.hero-body{padding:0 16px 40px}
.hero-h{font-size:clamp(3rem,14vw,4.5rem)}
.hero-p{font-size:1rem;max-width:28ch}
.hero-ctas{max-width:100%}
.btn{padding:14px 20px}
}

/* ═══════════ LANDSCAPE PHONE ═══════════ */
@media(max-width:768px) and (orientation:landscape){
.hero{min-height:100svh}
.hero-img img{object-position:center 30%}
.hero-body{padding:0 40px 32px}
.hero-h{font-size:clamp(1.8rem,5vw,2.6rem)}
}

/* ═══════════ RESPONSIVE  -  SMALL PHONE ═══════════ */
@media(max-width:380px){
.hero-h{font-size:2.8rem}
.hero-p{font-size:.85rem}
.sec-title{font-size:1.2rem}
.story-num{font-size:3rem}
.waypoint-specs{flex-direction:column;align-items:flex-start;gap:12px}
.comm-row{gap:20px}
.comm-n{font-size:2rem}
}

/* ═══════════ LANDSCAPE PHONE ═══════════ */
@media(max-width:768px) and (orientation:landscape){
.hero{min-height:100vw;min-height:100svh}
.hero-img img{object-position:center 30%}
.hero-body{padding:0 40px 32px}
.hero-h{font-size:clamp(1.8rem,5vw,2.6rem)}
}

/* ═══════════ MOBILE POLISH ═══════════ */
@media(max-width:768px){
.pgrid .pcard:first-child{grid-column:span 2}
.pgrid-2 .pcard:last-child{grid-column:span 2}
.cart-drawer{width:100%;max-width:100%}
.email-section-warm{padding:80px 20px !important}
}
@media(max-width:480px){
.pgrid{grid-template-columns:1fr !important}
.pgrid .pcard:first-child{grid-column:span 1}
.pgrid-2{grid-template-columns:1fr !important}
.pgrid-2 .pcard:last-child{grid-column:span 1}
}

@media(max-width:768px){
.pcard{height:500px}
.pcard-info{transform:translateY(0);background:linear-gradient(to top,rgba(21,20,19,.92) 0%,rgba(21,20,19,.6) 45%,rgba(21,20,19,.1) 85%,transparent 100%);padding:18px 18px 20px}
}
@media(max-width:480px){
.pcard{height:540px}
}


/* ═══════════ MOBILE OPTIMIZATION ═══════════ */

/* Foundation — prevent horizontal scroll, smooth text, remove tap flash */
html,body{overflow-x:hidden;max-width:100vw;-webkit-tap-highlight-color:transparent;-webkit-text-size-adjust:100%;text-size-adjust:100%}
*{-webkit-tap-highlight-color:transparent}
button,a{touch-action:manipulation}

/* Prevent content jumping when scrollbar appears */
html{scrollbar-gutter:stable}

/* ═══════════ MOBILE: PDP GALLERY ═══════════ */
@media(max-width:768px){
  /* Main gallery image — slightly less tall on mobile to show info below faster */
  .pdp-main-img-wrap{aspect-ratio:4/5}
  
  /* Thumbnails — 4 cols but ensure tap targets are comfortable */
  .pdp-thumbs{grid-template-columns:repeat(4,1fr);gap:3px;padding:3px 0 0}
  .pdp-thumb{min-height:70px}
  
  /* Gallery dot navigation — larger touch targets */
  .pdp-main-img-wrap .dot-nav{bottom:16px;gap:10px;padding:12px;border-radius:20px;background:rgba(21,20,19,.4);backdrop-filter:blur(10px)}
  .pdp-main-img-wrap .dot{width:8px;height:8px}
  .pdp-main-img-wrap .dot.active{width:28px}
  
  /* Model fit line — more breathing room */
  .pdp-model-fit{padding:18px 16px;font-size:.58rem;flex-wrap:wrap;text-align:center;letter-spacing:.12em}
}

/* ═══════════ MOBILE: PDP INFO PANEL ═══════════ */
@media(max-width:768px){
  .pdp-info{padding:40px 20px 48px}
  .pdp-eyebrow{font-size:.5rem;margin-bottom:12px}
  .pdp-h1{font-size:clamp(1.5rem,5vw,1.9rem);margin-bottom:8px;line-height:1;letter-spacing:.04em}
  .pdp-tagline{font-size:.95rem;margin-bottom:16px}
  .pdp-rating{flex-wrap:wrap;gap:8px;margin-bottom:18px;padding-bottom:18px;font-size:.7rem}
  .pdp-rating .count{font-size:.62rem}
  .pdp-rating .read-reviews{margin-left:0;margin-top:4px;font-size:.58rem;width:100%}
  .pdp-price{font-size:1.05rem;margin-bottom:18px}
  .pdp-price-sub{display:block;margin-left:0;margin-top:6px;font-size:.55rem;line-height:1.4}
  .pdp-desc{font-size:.85rem;margin-bottom:24px;line-height:1.7}
  
  /* Section labels — comfortable tap targets for Size guide link */
  .pdp-section{margin-bottom:20px}
  .pdp-section-label{margin-bottom:10px}
  .pdp-size-guide-link{padding:6px 0;min-height:32px;display:flex;align-items:center}
  
  /* Color swatches — ensure 44px tap target */
  .pdp-color{width:44px;height:44px}
  
  /* Size buttons — bigger height on mobile */
  .pdp-sizes{gap:8px}
  .pdp-size{height:52px;font-size:.72rem}
  
  /* CTA — dominant, unmissable */
  .pdp-cta{padding:22px;font-size:.74rem;letter-spacing:.2em;margin-top:24px}
  .pdp-cta:hover{letter-spacing:.22em}
  
  /* Trust row — stay 3-column but more compact */
  .pdp-trust{gap:8px;padding:20px 0;margin-top:22px;grid-template-columns:repeat(3,1fr)}
  .pdp-trust-i svg{width:18px;height:18px;margin-bottom:6px}
  .pdp-trust-h{font-size:.45rem;letter-spacing:.16em;line-height:1.2;margin-bottom:3px}
  .pdp-trust-p{font-size:.5rem;line-height:1.3}
  
  /* Accordion — extend tap area */
  .pdp-accordion{margin-top:22px}
  .pdp-acc-btn{padding:20px 0;font-size:.64rem;min-height:48px}
  .pdp-acc-inner{font-size:.78rem;padding:0 0 20px}
}

@media(max-width:480px){
  .pdp-trust{grid-template-columns:repeat(3,1fr);gap:6px}
  .pdp-trust-h{font-size:.4rem}
  .pdp-trust-p{font-size:.45rem}
}

/* Very small phones (iPhone SE etc.) */
@media(max-width:380px){
  .pdp-info{padding:36px 16px 40px}
  .pdp-h1{font-size:1.4rem}
  .pdp-sizes{grid-template-columns:repeat(3,1fr)}
  .pdp-trust{grid-template-columns:1fr 1fr;gap:10px}
  .pdp-trust-i{text-align:left;display:flex;align-items:center;gap:10px}
  .pdp-trust-i svg{margin:0;flex-shrink:0}
}

/* ═══════════ MOBILE: COMPLETE THE LOOK ═══════════ */
@media(max-width:768px){
  
  
  
  
  
  /* Bundle checkbox — bigger tap target */
  
  
  
  /* Bundle item content — cleaner layout */
  
  
  
  /* Bundle size buttons — proper touch size */
  
  
  
  
  
  /* Bundle footer — full-width stacked layout */
  
  
  
  
}

/* ═══════════ MOBILE: STORY SECTION ═══════════ */
@media(max-width:768px){
  .pdp-story{padding:60px 20px}
  .pdp-story-grid{gap:32px}
  .pdp-story-num{font-size:clamp(3.5rem,14vw,5rem);margin-bottom:0}
  .pdp-story-h{font-size:clamp(1.8rem,7vw,2.4rem);margin-bottom:20px}
  .pdp-story-p{font-size:.95rem;line-height:1.7;margin-bottom:16px}
  .pdp-story-img{aspect-ratio:4/3}
}

/* ═══════════ MOBILE: CRAFTSMANSHIP ═══════════ */
@media(max-width:768px){
  
  
  
  
  
  
  
  
}

/* ═══════════ MOBILE: REVIEWS ═══════════ */
@media(max-width:960px){
  .pdp-reviews{padding:64px 20px}
  .pdp-reviews-head{gap:28px;margin-bottom:32px}
  .pdp-reviews-summary{text-align:center}
  .pdp-reviews-summary .big-stars{justify-content:center}
  .pdp-reviews-summary .big-rating{font-size:clamp(3.5rem,14vw,5rem)}
}
@media(max-width:768px){
  .pdp-review-list{gap:14px}
  .pdp-review{padding:22px 20px}
  .pdp-review-title{font-size:.85rem}
  .pdp-review-body{font-size:.8rem;line-height:1.7}
  .pdp-review-meta{margin-bottom:10px}
  .pdp-review-name{font-size:.7rem}
  .pdp-review-date{font-size:.55rem}
}

/* ═══════════ MOBILE: UGC ═══════════ */
@media(max-width:768px){
  .pdp-ugc{padding:56px 16px}
  .pdp-ugc-head{margin-bottom:32px}
  .pdp-ugc-head h2{font-size:clamp(1.8rem,7vw,2.4rem)}
  .pdp-ugc-head p{font-size:.88rem}
  .pdp-ugc-grid{grid-template-columns:repeat(2,1fr);gap:3px}
  /* Always show username on mobile since there's no hover */
  .ugc-item .ugc-overlay{opacity:1;background:linear-gradient(to top,rgba(21,20,19,.75) 0%,rgba(21,20,19,.2) 40%,transparent 60%);padding:12px}
  .ugc-username{font-size:.55rem}
  .ugc-username svg{width:12px;height:12px}
  .pdp-ugc-cta{margin-top:32px}
}
@media(max-width:400px){
  .pdp-ugc-grid{grid-template-columns:repeat(2,1fr)}
}

/* ═══════════ MOBILE: RELATED PRODUCTS ═══════════ */
@media(max-width:768px){
  .pdp-related{padding:56px 16px 40px}
  .pdp-related-head{margin-bottom:28px}
  .pdp-related-grid{grid-template-columns:repeat(2,1fr);gap:2px}
}
@media(max-width:480px){
  .pdp-related-grid{grid-template-columns:1fr}
}


/* ═══════════ REDUCED MOTION ═══════════ */
@media(prefers-reduced-motion:reduce){
*,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
.rv,.rv-l,.rv-r{opacity:1;transform:none}
.loader{display:none}
.scroll-progress{display:none}
}

/* ═══════════ PDP ═══════════ */
.pdp-crumbs{padding:20px 56px 0;display:flex;align-items:center;gap:10px;font-family:var(--sans);font-size:.55rem;letter-spacing:.16em;text-transform:uppercase;color:var(--brass)}
.pdp-crumbs a{color:var(--brass);transition:color .3s}
.pdp-crumbs a:hover{color:var(--t1)}
.pdp-crumbs .sep{opacity:.5}
.pdp-crumbs .cur{color:var(--bone-pale)}

.pdp{display:grid;grid-template-columns:1.2fr 1fr;gap:0;padding:16px 0 0;align-items:flex-start}
.pdp-gallery{position:relative;background:var(--bg);display:flex;flex-direction:column}
.pdp-main-img-wrap{position:relative;overflow:hidden;aspect-ratio:4/5;width:100%}
.pdp-main-img-wrap img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1) saturate(.88) sepia(.03);transition:opacity .3s}
.pdp-main-img-wrap .dot-nav{position:absolute;bottom:24px;left:50%;transform:translateX(-50%);display:flex;gap:8px;z-index:2}
.pdp-main-img-wrap .dot{width:6px;height:6px;border-radius:50%;background:rgba(201,191,168,.3);transition:all .3s;cursor:pointer;border:none;padding:0}
.pdp-main-img-wrap .dot.active{background:var(--t1);width:24px;border-radius:3px}
.pdp-thumbs{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;padding:2px 0 0}
.pdp-thumb{aspect-ratio:1;cursor:pointer;overflow:hidden;position:relative;background:var(--el);border:0.5px solid var(--bd);transition:border-color .3s}
.pdp-thumb img{width:100%;height:100%;object-fit:cover;display:block;opacity:.7;transition:opacity .3s}
.pdp-thumb.active{border-color:var(--t1)}
.pdp-thumb.active img,.pdp-thumb:hover img{opacity:1}

.pdp-info{padding:64px 56px;max-width:560px;align-self:start;position:sticky;top:80px}
.pdp-eyebrow{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--brass);margin-bottom:16px}
.pdp-h1{font-family:var(--display);font-weight:700;font-size:clamp(1.6rem,2.2vw,2rem);text-transform:uppercase;letter-spacing:.04em;line-height:1;color:var(--t1);margin-bottom:10px}
.pdp-tagline{font-family:var(--serif);font-style:italic;font-size:.92rem;color:var(--t2);margin-bottom:18px;line-height:1.5}
.pdp-rating{display:flex;align-items:center;gap:10px;margin-bottom:22px;font-family:var(--sans);font-size:.7rem;color:var(--t2);letter-spacing:.04em;padding-bottom:22px;border-bottom:0.5px solid var(--bd)}
.pdp-rating .stars{display:flex;gap:1px;color:var(--t1)}
.pdp-rating .stars svg{width:13px;height:13px}
.pdp-rating .count{color:var(--t3);font-size:.65rem}
.pdp-rating .read-reviews{margin-left:auto;font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--t2);text-decoration:underline;text-underline-offset:3px;background:none;border:none;cursor:pointer;padding:0}
.pdp-rating .read-reviews:hover{color:var(--t1)}
.pdp-price{font-family:var(--display);font-weight:700;font-size:1.15rem;color:var(--t1);letter-spacing:.02em;margin-bottom:22px}
.pdp-price-sub{font-family:var(--sans);font-size:.6rem;font-weight:400;letter-spacing:.12em;text-transform:uppercase;color:var(--brass);margin-left:8px}
.pdp-desc{font-family:var(--sans);font-weight:400;font-size:.82rem;line-height:1.75;color:var(--t2);margin-bottom:32px;letter-spacing:.01em}

.pdp-section{margin-bottom:24px}
.pdp-section-label{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}
.pdp-section-label>span:first-child{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--t2)}
.pdp-section-label .selected-val{font-family:var(--sans);font-size:.65rem;color:var(--t1);font-weight:400;letter-spacing:.05em}
.pdp-size-guide-link{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.15em;text-transform:uppercase;color:var(--t1);text-decoration:underline;text-underline-offset:3px;background:none;border:none;cursor:pointer;padding:0}
.pdp-size-guide-link:hover{color:var(--t2)}

.pdp-colors{display:flex;gap:10px;flex-wrap:wrap}
.pdp-color{width:40px;height:40px;border:0.5px solid var(--bd);cursor:pointer;position:relative;transition:all .3s;background:var(--bg)}
.pdp-color.selected{border-color:var(--t1);border-width:1px}
.pdp-color.selected::after{content:"";position:absolute;inset:-4px;border:0.5px solid var(--t1)}

.pdp-sizes{display:grid;grid-template-columns:repeat(5,1fr);gap:6px}
.pdp-size{height:46px;display:flex;align-items:center;justify-content:center;font-family:var(--sans);font-size:.7rem;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--t1);border:0.5px solid var(--bd);background:transparent;cursor:pointer;transition:all .3s}
.pdp-size:hover{border-color:var(--t2)}
/* Selected size button: B1 pattern (--ink bg, --bone text) — matches
   the primary CTA so the active size visually pairs with the cart action. */
.pdp-size.selected{background:var(--ink);color:var(--bone);border-color:var(--ink)}
.pdp-size.unavail{opacity:.3;cursor:not-allowed;text-decoration:line-through}

/* Primary PDP CTA: B1 pattern. Default = warm-black bg + warm-white text.
   Hover = burnt orange bg (precious accent moment on interaction).
   Disabled = bone-dim gray (preserves visual signal that the action isn't
   available; lower-priority button doesn't compete). */
.pdp-cta{width:100%;padding:20px;background:var(--ink);color:var(--bone);font-family:var(--sans);font-size:.72rem;font-weight:500;letter-spacing:.24em;text-transform:uppercase;border:none;cursor:pointer;transition:all .3s;margin-top:20px}
.pdp-cta:hover{background:var(--accent);letter-spacing:.28em}
.pdp-cta:disabled{opacity:.55;cursor:not-allowed;background:var(--bone-dim);color:var(--bone)}
.pdp-cta-alt{width:100%;padding:16px;background:transparent;color:var(--ink);font-family:var(--sans);font-size:.58rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;border:0.5px solid var(--bd);cursor:pointer;transition:all .3s;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:8px}
.pdp-cta-alt:hover{border-color:var(--ink);background:var(--ink);color:var(--bone)}
.pdp-cta-alt svg{width:12px;height:12px}

.pdp-trust{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:28px;padding:24px 0;border-top:0.5px solid var(--bd);border-bottom:0.5px solid var(--bd)}
.pdp-trust-i{text-align:center}
.pdp-trust-i svg{width:20px;height:20px;color:var(--t2);margin:0 auto 8px;display:block}
.pdp-trust-h{font-family:var(--sans);font-size:.5rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--t1);margin-bottom:4px}
.pdp-trust-p{font-family:var(--sans);font-size:.55rem;color:var(--t3);line-height:1.3;letter-spacing:.04em}

/* Payment methods row — single line below the trust strip. Voice-aligned
   text-based treatment instead of icon-heavy badges (cleaner with current
   palette + maintains heritage tone). Injected via pdp-page.js after the
   .pdp-trust block on init. */
.pdp-payments{margin-top:18px;padding:0;text-align:center;font-family:var(--sans);font-size:.62rem;font-weight:400;letter-spacing:.16em;text-transform:uppercase;color:var(--t2);line-height:1.6}
.pdp-payments-label{display:block;font-size:.5rem;letter-spacing:.32em;color:var(--t3);margin-bottom:6px}
.pdp-payments-list{display:inline}
.pdp-payments-list .sep{margin:0 6px;color:var(--bone-dim);opacity:.6}
@media(max-width:480px){.pdp-payments{font-size:.55rem;letter-spacing:.12em}}

/* Mobile sticky add-to-cart bar. Slides up from viewport bottom when
   the user scrolls past the primary .pdp-cta. Mobile-only (≤768px) —
   desktop has the primary CTA always-visible alongside the gallery so
   sticky bar isn't needed. Injected via pdp-page.js on init; visibility
   toggled by IntersectionObserver on the primary CTA. */
.pdp-sticky-cart{position:fixed;left:0;right:0;bottom:0;display:none;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;background:var(--bone);border-top:0.5px solid var(--bd);box-shadow:0 -1px 8px rgba(29,29,27,.06);transform:translateY(100%);transition:transform .24s var(--ease);z-index:90}
.pdp-sticky-cart.is-visible{transform:translateY(0)}
.pdp-sticky-cart-info{display:flex;flex-direction:column;min-width:0;flex:1}
.pdp-sticky-cart-name{font-family:var(--sans);font-size:.7rem;font-weight:600;letter-spacing:.04em;color:var(--ink);line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pdp-sticky-cart-price{font-family:var(--sans);font-size:.65rem;font-weight:500;color:var(--t2);margin-top:2px}
.pdp-sticky-cart-cta{flex-shrink:0;padding:14px 22px;background:var(--ink);color:var(--bone);font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;border:none;cursor:pointer;transition:background .25s var(--ease)}
.pdp-sticky-cart-cta:hover{background:var(--accent)}
.pdp-sticky-cart-cta:disabled{opacity:.55;cursor:not-allowed;background:var(--bone-dim)}
@media(min-width:769px){.pdp-sticky-cart{display:none !important}}
@media(max-width:768px){.pdp-sticky-cart{display:flex}body.has-sticky-cart{padding-bottom:80px}}

.pdp-accordion{margin-top:28px}
.pdp-acc-item{border-top:0.5px solid var(--bd)}
.pdp-acc-item:last-child{border-bottom:0.5px solid var(--bd)}
.pdp-acc-btn{width:100%;padding:18px 0;display:flex;justify-content:space-between;align-items:center;background:none;border:none;font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--t1);cursor:pointer;text-align:left}
.pdp-acc-btn .icon{width:10px;height:10px;transition:transform .3s;color:var(--t2)}
.pdp-acc-item.open .pdp-acc-btn .icon{transform:rotate(45deg)}
.pdp-acc-content{max-height:0;overflow:hidden;transition:max-height .4s var(--ease)}
.pdp-acc-item.open .pdp-acc-content{max-height:500px}
.pdp-acc-inner{padding:0 0 22px;font-family:var(--sans);font-size:.75rem;line-height:1.7;color:var(--t2);font-weight:400}
.pdp-acc-inner strong{color:var(--t1);font-weight:500}
.pdp-acc-inner ul{list-style:none;padding:0;margin:8px 0}
.pdp-acc-inner ul li{padding:4px 0 4px 16px;position:relative}
.pdp-acc-inner ul li::before{content:"·";position:absolute;left:4px;color:var(--t3)}

/* ═══════════ PDP STORY SECTION ═══════════ */
.pdp-story{padding:120px 56px;background:var(--bg);position:relative;overflow:hidden}
.pdp-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:80px;align-items:center;max-width:1280px;margin:0 auto}
.pdp-story-body{max-width:480px}
.pdp-story-num{font-family:var(--display);font-weight:700;font-size:clamp(4rem,8vw,7rem);color:rgba(201,191,168,.04);line-height:.8;margin-bottom:4px;letter-spacing:.01em}
.pdp-story-tag{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t3);margin-bottom:16px}
.pdp-story-h{font-family:var(--display);font-weight:700;font-size:clamp(2rem,3.5vw,3rem);text-transform:uppercase;letter-spacing:.01em;line-height:1.02;color:var(--t1);margin-bottom:28px}
.pdp-story-p{font-family:var(--serif);font-size:1rem;line-height:1.7;color:var(--t2);margin-bottom:18px;font-weight:400}
.pdp-story-p strong{color:var(--t1);font-weight:500;font-style:normal}
.pdp-story-img{position:relative;overflow:hidden;aspect-ratio:4/5;background:var(--el)}
.pdp-story-img img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1) saturate(.88) sepia(.03)}

/* ═══════════ REVIEWS SECTION ═══════════ */
.pdp-reviews{padding:100px 56px;background:var(--sf);border-top:0.5px solid var(--bd);border-bottom:0.5px solid var(--bd)}
.pdp-reviews-head{display:grid;grid-template-columns:1fr 2fr;gap:56px;max-width:1280px;margin:0 auto 48px;align-items:end}
.pdp-reviews-summary .sec-label{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t3);margin-bottom:12px}
.pdp-reviews-summary .big-rating{font-family:var(--display);font-weight:700;font-size:clamp(4rem,8vw,6rem);color:var(--t1);line-height:.9;letter-spacing:.01em}
.pdp-reviews-summary .big-stars{display:flex;gap:3px;color:var(--t1);margin-top:12px;margin-bottom:6px}
.pdp-reviews-summary .big-stars svg{width:18px;height:18px}
.pdp-reviews-summary .review-count{font-family:var(--sans);font-size:.65rem;color:var(--t3);letter-spacing:.05em}
.pdp-reviews-bars{display:flex;flex-direction:column;gap:6px;padding-top:16px}
.pdp-review-bar{display:flex;align-items:center;gap:12px;font-family:var(--sans);font-size:.65rem;color:var(--t2)}
.pdp-review-bar .lbl{width:44px;display:flex;align-items:center;gap:3px;color:var(--t2)}
.pdp-review-bar .lbl svg{width:10px;height:10px;color:var(--t1)}
.pdp-review-bar .track{flex:1;height:4px;background:var(--bd);position:relative;overflow:hidden}
.pdp-review-bar .track-fill{height:100%;background:var(--t1)}
.pdp-review-bar .pct{width:40px;text-align:right;font-size:.6rem;color:var(--t3)}

.pdp-review-list{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(2,1fr);gap:32px}
.pdp-review{padding:28px;border:0.5px solid var(--bd);background:var(--bg)}
.pdp-review-meta{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:14px}
.pdp-review-name{font-family:var(--sans);font-size:.72rem;font-weight:500;color:var(--t1);letter-spacing:.03em}
.pdp-review-verified{font-family:var(--sans);font-size:.5rem;font-weight:400;letter-spacing:.15em;text-transform:uppercase;color:var(--t3);margin-top:2px}
.pdp-review-date{font-family:var(--sans);font-size:.55rem;color:var(--t3);letter-spacing:.05em}
.pdp-review-stars{display:flex;gap:2px;color:var(--t1);margin-bottom:14px}
.pdp-review-stars svg{width:12px;height:12px}
.pdp-review-title{font-family:var(--display);font-weight:700;font-size:.9rem;color:var(--t1);margin-bottom:8px;letter-spacing:.02em;text-transform:uppercase}
.pdp-review-body{font-family:var(--sans);font-size:.78rem;line-height:1.75;color:var(--t2);font-weight:400;letter-spacing:.01em}

.pdp-reviews-cta{text-align:center;margin-top:40px}

/* ═══════════ RELATED PRODUCTS ═══════════ */
.pdp-related{padding:100px 56px 60px;background:var(--bg)}
.pdp-related-head{max-width:1280px;margin:0 auto 40px;text-align:center}
.pdp-related-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2px;max-width:1280px;margin:0 auto}

/* ═══════════ MODEL FIT LINE ═══════════ */
.pdp-model-fit{display:flex;align-items:center;gap:10px;padding:20px 16px;font-family:var(--sans);font-size:.6rem;color:var(--t2);letter-spacing:.12em;justify-content:center;background:var(--bg);text-transform:uppercase;font-weight:400}
.pdp-model-fit svg{width:13px;height:13px;color:var(--t2)}
.pdp-model-fit strong{color:var(--t1);font-weight:500}

/* ═══════════ COMPLETE THE LOOK ═══════════ */


/* ═══════════ UGC / AS WORN ═══════════ */
.pdp-ugc{padding:100px 56px;background:var(--sf);border-top:0.5px solid var(--bd)}
.pdp-ugc-head{text-align:center;max-width:680px;margin:0 auto 48px}
.pdp-ugc-head .sec-label{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t3);margin-bottom:12px;display:block}
.pdp-ugc-head h2{font-family:var(--display);font-weight:700;font-size:clamp(2rem,3.5vw,2.8rem);text-transform:uppercase;letter-spacing:.02em;color:var(--t1);line-height:1;margin-bottom:14px}
.pdp-ugc-head p{font-family:var(--serif);font-style:italic;font-size:.92rem;color:var(--t2);line-height:1.5}
.pdp-ugc-head p strong{color:var(--t1);font-weight:500;font-style:normal;letter-spacing:.04em}
.pdp-ugc-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:2px;max-width:1280px;margin:0 auto}
.ugc-item{position:relative;overflow:hidden;aspect-ratio:1;display:block;background:var(--el)}
.ugc-item img{width:100%;height:100%;object-fit:cover;display:block;filter:brightness(1) saturate(.88) sepia(.03);transition:transform .6s var(--ease),filter .3s}
.ugc-item:hover img{transform:scale(1.05);filter:brightness(1.05) saturate(.95)}
.ugc-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(21,20,19,.7) 0%,transparent 50%);opacity:0;transition:opacity .4s var(--ease);display:flex;align-items:flex-end;padding:16px}
.ugc-item:hover .ugc-overlay{opacity:1}
.ugc-username{font-family:var(--sans);font-size:.62rem;font-weight:500;letter-spacing:.04em;color:var(--t1);display:flex;align-items:center;gap:6px}
.ugc-username svg{width:14px;height:14px}
.pdp-ugc-cta{text-align:center;margin-top:48px}
.pdp-ugc-cta .btn{display:inline-block}

@media(max-width:960px){


.pdp-ugc{padding:72px 24px}
.pdp-ugc-grid{grid-template-columns:repeat(2,1fr)}
}
@media(max-width:600px){

}

/* ═══════════ INNER PAGE SPACING ═══════════ */
/* Homepage hero extends under the fixed nav (intentional),
   but inner pages need content to clear the nav + announce bar */
main#main-content{padding-top:89px}
@media(max-width:768px){main#main-content{padding-top:calc(76px + env(safe-area-inset-top, 0px))}}
@media(max-width:380px){main#main-content{padding-top:calc(72px + env(safe-area-inset-top, 0px))}}

/* Nav — always slightly visible with frosted-glass effect (was only visible on scroll) */
.nav{background:rgba(21,20,19,.55);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px)}
.nav.scrolled{background:rgba(21,20,19,.96) !important;backdrop-filter:blur(20px) !important;-webkit-backdrop-filter:blur(20px) !important}

/* Give PDP breadcrumbs a bit more breathing room */
.pdp-crumbs{padding:32px 56px 16px}
@media(max-width:768px){.pdp-crumbs{padding:24px 24px 12px}}

/* ═══════════ MOBILE ═══════════ */
@media(max-width:960px){
.pdp{grid-template-columns:1fr}
.pdp-info{padding:48px 24px;position:static;max-width:none}
.pdp-story{padding:80px 24px}
.pdp-story-grid{grid-template-columns:1fr;gap:40px}
.pdp-reviews{padding:72px 24px}
.pdp-reviews-head{grid-template-columns:1fr;gap:32px;margin-bottom:36px}
.pdp-review-list{grid-template-columns:1fr;gap:16px}
.pdp-related{padding:72px 24px 40px}
.pdp-related-grid{grid-template-columns:repeat(2,1fr)}
.pdp-crumbs{padding:16px 24px 0}
}
@media(max-width:600px){
.pdp-h1{font-size:clamp(1.5rem,5vw,1.9rem)}
.pdp-related-grid{grid-template-columns:1fr}
.pdp-trust{grid-template-columns:1fr;gap:20px}
}


/* ═══════════ FULL-WIDTH EDITORIAL BREAK ═══════════ */
.pdp-break{position:relative;width:100%;height:90vh;min-height:620px;overflow:hidden;background:var(--bg)}
.pdp-break-img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;filter:brightness(.82) saturate(.88) sepia(.03);transform:scale(1.02);transition:transform 1.4s var(--ease)}
.pdp-break:hover .pdp-break-img{transform:scale(1)}
.pdp-break::after{content:'';position:absolute;inset:0;background:linear-gradient(to top,rgba(21,20,19,.72) 0%,rgba(21,20,19,.15) 45%,transparent 70%,rgba(21,20,19,.2) 100%);pointer-events:none;z-index:1}
.pdp-break-caption{position:absolute;left:56px;bottom:56px;max-width:620px;z-index:2}
.pdp-break-label{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--t2);margin-bottom:14px;display:flex;align-items:center;gap:12px}
.pdp-break-label::before{content:'';width:28px;height:.5px;background:rgba(201,191,168,.4)}
.pdp-break-quote{font-family:var(--serif);font-style:italic;font-size:clamp(1.4rem,2.6vw,2.2rem);line-height:1.38;color:var(--t1);font-weight:400;letter-spacing:.005em}
.pdp-break-attrib{font-family:var(--sans);font-size:.55rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--t3);margin-top:22px;display:block}
.pdp-break-attrib em{font-style:normal;color:var(--t2);font-weight:400}
@media(max-width:768px){
.pdp-break{height:70vh;min-height:500px}
.pdp-break-caption{left:24px;right:24px;bottom:40px;max-width:100%}
.pdp-break-quote{font-size:clamp(1.15rem,4.5vw,1.6rem);line-height:1.4}
.pdp-break-label{font-size:.5rem;margin-bottom:10px}
.pdp-break-attrib{margin-top:16px;font-size:.5rem}
}


/* ═══════════ RELATED GRID — compact cards (don't compete with hero product) ═══════════ */
.pdp-related{padding:80px 56px 60px}
.pdp-related-head{margin-bottom:32px}
.pdp-related-head h2{font-size:clamp(1.4rem,2.4vw,2rem)}
.pdp-related-grid{gap:16px;max-width:1180px}
.pdp-related-grid .pcard{height:460px}
.pdp-related-grid .pcard-info{padding:14px 16px 18px}
.pdp-related-grid .pcard-name{font-size:.92rem;letter-spacing:.02em}
.pdp-related-grid .pcard-price{font-size:.78rem;margin-top:2px}
.pdp-related-grid .pcard-rating{font-size:.54rem;gap:4px;margin-top:6px}
.pdp-related-grid .pcard-rating .stars svg{width:9px;height:9px}
@media(max-width:960px){
.pdp-related{padding:56px 24px 40px}
.pdp-related-grid .pcard{height:380px}
}
@media(max-width:600px){
.pdp-related-grid .pcard{height:340px}
}

/* ═══════════ RELATED GRID — compact cards (don't compete with hero product) ═══════════ */
.pdp-related{padding:80px 56px 60px}
.pdp-related-head{margin-bottom:32px}
.pdp-related-head h2{font-size:clamp(1.4rem,2.4vw,2rem)}
.pdp-related-grid{gap:16px;max-width:1180px}
.pdp-related-grid .pcard{height:460px}
.pdp-related-grid .pcard-info{padding:14px 16px 18px}
.pdp-related-grid .pcard-name{font-size:.92rem;letter-spacing:.02em}
.pdp-related-grid .pcard-price{font-size:.78rem;margin-top:2px}
.pdp-related-grid .pcard-rating{font-size:.54rem;gap:4px;margin-top:6px}
.pdp-related-grid .pcard-rating .stars svg{width:9px;height:9px}
@media(max-width:960px){
.pdp-related{padding:56px 24px 40px}
.pdp-related-grid .pcard{height:380px}
}
@media(max-width:600px){
.pdp-related-grid .pcard{height:340px}
}


/* ═══════════ STORY — compact touchpoint override ═══════════ */
.pdp-story{padding:72px 56px}
.pdp-story-grid{gap:56px;max-width:880px;align-items:center}
.pdp-story-body{max-width:100%}
.pdp-story-num{display:none}
.pdp-story-tag{font-size:.5rem;letter-spacing:.26em;margin-bottom:12px;color:var(--t3);font-weight:500}
.pdp-story-h{font-size:clamp(1.25rem,2.1vw,1.7rem);margin-bottom:20px;line-height:1.2;letter-spacing:.02em}
.pdp-story-p{font-size:.9rem;line-height:1.65;margin-bottom:12px}
.pdp-story-p:last-child{margin-bottom:0}
@media(max-width:960px){
.pdp-story{padding:56px 24px}
.pdp-story-grid{gap:28px;max-width:100%;grid-template-columns:1fr}
.pdp-story-h{font-size:clamp(1.25rem,5.2vw,1.6rem);margin-bottom:14px}
.pdp-story-p{font-size:.9rem;margin-bottom:10px}
.pdp-story-img{aspect-ratio:4/5;max-width:420px;margin:0 auto}
}

/* .rv / .rv-r reveal-on-scroll — vanilla CSS replacement for the prior
   GSAP+ScrollTrigger pattern. JS adds .is-visible on viewport entry. */
.rv,.rv-r{opacity:0;transition:opacity .8s cubic-bezier(.16,1,.3,1),transform .8s cubic-bezier(.16,1,.3,1)}
.rv{transform:translateY(30px)}
.rv-r{transform:translateX(30px)}
.rv.is-visible,.rv-r.is-visible{opacity:1;transform:none}
@media(prefers-reduced-motion:reduce){.rv,.rv-r{opacity:1!important;transform:none!important;transition:none!important}}

/* ───────── Cross-sell carousel override ───────── */
/* Reduces "More from STY" visual weight: horizontal scroll instead
   of full-width grid, smaller card scale, scroll-snap for natural
   feel. Star ratings + review counts removed from card markup
   already; styling is just for layout.
   Card-info reset from absolute-overlay (the original full-bleed
   tile pattern) to a normal-flow block below the image so name +
   price breathe with proper padding instead of sitting on the
   image edge.
   Section H2 styled as eyebrow utility (small caps, letter-spaced,
   bone-dim) to read as quiet curatorial recommendation, not a
   second hero heading. */
.pdp-related{padding:72px 0 48px}
.pdp-related-header{padding:0 24px;margin:0 auto 28px;max-width:1280px;text-align:left}
.pdp-related-h{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.3em;text-transform:uppercase;color:var(--brass);margin:0;line-height:1}
.pdp-related-grid{display:flex;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;gap:14px;padding:4px 24px 16px;margin:0 auto;max-width:none;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch;scrollbar-width:thin;scrollbar-color:rgba(201,191,168,.25) transparent}
.pdp-related-grid::-webkit-scrollbar{height:4px}
.pdp-related-grid::-webkit-scrollbar-track{background:transparent}
.pdp-related-grid::-webkit-scrollbar-thumb{background:rgba(201,191,168,.25);border-radius:2px}
.pdp-related-grid .pcard{flex:0 0 auto;width:220px;height:auto;scroll-snap-align:start;background:transparent;overflow:visible}
.pdp-related-grid .pcard-img-wrap{position:relative;aspect-ratio:4/5;width:100%;overflow:hidden;background:var(--el)}
.pdp-related-grid .pcard-img,.pdp-related-grid .pcard .pf,.pdp-related-grid .pcard .pb{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block}
.pdp-related-grid .pcard-info{position:static;transform:none;background:none;padding:14px 0 0;color:var(--t1)}
.pdp-related-grid .pcard-name{font-family:var(--display);font-size:.78rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--t1);line-height:1;margin-bottom:6px}
.pdp-related-grid .pcard-price{font-family:var(--sans);font-size:.6rem;font-weight:500;letter-spacing:.06em;color:var(--t2)}
.pdp-related-grid .pcard-meta{display:flex;align-items:baseline;justify-content:flex-start;gap:10px}
@media(min-width:769px){
  .pdp-related-grid{padding:4px 56px 16px;gap:18px}
  .pdp-related-header{padding:0 56px}
  .pdp-related-grid .pcard{width:260px}
}



/* ═══════════ Waypoint PDP additions ═══════════
 * Watch-specific component styles (placeholder thumbnails, static fit
 * line, "new release" indicator, "first reviews coming soon" placeholder,
 * editorial-break image placeholder, story-image placeholder).
 *
 * These selectors only fire on Waypoint shell markup. Non-Waypoint PDPs
 * never carry these classes, so the rules are inert there.
 *
 * Source: products/the-coastline.html cluster-3 inline <style> block.
 * The Waypoint cross-sell variant overrides (.pdp-related background +
 * .pcard-img filter/transform on hover) remain inline on the 4 Waypoint
 * shells to preserve byte-equivalent behavior on non-Waypoint shells.
 */
/* ═══════════ MOJAVE PDP — additions for watch-tuned slots ═══════════ */
/* TBD thumbnail slots in the gallery — match the deep-green ed-placeholder pattern */
.pdp-thumb-todo{background:linear-gradient(180deg,var(--green) 0%,var(--bg) 100%);display:flex;align-items:center;justify-content:center;cursor:default !important;opacity:.85;border:0.5px solid var(--bd) !important}
.pdp-thumb-todo:hover{opacity:.85;border-color:var(--bd) !important}
.pdp-thumb-todo-note{font-family:var(--condensed);font-size:.5rem;font-weight:500;letter-spacing:.28em;text-transform:uppercase;color:var(--t3);text-align:center;line-height:1.4}

/* Static fit line — replaces the size button row for sizeless products like watches */
.pdp-static-fit{font-family:var(--sans);font-weight:400;font-size:.92rem;color:var(--t1);padding:14px 0;border-top:0.5px solid var(--bd);border-bottom:0.5px solid var(--bd);margin-top:8px}

/* New release indicator — replaces the rating block for products without review history */
.pdp-new-release{display:inline-flex;align-items:center;gap:10px;font-family:var(--condensed);font-size:.6rem;font-weight:500;letter-spacing:.22em;text-transform:uppercase;color:var(--t2);margin:14px 0 4px}
.pdp-new-release-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--olive);box-shadow:0 0 8px var(--olive)}

/* "First reviews coming soon" — quiet placeholder block where the full reviews section would otherwise sit */
.pdp-reviews-coming-soon{padding:96px 56px;background:var(--bg);border-top:0.5px solid var(--bd);border-bottom:0.5px solid var(--bd);text-align:center}
.pdp-reviews-coming-soon-inner{max-width:540px;margin:0 auto}
.pdp-reviews-coming-soon-h{font-family:var(--display);font-weight:700;font-size:clamp(1.4rem,2.6vw,1.8rem);text-transform:uppercase;letter-spacing:.02em;color:var(--t1);line-height:1;margin:14px 0 16px}
.pdp-reviews-coming-soon-p{font-family:var(--serif);font-style:italic;font-size:.95rem;color:var(--t2);line-height:1.55;max-width:42ch;margin:0 auto}
@media(max-width:768px){.pdp-reviews-coming-soon{padding:72px 24px}.pdp-reviews-coming-soon-p{font-size:.9rem}}

/* Editorial break image placeholder */
.pdp-break-img-todo{aspect-ratio:16/9;width:100%;background:linear-gradient(180deg,var(--green) 0%,var(--bg) 100%);display:flex;align-items:center;justify-content:center;border-bottom:0.5px solid var(--bd)}
.pdp-break-todo-note{font-family:var(--condensed);font-size:.55rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--t3);padding:12px 24px;border:0.5px solid var(--bd)}

/* Story image placeholder — fits the existing pdp-story-img grid slot */
.pdp-story-img-todo{background:linear-gradient(180deg,var(--green) 0%,var(--bg) 100%);display:flex;align-items:center;justify-content:center;aspect-ratio:4/5;border:0.5px solid var(--bd)}
.pdp-story-todo-note{font-family:var(--condensed);font-size:.55rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--t3);padding:12px 24px;border:0.5px solid var(--bd);text-align:center}


/* ───────── PDP GALLERY POLISH (Phase 3.3) ─────────
   Click-to-zoom overlay, smooth crossfade transition on main image,
   keyboard arrow navigation, mobile swipe gestures.

   Wired by /assets/js/pdp-gallery.js — runs on any page with #mainImg.

   Crossfade: opacity transition managed by JS (it sets the inline
   transition + opacity directly when src is being swapped). The CSS
   here only adds the zoom-cursor affordance + zoom overlay surface.

   Reduced-motion: JS handles the crossfade short-circuit. The
   overlay still appears (no entrance animation to disable).
*/

#mainImg{cursor:zoom-in;transition:opacity .25s var(--ease)}

/* Zoom overlay — full-screen image inspection with dim backdrop. */
body.pdp-zoom-open{overflow:hidden}
.pdp-zoom-overlay{position:fixed;inset:0;z-index:1300;display:none;align-items:center;justify-content:center;padding:24px}
.pdp-zoom-overlay.is-open{display:flex}
.pdp-zoom-backdrop{position:absolute;inset:0;background:rgba(29,29,27,.85);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);cursor:zoom-out}
.pdp-zoom-img{position:relative;z-index:1;max-width:min(96vw,1400px);max-height:calc(100vh - 48px);width:auto;height:auto;object-fit:contain;display:block;cursor:default;touch-action:pinch-zoom}
.pdp-zoom-close{position:fixed;top:16px;right:16px;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,247,.95);border:1px solid var(--bone-pale);color:var(--ink);cursor:pointer;z-index:2;padding:0;border-radius:50%;transition:background .25s var(--ease),color .25s var(--ease)}
.pdp-zoom-close:hover,.pdp-zoom-close:focus-visible{background:var(--ink);color:var(--bone);outline:none}
@media(max-width:768px){
  .pdp-zoom-overlay{padding:14px;padding-top:max(14px,env(safe-area-inset-top, 14px));padding-bottom:max(14px,env(safe-area-inset-bottom, 14px))}
  .pdp-zoom-close{top:12px;right:12px}
  .pdp-zoom-img{max-width:96vw;max-height:calc(100vh - 28px)}
}
@media(prefers-reduced-motion:reduce){
  #mainImg{transition:none}
  .pdp-zoom-close{transition:none}
}

/* Visible keyboard focus on thumb strip — was previously implicit
   via .pdp-thumb.active border. Phase 3.3 adds an explicit focus-
   visible ring so keyboard users see exactly where they are when
   arrow-navigating. */
.pdp-thumb:focus-visible{outline:2px solid var(--accent);outline-offset:2px}


/* ───────── PDP "WEAR WITH" PAIRING SECTION (Phase 4.1C) ─────────
   Curated 2-3 product pairing grid above the catalog-derived
   "More from STY" section on flagship PDPs. Editorial framing —
   small cards, generous breathing room, brand-restrained typography.

   Pairings are defined per product in products.json `pair_with`
   array. Section auto-hides via .is-empty when pdp-pair-loader.js
   renders 0 cards (e.g., all paired products are still pending
   photography). */
.pdp-pair{padding:80px var(--gutter,56px) 32px;background:var(--bg)}
.pdp-pair.is-empty{display:none}
.pdp-pair-eyebrow{margin:0 auto 36px;max-width:1280px;font-family:var(--condensed);font-size:.62rem;font-weight:500;letter-spacing:.32em;text-transform:uppercase;color:var(--accent);text-align:center}
.pdp-pair-grid{max-width:1080px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:24px}
.pdp-pair-card{position:relative;display:flex;flex-direction:column;background:var(--bg);text-decoration:none;color:inherit;transition:transform .28s cubic-bezier(.2,.6,.3,1),box-shadow .28s cubic-bezier(.2,.6,.3,1)}
.pdp-pair-card-img{position:relative;aspect-ratio:1/1;width:100%;overflow:hidden;background:var(--bone-soft);border-radius:4px;margin-bottom:14px}
.pdp-pair-card-img img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;transition:transform .55s var(--ease)}
.pdp-pair-card-meta{display:flex;align-items:baseline;justify-content:space-between;gap:12px;padding:0 2px}
.pdp-pair-card-name{font-family:var(--display);font-weight:700;font-size:.95rem;text-transform:uppercase;letter-spacing:.02em;color:var(--ink);line-height:1.1}
.pdp-pair-card-price{font-family:var(--sans);font-size:.78rem;font-weight:500;letter-spacing:.04em;color:var(--t2)}
.pdp-pair-card-arrow{position:absolute;top:14px;right:14px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:rgba(255,255,247,.92);backdrop-filter:blur(4px);border-radius:50%;font-family:var(--sans);font-size:.9rem;font-weight:300;color:var(--ink);opacity:0;transform:translateX(-4px);transition:opacity .25s var(--ease),transform .3s var(--ease)}

@media (hover: hover) {
  .pdp-pair-card:hover,
  .pdp-pair-card:focus-visible{transform:translateY(-2px) scale(1.015);box-shadow:0 12px 28px rgba(29,29,27,.08),0 2px 6px rgba(29,29,27,.04);outline:none}
  .pdp-pair-card:hover .pdp-pair-card-img img,
  .pdp-pair-card:focus-visible .pdp-pair-card-img img{transform:scale(1.04)}
  .pdp-pair-card:hover .pdp-pair-card-arrow,
  .pdp-pair-card:focus-visible .pdp-pair-card-arrow{opacity:1;transform:translateX(0)}
}
.pdp-pair-card:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
@media(max-width:768px){
  .pdp-pair{padding:64px 24px 24px}
  .pdp-pair-eyebrow{margin-bottom:28px;font-size:.55rem;letter-spacing:.24em}
  .pdp-pair-grid{grid-template-columns:repeat(2,1fr);gap:14px;max-width:none}
  .pdp-pair-card-name{font-size:.85rem}
  .pdp-pair-card-price{font-size:.7rem}
  .pdp-pair-card-arrow{opacity:1;transform:none;width:28px;height:28px;font-size:.8rem}
}
@media(prefers-reduced-motion:reduce){
  .pdp-pair-card,
  .pdp-pair-card-img img,
  .pdp-pair-card-arrow{transition:none}
  .pdp-pair-card:hover{transform:none}
  .pdp-pair-card:hover .pdp-pair-card-img img{transform:none}
}
