@import url('https://fonts.googleapis.com/css2?family=Bodoni+Moda:ital,opsz,wght@0,6..96,400;0,6..96,500;1,6..96,400&display=swap');
:root{
  --ivory:#F6F1E9; --paper:#FFFFFF; --sand:#EFE7D8; --mist:#ECE3D2;
  --ink:#171310; --espresso:#2A1F15; --cocoa:#3C2C1D; --cognac:#7E4F28; --tan:#9A6A3C;
  --gold:#B0894E; --muted:#8C7F6D; --line:#E0D5C2; --line2:#D2C4AC;
  --display:'Bodoni Moda',Georgia,serif; --serif:'Cormorant Garamond',Georgia,serif; --sans:'Jost',-apple-system,system-ui,sans-serif;
  --leather:radial-gradient(120% 120% at 35% 25%,#5a3f27,#251a10);
  --maxw:1380px; --ease:cubic-bezier(.22,.65,.18,1);
}
*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{font-family:var(--sans);color:var(--espresso);background:var(--ivory);font-weight:300;font-size:16px;line-height:1.65;-webkit-font-smoothing:antialiased;overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 38px}
.serif{font-family:var(--serif)} .display{font-family:var(--display)}
h1,h2,h3{font-weight:400;line-height:1.02}
.eyebrow{font-size:11px;letter-spacing:.42em;text-transform:uppercase;color:var(--tan);font-weight:400}
.btn{display:inline-block;font-family:var(--sans);font-size:11px;letter-spacing:.3em;text-transform:uppercase;font-weight:400;padding:17px 44px;border:1px solid var(--ink);background:var(--ink);color:var(--ivory);cursor:pointer;transition:.45s var(--ease);text-align:center}
.btn:hover{background:transparent;color:var(--ink)}
.btn-ghost{background:transparent;color:var(--ink);border-color:var(--ink)}
.btn-ghost:hover{background:var(--ink);color:var(--ivory)}
.btn-light{border-color:var(--ivory);background:transparent;color:var(--ivory)}
.btn-light:hover{background:var(--ivory);color:var(--ink)}
.btn-block{display:block;width:100%}
.btn[disabled]{opacity:.4;cursor:not-allowed}
.link-u{font-size:11px;letter-spacing:.24em;text-transform:uppercase;border-bottom:1px solid currentColor;padding-bottom:4px;transition:.3s}
.link-u:hover{color:var(--cognac)}

.reveal{opacity:0;transform:translateY(30px);transition:opacity 1s var(--ease),transform 1.1s var(--ease)}
.reveal.in{opacity:1;transform:none}

.announce{background:var(--ink);color:var(--ivory);text-align:center;font-size:10.5px;letter-spacing:.3em;text-transform:uppercase;padding:11px 16px}
.announce b{color:var(--gold);font-weight:400}

header.site{position:sticky;top:0;z-index:200;background:rgba(246,241,233,.9);backdrop-filter:blur(10px);border-bottom:1px solid transparent;transition:.4s}
header.site.scrolled{border-color:var(--line);background:rgba(246,241,233,.96)}
.nav{display:flex;align-items:center;justify-content:space-between;height:88px;gap:20px}
.nav-l,.nav-r{flex:1;display:flex;align-items:center;gap:30px}
.nav-r{justify-content:flex-end}
.logo{font-family:var(--display);font-size:30px;letter-spacing:.46em;text-transform:uppercase;font-weight:500;padding-left:.46em;white-space:nowrap}
.menu{display:flex;gap:34px;list-style:none}
.menu>li{position:relative}
.menu>li>a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;padding:33px 0;display:inline-block;position:relative}
.menu>li>a::after{content:'';position:absolute;left:0;bottom:28px;height:1px;width:0;background:var(--cognac);transition:.4s var(--ease)}
.menu>li:hover>a::after{width:100%}
.menu>li>a.gold{color:var(--cognac)}
.mega{position:absolute;top:100%;left:50%;transform:translateX(-50%) translateY(12px);background:var(--ivory);border:1px solid var(--line);min-width:230px;padding:18px 0;opacity:0;visibility:hidden;transition:.28s var(--ease);box-shadow:0 30px 60px rgba(40,30,20,.12)}
.menu>li:hover .mega{opacity:1;visibility:visible;transform:translateX(-50%) translateY(0)}
.mega a{display:block;padding:10px 30px;font-size:12.5px;letter-spacing:.06em;color:var(--muted);white-space:nowrap;transition:.2s}
.mega a:hover{color:var(--ink);padding-left:36px}
.icons{display:flex;gap:22px;align-items:center}
.icons button,.icons a{background:none;border:none;cursor:pointer;color:var(--ink);display:flex;position:relative;padding:2px}
.icons svg{width:20px;height:20px;stroke:currentColor;fill:none;stroke-width:1.3}
.cart-count{position:absolute;top:-8px;right:-9px;background:var(--cognac);color:#fff;font-size:9.5px;font-weight:500;min-width:17px;height:17px;padding:0 4px;border-radius:9px;display:flex;align-items:center;justify-content:center;font-family:var(--sans)}
.burger{display:none;background:none;border:none;cursor:pointer;flex-direction:column;gap:6px;padding:6px}
.burger span{width:24px;height:1px;background:var(--ink);transition:.3s}

.searchbar{position:fixed;top:0;left:0;right:0;background:var(--ivory);z-index:260;transform:translateY(-100%);transition:.4s var(--ease);padding:34px 38px;box-shadow:0 20px 50px rgba(40,30,20,.1)}
.searchbar.open{transform:translateY(0)}
.searchbar form{max-width:880px;margin:0 auto;display:flex;align-items:center;gap:18px;border-bottom:1px solid var(--ink);padding-bottom:16px}
.searchbar input{flex:1;border:none;background:none;outline:none;font-family:var(--display);font-size:30px;color:var(--ink)}
.searchbar input::placeholder{color:var(--muted);font-family:var(--serif);font-style:italic}
.searchbar .sgrid{max-width:880px;margin:18px auto 0;display:flex;gap:10px;flex-wrap:wrap}
.searchbar .sgrid span{font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);border:1px solid var(--line);padding:9px 16px;cursor:pointer;transition:.25s}
.searchbar .sgrid span:hover{border-color:var(--cognac);color:var(--cognac)}

.scrim{position:fixed;inset:0;background:rgba(20,16,12,.5);z-index:240;opacity:0;pointer-events:none;transition:.4s}
.scrim.open{opacity:1;pointer-events:auto}
.drawer{position:fixed;inset:0 0 0 auto;width:88%;max-width:380px;background:var(--ivory);z-index:250;transform:translateX(100%);transition:.45s var(--ease);padding:32px;display:flex;flex-direction:column;gap:2px;overflow-y:auto}
.drawer.open{transform:translateX(0)}
.drawer .x{align-self:flex-end;background:none;border:none;font-size:30px;cursor:pointer;line-height:1}
.drawer a{font-family:var(--display);font-size:23px;padding:14px 0;border-bottom:1px solid var(--line)}

.cartd{position:fixed;inset:0 0 0 auto;width:93%;max-width:440px;background:var(--ivory);z-index:255;transform:translateX(100%);transition:.45s var(--ease);display:flex;flex-direction:column}
.cartd.open{transform:translateX(0)}
.cartd .ch{display:flex;justify-content:space-between;align-items:center;padding:30px 32px;border-bottom:1px solid var(--line)}
.cartd .ch h3{font-family:var(--display);font-size:22px;font-weight:500}
.cartd .x{background:none;border:none;font-size:28px;cursor:pointer;line-height:1}
.citems{flex:1;overflow-y:auto;padding:6px 32px}
.cempty{text-align:center;color:var(--muted);padding:80px 20px;font-family:var(--serif);font-style:italic;font-size:22px}
.ci{display:flex;gap:18px;padding:22px 0;border-bottom:1px solid var(--line)}
.ci-img{width:86px;height:100px;background:var(--ivory);flex:none;overflow:hidden}
.ci-img img{width:100%;height:100%;object-fit:contain}
.ci-info{flex:1;min-width:0}
.ci-info .k{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--tan)}
.ci-info h4{font-family:var(--serif);font-size:21px;font-weight:500;margin:3px 0 3px}
.ci-info .clr{font-size:12px;color:var(--muted);margin-bottom:10px}
.ci-row{display:flex;justify-content:space-between;align-items:center}
.qtyb{display:inline-flex;border:1px solid var(--line2)}
.qtyb button{background:none;border:none;width:30px;height:30px;cursor:pointer;font-size:15px}
.qtyb span{min-width:30px;text-align:center;line-height:30px;font-size:13px}
.ci .rm{background:none;border:none;color:var(--muted);font-size:10px;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;text-decoration:underline;margin-top:9px}
.cartd .cf{padding:26px 32px;border-top:1px solid var(--line)}
.cartd .subtot{display:flex;justify-content:space-between;font-size:12px;letter-spacing:.1em;text-transform:uppercase;margin-bottom:6px}
.cartd .subtot b{font-family:var(--display);font-size:22px;font-weight:500;text-transform:none}
.cartd .note{font-size:11.5px;color:var(--muted);margin-bottom:18px}

/* hero */
.hero{position:relative;min-height:94vh;display:flex;align-items:center;overflow:hidden;background:var(--ivory)}
.hero-grid{display:grid;grid-template-columns:1.02fr 1fr;align-items:center;gap:50px;width:100%}
.hero-copy{opacity:0;animation:rise 1.3s var(--ease) .15s forwards}
.hero-copy .eyebrow{display:block;margin-bottom:26px}
.hero-copy h1{font-family:var(--display);font-weight:500;font-size:clamp(54px,6.6vw,108px);line-height:.95;letter-spacing:.005em}
.hero-copy h1 em{font-style:italic;font-family:var(--serif);font-weight:500}
.hero-copy p{max-width:42ch;margin:28px 0 40px;font-size:17px;color:var(--muted)}
.hero-cta{display:flex;gap:18px;flex-wrap:wrap;align-items:center}
.hero-img{position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--ivory)}
.hero-img img{width:100%;height:100%;object-fit:contain;animation:kenburns 16s ease-in-out infinite alternate}
.hero-cap{position:absolute;bottom:18px;left:0;right:0;text-align:center;font-size:10px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
@keyframes rise{from{opacity:0;transform:translateY(34px)}to{opacity:1;transform:none}}
@keyframes kenburns{from{transform:scale(1)}to{transform:scale(1.07)}}

.marq{background:var(--ink);color:var(--ivory);overflow:hidden}
.marq .row{display:flex;gap:64px;padding:17px 0;white-space:nowrap;animation:marq 34s linear infinite;width:max-content}
.marq span{font-family:var(--serif);font-size:18px;font-style:italic;letter-spacing:.02em;display:inline-flex;align-items:center;gap:64px}
.marq span::after{content:'\2766';color:var(--gold);font-style:normal}
@keyframes marq{from{transform:translateX(0)}to{transform:translateX(-50%)}}

section{padding:108px 0}
.shead{text-align:center;max-width:720px;margin:0 auto 60px}
.shead h2{font-family:var(--display);font-weight:500;font-size:clamp(38px,4.6vw,62px);line-height:1.02;margin-top:16px}
.shead h2 em{font-style:italic;font-family:var(--serif)}
.shead p{color:var(--muted);margin-top:16px;font-size:16px}
.rowhead{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:46px;gap:20px;flex-wrap:wrap}
.rowhead h2{font-family:var(--display);font-weight:500;font-size:clamp(32px,3.8vw,50px)}
.rowhead .eyebrow{display:block;margin-bottom:14px}

/* category tiles */
.cats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.cats a{position:relative;overflow:hidden;aspect-ratio:3/4;display:flex;align-items:flex-end;color:#fff;background:var(--leather)}
.cats a.tall{grid-row:span 2;aspect-ratio:auto}
.cats a img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;transition:transform 1.2s var(--ease)}
.cats a:hover img{transform:scale(1.07)}
.cats .grad{position:absolute;inset:0;background:linear-gradient(0deg,rgba(20,14,9,.78),rgba(20,14,9,.04) 62%)}
.cats .lab{position:relative;z-index:2;padding:34px 34px}
.cats .lab .k{font-size:10px;letter-spacing:.28em;text-transform:uppercase;opacity:.85}
.cats .lab .t{font-family:var(--display);font-size:36px;font-weight:500;margin-top:4px}
.cats .lab .ln{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;margin-top:10px;border-bottom:1px solid rgba(255,255,255,.45);display:inline-block;padding-bottom:3px}

/* product grid — float on ivory, no borders */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px 26px}
.grid.g3{grid-template-columns:repeat(3,1fr)}
.pcard{position:relative;display:flex;flex-direction:column;background:transparent}
.pcard .ph{position:relative;aspect-ratio:1;overflow:hidden;background:var(--ivory)}
.pcard .ph img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:7%;transition:opacity .6s var(--ease),transform 1s var(--ease)}
.pcard .ph .alt{opacity:0}
.pcard:hover .ph .main{opacity:0}
.pcard:hover .ph .alt{opacity:1;transform:scale(1.04)}
.pcard .tag{position:absolute;top:14px;left:14px;z-index:3;font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--cognac)}
.pcard .wish{position:absolute;top:12px;right:12px;z-index:3;background:none;border:none;cursor:pointer;font-size:18px;color:var(--muted);opacity:0;transition:.3s}
.pcard:hover .wish{opacity:1}
.pcard .wish.on{color:var(--cognac)}
.pcard .qadd{position:absolute;left:50%;transform:translateX(-50%) translateY(14px);bottom:14px;z-index:3;background:var(--ink);color:var(--ivory);border:none;font-family:var(--sans);font-size:10px;letter-spacing:.22em;text-transform:uppercase;padding:13px 26px;cursor:pointer;opacity:0;transition:.45s var(--ease);white-space:nowrap}
.pcard:hover .qadd{opacity:1;transform:translateX(-50%) translateY(0)}
.pcard .body{padding:20px 6px 6px;text-align:center}
.pcard .k{font-size:9.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--tan)}
.pcard h3{font-family:var(--serif);font-size:23px;font-weight:500;margin:6px 0 4px}
.pcard .clr{font-size:12px;color:var(--muted)}
.pcard .price{font-family:var(--serif);font-size:18px;margin-top:9px;letter-spacing:.01em}

/* editorial full-bleed band */
.editorial{position:relative;min-height:78vh;display:flex;align-items:center;justify-content:center;text-align:center;color:var(--ivory);background:var(--leather);overflow:hidden}
.editorial .inner{position:relative;z-index:2;max-width:720px;padding:40px}
.editorial .eyebrow{color:var(--gold);display:block;margin-bottom:22px}
.editorial h2{font-family:var(--display);font-weight:500;font-size:clamp(40px,5.4vw,76px);line-height:1.0}
.editorial h2 em{font-style:italic;font-family:var(--serif)}
.editorial p{margin:24px auto 36px;max-width:46ch;color:rgba(246,241,233,.82);font-size:17px}

.diff{display:grid;grid-template-columns:repeat(3,1fr);gap:60px;text-align:center}
.diff svg{width:46px;height:46px;margin:0 auto 22px;stroke:var(--cognac);fill:none;stroke-width:1}
.diff h3{font-family:var(--display);font-size:24px;font-weight:500;margin-bottom:10px}
.diff p{color:var(--muted);font-size:15px;max-width:30ch;margin:0 auto}

.split{display:grid;grid-template-columns:1fr 1fr;align-items:center;min-height:620px}
.split.flip .pic{order:2}
.split .pic{align-self:stretch;position:relative;overflow:hidden;background:var(--ivory)}
.split .pic img{position:absolute;inset:0;width:100%;height:100%;object-fit:contain;padding:5%}
.split .pic.leather{background:var(--leather)}
.split .tx{padding:0 10% 0 9%}
.split.heritage{background:var(--sand)}
.split.heritage .pic{background:var(--ivory)}
.split .tx h2{font-family:var(--display);font-weight:500;font-size:clamp(36px,4.2vw,58px);margin:18px 0 24px;line-height:1.02}
.split .tx h2 em{font-style:italic;font-family:var(--serif)}
.split .tx p{color:var(--muted);margin-bottom:18px}
.stats{display:flex;gap:46px;margin:34px 0 38px;flex-wrap:wrap}
.stats .n{font-family:var(--display);font-size:46px;font-weight:500;color:var(--cognac);line-height:1}
.stats .l{font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted);margin-top:8px}

.mono{background:var(--ink);color:var(--ivory)}
.mono .split{min-height:520px}
.mono .panel{align-self:stretch;display:flex;align-items:center;justify-content:center;background:var(--leather);position:relative;overflow:hidden}
.mono .panel::after{content:'';position:absolute;inset:24px;border:1px solid rgba(255,255,255,.3)}
.mono .crest{position:relative;z-index:2;text-align:center}
.mono .crest .sm{font-size:10.5px;letter-spacing:.4em;text-transform:uppercase;opacity:.72}
.mono .crest .ini{font-family:var(--display);font-size:118px;line-height:1;letter-spacing:.06em;margin:14px 0}
.mono .tx{padding:64px 9%}
.mono h2{font-family:var(--display);font-size:clamp(34px,4vw,54px);font-weight:500;margin:16px 0 20px}
.mono h2 em{font-style:italic;font-family:var(--serif)}
.mono p{color:rgba(246,241,233,.76);margin-bottom:30px;max-width:42ch}
.sw{display:flex;gap:14px;margin-bottom:34px}
.sw span{width:34px;height:34px;border-radius:50%;cursor:pointer;border:1.5px solid transparent;transition:.2s}
.sw span.on{border-color:var(--gold)}

.press{border-block:1px solid var(--line)}
.press .wrap{display:flex;align-items:center;justify-content:space-between;gap:24px;padding:36px 38px;flex-wrap:wrap}
.press .lbl{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--muted)}
.press .lg{display:flex;gap:52px;flex-wrap:wrap;align-items:center}
.press .lg span{font-family:var(--display);font-size:24px;color:var(--ink);opacity:.55}

.revs{display:grid;grid-template-columns:repeat(3,1fr);gap:30px}
.rev{padding:42px 36px;border:1px solid var(--line)}
.stars{color:var(--gold);letter-spacing:4px;margin-bottom:18px}
.rev p{font-family:var(--serif);font-style:italic;font-size:22px;line-height:1.45;margin-bottom:22px}
.rev .who{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

.news{background:var(--ink);color:var(--ivory);text-align:center}
.news h2{font-family:var(--display);font-size:clamp(34px,4vw,56px);font-weight:500}
.news h2 em{font-style:italic;font-family:var(--serif)}
.news p{color:rgba(246,241,233,.7);max-width:48ch;margin:16px auto 34px}
.news form{display:flex;max-width:520px;margin:0 auto}
.news input{flex:1;padding:17px 20px;border:1px solid rgba(246,241,233,.3);background:transparent;color:var(--ivory);font-family:var(--sans);outline:none}
.news input::placeholder{color:rgba(246,241,233,.5)}
.news button{padding:17px 34px;border:1px solid var(--gold);background:var(--gold);color:var(--ink);font-size:11px;letter-spacing:.2em;text-transform:uppercase;cursor:pointer;transition:.3s}
.news button:hover{background:transparent;color:var(--gold)}

footer.site{background:var(--ink);color:rgba(246,241,233,.68);padding:88px 0 34px}
.fgrid{display:grid;grid-template-columns:1.7fr 1fr 1fr 1.2fr;gap:46px}
.flogo{font-family:var(--display);font-size:30px;letter-spacing:.38em;text-transform:uppercase;color:var(--ivory);margin-bottom:18px}
footer h4{font-size:10.5px;letter-spacing:.24em;text-transform:uppercase;color:var(--gold);margin-bottom:20px}
footer ul{list-style:none}
footer li{margin-bottom:12px;font-size:14.5px}
footer a:hover{color:var(--ivory)}
footer .contact b{color:var(--ivory);font-weight:400}
.social{display:flex;gap:14px;margin-top:20px}
.social a{width:40px;height:40px;border:1px solid rgba(246,241,233,.28);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
.social a:hover{background:var(--gold);border-color:var(--gold);color:var(--ink)}
.social svg{width:17px;height:17px;stroke:currentColor;fill:none;stroke-width:1.3}
.fbot{border-top:1px solid rgba(246,241,233,.12);margin-top:54px;padding-top:28px;display:flex;justify-content:space-between;flex-wrap:wrap;gap:14px;font-size:11.5px;color:rgba(246,241,233,.45)}
.pays{display:flex;gap:10px}
.pays span{border:1px solid rgba(246,241,233,.22);border-radius:3px;padding:3px 10px;font-size:9.5px;letter-spacing:.12em}

.pagehead{text-align:center;padding:82px 0 46px}
.pagehead .crumb{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:16px}
.pagehead h1{font-family:var(--display);font-weight:500;font-size:clamp(44px,5.6vw,76px)}
.pagehead h1 em{font-style:italic;font-family:var(--serif)}
.pagehead p{color:var(--muted);margin-top:12px}

.toolbar{display:flex;justify-content:space-between;align-items:center;gap:18px;padding:26px 0;flex-wrap:wrap;border-block:1px solid var(--line);margin-bottom:48px}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.filters button{background:none;border:none;font-family:var(--sans);font-size:11px;letter-spacing:.18em;text-transform:uppercase;padding:10px 18px;cursor:pointer;color:var(--muted);transition:.25s;position:relative}
.filters button::after{content:'';position:absolute;left:18px;right:18px;bottom:6px;height:1px;background:var(--ink);transform:scaleX(0);transition:.3s var(--ease)}
.filters button:hover{color:var(--ink)}
.filters button.on{color:var(--ink)}
.filters button.on::after{transform:scaleX(1)}
.toolbar select{font-family:var(--sans);font-size:11px;letter-spacing:.12em;text-transform:uppercase;border:1px solid var(--line2);padding:11px 16px;background:var(--ivory);cursor:pointer;color:var(--ink)}
.count{font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}

/* PDP */
.pdp{display:grid;grid-template-columns:1.25fr 1fr;gap:64px;padding:54px 0 96px}
.pdp-gallery{display:flex;gap:18px}
.pdp-thumbs{display:flex;flex-direction:column;gap:12px;width:82px;flex:none}
.pdp-thumbs .tb{width:82px;height:96px;background:var(--ivory);cursor:pointer;overflow:hidden;opacity:.6;transition:.3s;border-bottom:1px solid transparent}
.pdp-thumbs .tb:hover{opacity:1}
.pdp-thumbs .tb.on{opacity:1;border-color:var(--ink)}
.pdp-thumbs .tb img{width:100%;height:100%;object-fit:contain;padding:8%}
.pdp-stage{flex:1;aspect-ratio:1;background:var(--ivory);overflow:hidden;position:relative}
.pdp-stage img{width:100%;height:100%;object-fit:contain;padding:5%}
.pdp-stage .nav{position:absolute;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;font-size:22px;color:var(--muted);padding:14px;transition:.2s}
.pdp-stage .nav:hover{color:var(--ink)}
.pdp-stage .prev{left:4px}.pdp-stage .next{right:4px}
.pdp-info{padding-top:8px}
.pdp-info .crumb{font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted);margin-bottom:22px}
.pdp-info h1{font-family:var(--display);font-weight:500;font-size:clamp(36px,3.6vw,52px);margin-bottom:10px;line-height:1.02}
.pdp-info .code{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}
.pdp-info .price{font-family:var(--serif);font-size:30px;margin:24px 0}
.pdp-info .lead{color:var(--muted);margin-bottom:30px;max-width:46ch}
.pdp-info .lbl{font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:14px}
.colorways{display:flex;gap:12px;flex-wrap:wrap;margin-bottom:32px}
.colorways a{width:60px;height:68px;overflow:hidden;background:var(--ivory);opacity:.62;transition:.25s;border-bottom:1px solid transparent}
.colorways a:hover{opacity:1}
.colorways a.on{opacity:1;border-color:var(--ink)}
.colorways a img{width:100%;height:100%;object-fit:contain;padding:8%}
.pdp-actions{display:flex;gap:14px;margin-bottom:14px}
.pdp-actions .btn{flex:1}
.assure{display:flex;gap:26px;flex-wrap:wrap;margin:26px 0 30px;padding:24px 0;border-block:1px solid var(--line)}
.assure div{display:flex;align-items:center;gap:9px;font-size:11.5px;color:var(--muted)}
.acc details{border-bottom:1px solid var(--line)}
.acc details:first-child{border-top:1px solid var(--line)}
.acc summary{padding:20px 2px;cursor:pointer;font-size:11px;letter-spacing:.18em;text-transform:uppercase;list-style:none;display:flex;justify-content:space-between}
.acc summary::-webkit-details-marker{display:none}
.acc summary::after{content:'+';font-size:18px;color:var(--muted)}
.acc details[open] summary::after{content:'\2212'}
.acc p{padding:0 2px 22px;color:var(--muted);font-size:15px}

.cartpage{display:grid;grid-template-columns:1.6fr 1fr;gap:60px;padding:54px 0 96px}
.cartlines .cl{display:flex;gap:24px;padding:28px 0;border-bottom:1px solid var(--line)}
.cartlines .cl-img{width:130px;height:150px;background:var(--ivory);flex:none;overflow:hidden}
.cartlines .cl-img img{width:100%;height:100%;object-fit:contain}
.cartlines .cl-info{flex:1}
.cartlines .cl-info .k{font-size:9.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--tan)}
.cartlines .cl-info h3{font-family:var(--serif);font-size:26px;font-weight:500;margin:4px 0 4px}
.cartlines .cl-info .clr{font-size:13px;color:var(--muted)}
.cartlines .cl-end{text-align:right;display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end}
.cartlines .cl-price{font-family:var(--serif);font-size:18px}
.summary{background:var(--sand);padding:38px;align-self:start;position:sticky;top:120px}
.summary h3{font-family:var(--display);font-size:24px;font-weight:500;margin-bottom:26px}
.sl{display:flex;justify-content:space-between;padding:11px 0;font-size:14px;color:var(--muted)}
.sl.tot{border-top:1px solid var(--line2);margin-top:10px;padding-top:20px;color:var(--ink);font-size:16px}
.sl.tot b{font-family:var(--display);font-size:26px;font-weight:500}
.summary .btn{margin-top:26px}
.summary .micro{font-size:11.5px;color:var(--muted);text-align:center;margin-top:16px}

.steps{display:flex;justify-content:center;gap:0;margin:44px 0 56px;flex-wrap:wrap}
.steps .st{display:flex;align-items:center;font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.steps .st .dot{width:28px;height:28px;border-radius:50%;border:1px solid var(--line2);display:flex;align-items:center;justify-content:center;margin-right:11px;font-size:12px}
.steps .st.on{color:var(--ink)}
.steps .st.on .dot{background:var(--ink);color:var(--ivory);border-color:var(--ink)}
.steps .st.done .dot{background:var(--cognac);color:#fff;border-color:var(--cognac)}
.steps .sep{width:50px;height:1px;background:var(--line2);margin:0 20px}
.checkout{display:grid;grid-template-columns:1.5fr 1fr;gap:60px;padding-bottom:96px}
.cform h2{font-family:var(--display);font-size:28px;font-weight:500;margin-bottom:6px}
.cform .sub{color:var(--muted);font-size:14px;margin-bottom:28px}
.field{margin-bottom:18px}
.field label{display:block;font-size:10.5px;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);margin-bottom:8px}
.field input,.field select{width:100%;padding:14px 16px;border:1px solid var(--line2);background:var(--paper);font-family:var(--sans);font-size:15px;outline:none;transition:.2s;color:var(--ink)}
.field input:focus,.field select:focus{border-color:var(--ink)}
.field.err input{border-color:#b4453b}
.frow{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.opt{display:flex;align-items:center;gap:14px;border:1px solid var(--line2);padding:18px 20px;margin-bottom:12px;cursor:pointer;transition:.25s;background:var(--paper)}
.opt:hover{border-color:var(--ink)}
.opt.on{border-color:var(--ink);background:var(--sand)}
.opt .rd{width:18px;height:18px;border-radius:50%;border:1px solid var(--line2);flex:none;position:relative}
.opt.on .rd::after{content:'';position:absolute;inset:4px;border-radius:50%;background:var(--ink)}
.opt .ot{flex:1}.opt .ot .t{font-size:14px}.opt .ot .d{font-size:12px;color:var(--muted)}.opt .op{font-size:14px}
.cnav{display:flex;justify-content:space-between;align-items:center;margin-top:28px;gap:16px}
.cnav .back{background:none;border:none;cursor:pointer;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--muted)}
.cnav .back:hover{color:var(--ink)}
.osum{background:var(--sand);padding:34px;align-self:start;position:sticky;top:30px}
.osum h3{font-family:var(--display);font-size:23px;font-weight:500;margin-bottom:22px}
.osum .oi{display:flex;gap:14px;padding:15px 0;border-bottom:1px solid var(--line2)}
.osum .oi-img{width:62px;height:74px;background:var(--ivory);flex:none;overflow:hidden;position:relative}
.osum .oi-img img{width:100%;height:100%;object-fit:contain}
.osum .oi-img .qb{position:absolute;top:-7px;right:-7px;background:var(--muted);color:#fff;font-size:10px;width:18px;height:18px;border-radius:9px;display:flex;align-items:center;justify-content:center}
.osum .oi-info{flex:1;font-size:13px}.osum .oi-info .nm{font-family:var(--serif);font-size:18px}.osum .oi-info .cl{color:var(--muted);font-size:12px}.osum .oi .pr{font-size:13px}
.osum .ototals{margin-top:20px}

.confirm{text-align:center;max-width:700px;margin:0 auto;padding:64px 0 100px}
.confirm .tick{width:78px;height:78px;border-radius:50%;background:var(--sand);display:flex;align-items:center;justify-content:center;margin:0 auto 28px;font-size:32px;color:var(--cognac)}
.confirm h1{font-family:var(--display);font-weight:500;font-size:clamp(40px,4.8vw,62px);margin-bottom:14px}
.confirm h1 em{font-style:italic;font-family:var(--serif)}
.confirm .ordno{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:10px}
.confirm p{color:var(--muted);max-width:48ch;margin:0 auto 10px}
.confirm .rec{border:1px solid var(--line);padding:32px;margin:38px 0;text-align:left}

.toast{position:fixed;bottom:30px;left:50%;transform:translateX(-50%) translateY(160%);background:var(--ink);color:var(--ivory);padding:16px 30px;font-size:12px;letter-spacing:.06em;z-index:300;transition:.5s var(--ease);display:flex;gap:10px;align-items:center}
.toast.show{transform:translateX(-50%) translateY(0)}
.toast svg{width:18px;height:18px;stroke:var(--gold);fill:none;stroke-width:1.6}

.hidden{display:none!important}

@media(max-width:1000px){
  .fgrid{grid-template-columns:1fr 1fr}
  .grid{grid-template-columns:repeat(3,1fr)}
  .hero-grid,.split,.mono .split,.pdp,.cartpage,.checkout{grid-template-columns:1fr}
  .split .pic,.mono .panel,.split.flip .pic{order:0;min-height:420px}
  .split .tx,.mono .tx{padding:60px 34px}
  .summary,.osum{position:static}
  .diff{grid-template-columns:1fr;gap:46px}
  .revs{grid-template-columns:1fr}
  .pdp-gallery{flex-direction:column-reverse}
  .pdp-thumbs{flex-direction:row;width:auto}
}
@media(max-width:760px){
  .wrap{padding:0 22px}
  .menu{display:none}.nav-l{flex:0}.burger{display:flex}
  .nav{height:70px}.logo{font-size:24px}
  .grid,.grid.g3{grid-template-columns:repeat(2,1fr);gap:18px}
  .cats{grid-template-columns:1fr 1fr}.cats a.tall{grid-row:auto;aspect-ratio:3/4}
  section{padding:72px 0}
  .frow{grid-template-columns:1fr}
  .cartlines .cl-img{width:96px;height:112px}
  .news form{flex-direction:column;gap:10px}
  .editorial{min-height:62vh}
}
@media(max-width:460px){.grid,.grid.g3{grid-template-columns:1fr 1fr;gap:12px}.pcard h3{font-size:19px}}
