/* =========================================================================
   Charmies — design system + components
   Warm pink-cream palette, navy primary, playful rounded e-commerce.
   ========================================================================= */

:root{
  --radius:1rem;
  --radius-sm:calc(var(--radius) - 4px);
  --radius-md:calc(var(--radius) - 2px);
  --radius-lg:var(--radius);
  --radius-xl:calc(var(--radius) + 4px);
  --radius-2xl:calc(var(--radius) + 8px);
  --radius-3xl:calc(var(--radius) + 12px);

  --font-display:"Bagel Fat One","Cairo",system-ui,sans-serif;
  --font-body:"Inter","Cairo",system-ui,sans-serif;
  --font-arabic:"Cairo",system-ui,sans-serif;

  --background:oklch(0.985 0.012 20);
  --foreground:oklch(0.22 0.03 340);
  --card:oklch(1 0 0);
  --card-foreground:oklch(0.22 0.03 340);
  --popover:oklch(1 0 0);
  --popover-foreground:oklch(0.22 0.03 340);
  --primary:oklch(0.24 0.05 270);
  --primary-foreground:oklch(0.985 0.005 60);
  --secondary:oklch(0.955 0.025 10);
  --secondary-foreground:oklch(0.22 0.03 340);
  --muted:oklch(0.965 0.012 20);
  --muted-foreground:oklch(0.5 0.025 340);
  --accent:oklch(0.92 0.06 5);
  --accent-foreground:oklch(0.25 0.04 340);
  --destructive:oklch(0.6 0.22 25);
  --destructive-foreground:oklch(0.985 0 0);
  --border:oklch(0.92 0.015 20);
  --input:oklch(0.92 0.015 20);
  --ring:oklch(0.78 0.08 5);
  --rose-soft:oklch(0.9 0.06 10);
  --rose-deep:oklch(0.72 0.13 5);
  --blush:oklch(0.94 0.04 15);
  --success:oklch(0.62 0.14 160);

  --shadow-sm:0 1px 2px -1px color-mix(in oklab,var(--primary) 16%,transparent);
  --shadow:0 4px 14px -6px color-mix(in oklab,var(--primary) 18%,transparent);
  --shadow-lg:0 16px 40px -16px color-mix(in oklab,var(--primary) 26%,transparent);
  --shadow-elegant:0 10px 30px -10px color-mix(in oklab,oklch(0.24 0.05 270) 30%,transparent);

  --container:1200px;
}

.dark,[data-theme="dark"]{
  --background:oklch(0.18 0.02 340);
  --foreground:oklch(0.97 0.01 20);
  --card:oklch(0.22 0.03 340);
  --card-foreground:oklch(0.97 0.01 20);
  --popover:oklch(0.22 0.03 340);
  --primary:oklch(0.97 0.01 20);
  --primary-foreground:oklch(0.22 0.03 340);
  --secondary:oklch(0.28 0.03 340);
  --muted:oklch(0.28 0.03 340);
  --muted-foreground:oklch(0.7 0.02 340);
  --accent:oklch(0.32 0.05 5);
  --border:oklch(1 0 0 / 10%);
  --input:oklch(1 0 0 / 15%);
  --ring:oklch(0.6 0.08 5);
}

/* ----- reset / base -------------------------------------------------------- */
*,*::before,*::after{box-sizing:border-box}
*{border-color:var(--border)}
html{-webkit-text-size-adjust:100%;text-size-adjust:100%}
html,body{margin:0;overflow-x:clip}
body{
  background:var(--background);
  color:var(--foreground);
  font-family:var(--font-body);
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
  -webkit-tap-highlight-color:transparent;
}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
input,select,textarea{font-size:16px;font-family:inherit}
.icon{display:inline-block;vertical-align:middle;flex:none}

h1,h2,h3{font-family:var(--font-display);letter-spacing:-0.01em;text-wrap:balance;line-height:1.1;font-weight:400}
.cm-rtl body,.cm-lang-ar body{font-family:var(--font-arabic)}
/* live site keeps the -0.01em tracking on Arabic headings too */
.cm-rtl h1,.cm-rtl h2,.cm-rtl h3{font-family:var(--font-arabic);font-weight:800}

.container{width:100%;max-width:var(--container);margin-inline:auto;padding-inline:1.25rem}
.section{padding-block:3.5rem}
.display{font-family:var(--font-display)}
.cm-rtl .display{font-family:var(--font-arabic);font-weight:800}
.muted{color:var(--muted-foreground)}

/* ----- buttons ------------------------------------------------------------- */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.8rem 1.5rem;border-radius:999px;font-weight:500;font-size:1rem;
  border:1px solid transparent;cursor:pointer;transition:transform .15s ease,box-shadow .2s ease,background .2s ease,opacity .2s;
  line-height:1.5;white-space:nowrap;
}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn[disabled],.btn.is-disabled{opacity:.5;cursor:not-allowed;transform:none}
.btn-primary{background:var(--primary);color:var(--primary-foreground);box-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1)}
.btn-primary:hover{box-shadow:var(--shadow)}
.btn-outline{background:transparent;color:var(--foreground);border-color:var(--border)}
.btn-outline:hover{background:var(--secondary)}
.btn-rose{background:var(--rose-deep);color:#fff}
.btn-block{width:100%}
.btn-lg{padding:.95rem 1.8rem;font-size:1.02rem}

/* ----- promo banner -------------------------------------------------------- */
.cm-promo{background:var(--primary);color:var(--primary-foreground);font-size:.82rem;text-align:center;letter-spacing:.01em}
.cm-promo .container{padding-block:.5rem}

/* ----- nav ----------------------------------------------------------------- */
.cm-nav{position:sticky;top:0;z-index:50;background:color-mix(in oklab,var(--background) 85%,transparent);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid color-mix(in oklab,var(--border) 60%,transparent);transition:border-color .2s,box-shadow .2s}
.cm-nav.is-scrolled{border-color:var(--border);box-shadow:var(--shadow-sm)}
.cm-nav__inner{display:flex;align-items:center;gap:1rem;height:68px}
.cm-logo{font-family:var(--font-display);font-size:1.6rem;color:var(--primary);line-height:1}
.cm-logo--lg{font-size:2.2rem}
.cm-nav__links{display:flex;gap:1.6rem;margin-inline:auto;font-weight:500}
.cm-nav__links a{color:var(--foreground);position:relative;padding-block:.25rem;transition:color .2s}
.cm-nav__links a:hover,.cm-nav__links a.is-active{color:var(--rose-deep)}
.cm-nav__links a.is-active::after{content:"";position:absolute;inset-inline:0;bottom:-2px;height:2px;border-radius:2px;background:var(--rose-deep)}
.cm-nav__right{display:flex;align-items:center;gap:.5rem}
.cm-lang-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:38px;height:38px;border-radius:999px;border:1px solid var(--border);font-weight:700;font-size:.85rem;color:var(--foreground);transition:background .2s;font-family:var(--font-arabic)}
.cm-lang-toggle:hover{background:var(--secondary)}
.cm-icon-btn{position:relative;display:inline-flex;align-items:center;justify-content:center;width:42px;height:42px;border-radius:999px;color:var(--foreground);transition:background .2s}
.cm-icon-btn:hover{background:var(--secondary)}
.cm-cart-count{position:absolute;top:2px;inset-inline-end:2px;min-width:18px;height:18px;padding:0 5px;border-radius:999px;background:var(--destructive);color:#fff;font-size:.68rem;font-weight:700;display:none;align-items:center;justify-content:center;line-height:1}
.cm-cart-count.is-on{display:flex}
.cm-nav__burger{display:none;flex-direction:column;gap:4px;width:42px;height:42px;border:none;background:transparent;cursor:pointer;align-items:center;justify-content:center}
.cm-nav__burger span{width:20px;height:2px;background:var(--foreground);border-radius:2px;transition:.25s}
.cm-nav.is-open .cm-nav__burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
.cm-nav.is-open .cm-nav__burger span:nth-child(2){opacity:0}
.cm-nav.is-open .cm-nav__burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
.cm-mobile{display:none;flex-direction:column;padding:1rem 1.25rem 1.5rem;gap:.25rem;border-top:1px solid var(--border);background:var(--background)}
.cm-mobile a{padding:.85rem .5rem;font-size:1.1rem;font-weight:600;border-radius:var(--radius-md)}
.cm-mobile a:hover{background:var(--secondary)}
.cm-mobile__lang{color:var(--rose-deep)}
.cm-nav.is-open .cm-mobile{display:flex}

/* ----- hero ---------------------------------------------------------------- */
.cm-hero{background:linear-gradient(160deg,var(--blush),var(--background) 55%,var(--accent));overflow:hidden}
.cm-hero__inner{display:grid;grid-template-columns:1.05fr .95fr;gap:2.5rem;align-items:center;padding-block:3.5rem 4rem}
.cm-hero__title{font-size:clamp(2.4rem,6vw,4.5rem);line-height:1.05;color:var(--primary);margin:0 0 1.5rem}
.cm-hero__sub{font-size:1.12rem;color:var(--muted-foreground);max-width:42ch;margin:0 0 1.8rem}
.cm-hero__cta{display:flex;gap:.8rem;flex-wrap:wrap}
.cm-hero__media{position:relative}
.cm-hero__media::before{content:"";position:absolute;inset:8% 6%;background:var(--rose-soft);filter:blur(48px);opacity:.6;border-radius:50%;z-index:0}
.cm-hero__media img{position:relative;z-index:1;width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:2rem;box-shadow:var(--shadow-lg)}

/* ----- section heads ------------------------------------------------------- */
.cm-sechead{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.6rem;gap:1rem}
.cm-sechead h2{font-size:clamp(1.6rem,3vw,2.25rem);line-height:1.12;color:var(--foreground);margin:0}
.cm-eyebrow{text-transform:uppercase;letter-spacing:.18em;font-size:.72rem;font-weight:700;color:var(--rose-deep)}

/* ----- product grid + cards (WooCommerce loop) ----------------------------- */
ul.products,.woocommerce ul.products{list-style:none;margin:0;padding:0;display:grid;gap:1.4rem;grid-template-columns:repeat(2,1fr);float:none}
/* WooCommerce's clearfix ::before/::after become stray grid items — remove them */
ul.products::before,ul.products::after,.woocommerce ul.products::before,.woocommerce ul.products::after{display:none}
@media(min-width:768px){ul.products,.woocommerce ul.products{grid-template-columns:repeat(3,1fr)}}
@media(min-width:1024px){ul.products,.woocommerce ul.products{grid-template-columns:repeat(4,1fr)}}
.woocommerce ul.products li.product,
ul.products li.product{width:auto;margin:0;float:none}
ul.products li.product{
  background:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);
  padding:.9rem;display:flex;flex-direction:column;gap:.45rem;text-align:center;
  box-shadow:var(--shadow-sm);transition:box-shadow .25s,transform .2s;position:relative;overflow:hidden;
}
ul.products li.product:hover{box-shadow:var(--shadow-lg);transform:translateY(-3px)}
ul.products li.product a.woocommerce-LoopProduct-link{display:block}
ul.products li.product img{width:100%;aspect-ratio:1/1;object-fit:cover;border-radius:var(--radius-xl);background:#f1efed;transition:transform .35s}
ul.products li.product:hover img{transform:scale(1.05)}
.woocommerce-loop-product__title{font-family:var(--font-body);font-size:1.05rem;font-weight:700;margin:.3rem 0 0;color:var(--foreground);padding:0}
.cm-rtl .woocommerce-loop-product__title{font-family:var(--font-arabic)}
.cm-card-price,ul.products li.product .price{color:var(--muted-foreground);font-weight:600;font-size:.95rem;margin:0}
.cm-card-price .price,.cm-card-price bdi{color:var(--rose-deep);font-weight:700}
.cm-from{color:var(--muted-foreground);font-weight:500;font-size:.9rem}
ul.products li.product .price del{color:var(--muted-foreground);font-weight:500;opacity:.7;margin-inline-end:.4rem}
.cm-card-cta{margin-top:.5rem;width:100%;font-size:.9rem;padding:.7rem 1rem}
.cm-swatches{display:flex;gap:.4rem;align-items:center;justify-content:center;flex-wrap:wrap;margin:.25rem 0}
.cm-swatch{width:20px;height:20px;border-radius:999px;background:var(--sw);box-shadow:0 0 0 1px color-mix(in oklab,var(--foreground) 14%,transparent) inset;display:inline-block;transition:transform .15s}
.cm-swatch.is-active{box-shadow:0 0 0 2px var(--background),0 0 0 3px var(--primary)}

/* shop title band */
.cm-shop-title{background:linear-gradient(160deg,var(--blush),var(--background) 60%,var(--accent));padding-block:2.4rem}
.cm-shop-title h1{font-size:clamp(2rem,4vw,2.8rem);color:var(--primary);margin:0}

/* ----- single product ------------------------------------------------------ */
.cm-product{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;padding-block:2.4rem}
.cm-product__gallery .cm-main-img{width:100%;aspect-ratio:4/5;object-fit:cover;border-radius:var(--radius-3xl);background:#f1efed}
.cm-thumbs{display:flex;gap:.5rem;margin-top:.7rem;overflow-x:auto}
.cm-thumbs img{width:72px;height:72px;border-radius:var(--radius-md);object-fit:cover;cursor:pointer;border:2px solid transparent;opacity:.7;flex:none}
.cm-thumbs img.is-active{border-color:var(--primary);opacity:1}
.cm-product__title{font-size:clamp(1.8rem,4vw,2.6rem);color:var(--primary);margin:0 0 .5rem}
.cm-rating{display:flex;align-items:center;gap:.4rem;color:var(--rose-deep);font-size:.9rem;margin-bottom:.6rem}
.cm-rating .stars{display:inline-flex;gap:1px}
.cm-rating .icon-star{fill:currentColor}
.cm-product__price{font-size:1.5rem;font-weight:700;color:var(--foreground);margin:.3rem 0 1rem}
.cm-viewer{display:inline-flex;align-items:center;gap:.45rem;background:color-mix(in oklab,var(--rose-soft) 35%,transparent);color:var(--rose-deep);font-size:.82rem;font-weight:600;padding:.4rem .8rem;border-radius:999px;margin-bottom:1.2rem}
.cm-field{margin-bottom:1.2rem}
.cm-field__label{font-weight:600;font-size:.9rem;margin-bottom:.5rem;display:block}
/* bundle slot color picker — circular charm-image swatches */
.cm-colorpick{display:flex;gap:.5rem;flex-wrap:wrap}
.cm-colorpick button{width:60px;height:60px;border-radius:999px;border:none;background:var(--c,#f1efed);cursor:pointer;position:relative;overflow:hidden;padding:0;transition:transform .15s,box-shadow .15s}
.cm-colorpick button img{width:100%;height:100%;object-fit:contain;padding:5px;display:block}
.cm-colorpick button:hover{transform:scale(1.06)}
.cm-colorpick button.is-active{box-shadow:0 0 0 2px var(--background),0 0 0 4px var(--primary)}
.cm-colorpick button.is-active::after{content:"";position:absolute;inset:0;background:color-mix(in oklab,var(--primary) 78%,transparent);border-radius:999px}
.cm-colorpick button.is-active::before{content:"✓";position:absolute;inset:0;z-index:1;display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:800}
/* scent picker — full-pill buttons */
.cm-scentpick{display:grid;grid-template-columns:repeat(2,1fr);gap:.55rem}
@media(min-width:480px){.cm-scentpick{grid-template-columns:repeat(4,1fr)}}
.cm-scentpick button{padding:.8rem .5rem;border-radius:999px;border:1.5px solid var(--border);background:var(--card);font-weight:600;font-size:.9rem;cursor:pointer;transition:.15s}
.cm-scentpick button:hover{border-color:var(--rose-deep)}
.cm-scentpick button.is-active{background:var(--primary);color:var(--primary-foreground);border-color:var(--primary)}
.cm-actions{display:flex;gap:.7rem;margin-top:1.4rem;flex-wrap:wrap}
.cm-actions .btn{flex:1;min-width:140px}

/* tier selector */
.cm-tiers{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin:.6rem 0 1.6rem}
.cm-tier{position:relative;border:2px solid var(--border);border-radius:var(--radius-lg);padding:1rem .55rem .85rem;text-align:center;cursor:pointer;background:var(--card);transition:.18s}
.cm-tier:hover{border-color:var(--rose-soft);transform:translateY(-1px)}
.cm-tier.is-active{border-color:var(--primary);background:color-mix(in oklab,var(--blush) 35%,var(--card));box-shadow:var(--shadow)}
.cm-tier__label{font-weight:700;font-size:.95rem;color:var(--foreground)}
.cm-tier__qty{font-size:.74rem;color:var(--muted-foreground);margin-top:.1rem}
.cm-tier__price{font-weight:800;color:var(--rose-deep);margin-top:.45rem;font-size:1.02rem;line-height:1.1}
.cm-tier__orig{display:block;text-decoration:line-through;color:var(--muted-foreground);font-size:.76rem;font-weight:500;margin-top:.1rem}
.cm-tier__save{display:inline-block;font-size:.68rem;color:#fff;background:var(--success);font-weight:700;margin-top:.4rem;padding:.1rem .45rem;border-radius:999px}
.cm-tier__best{position:absolute;top:-11px;inset-inline-start:50%;transform:translateX(-50%);background:var(--rose-deep);color:#fff;font-size:.64rem;font-weight:700;padding:.2rem .6rem;border-radius:999px;white-space:nowrap;box-shadow:var(--shadow-sm)}
.cm-rtl .cm-tier__best{transform:translateX(50%)}

/* accordion */
.cm-accordion{border-top:1px solid var(--border);margin-top:1.6rem}
.cm-acc{border-bottom:1px solid var(--border)}
.cm-acc__head{width:100%;display:flex;justify-content:space-between;align-items:center;padding:1rem 0;background:none;border:none;cursor:pointer;font-weight:600;font-size:1rem;color:var(--foreground);text-align:start}
.cm-acc__head .icon{transition:transform .2s}
.cm-acc.is-open .cm-acc__head .icon{transform:rotate(180deg)}
.cm-acc__body{display:none;padding-bottom:1.1rem;color:var(--muted-foreground)}
.cm-acc.is-open .cm-acc__body{display:block}

/* reviews */
.cm-stars{display:inline-flex;gap:2px;color:var(--rose-deep);line-height:0}
.cm-star svg{display:block}
.cm-star.is-filled svg{fill:currentColor}
.cm-star:not(.is-filled) svg{fill:none;opacity:.4}
.cm-reviews{padding-block:1rem}
.cm-reviews__head{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:1.5rem}
.cm-reviews__title h2{font-size:clamp(1.7rem,3.5vw,2.4rem);color:var(--primary);margin:0}
.cm-reviews__title .muted{margin:.2rem 0 0;font-size:.92rem}
.cm-reviews__avg{display:flex;align-items:center;gap:.55rem}
.cm-reviews__avg-n{font-size:1.6rem;font-weight:800;color:var(--foreground)}
.cm-reviews__grid{display:grid;grid-template-columns:1fr;gap:1rem;margin-bottom:1.8rem}
.cm-review{background:color-mix(in oklab,var(--blush) 60%,transparent);border-radius:var(--radius-xl);padding:1.2rem 1.4rem}
.cm-review__top{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.5rem}
.cm-review__name{font-weight:700;font-size:1rem;color:var(--foreground)}
.cm-review__text{margin:0;color:var(--muted-foreground);line-height:1.6}

/* review form */
.cm-reviews .comment-respond,.cm-reviews #respond{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.4rem;margin-top:.5rem;max-width:620px}
.cm-reviews .comment-reply-title{font-family:var(--font-body);font-weight:700;font-size:1.1rem;display:block;margin-bottom:.8rem}
.cm-rtl .cm-reviews .comment-reply-title{font-family:var(--font-arabic)}
.cm-reviews .comment-form-rating label,.cm-reviews .comment-form-comment label,.cm-reviews .comment-form-author label,.cm-reviews .comment-form-email label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.4rem}
.cm-reviews select#rating,.cm-reviews .comment-form input[type=text],.cm-reviews .comment-form input[type=email],.cm-reviews .comment-form textarea{width:100%;max-width:100%;border:1px solid var(--input);border-radius:var(--radius-md);padding:.6rem .8rem;background:var(--background);margin-bottom:1rem;font-family:inherit}
.cm-reviews .form-submit input,.cm-reviews #submit{background:var(--primary);color:var(--primary-foreground);border:none;border-radius:999px;padding:.75rem 1.6rem;font-weight:600;cursor:pointer}

/* ----- bundle builder ------------------------------------------------------ */
.cm-bundle__intro{color:var(--muted-foreground);max-width:60ch;margin:.4rem 0 1.6rem}
.cm-slot{border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:.7rem;overflow:hidden;background:var(--card);transition:border-color .2s,box-shadow .2s}
.cm-slot.is-open{border-color:var(--primary);box-shadow:0 0 0 1px var(--primary)}
.cm-slot__head{width:100%;display:flex;justify-content:space-between;align-items:center;gap:.6rem;padding:.9rem 1.1rem;background:none;border:none;cursor:pointer;font-weight:700;text-align:start}
.cm-slot__head .cm-slot__sum{font-weight:500;font-size:.82rem;color:var(--muted-foreground)}
.cm-slot__body{display:none;padding:0 1.1rem 1.1rem;border-top:1px solid var(--border)}
.cm-slot.is-open .cm-slot__body{display:block}
.cm-typepick{display:grid;grid-template-columns:repeat(3,1fr);gap:.6rem;margin:.9rem 0}
.cm-typepick button{border:2px solid var(--border);border-radius:var(--radius-lg);padding:.7rem .5rem;background:var(--card);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.45rem;font-weight:600;font-size:.85rem;transition:.15s}
.cm-typepick button:hover{border-color:var(--rose-soft)}
.cm-typepick button.is-active{border-color:var(--primary);background:color-mix(in oklab,var(--blush) 35%,var(--card))}
.cm-typepick img{width:66px;height:66px;object-fit:contain;background:#f1efed;border-radius:var(--radius-md);padding:4px}
.cm-bundle-summary{background:color-mix(in oklab,var(--blush) 50%,transparent);border-radius:var(--radius-lg);padding:1.1rem 1.2rem;margin-top:1rem}
.cm-bundle-summary h3{font-family:var(--font-body);font-size:1rem;margin:0 0 .6rem;font-weight:700}
.cm-bundle-summary__row{display:flex;justify-content:space-between;font-size:.88rem;padding:.25rem 0;color:var(--muted-foreground)}
.cm-bundle-summary__total{display:flex;justify-content:space-between;font-weight:700;border-top:1px solid var(--border);margin-top:.5rem;padding-top:.6rem;color:var(--foreground)}

/* ----- cart ---------------------------------------------------------------- */
.cm-freeship{background:color-mix(in oklab,var(--blush) 40%,transparent);border-radius:var(--radius-lg);padding:.9rem 1.1rem;margin-bottom:1.4rem;display:flex;flex-direction:column;gap:.5rem}
.cm-freeship__msg{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:600}
.cm-freeship__bar{height:8px;border-radius:999px;background:color-mix(in oklab,var(--rose-soft) 45%,transparent);overflow:hidden}
.cm-freeship__fill{height:100%;background:var(--rose-deep);border-radius:999px;transition:width .4s}
.cm-freeship.is-qualified .cm-freeship__fill{background:var(--success)}
.cm-freeship.is-qualified .cm-freeship__msg{color:var(--success)}

/* ----- bare empty cart ----------------------------------------------------- */
.cm-content--bare{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--background)}
.cm-empty-cart{text-align:center;padding:2rem;max-width:560px}
.cm-empty-cart__icon{width:96px;height:96px;border-radius:999px;background:color-mix(in oklab,var(--rose-soft) 32%,transparent);color:var(--rose-deep);display:flex;align-items:center;justify-content:center;margin:0 auto 1.5rem}
.cm-empty-cart__title{font-size:2rem;color:var(--primary);margin:0 0 .4rem}
.cm-empty-cart__sub{color:var(--muted-foreground);margin:0 0 1.5rem}

/* ----- footer -------------------------------------------------------------- */
.cm-footer{background:linear-gradient(180deg,var(--background),var(--blush));margin-top:3rem;padding-block:3rem 1.5rem;border-top:1px solid var(--border)}
.cm-footer__grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:2rem}
.cm-footer__tag{color:var(--muted-foreground);max-width:34ch;margin-top:.7rem;font-size:.9rem}
.cm-footer__col h4{font-family:var(--font-body);font-size:.82rem;text-transform:uppercase;letter-spacing:.12em;color:var(--muted-foreground);margin:0 0 .9rem}
.cm-footer__col a{display:block;padding:.28rem 0;color:var(--foreground);font-size:.92rem}
.cm-footer__col a:hover{color:var(--rose-deep)}
.cm-socials{display:flex;gap:.5rem;margin-top:.6rem}
.cm-socials a{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:999px;background:var(--card);border:1px solid var(--border);color:var(--foreground);transition:.2s}
.cm-socials a:hover{color:var(--rose-deep);border-color:var(--rose-soft)}
.cm-footer__bottom{margin-top:2rem;padding-top:1.2rem;border-top:1px solid var(--border);font-size:.82rem;color:var(--muted-foreground)}

/* ----- whatsapp float ------------------------------------------------------ */
.cm-whatsapp-float{position:fixed;bottom:1.5rem;right:1.5rem;z-index:60;width:56px;height:56px;border-radius:999px;background:#25D366;color:#fff;display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-lg);transition:transform .15s}
.cm-whatsapp-float:hover{transform:scale(1.08)}
.cm-whatsapp-float:active{transform:scale(.95)}

/* ----- toast --------------------------------------------------------------- */
.cm-toast{position:fixed;bottom:1.2rem;inset-inline-start:50%;transform:translateX(-50%) translateY(140%);z-index:70;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:280px;max-width:92vw;opacity:0;transition:transform .3s,opacity .3s;overflow:hidden}
.cm-toast.is-on{transform:translateX(-50%) translateY(0);opacity:1}
.cm-toast__head{background:var(--success);color:#fff;padding:.5rem .9rem;display:flex;align-items:center;gap:.4rem;font-weight:700;font-size:.9rem}
.cm-toast__body{padding:.8rem .9rem;display:flex;gap:.7rem;align-items:center}
.cm-toast__body img{width:48px;height:48px;border-radius:var(--radius-sm);object-fit:cover}

/* ----- policy + about ------------------------------------------------------ */
.cm-policy{padding-block:2rem 3rem;max-width:860px;margin-inline:auto}
.cm-policy__crumb{font-size:.85rem;color:var(--muted-foreground);display:flex;gap:.5rem;align-items:center;margin-bottom:1.6rem}
.cm-policy__crumb a:hover{color:var(--rose-deep)}
.cm-policy__head{text-align:center;margin-bottom:1.8rem}
.cm-policy__head .cm-eyebrow{display:inline-block;background:var(--secondary);padding:.3rem .85rem;border-radius:999px;margin-bottom:.7rem}
.cm-policy__head h1{font-size:clamp(2rem,4vw,2.8rem);color:var(--primary);margin:.2rem 0}
.cm-policy__updated{color:var(--muted-foreground);font-size:.85rem;margin:.3rem 0 0}
.cm-policy__body{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:2.4rem;box-shadow:var(--shadow-sm)}
.cm-policy__body h2{font-family:var(--font-body);font-size:1.1rem;font-weight:700;color:var(--foreground);margin:1.7rem 0 .5rem;padding-inline-start:.7rem;border-inline-start:3px solid var(--rose-deep);line-height:1.3}
.cm-rtl .cm-policy__body h2{font-family:var(--font-arabic)}
.cm-policy__body>h2:first-of-type{margin-top:0}
.cm-policy__body p,.cm-policy__body li{color:var(--muted-foreground);margin:.4rem 0;line-height:1.7}
.cm-policy__body ul{padding-inline-start:1.2rem;margin:.4rem 0}
.cm-policy__note{background:color-mix(in oklab,var(--accent) 40%,transparent);border-radius:var(--radius-md);padding:.9rem 1.1rem;margin:0 0 1rem;color:var(--foreground)}
.cm-policy__related{margin-top:1.8rem}
.cm-policy__related .cm-eyebrow{display:block;margin-bottom:.7rem}
.cm-policy__pills{display:grid;grid-template-columns:1fr 1fr;gap:.7rem}
.cm-policy__pills a{display:flex;justify-content:space-between;align-items:center;background:var(--card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:.85rem 1.1rem;font-weight:600;font-size:.9rem;transition:border-color .2s,color .2s}
.cm-policy__pills a:hover{border-color:var(--rose-deep);color:var(--rose-deep)}
@media(max-width:600px){.cm-policy__pills{grid-template-columns:1fr}}

.cm-about-hero{position:relative;min-height:46vh;display:flex;align-items:center;justify-content:center;text-align:center;color:#fff;overflow:hidden}
.cm-about-hero img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.cm-about-hero::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(20,10,25,.7),rgba(20,10,25,.25))}
.cm-about-hero__in{position:relative;z-index:1;padding:2rem}
.cm-about-hero__in h1{font-size:clamp(2.4rem,6vw,4rem);margin:.3rem 0}
.cm-split{display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:center;padding-block:3rem}
.cm-split img{border-radius:var(--radius-2xl);box-shadow:var(--shadow);width:100%;object-fit:cover}
.cm-badge{display:inline-flex;align-items:center;gap:.4rem;background:var(--secondary);color:var(--secondary-foreground);padding:.35rem .8rem;border-radius:999px;font-size:.78rem;font-weight:700;margin-bottom:.7rem}
.cm-cards3{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.cm-cards3 .cm-vcard{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-xl);padding:1.4rem;text-align:center}
.cm-cards3 .cm-vcard .icon{color:var(--rose-deep);margin-bottom:.6rem}
.cm-about-cta{background:var(--primary);color:var(--primary-foreground);border-radius:var(--radius-3xl);padding:3rem 1.6rem;text-align:center;margin-block:2.5rem}
.cm-about-cta h2{color:var(--primary-foreground);font-size:clamp(1.6rem,4vw,2.4rem);margin:0 0 1.2rem}

/* ----- responsive ---------------------------------------------------------- */
@media(max-width:900px){
  .cm-footer__grid{grid-template-columns:1fr 1fr}
  .cm-footer__brand{grid-column:1/-1}
  .cm-cards3{grid-template-columns:1fr}
}
@media(max-width:768px){
  .cm-nav__links{display:none}
  .cm-nav__burger{display:flex;order:-1}
  .cm-logo{margin-inline-end:auto}
  .cm-hero__inner{grid-template-columns:1fr;gap:1.6rem;padding-block:2.2rem 2.6rem}
  .cm-hero__title{line-height:1.15;margin-bottom:.9rem}
  .cm-hero__cta{flex-direction:column}
  .cm-hero__cta .btn{width:100%}
  .cm-product{grid-template-columns:1fr;gap:1.4rem}
  .cm-split{grid-template-columns:1fr;gap:1.4rem}
  .cm-about-hero{min-height:38vh}
}
@media(max-width:480px){
  .cm-tiers{grid-template-columns:1fr}
}

/* RTL niceties: flip directional icons */
.cm-rtl .icon-arrow-right{transform:scaleX(-1)}
.cm-rtl .icon-arrow-left{transform:scaleX(-1)}

/* =========================================================================
   WooCommerce default-markup integration (buttons, forms, cart, checkout)
   ========================================================================= */
.cm-shop{padding-block:1.6rem 3rem}
.woocommerce-notices-wrapper,.woocommerce-message,.woocommerce-info,.woocommerce-error{
  border-radius:var(--radius-md);border:1px solid var(--border);background:var(--card);
  padding:.8rem 1rem;margin:0 0 1rem;list-style:none;font-size:.92rem}
.woocommerce-message{border-inline-start:4px solid var(--success)}
.woocommerce-error{border-inline-start:4px solid var(--destructive)}
.woocommerce-info{border-inline-start:4px solid var(--rose-deep)}

/* generic WC buttons -> our pill primary */
.woocommerce a.button,.woocommerce button.button,.woocommerce input.button,
.woocommerce .button,.wc-block-components-button,.single_add_to_cart_button{
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  background:var(--primary)!important;color:var(--primary-foreground)!important;
  border:1px solid transparent;border-radius:999px!important;font-weight:600;
  padding:.7rem 1.4rem;cursor:pointer;transition:transform .15s,box-shadow .2s;box-shadow:var(--shadow);text-decoration:none}
.woocommerce a.button:hover,.woocommerce button.button:hover,.single_add_to_cart_button:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}
.woocommerce .button.alt,.single_add_to_cart_button.alt{background:var(--rose-deep)!important}

/* add-to-cart form on single product */
.cm-addtocart{margin:1rem 0 1.4rem}
form.cart{display:flex;flex-wrap:wrap;gap:.7rem;align-items:center;margin:1rem 0}
form.cart .quantity{display:inline-flex;align-items:center}
form.cart .quantity input.qty{width:64px;height:46px;text-align:center;border:1px solid var(--input);border-radius:var(--radius-md);background:var(--card)}
.single_add_to_cart_button{flex:1;min-width:160px;padding:.85rem 1.4rem;font-size:1rem}
.variations{width:100%;border-collapse:collapse;margin-bottom:.4rem}
.variations th,.variations td{display:block;text-align:start;padding:.2rem 0}
.variations th.label label{font-weight:600;font-size:.9rem;color:var(--foreground)}
.variations select{width:100%;max-width:320px;height:44px;border:1px solid var(--input);border-radius:var(--radius-md);padding:0 .7rem;background:var(--card)}
.woocommerce-variation-price{font-size:1.3rem;font-weight:700;color:var(--foreground);margin:.4rem 0}
.reset_variations{font-size:.82rem;color:var(--muted-foreground)}
.woocommerce-variation-add-to-cart{display:flex;gap:.7rem;align-items:center;flex-wrap:wrap;width:100%}

/* price html */
.woocommerce div.product p.price,.woocommerce div.product span.price{color:var(--rose-deep);font-weight:700}

/* cart + checkout tables */
.woocommerce table.shop_table{border:1px solid var(--border);border-radius:var(--radius-lg);border-collapse:separate;border-spacing:0;overflow:hidden;background:var(--card);width:100%}
.woocommerce table.shop_table th{background:var(--secondary);font-weight:700;padding:.9rem 1rem;text-align:start}
.woocommerce table.shop_table td{padding:.9rem 1rem;border-top:1px solid var(--border)}
.woocommerce .cart_item img{width:64px;border-radius:var(--radius-sm)}
.cm-bundle-thumb{width:64px;border-radius:var(--radius-sm)}
.woocommerce .cart-collaterals,.woocommerce-cart .cart-collaterals{margin-top:1.4rem}
.woocommerce .cart_totals h2,.woocommerce-checkout h3{font-family:var(--font-body);font-weight:700;font-size:1.15rem}
.cm-rtl .woocommerce .cart_totals h2{font-family:var(--font-arabic)}
.woocommerce-cart .wc-proceed-to-checkout a.checkout-button{width:100%;font-size:1.05rem;padding:.9rem 1.4rem}
.woocommerce form .form-row input.input-text,.woocommerce form .form-row textarea,.select2-container--default .select2-selection--single{
  border:1px solid var(--input);border-radius:var(--radius-md);min-height:46px;padding:.5rem .8rem;background:var(--card)}
.woocommerce #respond input#submit,.woocommerce-checkout #place_order{width:100%;padding:.95rem;font-size:1.05rem;margin-top:.6rem}

/* ----- checkout: 2-column layout + cards -------------------------------- */
.woocommerce-checkout .cm-page__content{max-width:1080px;margin-inline:auto}
.woocommerce-checkout form.checkout.woocommerce-checkout{display:block}
.woocommerce-checkout .woocommerce-form-coupon-toggle,
.woocommerce-checkout form.checkout>.woocommerce-info{margin-bottom:1.2rem}
#customer_details .col-1,#customer_details .col-2{width:auto;float:none}
.woocommerce-billing-fields h3,.woocommerce-additional-fields h3,#order_review_heading{
  font-family:var(--font-body);font-weight:700;font-size:1.15rem;margin:0 0 1rem}
.cm-rtl .woocommerce-billing-fields h3,.cm-rtl #order_review_heading{font-family:var(--font-arabic)}
.woocommerce-checkout .form-row{margin:0 0 1rem}
.woocommerce-checkout .form-row label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.4rem}
#order_review{background:var(--card);border:1px solid var(--border);border-radius:var(--radius-2xl);padding:1.4rem;box-shadow:var(--shadow-sm)}
#order_review .shop_table{border:none;border-radius:0;background:transparent}
#order_review .shop_table th{background:transparent;border:none;padding:.5rem 0;border-bottom:1px solid var(--border)}
#order_review .shop_table td{border:none;padding:.6rem 0;border-bottom:1px solid var(--border)}
#order_review .order-total td,#order_review .order-total th{font-size:1.05rem;font-weight:700;border-bottom:none}
#payment{background:transparent;border-radius:var(--radius-lg);margin-top:.5rem}
#payment ul.payment_methods{border:none;padding:0;margin:0;list-style:none}
#payment ul.payment_methods li{padding:.7rem .9rem;border:1px solid var(--border);border-radius:var(--radius-md);margin-bottom:.5rem;background:var(--background)}
#payment ul.payment_methods li input[type=radio]{accent-color:var(--rose-deep);margin-inline-end:.4rem}
#payment .payment_box{background:color-mix(in oklab,var(--blush) 40%,transparent);border-radius:var(--radius-sm);padding:.7rem .9rem;font-size:.86rem;color:var(--muted-foreground)}
#payment .payment_box::before{display:none}
#payment .place-order{padding:0;margin-top:1rem}
.woocommerce-privacy-policy-text{font-size:.8rem;color:var(--muted-foreground);margin:.8rem 0}
@media(min-width:782px){
  .woocommerce-checkout form.checkout.woocommerce-checkout{
    display:grid;grid-template-columns:1.25fr .85fr;column-gap:2.5rem;align-items:start;
  }
  .woocommerce-checkout form.checkout>.woocommerce-form-coupon-toggle,
  .woocommerce-checkout form.checkout>.woocommerce-info,
  .woocommerce-checkout form.checkout>.woocommerce-form-login,
  .woocommerce-checkout form.checkout>.woocommerce-form-coupon{grid-column:1 / -1;grid-row:1}
  .woocommerce-checkout #customer_details{grid-column:1;grid-row:2 / span 2}
  .woocommerce-checkout #order_review_heading{grid-column:2;grid-row:2;margin-top:0}
  .woocommerce-checkout #order_review{grid-column:2;grid-row:3;position:sticky;top:88px}
}

/* related products spacing — 3-up like the live site */
.related.products,.up-sells.products{margin-top:1rem}
.related.products ul.products,.up-sells.products ul.products{grid-template-columns:repeat(2,1fr)}
@media(min-width:768px){.related.products ul.products,.up-sells.products ul.products{grid-template-columns:repeat(3,1fr)}}

/* reviews (native comments) */
#reviews .commentlist{list-style:none;padding:0;display:grid;gap:1rem;grid-template-columns:1fr}
@media(min-width:768px){#reviews .commentlist{grid-template-columns:1fr 1fr}}
#reviews .commentlist li{background:color-mix(in oklab,var(--blush) 55%,transparent);border:1px solid color-mix(in oklab,var(--rose-soft) 40%,transparent);border-radius:var(--radius-lg);padding:1rem 1.1rem}
#reviews .star-rating{color:var(--rose-deep)}
#review_form_wrapper{margin-top:1.2rem}

/* product gallery (if WC default used anywhere) */
.woocommerce-product-gallery{position:relative}
.woocommerce-product-gallery img{border-radius:var(--radius-2xl)}
