:root{
  --cream:#F2EFEA; --cream-dark:#E8E3DC; --taupe:#726658; --brown:#3D3028;
  --sage:#5C7A5E; --sage-dark:#3D5C3F; --rose:#C9968F; --gold:#C9A86A;
  --shadow:0 1px 4px rgba(0,0,0,0.06); --shadow-lg:0 8px 30px rgba(0,0,0,0.10);
  --maxw:1160px; --gutter:24px;
  --edge:max(var(--gutter), calc((100vw - var(--maxw)) / 2 + var(--gutter)));
}
*{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;}
body{font-family:'Nunito',sans-serif;background:var(--cream);color:var(--brown);line-height:1.55;-webkit-font-smoothing:antialiased;}
a{color:inherit;text-decoration:none;}
img{display:block;max-width:100%;}
.serif{font-family:'Cormorant Garamond',serif;}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;}

/* ── Header ── */
header.site{position:sticky;top:0;z-index:50;background:rgba(242,239,234,0.85);backdrop-filter:saturate(180%) blur(12px);border-bottom:1px solid var(--cream-dark);}
.hbar{max-width:var(--maxw);margin:0 auto;padding:15px 24px;display:flex;align-items:center;justify-content:space-between;gap:20px;}
.brand{font-family:'Cormorant Garamond',serif;font-size:1.55rem;font-weight:700;letter-spacing:0.5px;color:var(--brown);white-space:nowrap;}
.brand span{color:var(--sage);}
.nav{display:flex;align-items:center;gap:26px;}
.nav a{font-size:0.86rem;font-weight:600;color:var(--taupe);transition:color .15s;}
.nav a:hover,.nav a.active{color:var(--brown);}
.hsearch{flex:1;max-width:360px;display:flex;align-items:center;gap:8px;background:#fff;border:1.5px solid var(--cream-dark);border-radius:11px;padding:8px 13px;color:var(--taupe);min-width:0;}
.hsearch:focus-within{border-color:var(--sage);}
.hsearch .ico{width:16px;height:16px;flex-shrink:0;}
.hsearch input{border:none;outline:none;background:none;font-family:'Nunito',sans-serif;font-size:0.9rem;color:var(--brown);width:100%;}
@media(max-width:560px){.hsearch{display:none;}}
.cart-btn{position:relative;display:inline-flex;align-items:center;color:var(--brown);}
.cart-count{position:absolute;top:-8px;right:-10px;background:var(--sage-dark);color:#fff;font-size:0.62rem;font-weight:700;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 4px;}
.cart-count:empty{display:none;}

/* ── Buttons ── */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;border:none;border-radius:12px;font-family:'Nunito',sans-serif;font-size:0.96rem;font-weight:700;letter-spacing:0.02em;cursor:pointer;padding:14px 22px;transition:transform .08s, background .15s, box-shadow .15s;}
.btn-primary{background:var(--sage-dark);color:#fff;box-shadow:var(--shadow);}
.btn-primary:hover{background:#345034;box-shadow:var(--shadow-lg);}
.btn-primary:active{transform:translateY(1px);}
.btn-primary:disabled{background:var(--cream-dark);color:var(--taupe);cursor:not-allowed;box-shadow:none;}
.btn-ghost{background:#fff;color:var(--brown);border:1.5px solid var(--cream-dark);}
.btn-ghost:hover{border-color:var(--sage);}
.btn-block{width:100%;}

/* ── Hero (home) ── */
.hero-band{position:relative;overflow:hidden;}
.hero-band::before{content:"";position:absolute;inset:0;background-image:url(/pear-pattern.jpg);background-repeat:no-repeat;background-position:center;background-size:cover;opacity:0.65;z-index:0;}
.hero-band::after{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 62% 74% at 50% 46%, var(--cream) 28%, rgba(242,239,234,0.15) 100%);z-index:1;}
.hero-band .wrap{position:relative;z-index:2;}
.hero{padding:64px 0 40px;text-align:center;}
.hero-eyebrow{font-size:0.76rem;font-weight:700;letter-spacing:0.13em;text-transform:uppercase;color:var(--sage);margin-bottom:16px;}
.about-strip{text-align:center;padding:26px 0 6px;}
.about-strip p{max-width:680px;margin:0 auto;color:var(--taupe);font-family:'Cormorant Garamond',serif;font-size:1.32rem;line-height:1.45;}
.hero h1{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:3rem;line-height:1.1;color:var(--brown);margin-bottom:16px;}
.hero p{max-width:620px;margin:0 auto 26px;color:#5a4f44;font-size:1.05rem;}
.section-title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.9rem;color:var(--brown);margin:8px 0 22px;text-align:center;}

/* category tiles */
.cat-tiles{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:18px 0 56px;}
.cat-tile{position:relative;border-radius:14px;overflow:hidden;aspect-ratio:4/3;background:var(--cream-dark);box-shadow:var(--shadow);cursor:pointer;}
.cat-tile img{width:100%;height:100%;object-fit:cover;transition:transform .4s;}
.cat-tile:hover img{transform:scale(1.05);}
.cat-tile span{position:absolute;left:0;right:0;bottom:0;padding:26px 16px 14px;background:linear-gradient(transparent,rgba(0,0,0,0.55));color:#fff;font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.3rem;}

/* ── Product grid ── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:26px 22px;margin:8px 0 64px;}
.card{display:flex;flex-direction:column;cursor:pointer;}
.card .ph{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:14px;background:var(--cream-dark);box-shadow:var(--shadow);transition:box-shadow .15s, transform .15s;}
.card:hover .ph{box-shadow:var(--shadow-lg);transform:translateY(-2px);}
.card .cat{font-size:0.62rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--sage);margin:12px 0 4px;}
.card .nm{font-family:'Cormorant Garamond',serif;font-size:1.12rem;font-weight:600;color:var(--brown);line-height:1.25;margin-bottom:5px;}
.card .pr{font-size:0.92rem;font-weight:700;color:var(--brown);}

/* filter chips */
.filters{display:flex;flex-wrap:wrap;gap:9px;justify-content:center;margin:10px 0 30px;}
.chip{font-size:0.8rem;font-weight:600;color:var(--taupe);background:#fff;border:1.5px solid var(--cream-dark);border-radius:20px;padding:7px 15px;cursor:pointer;transition:all .15s;}
.chip:hover{border-color:var(--sage);}
.chip.active{background:var(--sage-dark);border-color:var(--sage-dark);color:#fff;}

/* ── PDP ── */
.product{display:grid;grid-template-columns:1.05fr 0.95fr;gap:48px;padding:32px 0 80px;}
@media(max-width:860px){.product{grid-template-columns:1fr;gap:28px;}.hero h1{font-size:2.2rem;}.nav{gap:16px;}}
/* swipeable main gallery */
.pdp-slides{display:flex;overflow-x:auto;scroll-snap-type:x mandatory;border-radius:16px;background:var(--cream-dark);box-shadow:var(--shadow);scrollbar-width:none;-ms-overflow-style:none;}
.pdp-slides::-webkit-scrollbar{display:none;}
.pdp-slide{flex:0 0 100%;width:100%;aspect-ratio:1/1;object-fit:cover;scroll-snap-align:center;cursor:zoom-in;}
.thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;}
.thumbs img{width:62px;height:62px;object-fit:cover;border-radius:9px;cursor:pointer;border:2px solid transparent;transition:border-color .15s;background:var(--cream-dark);}
.thumbs img.active{border-color:var(--sage);}

/* full-screen lightbox */
.lightbox{position:fixed;inset:0;z-index:1000;background:var(--cream);display:none;}
.lightbox.open{display:block;}
.lb-slides{position:absolute;inset:0;display:flex;overflow-x:auto;scroll-snap-type:x mandatory;scrollbar-width:none;-ms-overflow-style:none;}
.lb-slides::-webkit-scrollbar{display:none;}
.lb-slide{flex:0 0 100%;width:100vw;height:100vh;display:flex;align-items:center;justify-content:center;scroll-snap-align:center;}
.lb-slide img{max-width:88vw;max-height:84vh;object-fit:contain;}
.lb-close,.lb-arrow{position:absolute;z-index:2;border:none;background:rgba(255,255,255,0.82);color:var(--brown);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow);transition:background .15s;}
.lb-close:hover,.lb-arrow:hover{background:#fff;}
.lb-close{top:20px;right:22px;width:42px;height:42px;font-size:1.1rem;}
.lb-arrow{top:50%;transform:translateY(-50%);width:48px;height:48px;font-size:1.7rem;line-height:1;}
.lb-prev{left:22px;} .lb-next{right:22px;}
.lb-dots{position:absolute;bottom:26px;left:0;right:0;display:flex;justify-content:center;gap:9px;z-index:2;}
.lb-dots button{width:8px;height:8px;border-radius:50%;border:none;background:var(--cream-dark);cursor:pointer;padding:0;transition:background .15s;}
.lb-dots button.active{background:var(--brown);}
@media(max-width:600px){.lb-arrow{display:none;}}
.cat-tag{display:inline-block;font-size:0.66rem;font-weight:700;letter-spacing:0.1em;text-transform:uppercase;color:var(--sage);background:rgba(92,122,94,0.10);padding:4px 11px;border-radius:20px;margin-bottom:14px;}
h1.title{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:2.15rem;line-height:1.15;color:var(--brown);margin-bottom:14px;}
.price{font-family:'Cormorant Garamond',serif;font-size:2rem;font-weight:600;color:var(--brown);margin-bottom:4px;}
.price small{font-size:0.85rem;font-family:'Nunito',sans-serif;color:var(--taupe);font-weight:600;letter-spacing:0.04em;}
.desc{font-size:0.92rem;color:#5a4f44;margin:18px 0 24px;}
.desc p{margin-bottom:10px;}
.desc ul{list-style:none;margin:8px 0 14px;}
.desc li{position:relative;padding-left:16px;margin-bottom:5px;}
.desc li:before{content:"–";position:absolute;left:0;color:var(--sage);}
.opt{margin-bottom:20px;}
.opt label{display:block;font-size:0.74rem;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;color:var(--taupe);margin-bottom:7px;}
.opt select,.opt input[type=text]{width:100%;padding:11px 13px;font-family:'Nunito',sans-serif;font-size:0.95rem;color:var(--brown);background:#fff;border:1.5px solid var(--cream-dark);border-radius:11px;outline:none;transition:border-color .15s;}
.opt select:focus,.opt input[type=text]:focus{border-color:var(--sage);}
.opt .hint{font-size:0.76rem;color:var(--taupe);margin-top:6px;line-height:1.45;}
.opt .counter{float:right;font-size:0.72rem;color:var(--taupe);font-weight:600;}
.req{color:var(--rose);}
.qtybox{display:inline-flex;align-items:center;border:1.5px solid var(--cream-dark);border-radius:11px;overflow:hidden;background:#fff;}
.qtybox button{width:40px;height:42px;border:none;background:#fff;font-size:1.2rem;color:var(--brown);cursor:pointer;transition:background .12s;}
.qtybox button:hover{background:var(--cream);}
.qtybox input{width:46px;text-align:center;border:none;outline:none;font-family:'Nunito',sans-serif;font-size:1rem;font-weight:600;color:var(--brown);}
.pdp-actions{display:flex;gap:10px;margin-top:8px;}
.pdp-actions .btn{flex:1;}
.ship-note{font-size:0.78rem;color:var(--taupe);margin-top:14px;display:flex;align-items:flex-start;gap:7px;line-height:1.5;}
.err{color:var(--rose);font-size:0.82rem;font-weight:600;margin-top:10px;min-height:1em;}

/* ── Cart ── */
.cart-wrap{padding:32px 0 80px;max-width:780px;margin:0 auto;}
.cart-row{display:grid;grid-template-columns:84px 1fr auto;gap:16px;align-items:center;padding:16px 0;border-bottom:1px solid var(--cream-dark);}
.cart-row img{width:84px;height:84px;object-fit:cover;border-radius:11px;background:var(--cream-dark);}
.cart-row .meta{font-size:0.78rem;color:var(--taupe);margin-top:3px;}
.cart-row .rm{font-size:0.74rem;color:var(--rose);cursor:pointer;font-weight:600;margin-top:6px;display:inline-block;}
.cart-summary{margin-top:24px;display:flex;flex-direction:column;gap:10px;}
.cart-total{display:flex;justify-content:space-between;font-family:'Cormorant Garamond',serif;font-size:1.5rem;font-weight:600;}

/* ── Generic ── */
.loading,.empty-state{text-align:center;padding:80px 20px;color:var(--taupe);font-size:0.95rem;}
.hsecure{font-size:0.72rem;color:var(--taupe);display:flex;align-items:center;gap:6px;}
.footer{text-align:center;padding:46px 20px;color:var(--taupe);font-size:0.76rem;border-top:1px solid var(--cream-dark);margin-top:30px;}
.footer a{color:var(--taupe);margin:0 8px;text-decoration:underline;}
svg.ico{width:14px;height:14px;flex-shrink:0;stroke:currentColor;fill:none;stroke-width:2;stroke-linecap:round;stroke-linejoin:round;}
.prose{max-width:720px;margin:0 auto;padding:36px 0 70px;}
.prose h1{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:2.2rem;margin-bottom:18px;}
.prose h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.4rem;margin:26px 0 8px;}
.prose p{margin-bottom:12px;color:#5a4f44;}

/* ── Full-bleed overflow carousels (Apple / ui.com style) ── */
.row-head{display:flex;align-items:baseline;justify-content:space-between;gap:16px;margin:40px 0 14px;}
.row-head h2{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.85rem;color:var(--brown);}
.row-head h2 .muted{color:var(--taupe);}
.row-head .viewall{font-size:0.82rem;font-weight:700;color:var(--sage-dark);white-space:nowrap;}
.row-head .viewall:hover{text-decoration:underline;}

.carousel-shell{position:relative;}
/* first card aligns to the content gutter; cards bleed off the right edge */
.carousel{display:flex;gap:18px;overflow-x:auto;scroll-snap-type:x mandatory;
  padding:6px var(--edge) 20px;scroll-padding-left:var(--edge);
  scrollbar-width:none;-ms-overflow-style:none;scroll-behavior:smooth;}
.carousel::-webkit-scrollbar{display:none;}
.carousel > *{scroll-snap-align:start;flex:0 0 auto;}

/* arrow buttons (desktop) */
.carousel-shell .arrow{position:absolute;top:38%;transform:translateY(-50%);z-index:5;width:40px;height:40px;border-radius:50%;border:none;background:rgba(255,255,255,0.92);box-shadow:var(--shadow-lg);color:var(--brown);cursor:pointer;display:none;align-items:center;justify-content:center;transition:background .15s;}
.carousel-shell .arrow:hover{background:#fff;}
.carousel-shell .arrow.left{left:calc(var(--edge) - 20px);}
.carousel-shell .arrow.right{right:calc(var(--edge) - 20px);}
@media(min-width:861px){.carousel-shell:hover .arrow{display:inline-flex;}}

/* big feature card ("new arrivals") */
.feature{width:300px;border-radius:18px;overflow:hidden;background:#fff;box-shadow:var(--shadow);display:flex;flex-direction:column;transition:box-shadow .15s, transform .15s;}
.feature:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px);}
.feature .ftxt{padding:22px 22px 6px;}
.feature .tag{font-size:0.64rem;font-weight:700;letter-spacing:0.09em;text-transform:uppercase;color:var(--gold);}
.feature h3{font-family:'Cormorant Garamond',serif;font-weight:600;font-size:1.42rem;line-height:1.12;margin:6px 0 8px;color:var(--brown);}
.feature p{font-size:0.85rem;color:#5a4f44;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.feature .fimg{margin-top:16px;aspect-ratio:1/1;background:var(--cream-dark);}
.feature .fimg img{width:100%;height:100%;object-fit:cover;}
.feature .fprice{padding:10px 22px 18px;font-weight:700;font-size:0.92rem;color:var(--brown);}

/* product card sized for carousel */
.carousel .card{width:230px;}
