/* ================================================================
   style.css — House of MY Dr. v3  |  Mobile-first responsive
   ================================================================ */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400&display=swap');

:root{
  --bg:hsl(40,20%,98%);
  --fg:hsl(150,20%,10%);
  --card:hsl(0,0%,100%);
  --primary:hsl(152,96%,28%);        /* #038C4C — MY Dr */
  --primary-fg:hsl(0,0%,100%);
  --secondary:hsl(40,30%,95%);
  --secondary-fg:hsl(150,20%,15%);
  --muted:hsl(40,15%,93%);
  --muted-fg:hsl(150,10%,45%);
  --border:hsl(40,15%,88%);
  --danger:hsl(0,70%,50%);
  --radius:.75rem;
  --nav-h:56px;
  /* ── Brand colours (exact hex converted to HSL) ── */
  --brand-mydr:     hsl(152,96%,28%);   /* #038C4C */
  --brand-itchstop: hsl(98,62%,64%);    /* #95DC6C */
  --brand-softwalk: hsl(355,71%,50%);   /* #D92534 */
  --brand-nokas:    hsl(5,83%,46%);     /* #D92414 */
  --brand-orafree:  hsl(11,89%,55%);    /* #F24E29 */
  --brand-swachpet: hsl(110,16%,30%);   /* #445940 */
  --brand-maya:     hsl(0,0%,40%);      /* 60% Grey */
}
@media(min-width:768px){:root{--nav-h:64px;}}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;text-size-adjust:100%;}
body{font-family:'Inter',sans-serif;background:var(--bg);color:var(--fg);-webkit-font-smoothing:antialiased;line-height:1.6;font-size:15px;overflow-x:hidden;}
h1,h2,h3,h4{font-family:'Playfair Display',serif;line-height:1.2;}
a{text-decoration:none;color:inherit;}
img{max-width:100%;height:auto;display:block;}
button{cursor:pointer;border:none;background:none;font-family:inherit;font-size:inherit;-webkit-tap-highlight-color:transparent;}
input,select,textarea{font-family:inherit;font-size:inherit;}

@keyframes fadeUp{from{opacity:0;transform:translateY(32px)}to{opacity:1;transform:translateY(0)}}
@keyframes bounce{0%,100%{transform:translateY(0) translateX(-50%)}50%{transform:translateY(-8px) translateX(-50%)}}
@keyframes slideIn{from{transform:translateX(110%);opacity:0}to{transform:translateX(0);opacity:1}}
@keyframes slideOut{from{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(110%)}}
.animate-fade-up{animation:fadeUp .7s ease-out both;}
.text-gradient-primary{background:linear-gradient(135deg,hsl(152,96%,28%),hsl(152,70%,42%));-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;}

.container{width:100%;max-width:1280px;margin:0 auto;padding:0 1rem;}
@media(min-width:640px){.container{padding:0 1.5rem;}}
@media(min-width:1024px){.container{padding:0 2rem;}}

/* ── Navbar ─────────────────────────────────────────────── */
.navbar{position:fixed;top:0;left:0;right:0;z-index:100;background:hsla(40,20%,98%,.93);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border);height:var(--nav-h);display:flex;align-items:center;}
.navbar-inner{display:flex;align-items:center;justify-content:space-between;height:100%;gap:.5rem;}
.navbar-brand{font-family:'Playfair Display',serif;font-size:clamp(.9rem,2.5vw,1.2rem);font-weight:700;color:var(--primary);white-space:nowrap;flex-shrink:0;max-width:calc(100vw - 140px);overflow:hidden;text-overflow:ellipsis;}
.navbar-links{display:none;align-items:center;gap:clamp(.75rem,1.5vw,1.5rem);}
@media(min-width:1024px){.navbar-links{display:flex;overflow:hidden;}}
.navbar-links a{font-size:.8125rem;font-weight:500;color:var(--muted-fg);transition:color .2s;white-space:nowrap;}
.navbar-links a:hover{color:var(--primary);}
.navbar-right{display:flex;align-items:center;gap:.375rem;flex-shrink:0;}
.cart-btn{position:relative;padding:.4rem .5rem;border-radius:.5rem;color:var(--fg);transition:background .2s;display:flex;-webkit-tap-highlight-color:transparent;}
.cart-btn:hover{background:var(--secondary);}
.cart-btn svg{width:20px;height:20px;}
.cart-count{position:absolute;top:-2px;right:-2px;min-width:17px;height:17px;background:var(--primary);color:#fff;font-size:10px;font-weight:700;border-radius:9999px;display:flex;align-items:center;justify-content:center;padding:0 3px;}
.cart-count.hidden{display:none;}
.hamburger{display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:.5rem;color:var(--fg);}
@media(min-width:1024px){.hamburger{display:none;}}
.mobile-menu{display:none;position:fixed;top:var(--nav-h);left:0;right:0;z-index:99;background:var(--bg);border-bottom:2px solid var(--border);max-height:calc(100vh - var(--nav-h));overflow-y:auto;-webkit-overflow-scrolling:touch;}
.mobile-menu.open{display:block;}
.mobile-menu a{display:flex;align-items:center;padding:.75rem 1rem;font-size:.9375rem;color:var(--fg);border-bottom:1px solid hsl(40,15%,93%);transition:color .15s;}
.mobile-menu a:hover,.mobile-menu a:active{color:var(--primary);background:hsl(145,55%,97%);}

/* ── Buttons ─────────────────────────────────────────────── */
.btn-primary{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:.5rem;background:var(--primary);color:#fff;font-weight:600;font-size:.9375rem;transition:opacity .2s;-webkit-tap-highlight-color:transparent;}
.btn-primary:hover,.btn-primary:active{opacity:.9;}
.btn-outline{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem 1.75rem;border-radius:.5rem;border:1.5px solid var(--border);color:var(--fg);font-weight:600;font-size:.9375rem;background:transparent;transition:background .2s;}
.btn-outline:hover{background:var(--secondary);}
.btn-explore{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:.5rem;background:var(--primary);color:#fff;font-weight:600;font-size:.875rem;transition:opacity .2s;}
.btn-explore:hover,.btn-explore:active{opacity:.9;}
.btn-explore .arrow-icon{width:15px;height:15px;transition:transform .2s;}
.btn-explore:hover .arrow-icon{transform:translateX(4px);}

/* ── Full-Page Scroll ────────────────────────────────────── */
.section-dots{position:fixed;right:.75rem;top:50%;transform:translateY(-50%);z-index:50;display:flex;flex-direction:column;gap:.375rem;}
@media(max-width:400px){.section-dots{right:.25rem;}}
.section-dot{width:8px;height:8px;border-radius:50%;background:rgba(120,120,120,.3);border:none;cursor:pointer;transition:all .4s;-webkit-tap-highlight-color:transparent;}
.section-dot.active{background:var(--primary);transform:scale(1.4);}
.fps-section{position:absolute;top:0;left:0;right:0;bottom:0;width:100%;height:100%;transition:transform .8s cubic-bezier(.76,0,.24,1),opacity .8s cubic-bezier(.76,0,.24,1);will-change:transform,opacity;}
.fps-section.active{transform:translateY(0) scale(1);opacity:1;z-index:20;pointer-events:auto;}
.fps-section.above{transform:translateY(-100%) scale(.95);opacity:0;z-index:10;pointer-events:none;}
.fps-section.below{transform:translateY(100%) scale(1.04);opacity:0;z-index:10;pointer-events:none;}

/* ── Hero ───────────────────────────────────────────────── */
.hero-section{display:flex;align-items:center;justify-content:center;width:100%;height:100%;background:linear-gradient(180deg,hsla(145,55%,30%,.05),var(--bg),var(--bg));overflow:hidden;position:relative;}
.hero-blobs{position:absolute;inset:0;overflow:hidden;pointer-events:none;}
.hero-blob-1{position:absolute;top:20%;left:15%;width:clamp(10rem,25vw,22rem);height:clamp(10rem,25vw,22rem);background:hsla(145,55%,30%,.05);border-radius:50%;filter:blur(60px);}
.hero-blob-2{position:absolute;bottom:20%;right:10%;width:clamp(8rem,20vw,18rem);height:clamp(8rem,20vw,18rem);background:hsla(0,70%,50%,.05);border-radius:50%;filter:blur(60px);}
.hero-content{position:relative;z-index:10;text-align:center;padding:1.5rem 1.25rem;max-width:50rem;margin:0 auto;width:100%;}
.hero-eyebrow{font-size:clamp(.6rem,.8vw,.7rem);font-weight:600;letter-spacing:.25em;text-transform:uppercase;color:var(--primary);margin-bottom:.875rem;animation:fadeUp .8s .2s ease-out both;}
.hero-title{font-size:clamp(1.875rem,7vw,5.5rem);font-weight:700;color:var(--fg);margin-bottom:.875rem;line-height:1.08;animation:fadeUp .8s .4s ease-out both;}
.hero-subtitle{font-size:clamp(.875rem,2vw,1.3rem);color:var(--muted-fg);font-weight:300;margin-bottom:1.75rem;animation:fadeUp .8s .6s ease-out both;}
.hero-actions{display:flex;flex-wrap:wrap;gap:.625rem;justify-content:center;animation:fadeUp .8s .8s ease-out both;}
.scroll-indicator{position:absolute;bottom:1rem;left:50%;animation:bounce 2s infinite;}
.scroll-indicator svg{width:20px;height:20px;color:rgba(120,120,120,.5);}

/* ── Brand sections (fps) ───────────────────────────────── */
.brand-section{display:flex;align-items:center;overflow:hidden;width:100%;height:100%;}
.brand-section-inner{position:relative;height:100%;width:100%;display:flex;align-items:center;overflow:hidden;}
.brand-slice-overlay{position:absolute;inset:0;z-index:10;transform-origin:top;transition:transform .6s cubic-bezier(.76,0,.24,1);transform:scaleY(1);}
.fps-section.active .brand-slice-overlay{transform:scaleY(0);transition-delay:0ms;}
.fps-section:not(.active) .brand-slice-overlay{transform:scaleY(1);transition-delay:200ms;}
.brand-blob{position:absolute;width:clamp(180px,35vw,450px);height:clamp(180px,35vw,450px);border-radius:50%;filter:blur(80px);opacity:.07;pointer-events:none;}
.brand-grid{display:flex;flex-direction:column;align-items:center;gap:1.25rem;padding:0 .75rem;width:100%;}
@media(min-width:768px){.brand-grid{display:grid;grid-template-columns:1fr 1fr;gap:3rem;padding:0;}.brand-grid.reverse{direction:rtl;}.brand-grid.reverse>*{direction:ltr;}}
@media(min-width:1024px){.brand-grid{gap:4.5rem;}}
.logo-card-wrapper{display:flex;justify-content:center;transition:opacity .7s .3s,transform .7s .3s;}
.fps-section:not(.active) .logo-card-wrapper{opacity:0;transform:translateY(40px);}
.fps-section.active .logo-card-wrapper{opacity:1;transform:translateY(0);}
.logo-card{position:relative;background:var(--card);border-radius:1.5rem;padding:clamp(1.25rem,4vw,3.5rem);box-shadow:0 4px 24px rgba(0,0,0,.06);border:1px solid rgba(0,0,0,.05);}
.logo-card-glow{position:absolute;inset:0;border-radius:1.5rem;opacity:.1;filter:blur(32px);}
.logo-card img{width:clamp(100px,18vw,220px);height:auto;object-fit:contain;position:relative;z-index:1;}
.brand-text{text-align:center;padding:0 .25rem;}
@media(min-width:768px){.brand-text{text-align:left;padding:0;}}
.brand-eyebrow,.brand-name,.brand-tagline,.brand-description,.benefits-row,.brand-cta-row{transition:opacity .7s,transform .7s;}
.fps-section:not(.active) .brand-eyebrow,.fps-section:not(.active) .brand-name,.fps-section:not(.active) .brand-tagline,.fps-section:not(.active) .brand-description,.fps-section:not(.active) .benefits-row,.fps-section:not(.active) .brand-cta-row{opacity:0;transform:translateY(20px);}
.fps-section.active .brand-eyebrow{opacity:1;transform:none;transition-delay:.4s;}
.fps-section.active .brand-name{opacity:1;transform:none;transition-delay:.5s;}
.fps-section.active .brand-tagline{opacity:1;transform:none;transition-delay:.6s;}
.fps-section.active .brand-description{opacity:1;transform:none;transition-delay:.7s;}
.fps-section.active .benefits-row{opacity:1;transform:none;transition-delay:.8s;}
.fps-section.active .brand-cta-row{opacity:1;transform:none;transition-delay:.9s;}
.brand-eyebrow{font-size:.63rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-fg);margin-bottom:.4rem;}
.brand-name{font-size:clamp(1.625rem,5vw,3.25rem);font-weight:700;color:var(--fg);margin-bottom:.35rem;}
.brand-tagline{font-size:clamp(.8rem,1.8vw,1rem);color:var(--muted-fg);font-style:italic;margin-bottom:.875rem;}
.brand-description{font-size:clamp(.78rem,1.4vw,.9rem);color:var(--muted-fg);line-height:1.7;margin-bottom:1.25rem;max-width:28rem;margin-left:auto;margin-right:auto;}
@media(min-width:768px){.brand-description{margin-left:0;}}
.benefits-row{display:flex;flex-wrap:wrap;gap:.375rem;justify-content:center;margin-bottom:1rem;}
@media(min-width:768px){.benefits-row{justify-content:flex-start;}}
.benefit-pill{display:inline-flex;align-items:center;gap:.3rem;padding:.3rem .75rem;border-radius:9999px;background:var(--secondary);color:var(--secondary-fg);font-size:.74rem;font-weight:500;}
.benefit-pill svg{width:12px;height:12px;color:var(--primary);flex-shrink:0;}
.section-counter{position:absolute;bottom:.875rem;left:50%;transform:translateX(-50%);font-size:.6rem;font-weight:500;color:rgba(120,120,120,.5);letter-spacing:.2em;}

/* ── Banner Carousel ─────────────────────────────────────── */
.banner-carousel{position:relative;width:100%;overflow:hidden;border-radius:.75rem;background:#eee;}
.banner-carousel{aspect-ratio:3/1;}
@media(max-width:480px){.banner-carousel{aspect-ratio:2/1;border-radius:.5rem;}}
.banner-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1);height:100%;}
.banner-slide{flex:0 0 100%;height:100%;overflow:hidden;position:relative;}
.banner-slide img{width:100%;height:100%;object-fit:cover;}
.banner-slide-text{position:absolute;bottom:0;left:0;right:0;padding:.875rem 1.125rem;background:linear-gradient(transparent,rgba(0,0,0,.55));color:#fff;}
.banner-slide-text h3{font-family:'Playfair Display',serif;font-size:clamp(.8rem,2.5vw,1.375rem);margin-bottom:.15rem;}
.banner-slide-text p{font-size:clamp(.65rem,1.5vw,.8rem);opacity:.85;}
.banner-prev,.banner-next{position:absolute;top:50%;transform:translateY(-50%);width:34px;height:34px;background:rgba(255,255,255,.85);border-radius:50%;display:flex;align-items:center;justify-content:center;z-index:10;border:none;cursor:pointer;}
.banner-prev{left:7px;}.banner-next{right:7px;}
.banner-prev svg,.banner-next svg{width:15px;height:15px;color:#333;}
.banner-dots{position:absolute;bottom:7px;left:50%;transform:translateX(-50%);display:flex;gap:5px;z-index:10;}
.banner-dot{width:6px;height:6px;border-radius:50%;background:rgba(255,255,255,.6);border:none;cursor:pointer;transition:background .2s,transform .2s;}
.banner-dot.active{background:#fff;transform:scale(1.3);}

/* ── Brand Detail Page ───────────────────────────────────── */
.brand-hero{padding-top:var(--nav-h);display:flex;align-items:center;position:relative;overflow:hidden;}
.brand-hero-blob{position:absolute;width:clamp(200px,35vw,450px);height:clamp(200px,35vw,450px);border-radius:50%;filter:blur(100px);opacity:.06;top:10%;right:-5%;pointer-events:none;}
.brand-hero-inner{position:relative;z-index:10;padding:1.75rem 0 2rem;}
.back-link{display:inline-flex;align-items:center;gap:.35rem;font-size:.8rem;color:var(--muted-fg);margin-bottom:1.25rem;transition:color .2s;}
.back-link:hover{color:var(--fg);}
.back-link svg{width:13px;height:13px;}
.brand-hero-layout{display:flex;flex-direction:column;align-items:center;gap:1.75rem;}
@media(min-width:768px){.brand-hero-layout{flex-direction:row;gap:3rem;}}
@media(min-width:1024px){.brand-hero-layout{gap:4rem;}}
.brand-hero-text{flex:1;text-align:center;}
@media(min-width:768px){.brand-hero-text{text-align:left;}}
.brand-hero-logo{flex-shrink:0;}
.brand-page-category{font-size:.63rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--muted-fg);margin-bottom:.5rem;}
.brand-page-name{font-size:clamp(1.625rem,5vw,3.25rem);font-weight:700;color:var(--fg);margin-bottom:.75rem;}
.brand-page-tagline{font-size:clamp(.9rem,2vw,1.175rem);color:var(--muted-fg);font-style:italic;margin-bottom:1.125rem;}
.brand-page-desc{font-size:clamp(.8rem,1.5vw,.9rem);color:var(--muted-fg);line-height:1.75;margin-bottom:1.375rem;max-width:30rem;}
.btn-shop{display:inline-flex;align-items:center;gap:.5rem;padding:.8rem 1.5rem;border-radius:.5rem;background:var(--primary);color:#fff;font-weight:600;font-size:.875rem;transition:opacity .2s;}
.btn-shop:hover,.btn-shop:active{opacity:.9;}

/* ── Product Grid (brand page) ───────────────────────────── */
.products-section{padding:2.5rem 0 3.5rem;}
.section-header{text-align:center;margin-bottom:1.75rem;}
.section-eyebrow{font-size:.68rem;font-weight:700;letter-spacing:.2em;text-transform:uppercase;color:var(--primary);margin-bottom:.5rem;}
.section-title{font-size:clamp(1.375rem,4vw,2.25rem);font-weight:700;color:var(--fg);margin-bottom:.5rem;}
.section-subtitle{font-size:clamp(.78rem,1.5vw,.9rem);color:var(--muted-fg);max-width:36rem;margin:0 auto;}
.product-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.75rem;}
@media(min-width:480px){.product-grid{gap:.875rem;}}
@media(min-width:768px){.product-grid{grid-template-columns:repeat(3,1fr);gap:1rem;}}
@media(min-width:1024px){.product-grid{grid-template-columns:repeat(4,1fr);gap:1.125rem;}}
.product-card{background:var(--card);border-radius:.75rem;border:1px solid rgba(0,0,0,.06);overflow:hidden;display:flex;flex-direction:column;transition:box-shadow .25s;}
.product-card:hover{box-shadow:0 5px 20px rgba(0,0,0,.09);}
.product-card-img{aspect-ratio:1;background:var(--secondary);overflow:hidden;}
.product-card-img img{width:100%;height:100%;object-fit:cover;transition:transform .3s;}
.product-card:hover .product-card-img img{transform:scale(1.04);}
.product-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.68rem;color:var(--muted-fg);}
.product-card-body{padding:.625rem .75rem;flex:1;display:flex;flex-direction:column;}
.product-card-brand{font-size:.62rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.07em;margin-bottom:.15rem;}
.product-card-name{font-family:'Playfair Display',serif;font-size:clamp(.78rem,1.4vw,.875rem);font-weight:600;color:var(--fg);margin-bottom:.15rem;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.product-card-desc{font-size:.7rem;color:var(--muted-fg);line-height:1.4;margin-bottom:.5rem;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;}
.product-card-footer{display:flex;align-items:center;justify-content:space-between;gap:.25rem;margin-top:auto;}
.product-card-price{font-weight:700;font-size:clamp(.8rem,1.4vw,.9375rem);color:var(--fg);}
.btn-add-card{padding:.35rem .625rem;font-size:.68rem;font-weight:600;border-radius:.375rem;background:var(--primary);color:#fff;white-space:nowrap;transition:opacity .2s;-webkit-tap-highlight-color:transparent;}
.btn-add-card:hover,.btn-add-card:active{opacity:.9;}

/* ── Amazon Product Page ─────────────────────────────────── */
.product-page{padding-top:var(--nav-h);}
.product-breadcrumb{display:flex;align-items:center;gap:.35rem;font-size:.74rem;color:var(--muted-fg);padding:.875rem 0 0;flex-wrap:wrap;}
.product-breadcrumb a{color:var(--primary);}
.amz-layout{display:grid;grid-template-columns:1fr;gap:1.25rem;padding-bottom:2.5rem;}
@media(min-width:600px){.amz-layout{grid-template-columns:1fr 1fr;gap:1.75rem;align-items:start;}}
@media(min-width:1024px){.amz-layout{grid-template-columns:3fr 2fr;gap:2.5rem;}}
.amz-gallery{position:relative;}
@media(min-width:600px){.amz-gallery{display:grid;grid-template-columns:68px 1fr;gap:.5rem;align-items:start;}}
.amz-thumbs{display:flex;flex-direction:row;gap:.375rem;overflow-x:auto;padding-bottom:.25rem;order:2;-webkit-overflow-scrolling:touch;}
@media(min-width:600px){.amz-thumbs{flex-direction:column;order:0;overflow-x:visible;overflow-y:auto;max-height:460px;}}
.amz-thumb{width:60px;height:60px;flex-shrink:0;border-radius:.375rem;border:2px solid var(--border);cursor:pointer;background:#f8f8f8;padding:3px;transition:border-color .15s;}
.amz-thumb.active,.amz-thumb:hover{border-color:var(--primary);}
.amz-thumb img{width:100%;height:100%;object-fit:contain;}
.amz-main-wrap{border-radius:.75rem;overflow:hidden;border:1px solid var(--border);background:#f8f8f8;aspect-ratio:1;order:1;}
.amz-main-wrap img{width:100%;height:100%;object-fit:contain;padding:.5rem;display:block;transition:opacity .2s;}
.amz-img-count{position:absolute;bottom:.5rem;right:.5rem;background:rgba(0,0,0,.55);color:#fff;font-size:.68rem;font-weight:600;padding:.2rem .5rem;border-radius:9999px;}
.amz-no-img{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:.8rem;color:var(--muted-fg);flex-direction:column;gap:.5rem;}
.amz-info{}
.amz-info-brand{font-size:.68rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.08em;margin-bottom:.35rem;}
.amz-info-brand a{color:var(--primary);}
.amz-info-name{font-family:'Playfair Display',serif;font-size:clamp(1.075rem,2.8vw,1.625rem);font-weight:700;color:var(--fg);margin-bottom:.5rem;line-height:1.2;}
.amz-rating{display:flex;align-items:center;gap:.35rem;margin-bottom:.75rem;flex-wrap:wrap;}
.amz-stars{color:hsl(38,90%,50%);font-size:.875rem;letter-spacing:1px;}
.amz-rating-text{font-size:.76rem;color:var(--muted-fg);}
.amz-divider{height:1px;background:var(--border);margin:.625rem 0;}
.amz-price-box{background:hsl(40,30%,97%);border-radius:.625rem;padding:.75rem .875rem;margin-bottom:.75rem;border:1px solid var(--border);}
.amz-price{font-size:clamp(1.5rem,4vw,1.875rem);font-weight:700;color:var(--fg);line-height:1;}
.amz-price-note{font-size:.7rem;color:var(--muted-fg);margin-top:.2rem;}
.amz-qty-row{display:flex;align-items:center;gap:.625rem;margin-bottom:.75rem;}
.amz-qty-label{font-size:.8rem;font-weight:600;color:var(--fg);}
.amz-qty-ctrl{display:flex;align-items:center;border:1px solid var(--border);border-radius:.5rem;overflow:hidden;}
.amz-qty-ctrl button{padding:.45rem .7rem;font-size:1rem;font-weight:600;color:var(--fg);transition:background .15s;min-width:36px;}
.amz-qty-ctrl button:hover{background:var(--secondary);}
.amz-qty-ctrl input{width:40px;text-align:center;font-size:.9rem;font-weight:700;border:none;outline:none;background:transparent;color:var(--fg);}
.amz-actions{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;}
.btn-add-to-cart{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.25rem;border-radius:.5rem;background:hsl(38,90%,50%);color:#fff;font-size:.9rem;font-weight:700;transition:background .2s;border:none;cursor:pointer;width:100%;-webkit-tap-highlight-color:transparent;}
.btn-add-to-cart:hover,.btn-add-to-cart:active{background:hsl(38,90%,42%);}
.btn-buy-now{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.8rem 1.25rem;border-radius:.5rem;background:var(--primary);color:#fff;font-size:.9rem;font-weight:700;transition:opacity .2s;border:none;cursor:pointer;width:100%;-webkit-tap-highlight-color:transparent;}
.btn-buy-now:hover,.btn-buy-now:active{opacity:.9;}
.amz-features{border:1px solid var(--border);border-radius:.625rem;overflow:hidden;margin-top:.75rem;}
.amz-feature-row{display:flex;align-items:flex-start;gap:.5rem;padding:.5rem .75rem;font-size:.76rem;border-bottom:1px solid hsl(40,15%,94%);}
.amz-feature-row:last-child{border-bottom:none;}
.amz-feature-row svg{width:12px;height:12px;color:var(--primary);flex-shrink:0;margin-top:2px;}
.amz-feature-label{font-weight:600;color:var(--fg);min-width:76px;font-size:.75rem;}
.amz-feature-val{color:var(--muted-fg);}
.amz-desc-section{margin-top:1.125rem;}
.amz-desc-section h4{font-size:.9rem;font-weight:700;color:var(--fg);margin-bottom:.5rem;border-bottom:2px solid var(--primary);padding-bottom:.3rem;display:inline-block;}
.amz-desc-section p{font-size:.84rem;color:var(--muted-fg);line-height:1.75;}

/* ── A+ Content ──────────────────────────────────────────── */
.aplus-section{padding:2rem 0;}
.aplus-section+.aplus-section{padding-top:0;}
.aplus-banner{width:100%;border-radius:.75rem;overflow:hidden;}
.aplus-banner img{width:100%;height:auto;display:block;}
.aplus-text-image{display:grid;grid-template-columns:1fr;gap:1.375rem;align-items:center;}
@media(min-width:600px){.aplus-text-image{grid-template-columns:1fr 1fr;gap:2.25rem;}}
.aplus-text-image.reverse>*:first-child{order:2;}
.aplus-text-image.reverse>*:last-child{order:1;}
@media(min-width:600px){.aplus-text-image.reverse>*:first-child{order:2;}.aplus-text-image.reverse>*:last-child{order:1;}}
.aplus-text-image img{width:100%;border-radius:.625rem;object-fit:cover;}
.aplus-text h2{font-size:clamp(1.125rem,3vw,1.75rem);font-weight:700;color:var(--fg);margin-bottom:.75rem;}
.aplus-text p{font-size:clamp(.78rem,1.4vw,.9rem);color:var(--muted-fg);line-height:1.8;}
.aplus-text ul{font-size:clamp(.78rem,1.4vw,.9rem);color:var(--muted-fg);line-height:1.8;padding-left:1.125rem;}
.aplus-text ul li{margin-bottom:.3rem;}
.aplus-video{width:100%;border-radius:.75rem;overflow:hidden;aspect-ratio:16/9;}
.aplus-video iframe,.aplus-video video{width:100%;height:100%;border:none;display:block;}
.aplus-custom{font-size:clamp(.78rem,1.4vw,.875rem);color:var(--muted-fg);line-height:1.8;}
.aplus-custom img{max-width:100%;border-radius:.5rem;margin:.5rem 0;}
.aplus-divider-line{height:2px;background:linear-gradient(to right,transparent,var(--border),transparent);margin:1.75rem 0;}

/* ── Reviews ─────────────────────────────────────────────── */
.reviews-section{padding:2rem 0 3rem;}
.reviews-summary{display:flex;flex-direction:column;gap:1.25rem;margin-bottom:1.75rem;}
@media(min-width:600px){.reviews-summary{flex-direction:row;align-items:flex-start;gap:2.25rem;}}
.reviews-overall{text-align:center;flex-shrink:0;min-width:120px;}
.reviews-big-score{font-size:3rem;font-weight:700;color:var(--fg);line-height:1;}
.reviews-big-stars{font-size:1.375rem;color:hsl(38,90%,50%);margin:.2rem 0;}
.reviews-count{font-size:.78rem;color:var(--muted-fg);}
.reviews-bars{flex:1;}
.review-bar-row{display:flex;align-items:center;gap:.5rem;margin-bottom:.3rem;font-size:.78rem;color:var(--muted-fg);}
.review-bar-label{min-width:28px;text-align:right;font-weight:500;}
.review-bar-track{flex:1;height:7px;background:var(--muted);border-radius:4px;overflow:hidden;}
.review-bar-fill{height:100%;background:hsl(38,90%,50%);border-radius:4px;}
.review-bar-count{min-width:22px;font-weight:500;}
.reviews-list{display:flex;flex-direction:column;gap:.875rem;}
.review-card{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:.875rem 1rem;}
.review-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem;margin-bottom:.375rem;flex-wrap:wrap;}
.review-card-name{font-weight:700;font-size:.9rem;color:var(--fg);}
.review-card-date{font-size:.72rem;color:var(--muted-fg);}
.review-card-stars{color:hsl(38,90%,50%);font-size:.875rem;margin-bottom:.2rem;}
.review-verified{display:inline-flex;align-items:center;gap:.225rem;font-size:.68rem;font-weight:600;color:hsl(145,55%,35%);margin-bottom:.3rem;}
.review-verified svg{width:10px;height:10px;}
.review-card-title{font-weight:700;font-size:.9rem;color:var(--fg);margin-bottom:.2rem;}
.review-card-body{font-size:.84rem;color:var(--muted-fg);line-height:1.65;}
.review-write-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.375rem;border-radius:.5rem;background:var(--primary);color:#fff;font-weight:600;font-size:.875rem;margin-bottom:1.25rem;border:none;cursor:pointer;transition:opacity .2s;-webkit-tap-highlight-color:transparent;}
.review-write-btn:hover{opacity:.9;}
.review-form-card{background:var(--card);border:1px solid var(--border);border-radius:.75rem;padding:1.125rem;margin-bottom:1.5rem;display:none;}
.review-form-card.open{display:block;}
.star-select{display:flex;gap:.2rem;margin-bottom:.875rem;}
.star-select span{font-size:1.75rem;color:var(--border);transition:color .1s;cursor:pointer;line-height:1;user-select:none;-webkit-user-select:none;}
.star-select span.lit{color:hsl(38,90%,50%);}
.form-group{display:flex;flex-direction:column;gap:.25rem;margin-bottom:.75rem;}
.form-label{font-size:.8rem;font-weight:600;color:var(--fg);}
.form-input,.form-textarea{width:100%;padding:.55rem .7rem;border:1px solid var(--border);border-radius:.5rem;font-size:.875rem;font-family:inherit;color:var(--fg);background:#fff;transition:border-color .15s;}
.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px hsla(145,55%,30%,.1);}
.form-textarea{resize:vertical;min-height:80px;}

/* ── Cart ───────────────────────────────────────────────── */
.cart-page{padding-top:var(--nav-h);padding-bottom:2.5rem;}
.cart-layout{display:grid;grid-template-columns:1fr;gap:1.125rem;}
@media(min-width:768px){.cart-layout{grid-template-columns:1fr 300px;align-items:start;}}
.cart-items-card{background:var(--card);border-radius:.75rem;border:1px solid var(--border);overflow:hidden;}
.cart-header{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-weight:700;font-size:.9rem;}
.cart-item{display:flex;gap:.75rem;padding:.75rem 1rem;border-bottom:1px solid hsl(40,15%,94%);align-items:flex-start;}
.cart-item:last-child{border-bottom:none;}
.cart-item-img{width:68px;height:68px;flex-shrink:0;border-radius:.5rem;overflow:hidden;background:var(--secondary);}
.cart-item-img img{width:100%;height:100%;object-fit:contain;padding:3px;}
.cart-item-info{flex:1;min-width:0;}
.cart-item-brand{font-size:.62rem;font-weight:700;color:var(--primary);text-transform:uppercase;letter-spacing:.06em;}
.cart-item-name{font-weight:600;font-size:.84rem;color:var(--fg);margin-bottom:.15rem;line-height:1.3;}
.cart-item-price{font-size:.76rem;color:var(--muted-fg);}
.cart-item-right{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0;}
.cart-item-total{font-weight:700;font-size:.9rem;}
.cart-remove{font-size:.7rem;color:var(--danger);cursor:pointer;}
.cart-remove:hover{text-decoration:underline;}
.cart-qty{display:flex;align-items:center;border:1px solid var(--border);border-radius:.375rem;overflow:hidden;}
.cart-qty button{padding:.275rem .5rem;font-size:.875rem;font-weight:600;color:var(--fg);transition:background .15s;min-width:28px;}
.cart-qty button:hover{background:var(--secondary);}
.cart-qty input{width:30px;text-align:center;font-size:.8rem;font-weight:700;border:none;outline:none;background:transparent;color:var(--fg);}
.cart-empty{text-align:center;padding:2.5rem 1rem;}
.cart-empty h2{font-size:1.25rem;margin-bottom:.75rem;}
.cart-empty p{color:var(--muted-fg);margin-bottom:1rem;font-size:.875rem;}
.order-summary-card{background:var(--card);border-radius:.75rem;border:1px solid var(--border);padding:1rem;position:sticky;top:calc(var(--nav-h) + .625rem);}
.order-summary-card h3{font-size:.9rem;font-weight:700;margin-bottom:.75rem;}
.summary-row{display:flex;justify-content:space-between;font-size:.84rem;margin-bottom:.35rem;}
.summary-row.discount{color:hsl(145,55%,35%);}
.summary-divider{height:1px;background:var(--border);margin:.5rem 0;}
.summary-total{display:flex;justify-content:space-between;font-weight:700;font-size:1rem;}
.coupon-row{margin-top:.75rem;}
.coupon-label{font-size:.78rem;font-weight:600;color:var(--fg);margin-bottom:.3rem;}
.coupon-input-row{display:flex;gap:.35rem;}
.coupon-input{flex:1;padding:.5rem .625rem;border:1px solid var(--border);border-radius:.5rem;font-size:.8rem;font-family:inherit;color:var(--fg);-webkit-appearance:none;}
.coupon-input:focus{outline:none;border-color:var(--primary);}
.btn-apply{padding:.5rem .8rem;font-size:.78rem;font-weight:600;border-radius:.5rem;background:var(--primary);color:#fff;white-space:nowrap;}
.coupon-msg{font-size:.72rem;margin-top:.3rem;padding:.275rem .55rem;border-radius:.375rem;}
.coupon-msg.ok{background:hsl(145,55%,93%);color:hsl(145,55%,25%);}
.coupon-msg.err{background:hsl(0,70%,94%);color:hsl(0,60%,35%);}

/* ── Checkout ─────────────────────────────────────────────── */
.checkout-page{padding-top:var(--nav-h);padding-bottom:2.5rem;}
.checkout-layout{display:grid;grid-template-columns:1fr;gap:1.125rem;}
@media(min-width:768px){.checkout-layout{grid-template-columns:1fr 320px;align-items:start;}}
.checkout-form-card{background:var(--card);border-radius:.75rem;border:1px solid var(--border);}
.checkout-form-header{padding:.75rem 1rem;border-bottom:1px solid var(--border);font-weight:700;font-size:.9rem;}
.checkout-form-body{padding:1rem;}
.form-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;}
@media(max-width:440px){.form-grid-2{grid-template-columns:1fr;}}
.form-select{width:100%;padding:.55rem .7rem;border:1px solid var(--border);border-radius:.5rem;font-size:.875rem;font-family:inherit;color:var(--fg);background:#fff;appearance:none;-webkit-appearance:none;}
.pay-btn{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.875rem;border-radius:.625rem;background:var(--primary);color:#fff;font-size:.9375rem;font-weight:700;transition:background .2s;border:none;cursor:pointer;margin-top:.875rem;-webkit-tap-highlight-color:transparent;}
.pay-btn:hover{background:hsl(145,55%,24%);}
.pay-btn:disabled{opacity:.6;cursor:not-allowed;}
.secure-note{display:flex;align-items:center;justify-content:center;gap:.35rem;font-size:.72rem;color:var(--muted-fg);margin-top:.5rem;}
.secure-note svg{width:12px;height:12px;}

/* ── Order success ───────────────────────────────────────── */
.success-page{padding-top:var(--nav-h);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:calc(var(--nav-h) + .875rem) 1rem 2.5rem;}
.success-card{background:var(--card);border-radius:1.125rem;border:1px solid var(--border);padding:clamp(1.375rem,5vw,2.75rem) clamp(1rem,4vw,2rem);max-width:500px;width:100%;text-align:center;box-shadow:0 6px 32px rgba(0,0,0,.07);}
.success-icon{width:68px;height:68px;background:hsl(145,55%,92%);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1.125rem;}
.success-icon svg{width:34px;height:34px;color:var(--primary);}
.success-card h1{font-size:clamp(1.25rem,4vw,1.625rem);font-weight:700;margin-bottom:.5rem;}
.success-card p{color:var(--muted-fg);font-size:.84rem;margin-bottom:.35rem;}
.order-num-badge{display:inline-block;padding:.3rem .8rem;background:var(--primary);color:#fff;border-radius:9999px;font-weight:700;font-size:.84rem;margin:.75rem 0;}
.success-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-top:1.375rem;}

/* ── Footer ──────────────────────────────────────────────── */
.site-footer{background:var(--fg);color:var(--bg);padding:2.5rem 0 0;}
.footer-grid{display:grid;grid-template-columns:1fr;gap:1.75rem;margin-bottom:1.75rem;}
@media(min-width:640px){.footer-grid{grid-template-columns:1fr 1fr;}}
@media(min-width:1024px){.footer-grid{grid-template-columns:1fr 1fr 1fr;}}
.footer-brand-name{font-family:'Playfair Display',serif;font-size:1.25rem;font-weight:700;margin-bottom:.75rem;}
.footer-tagline{font-size:.84rem;color:rgba(255,255,255,.5);line-height:1.7;}
.footer-heading{font-size:.68rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;color:rgba(255,255,255,.7);margin-bottom:.75rem;}
.footer-links{display:grid;grid-template-columns:1fr 1fr;gap:.3rem;}
.footer-links a,.footer-col a{font-size:.84rem;color:rgba(255,255,255,.4);transition:color .2s;display:block;padding:.125rem 0;}
.footer-links a:hover,.footer-col a:hover{color:rgba(255,255,255,1);}
.footer-col{display:flex;flex-direction:column;gap:.3rem;}
.footer-bottom{border-top:1px solid rgba(255,255,255,.08);padding:1.375rem 0;text-align:center;font-size:.78rem;color:rgba(255,255,255,.3);}

/* ── Toast ───────────────────────────────────────────────── */
.toast-container{position:fixed;bottom:1rem;right:.875rem;z-index:9999;display:flex;flex-direction:column;gap:.4rem;pointer-events:none;max-width:calc(100vw - 1.75rem);}
@media(max-width:440px){.toast-container{left:.875rem;right:.875rem;bottom:.875rem;}}
.toast{padding:.7rem .95rem;border-radius:.5rem;background:var(--fg);color:var(--bg);font-size:.84rem;font-weight:500;box-shadow:0 4px 20px rgba(0,0,0,.15);animation:slideIn .4s ease-out both;pointer-events:auto;word-break:break-word;}
.toast.success{background:var(--primary);}
.toast.error{background:hsl(0,70%,50%);}
.toast.hide{animation:slideOut .3s ease-in forwards;}

/* ── Not found ───────────────────────────────────────────── */
.not-found{min-height:calc(100vh - var(--nav-h));display:flex;align-items:center;justify-content:center;text-align:center;padding:2rem;}
.not-found h1{font-size:clamp(1.5rem,5vw,2.75rem);margin-bottom:.75rem;}
.not-found p{color:var(--muted-fg);margin-bottom:1.125rem;font-size:.9rem;}
