/* ============================================================
   Nat's Creations v3 — style.css
   Palette: lavender · lilac · soft pink · pearl white · charcoal
   ============================================================ */

:root {
  /* ── Brand palette from logo ── */
  --lavender:    #c9b8e8;
  --lilac:       #b8a0d8;
  --purple-mid:  #9b7fc0;
  --purple-deep: #6b4fa0;
  --pink-star:   #e060a0;
  --pink-soft:   #f0a8cc;
  --blush:       #fce4f0;
  --pearl:       #f5f0fa;
  --cream:       #fdfaff;
  --charcoal:    #2a1f38;
  --ink:         #3d2d55;
  --muted:       #7a6890;
  --gold:        #c8a060;
  --sale-red:    #c0304a;

  /* ── Semantic tokens ── */
  --bg:          var(--cream);
  --bg2:         var(--pearl);
  --bg3:         #ede8f5;
  --card-bg:     #fff;
  --text:        var(--ink);
  --text2:       var(--muted);
  --border:      rgba(155,127,192,0.22);
  --border-med:  rgba(155,127,192,0.4);
  --nav-bg:      rgba(253,250,255,0.94);
  --shadow-sm:   0 2px 16px rgba(107,79,160,0.10);
  --shadow-md:   0 8px 40px rgba(107,79,160,0.14);
  --shadow-lg:   0 16px 60px rgba(107,79,160,0.18);
  --sidebar-w:   230px;
  --radius:      2px;
}

[data-theme="dark"] {
  --bg:       #1a1325;
  --bg2:      #231830;
  --bg3:      #2d2040;
  --card-bg:  #281c38;
  --text:     #f0eaf8;
  --text2:    #a090b8;
  --border:   rgba(155,127,192,0.18);
  --border-med:rgba(155,127,192,0.32);
  --nav-bg:   rgba(26,19,37,0.96);
  --shadow-sm:0 2px 16px rgba(0,0,0,0.30);
  --shadow-md:0 8px 40px rgba(0,0,0,0.40);
  --shadow-lg:0 16px 60px rgba(0,0,0,0.50);
  --cream:    #1a1325;
  --pearl:    #281c38;
  --ink:      #f0eaf8;
  --muted:    #a090b8;
}

/* ── RESET ── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',sans-serif;overflow-x:hidden;cursor:none;transition:background .4s,color .4s;}
img{max-width:100%;display:block;}
a{text-decoration:none;color:inherit;}
button{font-family:inherit;cursor:none;border:none;background:none;}
ul{list-style:none;}
input,textarea{font-family:inherit;}

/* ── SCROLLBAR ── */
::-webkit-scrollbar{width:5px;}
::-webkit-scrollbar-track{background:var(--bg2);}
::-webkit-scrollbar-thumb{background:var(--lilac);border-radius:3px;}

/* ── CURSOR ── */
.cursor{position:fixed;width:10px;height:10px;background:var(--pink-star);border-radius:50%;pointer-events:none;z-index:99999;transform:translate(-50%,-50%);transition:width .25s,height .25s,background .25s;mix-blend-mode:multiply;}
.cursor-ring{position:fixed;width:32px;height:32px;border:1.5px solid var(--lavender);border-radius:50%;pointer-events:none;z-index:99998;transform:translate(-50%,-50%);transition:width .28s,height .28s,border-color .28s,transform .1s ease-out;}
.cursor.hover{width:18px;height:18px;background:var(--lavender);}
.cursor-ring.hover{width:48px;height:48px;border-color:var(--pink-star);}
[data-theme="dark"] .cursor{mix-blend-mode:screen;}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;right:0;z-index:300;display:flex;align-items:center;justify-content:space-between;padding:16px 5%;background:var(--nav-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);transition:padding .4s,box-shadow .3s,background .4s;}
nav.scrolled{padding:11px 5%;box-shadow:var(--shadow-sm);}
.nav-logo{font-family:'Pinyon Script',cursive;font-size:1.9rem;color:var(--purple-deep);letter-spacing:1px;transition:color .3s;}
[data-theme="dark"] .nav-logo{color:var(--lavender);}
.nav-links{display:flex;gap:26px;}
.nav-links a{font-size:.68rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--text);position:relative;transition:color .3s;padding-bottom:3px;}
.nav-links a::after{content:'';position:absolute;bottom:0;left:0;right:0;height:1.5px;background:var(--pink-star);transform:scaleX(0);transform-origin:left;transition:transform .3s ease;}
.nav-links a:hover,.nav-links a.active{color:var(--purple-deep);}
[data-theme="dark"] .nav-links a:hover,[data-theme="dark"] .nav-links a.active{color:var(--lavender);}
.nav-links a:hover::after,.nav-links a.active::after{transform:scaleX(1);}
.nav-actions{display:flex;gap:10px;align-items:center;}

/* cart icon */
.cart-trigger{position:relative;color:var(--text);display:flex;align-items:center;transition:color .3s;padding:6px;}
.cart-trigger:hover{color:var(--purple-deep);}
[data-theme="dark"] .cart-trigger:hover{color:var(--lavender);}
.cart-count{position:absolute;top:0;right:0;background:var(--pink-star);color:#fff;font-size:.5rem;font-weight:700;width:16px;height:16px;border-radius:50%;display:none;align-items:center;justify-content:center;transition:transform .3s;}
.cart-count.bump{animation:cartBump .4s ease;}
@keyframes cartBump{0%,100%{transform:scale(1)}50%{transform:scale(1.6)}}

/* theme toggle */
.theme-toggle{border:1.5px solid var(--border-med);color:var(--text);padding:5px 12px;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;display:flex;align-items:center;gap:5px;transition:all .3s;}
.theme-toggle:hover{border-color:var(--lavender);color:var(--purple-deep);}
[data-theme="dark"] .theme-toggle:hover{color:var(--lavender);}

/* nav social */
.nav-social{display:flex;gap:10px;align-items:center;}
.nav-social a{color:var(--text2);display:flex;align-items:center;transition:color .3s;padding:4px;}
.nav-social a:hover{color:var(--pink-star);}

/* hamburger */
.hamburger{display:none;flex-direction:column;gap:5px;padding:4px;}
.hamburger span{display:block;width:21px;height:1.5px;background:var(--text);transition:all .3s;}
.hamburger.open span:nth-child(1){transform:rotate(45deg) translate(4.5px,4.5px);}
.hamburger.open span:nth-child(2){opacity:0;}
.hamburger.open span:nth-child(3){transform:rotate(-45deg) translate(4.5px,-4.5px);}

/* mobile nav */
.mobile-nav{display:none;position:fixed;top:55px;left:0;right:0;background:var(--nav-bg);backdrop-filter:blur(16px);border-bottom:1px solid var(--border);padding:18px 5%;z-index:299;flex-direction:column;gap:0;animation:slideDown .28s ease;}
.mobile-nav.open{display:flex;}
@keyframes slideDown{from{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}
.mobile-nav a{padding:13px 0;font-size:.72rem;letter-spacing:2px;text-transform:uppercase;color:var(--text);border-bottom:1px solid var(--border);transition:color .3s;}
.mobile-nav a:last-child{border-bottom:none;}
.mobile-nav a:hover{color:var(--purple-deep);}

/* ── PAGES ── */
.page{display:none;}
.page.active{display:block;animation:pageIn .35s ease;}
@keyframes pageIn{from{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}

/* ── HERO ── */
.hero{min-height:100vh;display:grid;grid-template-columns:1fr 1fr;align-items:center;padding:110px 5% 60px;position:relative;overflow:hidden;gap:48px;}
.hero::before{content:'';position:absolute;inset:0;pointer-events:none;background:radial-gradient(ellipse 65% 70% at 75% 50%,rgba(201,184,232,.28) 0%,transparent 65%),radial-gradient(ellipse 45% 45% at 20% 75%,rgba(240,168,204,.14) 0%,transparent 60%);transition:background .4s;}
[data-theme="dark"] .hero::before{background:radial-gradient(ellipse 65% 70% at 75% 50%,rgba(107,79,160,.22) 0%,transparent 65%),radial-gradient(ellipse 45% 45% at 20% 75%,rgba(200,96,160,.1) 0%,transparent 60%);}
.hero-eyebrow{font-size:.65rem;letter-spacing:4px;text-transform:uppercase;color:var(--purple-mid);margin-bottom:16px;opacity:0;animation:fadeUp .8s forwards .3s;}
.hero-title{font-family:'Playfair Display',serif;font-size:clamp(2.6rem,4.8vw,4.8rem);line-height:1.08;color:var(--text);margin-bottom:20px;opacity:0;animation:fadeUp .9s forwards .5s;}
.hero-title em{font-style:italic;color:var(--purple-mid);}
.hero-sub{font-size:.92rem;line-height:1.8;color:var(--text2);max-width:400px;margin-bottom:36px;opacity:0;animation:fadeUp .9s forwards .7s;}
.hero-cta{display:flex;gap:12px;flex-wrap:wrap;opacity:0;animation:fadeUp .9s forwards .9s;}

/* ── BUTTONS ── */
.btn{display:inline-flex;align-items:center;gap:7px;padding:12px 28px;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;transition:all .3s;cursor:none;}
.btn svg{flex-shrink:0;}
.btn-primary{background:var(--purple-deep);color:#fff;}
.btn-primary:hover{background:var(--purple-mid);transform:translateY(-2px);box-shadow:var(--shadow-sm);}
.btn-outline{border:1.5px solid var(--border-med);color:var(--text);background:transparent;}
.btn-outline:hover{border-color:var(--lavender);color:var(--purple-deep);transform:translateY(-2px);}
[data-theme="dark"] .btn-outline:hover{color:var(--lavender);}
.btn-pink{background:var(--pink-star);color:#fff;}
.btn-pink:hover{background:var(--pink-soft);color:var(--ink);transform:translateY(-2px);}
.btn-wa{background:#25D366;color:#fff;}
.btn-wa:hover{background:#1ebe5d;transform:translateY(-2px);}
.btn-ghost{background:transparent;border:1.5px solid var(--border-med);color:var(--text2);font-size:.6rem;letter-spacing:1.5px;}
.btn-ghost:hover{border-color:var(--border-med);color:var(--text);}

/* ── HERO VISUAL ── */
.hero-visual{position:relative;height:520px;display:flex;align-items:center;justify-content:center;opacity:0;animation:fadeIn 1.2s forwards .6s;}
.bead-ring{position:absolute;border-radius:50%;border:1.5px solid transparent;animation:spinRing linear infinite;}
.bead-ring::before{content:'';position:absolute;width:13px;height:13px;border-radius:50%;top:-6.5px;left:50%;transform:translateX(-50%);}
.ring-1{width:290px;height:290px;border-color:rgba(201,184,232,.35);animation-duration:22s;}
.ring-1::before{background:var(--pink-star);box-shadow:0 0 10px var(--pink-star);}
.ring-2{width:210px;height:210px;border-color:rgba(184,160,216,.3);animation-duration:15s;animation-direction:reverse;}
.ring-2::before{background:var(--lavender);box-shadow:0 0 10px var(--lavender);}
.ring-3{width:130px;height:130px;border-color:rgba(107,79,160,.3);animation-duration:10s;}
.ring-3::before{background:var(--purple-mid);box-shadow:0 0 8px var(--purple-mid);}
.hero-center{position:relative;z-index:3;text-align:center;}
.hero-center .monogram{font-family:'Pinyon Script',cursive;font-size:4.2rem;color:var(--purple-deep);display:block;line-height:1;}
[data-theme="dark"] .hero-center .monogram{color:var(--lavender);}
.hero-center .tagline{font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--purple-mid);margin-top:8px;}
.float-dot{position:absolute;border-radius:50%;animation:floatBead ease-in-out infinite;opacity:.65;}
.float-dot:nth-child(1){width:20px;height:20px;background:var(--pink-star);top:12%;left:6%;animation-duration:5.8s;}
.float-dot:nth-child(2){width:13px;height:13px;background:var(--lavender);top:72%;left:10%;animation-duration:4.4s;animation-delay:.9s;}
.float-dot:nth-child(3){width:17px;height:17px;background:var(--purple-mid);top:22%;right:9%;animation-duration:6.2s;animation-delay:.4s;}
.float-dot:nth-child(4){width:9px;height:9px;background:var(--pink-soft);top:82%;right:14%;animation-duration:3.9s;animation-delay:1.4s;}
.float-dot:nth-child(5){width:25px;height:25px;background:var(--pearl);border:2px solid var(--lavender);top:48%;right:4%;animation-duration:7.1s;animation-delay:.2s;}

/* ── MARQUEE ── */
.marquee-band{background:var(--purple-deep);padding:12px 0;overflow:hidden;white-space:nowrap;}
[data-theme="dark"] .marquee-band{background:var(--purple-mid);}
.marquee-track{display:inline-flex;animation:marquee 24s linear infinite;}
.marquee-item{font-size:.6rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.85);padding:0 32px;}
.marquee-sep{color:var(--pink-star);opacity:.8;font-size:.9rem;vertical-align:middle;}

/* ── SECTION SHELLS ── */
.section{padding:88px 5%;}
.section-header{text-align:center;margin-bottom:52px;}
.section-label{font-size:.58rem;letter-spacing:4px;text-transform:uppercase;color:var(--purple-mid);margin-bottom:12px;}
.section-title{font-family:'Playfair Display',serif;font-size:clamp(1.7rem,2.8vw,2.7rem);color:var(--text);line-height:1.2;}
.section-title em{font-style:italic;color:var(--purple-mid);}
.section-rule{width:44px;height:1.5px;background:var(--pink-star);margin:14px auto 0;}
.section-left .section-header{text-align:left;}
.section-left .section-rule{margin-left:0;}

/* ── CATEGORY CARDS ── */
.cat-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;max-width:1040px;margin:0 auto;}
.cat-card{background:var(--card-bg);position:relative;overflow:hidden;aspect-ratio:3/4;cursor:none;transition:transform .4s,box-shadow .4s;border:1px solid var(--border);}
.cat-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);}
.cat-card::after{content:'';position:absolute;inset:0;border:1.5px solid transparent;transition:border-color .3s;pointer-events:none;z-index:5;}
.cat-card:hover::after{border-color:var(--lavender);}
.cat-card-inner{height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:32px 18px;}
.cat-visual{width:150px;height:150px;margin-bottom:22px;}
.cat-label{font-size:.55rem;letter-spacing:3px;text-transform:uppercase;color:var(--purple-mid);margin-bottom:5px;}
.cat-name{font-family:'Playfair Display',serif;font-size:1.3rem;color:var(--text);margin-bottom:7px;text-align:center;}
.cat-desc{font-size:.74rem;color:var(--text2);text-align:center;line-height:1.6;margin-bottom:16px;}
.cat-price{font-size:.66rem;letter-spacing:2px;text-transform:uppercase;color:var(--gold);font-weight:500;}
.cat-arrow{position:absolute;bottom:18px;right:18px;width:32px;height:32px;background:var(--lavender);color:var(--purple-deep);display:flex;align-items:center;justify-content:center;opacity:0;transform:translateX(8px);transition:opacity .3s,transform .3s;}
.cat-card:hover .cat-arrow{opacity:1;transform:translateX(0);}

/* ── PRODUCT GRID ── */
.products-section{background:var(--bg2);}
.page-header-bar{display:flex;align-items:center;gap:14px;margin-bottom:28px;flex-wrap:wrap;padding-bottom:20px;border-bottom:1px solid var(--border);}
.products-back{display:inline-flex;align-items:center;gap:6px;font-size:.62rem;letter-spacing:2px;text-transform:uppercase;color:var(--text2);transition:color .3s;}
.products-back:hover{color:var(--purple-mid);}
.page-title-sm{font-family:'Playfair Display',serif;font-size:1.7rem;color:var(--text);}
.page-title-sm em{font-style:italic;color:var(--purple-mid);}

.product-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;max-width:1200px;margin:0 auto;}
.product-card{background:var(--card-bg);position:relative;cursor:none;transition:transform .4s,box-shadow .4s;border:1px solid var(--border);}
.product-card:hover{transform:translateY(-7px);box-shadow:var(--shadow-md);}
.product-img{aspect-ratio:1;overflow:hidden;position:relative;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--pearl) 0%,var(--blush) 100%);}
.product-img svg{transition:transform .5s;}
.product-card:hover .product-img svg{transform:scale(1.05);}

/* alternating tints */
.product-card:nth-child(4n+1) .product-img{background:linear-gradient(135deg,#f0eaff 0%,#fce4f0 100%);}
.product-card:nth-child(4n+2) .product-img{background:linear-gradient(135deg,#eaeaff 0%,#f0e4fc 100%);}
.product-card:nth-child(4n+3) .product-img{background:linear-gradient(135deg,#fce4f0 0%,#ffe4ea 100%);}
.product-card:nth-child(4n+4) .product-img{background:linear-gradient(135deg,#e4f0fc 0%,#e4f4ff 100%);}
[data-theme="dark"] .product-card .product-img{background:var(--bg3)!important;}

.p-badge{position:absolute;top:9px;left:9px;z-index:2;font-size:.5rem;letter-spacing:2px;text-transform:uppercase;padding:3px 9px;}
.p-badge-purple{background:var(--purple-deep);color:#fff;}
.p-badge-pink{background:var(--pink-star);color:#fff;}
.p-badge-sale{background:var(--sale-red);color:#fff;}
.p-badge-lavender{background:var(--lavender);color:var(--purple-deep);}

.p-overlay{position:absolute;inset:0;background:rgba(42,31,56,.52);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.product-card:hover .p-overlay{opacity:1;}
.p-overlay-btn{background:var(--pearl);color:var(--purple-deep);padding:9px 20px;font-size:.6rem;letter-spacing:2px;text-transform:uppercase;transition:background .3s;}
.p-overlay-btn:hover{background:var(--lavender);}

.product-info{padding:14px 16px 18px;}
.product-theme{font-size:.54rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--purple-mid);margin-bottom:3px;}
.product-name{font-family:'Playfair Display',serif;font-size:.98rem;color:var(--text);line-height:1.3;margin-bottom:4px;}
.product-footer{display:flex;align-items:center;justify-content:space-between;margin-top:9px;}
.product-price{font-size:.92rem;font-weight:600;color:var(--text);}
.product-price-orig{font-size:.68rem;color:var(--text2);text-decoration:line-through;margin-left:5px;}
.add-btn{width:30px;height:30px;background:var(--purple-deep);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1rem;transition:background .3s,transform .3s;}
.add-btn:hover{background:var(--pink-star);transform:rotate(90deg);}

/* ── GENDER FILTER CHIPS ── */
.filter-bar{display:flex;align-items:center;gap:7px;margin-bottom:26px;flex-wrap:wrap;}
.filter-bar .bar-lbl{font-size:.58rem;letter-spacing:2px;text-transform:uppercase;color:var(--text2);margin-right:4px;}
.g-chip{padding:5px 14px;border:1.5px solid var(--border-med);background:transparent;color:var(--text);font-size:.6rem;letter-spacing:1.5px;text-transform:uppercase;transition:all .3s;}
.g-chip.active,.g-chip:hover{background:var(--purple-deep);color:#fff;border-color:var(--purple-deep);}
[data-theme="dark"] .g-chip.active,[data-theme="dark"] .g-chip:hover{background:var(--lavender);color:var(--purple-deep);border-color:var(--lavender);}

/* ── GENDER SIDEBAR ── */
.gender-sidebar{position:fixed;right:0;top:50%;transform:translateY(-50%);z-index:200;width:var(--sidebar-w);right:calc(-1 * var(--sidebar-w));transition:right .4s cubic-bezier(.77,0,.18,1);}
.gender-sidebar:hover,.gender-sidebar.open{right:0;}
.gender-tab-handle{writing-mode:vertical-lr;background:var(--purple-deep);color:#fff;font-size:.5rem;letter-spacing:3px;text-transform:uppercase;padding:14px 8px;position:absolute;left:-30px;top:50%;transform:translateY(-50%);white-space:nowrap;transition:background .3s;}
[data-theme="dark"] .gender-tab-handle{background:var(--lavender);color:var(--purple-deep);}
.gender-sidebar:hover .gender-tab-handle{background:var(--pink-star);}
.gender-panel{background:var(--card-bg);border-left:2px solid var(--lavender);padding:22px 16px;box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:5px;}
.gender-panel h3{font-family:'Playfair Display',serif;font-size:.8rem;color:var(--text2);letter-spacing:2px;text-transform:uppercase;margin-bottom:11px;padding-bottom:8px;border-bottom:1px solid var(--border);}
.gender-btn{display:flex;align-items:center;gap:9px;padding:10px 13px;border:1.5px solid var(--border-med);color:var(--text);font-size:.66rem;letter-spacing:1.5px;text-transform:uppercase;transition:all .3s;width:100%;text-align:left;}
.gender-btn:hover,.gender-btn.active{background:var(--purple-deep);color:#fff;border-color:var(--purple-deep);}
[data-theme="dark"] .gender-btn:hover,[data-theme="dark"] .gender-btn.active{background:var(--lavender);color:var(--purple-deep);border-color:var(--lavender);}
.g-icon{width:16px;height:16px;flex-shrink:0;}

/* ── ABOUT STRIP ── */
.about-strip{background:linear-gradient(120deg,var(--blush) 0%,var(--pearl) 100%);padding:64px 5%;display:flex;align-items:center;justify-content:center;gap:64px;flex-wrap:wrap;}
[data-theme="dark"] .about-strip{background:var(--bg3);}
.about-stat{text-align:center;}
.about-num{font-family:'Playfair Display',serif;font-size:2.6rem;color:var(--purple-deep);line-height:1;}
[data-theme="dark"] .about-num{color:var(--lavender);}
.about-lbl{font-size:.58rem;letter-spacing:3px;text-transform:uppercase;color:var(--purple-mid);margin-top:6px;}
.about-div{width:1px;height:44px;background:var(--border-med);}

/* ── SALE PAGE ── */
.sale-hero{background:linear-gradient(135deg,var(--sale-red) 0%,#8a1a2e 100%);color:#fff;padding:110px 5% 56px;text-align:center;}
[data-theme="dark"] .sale-hero{background:linear-gradient(135deg,#7a1020 0%,#4a0a18 100%);}
.sale-hero h1{font-family:'Playfair Display',serif;font-size:clamp(2.4rem,6vw,4.4rem);margin-bottom:13px;}
.sale-hero p{font-size:.9rem;opacity:.85;max-width:480px;margin:0 auto 24px;}
.sale-badges-row{display:flex;justify-content:center;gap:16px;flex-wrap:wrap;}
.sale-badge{padding:11px 24px;border:2px solid rgba(255,255,255,.4);font-size:.68rem;letter-spacing:2px;text-transform:uppercase;color:#fff;background:rgba(255,255,255,.1);}
.sale-badge strong{font-size:1.4rem;display:block;font-family:'Playfair Display',serif;}
.sale-note{background:var(--purple-deep);color:#fff;text-align:center;padding:11px 5%;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;position:sticky;top:54px;z-index:10;}
[data-theme="dark"] .sale-note{background:var(--purple-mid);}

/* ── CUSTOM BUILDER ── */
.builder-section{background:var(--bg2);}
.builder-wrap{display:grid;grid-template-columns:1fr 390px;gap:36px;max-width:1060px;margin:0 auto;align-items:start;}
.builder-preview{background:var(--card-bg);border:1px solid var(--border-med);padding:28px;display:flex;flex-direction:column;align-items:center;gap:16px;position:sticky;top:94px;}
.preview-lbl{font-size:.54rem;letter-spacing:3px;text-transform:uppercase;color:var(--text2);}
.preview-canvas{width:200px;height:200px;}
.preview-name{font-family:'Playfair Display',serif;font-size:.82rem;color:var(--text);letter-spacing:1px;min-height:22px;}
.builder-price-row{display:flex;align-items:center;justify-content:space-between;padding:14px 16px;background:var(--bg2);border:1px solid var(--border);width:100%;}
.builder-price{font-family:'Playfair Display',serif;font-size:1.4rem;color:var(--purple-deep);}
[data-theme="dark"] .builder-price{color:var(--lavender);}
.builder-price-lbl{font-size:.54rem;letter-spacing:2px;text-transform:uppercase;color:var(--text2);}
.builder-form{display:flex;flex-direction:column;gap:22px;}
.form-group label{display:block;font-size:.56rem;letter-spacing:2.5px;text-transform:uppercase;color:var(--purple-mid);margin-bottom:8px;}
.form-group input[type=text]{width:100%;padding:10px 14px;background:var(--bg2);border:1px solid var(--border-med);color:var(--text);font-size:.88rem;outline:none;transition:border-color .3s;}
.form-group input[type=text]:focus{border-color:var(--lavender);}
.color-swatches{display:flex;flex-wrap:wrap;gap:8px;}
.color-swatch{width:30px;height:30px;border-radius:50%;border:2.5px solid transparent;transition:transform .2s,border-color .2s;}
.color-swatch.selected{border-color:var(--pink-star);transform:scale(1.22);}
.charm-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:6px;}
.charm-btn{aspect-ratio:1;border:1.5px solid var(--border-med);background:var(--bg2);display:flex;align-items:center;justify-content:center;font-size:.75rem;transition:all .3s;}
.charm-btn.selected,.charm-btn:hover{border-color:var(--lavender);background:var(--blush);}
[data-theme="dark"] .charm-btn.selected,[data-theme="dark"] .charm-btn:hover{background:var(--bg3);}
.size-row,.type-row{display:flex;gap:7px;}
.size-btn,.type-btn{flex:1;padding:9px 6px;border:1.5px solid var(--border-med);background:transparent;color:var(--text);font-size:.66rem;letter-spacing:.5px;text-align:center;transition:all .3s;}
.size-btn.selected,.size-btn:hover,.type-btn.selected,.type-btn:hover{border-color:var(--lavender);background:var(--lavender);color:var(--purple-deep);}

/* ── CUSTOM DARK SECTION ── */
.custom-dark{background:var(--purple-deep);color:#fff;}
[data-theme="dark"] .custom-dark{background:var(--bg3);}
.custom-dark .section-title{color:#fff;}
[data-theme="dark"] .custom-dark .section-title{color:var(--text);}
.custom-dark .section-label{color:var(--pink-soft);}
.custom-dark .section-rule{background:var(--pink-star);}
.custom-layout{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;max-width:1040px;margin:0 auto;}
.custom-desc{color:rgba(255,255,255,.68);line-height:1.85;font-size:.86rem;margin-bottom:24px;}
[data-theme="dark"] .custom-desc{color:var(--text2);}
.themes-list{display:flex;flex-wrap:wrap;gap:7px;margin-bottom:24px;}
.theme-chip{padding:4px 12px;border:1px solid rgba(201,184,232,.3);font-size:.6rem;letter-spacing:1.5px;color:rgba(255,255,255,.7);transition:border-color .3s,color .3s;}
.theme-chip:hover{border-color:var(--pink-star);color:var(--pink-star);}
.feat-grid{display:grid;grid-template-columns:1fr 1fr;gap:11px;}
.feat-card{padding:18px 16px;border:1px solid rgba(201,184,232,.18);transition:border-color .3s;}
.feat-card:hover{border-color:var(--lavender);}
.feat-icon{width:22px;height:22px;color:var(--pink-star);margin-bottom:9px;}
[data-theme="dark"] .feat-icon{color:var(--lavender);}
.feat-title{font-family:'Playfair Display',serif;font-size:.86rem;color:#fff;margin-bottom:5px;}
[data-theme="dark"] .feat-title{color:var(--text);}
.feat-text{font-size:.7rem;color:rgba(255,255,255,.5);line-height:1.6;}
[data-theme="dark"] .feat-text{color:var(--text2);}

/* ── CART DRAWER ── */
.cart-overlay{position:fixed;inset:0;background:rgba(42,31,56,.6);z-index:500;opacity:0;pointer-events:none;transition:opacity .3s;}
.cart-overlay.open{opacity:1;pointer-events:all;}
.cart-drawer{position:fixed;right:0;top:0;bottom:0;width:min(400px,100vw);background:var(--card-bg);z-index:501;transform:translateX(100%);transition:transform .42s cubic-bezier(.77,0,.18,1);display:flex;flex-direction:column;box-shadow:-8px 0 40px rgba(42,31,56,.22);}
.cart-drawer.open{transform:translateX(0);}
.cart-header{display:flex;align-items:center;justify-content:space-between;padding:19px 22px;border-bottom:1px solid var(--border);}
.cart-header h2{font-family:'Playfair Display',serif;font-size:1.2rem;color:var(--text);}
.cart-close{color:var(--text2);font-size:1.2rem;transition:color .3s;}
.cart-close:hover{color:var(--text);}
.cart-items{flex:1;overflow-y:auto;padding:16px 22px;display:flex;flex-direction:column;gap:12px;}
.cart-empty{text-align:center;padding:48px 16px;color:var(--text2);}
.cart-empty-icon{width:44px;height:44px;margin:0 auto 14px;opacity:.35;}
.cart-empty p{font-size:.8rem;line-height:1.65;}
.cart-item{display:flex;gap:11px;align-items:flex-start;padding:12px;background:var(--bg2);border:1px solid var(--border);position:relative;}
.cart-item-icon{width:46px;height:46px;flex-shrink:0;background:var(--blush);display:flex;align-items:center;justify-content:center;}
[data-theme="dark"] .cart-item-icon{background:var(--bg3);}
.cart-item-icon svg{width:24px;height:24px;color:var(--purple-mid);}
.cart-item-info{flex:1;}
.cart-item-name{font-size:.82rem;font-weight:500;color:var(--text);line-height:1.3;margin-bottom:3px;}
.cart-item-meta{font-size:.62rem;color:var(--text2);letter-spacing:.3px;}
.cart-item-price{font-size:.88rem;font-weight:600;color:var(--text);margin-top:5px;}
.cart-item-qty{display:flex;align-items:center;gap:6px;margin-top:6px;}
.qty-btn{width:21px;height:21px;border:1px solid var(--border-med);color:var(--text);font-size:.82rem;display:flex;align-items:center;justify-content:center;transition:all .3s;}
.qty-btn:hover{background:var(--lavender);border-color:var(--lavender);color:var(--purple-deep);}
.qty-val{font-size:.8rem;width:20px;text-align:center;color:var(--text);}
.cart-item-remove{position:absolute;top:7px;right:7px;color:var(--text2);font-size:.72rem;transition:color .3s;}
.cart-item-remove:hover{color:var(--sale-red);}
.cart-footer{padding:16px 22px;border-top:1px solid var(--border);display:flex;flex-direction:column;gap:11px;}
.cart-totals{display:flex;flex-direction:column;gap:5px;}
.cart-row{display:flex;justify-content:space-between;align-items:center;}
.cr-lbl{font-size:.62rem;letter-spacing:1.5px;text-transform:uppercase;color:var(--text2);}
.cr-val{font-size:.88rem;color:var(--text);}
.cr-discount .cr-val{color:#25a855;font-size:.8rem;}
.cart-div{height:1px;background:var(--border);margin:2px 0;}
.cr-total .cr-lbl{color:var(--text);font-weight:600;font-size:.66rem;}
.cr-total .cr-val{font-family:'Playfair Display',serif;font-size:1.35rem;color:var(--purple-deep);}
[data-theme="dark"] .cr-total .cr-val{color:var(--lavender);}
.cart-checkout{width:100%;padding:14px;background:#25D366;color:#fff;font-size:.68rem;letter-spacing:2px;text-transform:uppercase;display:flex;align-items:center;justify-content:center;gap:9px;transition:background .3s,transform .2s;}
.cart-checkout:hover{background:#1ebe5d;transform:translateY(-2px);}
.cart-clear{width:100%;padding:7px;border:1px solid var(--border-med);color:var(--text2);font-size:.58rem;letter-spacing:1.5px;text-transform:uppercase;transition:all .3s;}
.cart-clear:hover{border-color:var(--sale-red);color:var(--sale-red);}

/* ── INSTAGRAM STRIP ── */
.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px;max-width:1200px;margin:0 auto 28px;}
.insta-cell{aspect-ratio:1;position:relative;overflow:hidden;background:var(--blush);}
[data-theme="dark"] .insta-cell{background:var(--bg3);}
.insta-cell svg{width:100%;height:100%;}
.insta-ov{position:absolute;inset:0;background:rgba(42,31,56,.5);display:flex;align-items:center;justify-content:center;opacity:0;transition:opacity .3s;}
.insta-ov svg{width:22px;height:22px;color:#fff;}
.insta-cell:hover .insta-ov{opacity:1;}
.insta-cta{text-align:center;}
.insta-handle{font-family:'Playfair Display',serif;font-size:.98rem;color:var(--text);display:inline-flex;align-items:center;gap:8px;transition:color .3s;}
.insta-handle:hover{color:var(--purple-mid);}

/* ── FOOTER ── */
footer{background:var(--charcoal);color:rgba(255,255,255,.9);padding:56px 5% 28px;}
[data-theme="dark"] footer{background:#110c1a;}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr;gap:48px;padding-bottom:40px;border-bottom:1px solid rgba(255,255,255,.08);margin-bottom:28px;}
.footer-logo{font-family:'Pinyon Script',cursive;font-size:2.2rem;color:var(--lavender);display:block;margin-bottom:12px;}
.footer-desc{font-size:.76rem;color:rgba(255,255,255,.42);line-height:1.75;max-width:250px;margin-bottom:20px;}
.social-links{display:flex;gap:9px;flex-wrap:wrap;}
.social-link{display:inline-flex;align-items:center;gap:6px;padding:7px 13px;border:1px solid rgba(255,255,255,.18);color:rgba(255,255,255,.7);font-size:.6rem;letter-spacing:1.5px;transition:border-color .3s,color .3s;}
.social-link:hover{border-color:var(--lavender);color:var(--lavender);}
.social-link svg{width:13px;height:13px;flex-shrink:0;}
.footer-col h4{font-size:.56rem;letter-spacing:3px;text-transform:uppercase;color:rgba(255,255,255,.3);margin-bottom:16px;}
.footer-col ul li{margin-bottom:9px;}
.footer-col a{color:rgba(255,255,255,.52);font-size:.76rem;transition:color .3s;}
.footer-col a:hover{color:var(--lavender);}
.footer-bottom{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:9px;}
.footer-bottom p{font-size:.58rem;color:rgba(255,255,255,.22);letter-spacing:.8px;}

/* ── TOAST ── */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(60px);background:var(--purple-deep);color:#fff;padding:10px 24px;font-size:.66rem;letter-spacing:1.5px;z-index:99999;opacity:0;pointer-events:none;transition:all .38s cubic-bezier(.34,1.56,.64,1);white-space:nowrap;}
[data-theme="dark"] .toast{background:var(--lavender);color:var(--purple-deep);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);}

/* ── BACK TO TOP ── */
.back-to-top{position:fixed;bottom:26px;right:26px;width:40px;height:40px;background:var(--purple-deep);color:#fff;display:flex;align-items:center;justify-content:center;opacity:0;pointer-events:none;transition:opacity .3s,background .3s,transform .2s;z-index:100;}
.back-to-top.visible{opacity:1;pointer-events:all;}
.back-to-top:hover{background:var(--pink-star);transform:translateY(-3px);}
.back-to-top svg{width:16px;height:16px;}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .75s,transform .75s;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ── SECTION DIVIDER ── */
.section-divider{height:1px;background:linear-gradient(90deg,transparent 0%,var(--border-med) 40%,var(--border-med) 60%,transparent 100%);max-width:1100px;margin:0 auto;}

/* ── KEYFRAMES ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(26px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes spinRing{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
@keyframes floatBead{0%,100%{transform:translateY(0)}50%{transform:translateY(-15px)}}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── RESPONSIVE ── */
@media(max-width:1100px){.product-grid{grid-template-columns:repeat(3,1fr);}}
@media(max-width:900px){
  .hero{grid-template-columns:1fr;padding:108px 5% 56px;}
  .hero-visual{height:260px;}
  .cat-grid{grid-template-columns:1fr 1fr;}
  .product-grid{grid-template-columns:repeat(2,1fr);}
  .custom-layout{grid-template-columns:1fr;gap:32px;}
  .footer-top{grid-template-columns:1fr;gap:30px;}
  .insta-grid{grid-template-columns:repeat(3,1fr);}
  nav .nav-links,.nav-social{display:none;}
  .hamburger{display:flex;}
  .builder-wrap{grid-template-columns:1fr;}
  .builder-preview{position:static;}
  .about-strip{gap:32px;}
  .about-div{display:none;}
  .gender-sidebar{display:none;}
}
@media(max-width:540px){
  .product-grid{grid-template-columns:1fr 1fr;gap:11px;}
  .cat-grid{grid-template-columns:1fr;}
  .feat-grid{grid-template-columns:1fr;}
  .hero-title{font-size:2.4rem;}
}

/* ── CART SALE ITEM TAGS ── */
.cart-sale-tag {
  display: inline-block;
  background: var(--sale-red);
  color: #fff;
  font-size: .46rem;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  padding: 2px 6px;
  vertical-align: middle;
  margin-left: 5px;
  line-height: 1.6;
}
.cart-sale-note {
  font-size: .6rem;
  color: #25a855;
  letter-spacing: .3px;
  font-weight: 400;
}

/* ── CART DISCOUNT ROW COLOURS ── */
.cr-discount .cr-lbl { color: #25a855; }
.cr-discount .cr-val { color: #25a855; font-size: .85rem; }

/* ── SALE PAGE ITEM INDICATOR ── */
.product-card.is-sale-item {
  outline: 1.5px solid rgba(192,48,74,.18);
}
