/* ============================================================
   RAFEA LINE — Atelier Ledger
   Main stylesheet (enqueued via functions.php)
   ============================================================ */

:root{
  --off-white:#EEEAE1;
  --paper:#F4F1EA;
  --strong-cafe:#7A6C63;
  --calm-cafe:#A4978A;
  --soft-beige:#D5D1C9;
  --soft-brown:#A7715B;
  --ink:#4A403A;
  --hairline:rgba(122,108,99,.28);
  --serif:'Italiana',serif;
  --accent-serif:'Cormorant Garamond',serif;
  --sans:'Jost',sans-serif;
  --maxw:1320px;
  --pad:clamp(20px,4vw,56px);
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  background:var(--off-white);color:var(--ink);
  font-family:var(--sans);font-weight:300;font-size:16px;line-height:1.65;
  -webkit-font-smoothing:antialiased;overflow-x:hidden;
}
::selection{background:var(--soft-brown);color:var(--off-white)}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%;height:auto}
button{font-family:inherit}
:focus-visible{outline:2px solid var(--soft-brown);outline-offset:3px}
h1,h2,h3,h4,h5{font-weight:400;line-height:1.1}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 var(--pad)}
.eyebrow{font-size:11px;letter-spacing:.32em;text-transform:uppercase;color:var(--soft-brown);font-weight:500;display:inline-flex;align-items:center;gap:14px}
.eyebrow::before{content:'';width:34px;height:1px;background:var(--soft-brown)}
.serif{font-family:var(--serif)}
.screen-reader-text{position:absolute!important;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
.skip-link{position:absolute;left:-9999px;top:0;background:var(--strong-cafe);color:var(--off-white);padding:10px 16px;z-index:999}
.skip-link:focus{left:0}

/* ——— intro loader (from Direction E) ——— */
#rl-veil{position:fixed;inset:0;z-index:9999;background:var(--off-white);display:flex;align-items:center;justify-content:center;flex-direction:column;gap:24px;transition:opacity .9s cubic-bezier(.23,.62,.22,1) .15s,visibility .9s .15s}
#rl-veil.off{opacity:0;visibility:hidden}
#rl-veil .vmark{width:54px;aspect-ratio:868/1020;background:var(--strong-cafe);-webkit-mask:var(--mask-symbol) center/contain no-repeat;mask:var(--mask-symbol) center/contain no-repeat;animation:rlBreathe 1.5s ease-in-out infinite alternate}
#rl-veil .vline{width:0;height:1px;background:var(--hairline);animation:rlLine 1.5s cubic-bezier(.23,.62,.22,1) forwards .2s}
@keyframes rlBreathe{from{opacity:.3;transform:scale(.97)}to{opacity:1;transform:scale(1)}}
@keyframes rlLine{to{width:150px}}

/* ——— reveal ——— */
.rv{opacity:0;transform:translateY(26px);transition:opacity .9s cubic-bezier(.2,.6,.2,1),transform .9s cubic-bezier(.2,.6,.2,1)}
.rv.in{opacity:1;transform:none}
.rv.d1{transition-delay:.12s}.rv.d2{transition-delay:.24s}.rv.d3{transition-delay:.36s}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.site-header{position:fixed;inset:0 0 auto 0;z-index:500;background:rgba(238,234,225,.85);backdrop-filter:blur(12px);border-bottom:1px solid var(--hairline)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:24px}
.brand{display:flex;align-items:center;gap:13px;flex:none}
.brand img,.brand-logo{height:30px;width:auto;display:block}
.brand .mark{font-family:var(--serif);font-size:23px;letter-spacing:.14em;color:var(--strong-cafe);text-transform:capitalize}
.brand-name{font-family:var(--serif);font-size:18px;letter-spacing:.34em;text-transform:uppercase;color:var(--strong-cafe);white-space:nowrap;line-height:1}
@media(max-width:520px){.brand-name{font-size:14px;letter-spacing:.2em}.brand img,.brand-logo{height:26px}}
.nav-menu{display:flex;gap:34px;list-style:none;font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:400}
.nav-menu a{position:relative;padding:4px 0;color:var(--strong-cafe);display:inline-block}
.nav-menu a::after{content:'';position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--soft-brown);transition:width .35s}
.nav-menu li:hover>a::after,.nav-menu .current-menu-item>a::after{width:100%}
.nav-menu .sub-menu{position:absolute;top:100%;left:0;background:var(--paper);border:1px solid var(--hairline);min-width:200px;padding:10px 0;display:none;flex-direction:column;gap:0;z-index:20}
.nav-menu li{position:relative}
.nav-menu li:hover>.sub-menu{display:flex}
.nav-menu .sub-menu a{padding:9px 20px;letter-spacing:.12em}
.nav-menu .sub-menu a::after{display:none}
.nav-right{display:flex;align-items:center;gap:18px;flex:none}
.nav-icon{background:none;border:none;cursor:pointer;color:var(--strong-cafe);font-size:12px;letter-spacing:.18em;text-transform:uppercase;display:flex;align-items:center;gap:7px;padding:6px;position:relative}
.nav-icon svg{width:18px;height:18px}
.cart-count{background:var(--soft-brown);color:var(--off-white);font-size:10px;min-width:17px;height:17px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;padding:0 4px;letter-spacing:0}
.nav-toggle{display:none}
@media(max-width:980px){
  .nav-menu{display:none}
  .nav-toggle{display:flex}
  .brand .mark{font-size:20px}
}

/* mobile drawer */
.mobile-drawer{position:fixed;inset:0;z-index:600;background:var(--off-white);transform:translateX(100%);transition:transform .5s cubic-bezier(.2,.6,.2,1);display:flex;flex-direction:column;padding:24px var(--pad);visibility:hidden}
.mobile-drawer.open{transform:none;visibility:visible}
.mobile-drawer .md-top{display:flex;justify-content:space-between;align-items:center;height:48px;margin-bottom:30px}
.mobile-drawer .md-close{background:none;border:none;font-size:24px;color:var(--strong-cafe);cursor:pointer}
.mobile-drawer ul{list-style:none}
.mobile-drawer .nav-menu{display:flex;flex-direction:column;gap:0}
.mobile-drawer .nav-menu li{border-bottom:1px solid var(--hairline)}
.mobile-drawer .nav-menu a{font-family:var(--serif);font-size:26px;letter-spacing:.04em;text-transform:none;padding:18px 0;color:var(--strong-cafe)}
.mobile-drawer .nav-menu .sub-menu{position:static;border:none;background:none;padding:0 0 10px 16px;display:flex}
.mobile-drawer .nav-menu .sub-menu a{font-size:16px;padding:8px 0}

/* ——— buttons ——— */
.btn-primary{font-family:var(--sans);font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;background:var(--strong-cafe);color:var(--off-white);border:1px solid var(--strong-cafe);padding:17px 40px;border-radius:999px;cursor:pointer;transition:background .35s,letter-spacing .35s,color .35s;display:inline-block;text-align:center}
.btn-primary:hover{background:var(--soft-brown);border-color:var(--soft-brown);letter-spacing:.3em;color:var(--off-white)}
.btn-ghost{font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;background:transparent;color:var(--strong-cafe);border:1px solid var(--strong-cafe);padding:16px 38px;border-radius:999px;cursor:pointer;transition:background .35s,color .35s;display:inline-block}
.btn-ghost:hover{background:var(--strong-cafe);color:var(--off-white)}
.link-quiet{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--strong-cafe);border-bottom:1px solid var(--hairline);padding-bottom:5px;transition:border-color .3s,color .3s;display:inline-block}
.link-quiet:hover{color:var(--soft-brown);border-color:var(--soft-brown)}

/* ============================================================
   HERO (front page)
   ============================================================ */
.hero{min-height:100vh;display:grid;grid-template-columns:1.05fr .95fr;align-items:center;gap:clamp(32px,5vw,80px);padding-top:120px;padding-bottom:64px;position:relative}
.hero-bg-mark{position:absolute;right:-12%;top:6%;width:min(58vw,760px);aspect-ratio:868/1020;background:var(--soft-beige);opacity:.38;pointer-events:none;-webkit-mask:var(--mask-symbol) center/contain no-repeat;mask:var(--mask-symbol) center/contain no-repeat}
.hero h1{font-family:var(--serif);color:var(--strong-cafe);font-size:clamp(46px,7.2vw,104px);line-height:1.02;letter-spacing:.01em;margin:26px 0 18px}
.hero h1 em{font-family:var(--accent-serif);font-style:italic;color:var(--soft-brown)}
.hero p.lede{max-width:46ch;color:var(--strong-cafe);margin-bottom:40px}
.hero-actions{display:flex;align-items:center;gap:28px;flex-wrap:wrap}
.fit-figure{position:relative;justify-self:end;width:min(100%,470px)}
.fit-figure .frame{position:relative;overflow:hidden;border-radius:2px;box-shadow:0 30px 80px -30px rgba(74,64,58,.35)}
.fit-figure img{width:100%;aspect-ratio:3/4;object-fit:cover;transform:scale(1.03);transition:transform 1.4s cubic-bezier(.2,.6,.2,1)}
.fit-figure:hover img{transform:scale(1.085)}
.fit-figure .frame::after{content:'';position:absolute;inset:14px;border:1px solid rgba(238,234,225,.4);pointer-events:none}
.annot{position:absolute;display:flex;align-items:center;font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;font-weight:500;color:var(--strong-cafe);white-space:nowrap}
.annot .lead{height:1px;background-image:linear-gradient(90deg,var(--soft-brown) 55%,transparent 0);background-size:7px 1px;width:0;transition:width 1.1s cubic-bezier(.2,.6,.2,1)}
.annot .dot{width:5px;height:5px;border-radius:50%;background:var(--soft-brown);flex:none}
.annot .tag{background:var(--off-white);border:1px solid var(--hairline);padding:6px 12px;border-radius:999px;opacity:0;transform:translateY(6px);transition:opacity .6s .5s,transform .6s .5s}
.annot.in .lead{width:74px}.annot.in .tag{opacity:1;transform:none}
.annot.left{flex-direction:row}.annot.right{flex-direction:row-reverse}
.a1{top:13%;left:calc(100% - 6px)}.a2{top:43%;left:calc(100% - 6px)}.a3{top:67%;right:calc(100% - 6px)}.a4{top:88%;right:calc(100% - 6px)}
.fit-caption{margin-top:18px;display:flex;justify-content:space-between;font-size:11px;letter-spacing:.22em;text-transform:uppercase;color:var(--calm-cafe)}
@media(max-width:980px){
  .hero{grid-template-columns:1fr;padding-top:110px}
  .fit-figure{justify-self:start;width:min(100%,440px)}
  .a1,.a2{left:auto;right:14px;flex-direction:row-reverse}
  .a3,.a4{right:auto;left:14px;flex-direction:row}
  .annot .tag{background:rgba(238,234,225,.92)}
  .annot.in .lead{width:40px}
  .hero-bg-mark{opacity:.2}
}

/* ——— marquee band ——— */
.band{border-top:1px solid var(--hairline);border-bottom:1px solid var(--hairline);padding:26px 0;overflow:hidden;background:var(--paper)}
.band-row{display:flex;gap:64px;width:max-content;animation:rlSlide 36s linear infinite}
.band-item{display:flex;align-items:center;gap:64px;flex:none}
.band-item span{font-family:var(--accent-serif);font-style:italic;font-size:19px;color:var(--calm-cafe);letter-spacing:.04em}
.band-item .glyph{width:26px;height:30px;flex:none;background:var(--soft-brown);opacity:.85;-webkit-mask:var(--mask-symbol) center/contain no-repeat;mask:var(--mask-symbol) center/contain no-repeat}
@keyframes rlSlide{to{transform:translateX(-50%)}}

/* ============================================================
   SECTIONS
   ============================================================ */
.section{padding:clamp(80px,11vw,150px) 0}
.sec-head{display:flex;align-items:flex-end;justify-content:space-between;gap:32px;margin-bottom:clamp(44px,6vw,80px);flex-wrap:wrap}
.sec-head h2{font-family:var(--serif);color:var(--strong-cafe);font-size:clamp(36px,4.6vw,64px);line-height:1.05;margin-top:22px}
.sec-head .note{max-width:34ch;color:var(--calm-cafe);font-size:15px}

/* ——— ledger / product cards (shared on home + shop) ——— */
.ledger{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,40px)}
.ledger.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:1100px){.ledger.cols-4{grid-template-columns:repeat(3,1fr)}}
@media(max-width:980px){.ledger,.ledger.cols-4{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.ledger,.ledger.cols-4{grid-template-columns:1fr;max-width:420px;margin-left:auto;margin-right:auto}}

.slip{background:var(--paper);border:1px solid var(--hairline);display:flex;flex-direction:column;transition:transform .6s cubic-bezier(.2,.6,.2,1),box-shadow .6s;position:relative}
.slip:hover{transform:translateY(-8px);box-shadow:0 36px 70px -34px rgba(74,64,58,.4)}
.slip-top{display:flex;justify-content:space-between;align-items:center;padding:14px 20px;border-bottom:1px solid var(--hairline);font-size:10px;letter-spacing:.26em;text-transform:uppercase;color:var(--calm-cafe);font-weight:500}
.slip-top .no{color:var(--soft-brown)}
.slip-img{overflow:hidden;position:relative;display:block}
.slip-img img{width:100%;aspect-ratio:4/5;object-fit:cover;transition:transform 1.3s cubic-bezier(.2,.6,.2,1)}
.slip:hover .slip-img img{transform:scale(1.07)}
.slip-img .quick{position:absolute;left:50%;bottom:18px;transform:translate(-50%,12px);opacity:0;transition:opacity .45s,transform .45s;font-size:11px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;background:rgba(238,234,225,.95);color:var(--strong-cafe);padding:11px 24px;border-radius:999px;border:none;cursor:pointer}
.slip:hover .quick{opacity:1;transform:translate(-50%,0)}
.slip-badge{position:absolute;top:48px;left:14px;background:var(--soft-brown);color:var(--off-white);font-size:9px;letter-spacing:.2em;text-transform:uppercase;padding:6px 12px;border-radius:999px;z-index:2}
.slip-body{padding:22px 20px 8px;display:flex;justify-content:space-between;gap:14px;align-items:baseline}
.slip-body h3{font-family:var(--serif);font-size:24px;color:var(--strong-cafe);letter-spacing:.02em}
.slip-body h3 a{color:inherit}
.slip-fab{padding:0 20px 18px;font-size:13px;color:var(--calm-cafe)}
.slip-fab .star-rating{margin-top:6px}
.slip-foot{margin-top:auto;border-top:1px dashed var(--hairline);padding:16px 20px;display:flex;justify-content:space-between;align-items:center;gap:12px}
.price{font-family:var(--accent-serif);font-size:21px;color:var(--strong-cafe)}
.price small,.price .woocommerce-Price-currencySymbol{font-size:12px;letter-spacing:.04em;color:var(--soft-brown);font-family:var(--sans);vertical-align:1px;margin-right:3px}
.price del{color:var(--calm-cafe);opacity:.7;margin-right:8px;font-size:16px}
.price ins{text-decoration:none}
.add{font-family:var(--sans);font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;font-weight:500;color:var(--soft-brown);background:none;border:none;cursor:pointer;display:flex;align-items:center;gap:8px;padding:4px 0;white-space:nowrap}
.add::after{content:'→';transition:transform .3s}
.add:hover::after{transform:translateX(5px)}
.add.loading{opacity:.5;pointer-events:none}
.add.added::after{content:'✓'}

/* ——— made to measure ——— */
.mtm{background:var(--strong-cafe);color:var(--off-white)}
.mtm .wrap{display:grid;grid-template-columns:1fr 1fr;gap:clamp(40px,6vw,100px);align-items:center}
@media(max-width:980px){.mtm .wrap{grid-template-columns:1fr}}
.mtm .eyebrow{color:var(--soft-beige)}.mtm .eyebrow::before{background:var(--soft-beige)}
.mtm h2{font-family:var(--serif);font-size:clamp(36px,4.4vw,60px);line-height:1.08;margin:24px 0 20px;color:var(--off-white)}
.mtm h2 em{font-family:var(--accent-serif);font-style:italic;color:var(--soft-beige)}
.mtm p{color:var(--soft-beige);max-width:50ch;margin-bottom:34px}
.measure-list{list-style:none;border-top:1px solid rgba(238,234,225,.22)}
.measure-list li{display:flex;justify-content:space-between;align-items:baseline;gap:20px;padding:17px 2px;border-bottom:1px solid rgba(238,234,225,.22);font-size:13px;letter-spacing:.16em;text-transform:uppercase}
.measure-list .ln{flex:1;border-bottom:1px dashed rgba(238,234,225,.3);transform:translateY(-4px)}
.mtm-figure{position:relative}
.mtm-figure img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2px}
.mtm-figure .veil{position:absolute;inset:0;background:var(--off-white);opacity:.06;-webkit-mask:var(--mask-symbol) center/72% no-repeat;mask:var(--mask-symbol) center/72% no-repeat;pointer-events:none}
.mtm-tagline{position:absolute;bottom:22px;left:22px;right:22px;display:flex;justify-content:space-between;font-size:10.5px;letter-spacing:.26em;text-transform:uppercase;color:rgba(238,234,225,.85)}

/* ——— policy ——— */
.policy .wrap{max-width:980px}
.policy .center{text-align:center}
.policy .eyebrow{justify-content:center}.policy .eyebrow::after{content:'';width:34px;height:1px;background:var(--soft-brown)}
.policy h2{font-family:var(--serif);color:var(--strong-cafe);font-size:clamp(32px,4vw,52px);margin-top:22px}
.policy-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(28px,4vw,56px);margin-top:clamp(40px,5vw,70px)}
@media(max-width:860px){.policy-grid{grid-template-columns:1fr}}
.pol{border-top:1px solid var(--strong-cafe);padding-top:22px}
.pol h4{font-family:var(--accent-serif);font-style:italic;font-weight:500;font-size:21px;color:var(--soft-brown);margin-bottom:12px}
.pol p{font-size:14px;color:var(--strong-cafe)}

/* ============================================================
   PAGE HEADER (interior pages / shop / archives)
   ============================================================ */
.page-hero{padding:140px 0 0;position:relative;overflow:hidden}
.page-hero .wrap{position:relative;z-index:2}
.page-hero .eyebrow{margin-bottom:18px}
.page-hero h1{font-family:var(--serif);color:var(--strong-cafe);font-size:clamp(40px,6vw,82px);line-height:1.02;max-width:18ch}
.page-hero .lede{color:var(--calm-cafe);max-width:52ch;margin-top:18px}
.page-hero .bg-mark{position:absolute;right:-8%;top:0;width:min(46vw,520px);aspect-ratio:868/1020;background:var(--soft-beige);opacity:.3;-webkit-mask:var(--mask-symbol) center/contain no-repeat;mask:var(--mask-symbol) center/contain no-repeat;pointer-events:none}
.breadcrumbs{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--calm-cafe);margin-top:30px}
.breadcrumbs a:hover{color:var(--soft-brown)}
.breadcrumbs .sep{margin:0 8px;color:var(--hairline)}

/* ============================================================
   WOOCOMMERCE — SHOP / ARCHIVE
   ============================================================ */
.woocommerce-shop-layout{padding:clamp(40px,6vw,72px) 0 clamp(80px,11vw,150px)}
.shop-toolbar{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;margin-bottom:clamp(30px,4vw,50px);padding-bottom:22px;border-bottom:1px solid var(--hairline)}
.shop-toolbar .woocommerce-result-count{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--calm-cafe);margin:0}
.shop-toolbar .woocommerce-ordering select,.rl-select{font-family:var(--sans);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--strong-cafe);background:var(--paper);border:1px solid var(--hairline);border-radius:999px;padding:11px 20px;cursor:pointer;appearance:none;-webkit-appearance:none;background-image:linear-gradient(45deg,transparent 50%,var(--soft-brown) 50%),linear-gradient(135deg,var(--soft-brown) 50%,transparent 50%);background-position:calc(100% - 19px) 50%,calc(100% - 14px) 50%;background-size:5px 5px;background-repeat:no-repeat;padding-right:42px}
.shop-content{display:grid;grid-template-columns:240px 1fr;gap:clamp(28px,4vw,56px);align-items:start}
.shop-content.no-sidebar{grid-template-columns:1fr}
@media(max-width:980px){.shop-content{grid-template-columns:1fr}.shop-sidebar{display:none}}
.shop-sidebar .widget{margin-bottom:36px}
.shop-sidebar .widget-title{font-family:var(--serif);font-size:22px;color:var(--strong-cafe);margin-bottom:16px}
.shop-sidebar ul{list-style:none}
.shop-sidebar li{padding:8px 0;border-bottom:1px solid var(--hairline);font-size:14px;color:var(--strong-cafe)}
.shop-sidebar li a:hover{color:var(--soft-brown)}
.shop-sidebar .count{color:var(--calm-cafe);font-size:12px;float:right}

ul.products{list-style:none;display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(20px,2.6vw,40px)}
.columns-2 ul.products{grid-template-columns:repeat(2,1fr)}
.columns-4 ul.products{grid-template-columns:repeat(4,1fr)}
@media(max-width:980px){ul.products,.columns-4 ul.products{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){ul.products,.columns-4 ul.products,.columns-2 ul.products{grid-template-columns:1fr;max-width:420px;margin:0 auto}}

/* pagination */
.woocommerce-pagination{margin-top:clamp(50px,7vw,80px);text-align:center}
.woocommerce-pagination ul{list-style:none;display:inline-flex;gap:8px}
.woocommerce-pagination a,.woocommerce-pagination span{display:inline-flex;align-items:center;justify-content:center;min-width:42px;height:42px;border:1px solid var(--hairline);border-radius:999px;font-size:13px;color:var(--strong-cafe);transition:background .3s,color .3s}
.woocommerce-pagination .current{background:var(--strong-cafe);color:var(--off-white);border-color:var(--strong-cafe)}
.woocommerce-pagination a:hover{background:var(--soft-brown);color:var(--off-white);border-color:var(--soft-brown)}

/* ============================================================
   WOOCOMMERCE — SINGLE PRODUCT
   ============================================================ */
.single-product-layout{padding:130px 0 clamp(80px,11vw,140px)}
.product-top{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(36px,5vw,80px);align-items:start}
@media(max-width:900px){.product-top{grid-template-columns:1fr;gap:40px}}
.product-gallery{position:relative}
.product-gallery .woocommerce-product-gallery__wrapper{display:flex;flex-direction:column;gap:14px}
.product-gallery .woocommerce-product-gallery__image{overflow:hidden;border-radius:2px}
.product-gallery img{width:100%;height:auto;border-radius:2px}
.product-gallery .frame-mark{position:absolute;top:18px;right:18px;width:40px;aspect-ratio:868/1020;background:var(--off-white);opacity:.85;-webkit-mask:var(--mask-symbol) center/contain no-repeat;mask:var(--mask-symbol) center/contain no-repeat;z-index:3;pointer-events:none}
.product-gallery .flex-control-thumbs{list-style:none;display:flex;gap:10px;margin-top:12px;padding:0}
.product-gallery .flex-control-thumbs li{width:72px;cursor:pointer}
.product-gallery .flex-control-thumbs img{border:1px solid var(--hairline);opacity:.6;transition:opacity .3s}
.product-gallery .flex-control-thumbs img.flex-active,.product-gallery .flex-control-thumbs img:hover{opacity:1}

.product-summary .product-ref{font-size:11px;letter-spacing:.26em;text-transform:uppercase;color:var(--soft-brown);margin-bottom:14px}
.product-summary .product_title{font-family:var(--serif);font-size:clamp(38px,4.6vw,62px);line-height:1.04;color:var(--strong-cafe);margin-bottom:10px}
.product-summary .woocommerce-product-rating{display:flex;align-items:center;gap:10px;margin-bottom:18px}
.product-summary .price{font-family:var(--accent-serif);font-size:30px;color:var(--strong-cafe);margin-bottom:22px;display:block}
.product-summary .woocommerce-product-details__short-description{color:var(--strong-cafe);max-width:48ch;margin-bottom:28px}
.product-summary .woocommerce-product-details__short-description p{margin-bottom:10px}

/* variations + qty + add to cart */
table.variations{width:100%;border-collapse:collapse;margin-bottom:20px}
table.variations th{text-align:left;font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--calm-cafe);font-weight:500;padding:12px 14px 12px 0;vertical-align:middle;width:120px}
table.variations td{padding:8px 0}
table.variations select,.rl-input{font-family:var(--sans);font-size:14px;color:var(--strong-cafe);background:var(--paper);border:1px solid var(--hairline);border-radius:6px;padding:12px 16px;width:100%;max-width:320px}
.reset_variations{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--soft-brown);display:inline-block;margin-top:8px}
.woocommerce-variation-price{margin:14px 0}
.woocommerce-variation-price .price{font-size:24px;margin-bottom:0}

.cart{display:flex;align-items:stretch;gap:14px;flex-wrap:wrap;margin-bottom:28px}
.quantity{display:inline-flex;align-items:center;border:1px solid var(--hairline);border-radius:999px;overflow:hidden;background:var(--paper)}
.quantity button{background:none;border:none;width:44px;height:54px;font-size:18px;color:var(--strong-cafe);cursor:pointer}
.quantity input.qty{width:48px;height:54px;text-align:center;border:none;background:none;font-family:var(--sans);font-size:15px;color:var(--strong-cafe);-moz-appearance:textfield}
.quantity input.qty::-webkit-outer-spin-button,.quantity input.qty::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}
.single_add_to_cart_button{font-family:var(--sans);font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;background:var(--strong-cafe);color:var(--off-white);border:1px solid var(--strong-cafe);padding:0 44px;height:54px;border-radius:999px;cursor:pointer;transition:background .35s,letter-spacing .35s;flex:1;min-width:200px}
.single_add_to_cart_button:hover{background:var(--soft-brown);border-color:var(--soft-brown);letter-spacing:.3em}
.product_meta{font-size:12px;letter-spacing:.04em;color:var(--calm-cafe);border-top:1px solid var(--hairline);padding-top:20px;line-height:2}
.product_meta>span{display:block}
.product_meta a:hover{color:var(--soft-brown)}

/* measurement note panel */
.measure-note{background:var(--paper);border:1px solid var(--hairline);border-radius:4px;padding:22px 24px;margin-bottom:26px}
.measure-note h4{font-family:var(--accent-serif);font-style:italic;font-size:19px;color:var(--soft-brown);margin-bottom:8px}
.measure-note p{font-size:13.5px;color:var(--strong-cafe);margin:0}

/* tabs */
.woocommerce-tabs{margin-top:clamp(60px,8vw,100px)}
.woocommerce-tabs ul.tabs{list-style:none;display:flex;gap:34px;border-bottom:1px solid var(--hairline);margin-bottom:34px;flex-wrap:wrap}
.woocommerce-tabs ul.tabs li{padding-bottom:14px;margin-bottom:-1px}
.woocommerce-tabs ul.tabs li a{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--calm-cafe);border-bottom:1px solid transparent;padding-bottom:14px}
.woocommerce-tabs ul.tabs li.active a{color:var(--strong-cafe);border-color:var(--soft-brown)}
.woocommerce-tabs .panel{color:var(--strong-cafe);max-width:760px}
.woocommerce-tabs .panel h2{font-family:var(--serif);font-size:28px;margin-bottom:16px;color:var(--strong-cafe)}
.woocommerce-tabs table{width:100%;border-collapse:collapse}
.woocommerce-tabs table th,.woocommerce-tabs table td{text-align:left;padding:12px 0;border-bottom:1px solid var(--hairline);font-size:14px}

/* related */
.related,.upsells{margin-top:clamp(70px,9vw,120px)}
.related>h2,.upsells>h2{font-family:var(--serif);font-size:clamp(30px,3.6vw,48px);color:var(--strong-cafe);margin-bottom:clamp(34px,4vw,56px)}

/* ============================================================
   CART / CHECKOUT / ACCOUNT (generic woo styling)
   ============================================================ */
.woocommerce-page-layout{padding:130px 0 clamp(80px,11vw,140px)}
.woocommerce-page-layout .page-hero{padding-top:0}
.woocommerce table.shop_table{width:100%;border-collapse:collapse;margin-bottom:30px}
.woocommerce table.shop_table th{text-align:left;font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--calm-cafe);font-weight:500;padding:16px 12px;border-bottom:1px solid var(--strong-cafe)}
.woocommerce table.shop_table td{padding:18px 12px;border-bottom:1px solid var(--hairline);font-size:14px;color:var(--strong-cafe)}
.woocommerce .cart_item img{width:72px;border-radius:2px}
.woocommerce .product-remove a{color:var(--soft-brown);font-size:18px}
.woocommerce .coupon input,.woocommerce .input-text,.woocommerce input[type=text],.woocommerce input[type=email],.woocommerce input[type=tel],.woocommerce input[type=password],.woocommerce textarea,.woocommerce select{font-family:var(--sans);font-size:14px;color:var(--strong-cafe);background:var(--paper);border:1px solid var(--hairline);border-radius:6px;padding:13px 16px}
.woocommerce form .form-row{margin-bottom:16px}
.woocommerce-checkout #payment{background:var(--paper);border:1px solid var(--hairline);border-radius:6px;padding:24px}
.cart-collaterals .cart_totals,.woocommerce-checkout-review-order{background:var(--paper);border:1px solid var(--hairline);border-radius:6px;padding:26px}
.cart_totals h2,.woocommerce-checkout #order_review_heading{font-family:var(--serif);font-size:26px;color:var(--strong-cafe);margin-bottom:16px}
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,.woocommerce #respond input#submit{font-family:var(--sans);font-size:12px;letter-spacing:.2em;text-transform:uppercase;font-weight:500;background:var(--strong-cafe);color:var(--off-white);border:1px solid var(--strong-cafe);padding:15px 32px;border-radius:999px;cursor:pointer;transition:background .35s,letter-spacing .35s}
.woocommerce a.button:hover,.woocommerce button.button:hover,.woocommerce input.button:hover,.woocommerce #respond input#submit:hover{background:var(--soft-brown);border-color:var(--soft-brown)}
.woocommerce a.button.alt,.woocommerce button.button.alt{background:var(--soft-brown);border-color:var(--soft-brown)}
.woocommerce-message,.woocommerce-info,.woocommerce-error{background:var(--paper);border:1px solid var(--hairline);border-left:3px solid var(--soft-brown);padding:16px 20px;list-style:none;margin-bottom:24px;font-size:14px;border-radius:0 4px 4px 0}
.woocommerce-error{border-left-color:#b3553f}

/* my account */
.woocommerce-account.logged-in .woocommerce{display:grid;grid-template-columns:230px 1fr;gap:clamp(30px,4vw,60px);align-items:start}
@media(max-width:860px){.woocommerce-account.logged-in .woocommerce{grid-template-columns:1fr}}
.woocommerce-MyAccount-navigation ul{list-style:none}
.woocommerce-MyAccount-navigation li{border-bottom:1px solid var(--hairline)}
.woocommerce-MyAccount-navigation li a{display:block;padding:14px 4px;font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--strong-cafe)}
.woocommerce-MyAccount-navigation li.is-active a{color:var(--soft-brown)}

/* ============================================================
   POSTS / PAGES / COMMENTS
   ============================================================ */
.content-area{padding:130px 0 clamp(80px,11vw,140px)}
.entry-layout{max-width:760px;margin:0 auto}
.entry-content{color:var(--strong-cafe);font-size:17px;line-height:1.8}
.entry-content h2{font-family:var(--serif);font-size:34px;margin:40px 0 16px;color:var(--strong-cafe)}
.entry-content h3{font-family:var(--serif);font-size:26px;margin:32px 0 12px;color:var(--strong-cafe)}
.entry-content p{margin-bottom:20px}
.entry-content a{color:var(--soft-brown);border-bottom:1px solid var(--hairline)}
.entry-content img{border-radius:2px;margin:24px 0}
.entry-content blockquote{border-left:2px solid var(--soft-brown);padding-left:24px;font-family:var(--accent-serif);font-style:italic;font-size:22px;color:var(--soft-brown);margin:30px 0}
.post-thumb{margin-bottom:36px;border-radius:2px;overflow:hidden}
.post-meta{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--calm-cafe);margin-bottom:16px}

.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:clamp(24px,3vw,48px)}
@media(max-width:900px){.blog-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:600px){.blog-grid{grid-template-columns:1fr}}
.post-card .thumb{overflow:hidden;border-radius:2px;aspect-ratio:4/3;margin-bottom:18px}
.post-card .thumb img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.6,.2,1)}
.post-card:hover .thumb img{transform:scale(1.06)}
.post-card h2{font-family:var(--serif);font-size:25px;color:var(--strong-cafe);margin-bottom:8px}
.post-card .excerpt{font-size:14px;color:var(--calm-cafe)}

.comment-list{list-style:none}
.comment-list li{border-bottom:1px solid var(--hairline);padding:20px 0}
.comment-form input,.comment-form textarea{width:100%;font-family:var(--sans);background:var(--paper);border:1px solid var(--hairline);border-radius:6px;padding:13px 16px;margin-bottom:14px}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{border-top:1px solid var(--hairline);background:var(--paper)}
.footer-main{display:grid;grid-template-columns:1.4fr 1fr 1fr 1.2fr;gap:clamp(30px,4vw,64px);padding:clamp(60px,8vw,100px) 0 clamp(40px,5vw,60px)}
@media(max-width:900px){.footer-main{grid-template-columns:1fr 1fr}}
@media(max-width:560px){.footer-main{grid-template-columns:1fr}}
.footer-brand .mark{font-family:var(--serif);font-size:30px;letter-spacing:.1em;color:var(--strong-cafe);display:block;margin-bottom:16px}
.footer-brand p{color:var(--calm-cafe);font-size:14px;max-width:32ch}
.footer-col h4{font-size:11px;letter-spacing:.24em;text-transform:uppercase;color:var(--soft-brown);margin-bottom:18px}
.footer-col ul{list-style:none}
.footer-col li{margin-bottom:11px}
.footer-col a{font-size:14px;color:var(--strong-cafe)}
.footer-col a:hover{color:var(--soft-brown)}
.footer-news input{width:100%;font-family:var(--sans);background:var(--off-white);border:1px solid var(--hairline);border-radius:999px;padding:13px 18px;margin-bottom:12px;font-size:14px}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:26px 0;border-top:1px solid var(--hairline);font-size:11px;letter-spacing:.06em;color:var(--calm-cafe)}
.footer-social{display:flex;gap:18px}
.footer-social a{font-size:11px;letter-spacing:.2em;text-transform:uppercase;color:var(--strong-cafe)}
.footer-social a:hover{color:var(--soft-brown)}

/* ============================================================
   WIDGETS / MISC
   ============================================================ */
.widget select{width:100%}
.search-overlay{position:fixed;inset:0;z-index:700;background:rgba(238,234,225,.97);backdrop-filter:blur(10px);display:flex;align-items:flex-start;justify-content:center;padding-top:18vh;opacity:0;visibility:hidden;transition:opacity .4s,visibility .4s}
.search-overlay.open{opacity:1;visibility:visible}
.search-overlay form{width:min(90vw,640px);position:relative}
.search-overlay input[type=search]{width:100%;font-family:var(--serif);font-size:clamp(28px,5vw,52px);background:none;border:none;border-bottom:1px solid var(--strong-cafe);padding:14px 0;color:var(--strong-cafe)}
.search-overlay .so-close{position:absolute;top:-60px;right:0;background:none;border:none;font-size:28px;color:var(--strong-cafe);cursor:pointer}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important}
  .rv{opacity:1;transform:none}
  #rl-veil{display:none}
}

/* ============================================================
   PAGE-BUILDER CANVAS (Elementor / Full-Width template)
   ============================================================ */
.rl-builder-canvas{padding-top:72px}            /* clear the fixed header */
body.rl-builder .content-area{padding-top:72px}

/* ============================================================
   NATIVE BLOCK CONTENT (About / Contact / FAQ, Gutenberg)
   ============================================================ */
.entry-content .wp-block-buttons{display:flex;gap:14px;flex-wrap:wrap;margin:26px 0}
.entry-content .wp-block-button__link{background:var(--strong-cafe);color:var(--off-white);border:1px solid var(--strong-cafe);border-radius:999px;padding:15px 38px;font-family:var(--sans);font-size:12px;letter-spacing:.24em;text-transform:uppercase;font-weight:500;transition:background .35s,letter-spacing .35s}
.entry-content .wp-block-button__link:hover{background:var(--soft-brown);border-color:var(--soft-brown);letter-spacing:.3em;color:var(--off-white)}
.entry-content .wp-block-columns{gap:clamp(28px,4vw,60px);margin:34px 0}
.entry-content .wp-block-column h3{font-family:var(--accent-serif);font-style:italic;font-weight:500;font-size:22px;color:var(--soft-brown);margin:0 0 8px}
.entry-content .wp-block-column h3:not(:first-child){margin-top:26px}
.entry-content .has-drop-cap:first-letter{font-family:var(--serif);font-size:3.4em;line-height:.78;float:left;margin:8px 12px 0 0;color:var(--soft-brown)}

/* FAQ accordions — core/details block */
.entry-content details.wp-block-details{border-top:1px solid var(--hairline);padding:20px 2px;margin:0}
.entry-content details.wp-block-details:last-of-type{border-bottom:1px solid var(--hairline)}
.entry-content details.wp-block-details summary{cursor:pointer;list-style:none;font-family:var(--serif);font-size:22px;color:var(--strong-cafe);display:flex;justify-content:space-between;align-items:center;gap:18px}
.entry-content details.wp-block-details summary::-webkit-details-marker{display:none}
.entry-content details.wp-block-details summary::after{content:'+';color:var(--soft-brown);font-size:26px;line-height:1;font-family:var(--sans);transition:transform .3s;flex:none}
.entry-content details.wp-block-details[open] summary::after{transform:rotate(45deg)}
.entry-content details.wp-block-details p{margin:12px 0 4px;font-size:15px;color:var(--calm-cafe)}

/* ============================================================
   CART / CHECKOUT / ACCOUNT — rendered via page.php now
   ============================================================ */
.woocommerce-cart .entry-layout,
.woocommerce-checkout .entry-layout,
.woocommerce-account .entry-layout{max-width:var(--maxw)}
.woocommerce-cart .entry-content,
.woocommerce-checkout .entry-content,
.woocommerce-account .entry-content{font-size:15px;line-height:1.6}
.woocommerce-cart .entry-content a:not(.button):not(.wp-block-button__link),
.woocommerce-checkout .entry-content a:not(.button):not(.wp-block-button__link),
.woocommerce-account .entry-content a:not(.button):not(.wp-block-button__link){border-bottom:none}
