/*============================================
  RR Hair Care - Main Stylesheet
  Clean, professional, single-file
  ============================================*/

/*--- FONTS & VARIABLES ---*/
:root {
  --rose: #c97b84;
  --gold: #c9a96e;
  --dark: #2c1e24;
  --text: #3d2c33;
  --muted: #7a6a72;
  --bg: #fdf7f5;
  --white: #fff;
  --border: #efe0e3;
  --font: 'Plus Jakarta Sans', sans-serif;
  --serif: 'Playfair Display', serif;
  --radius: 12px;
}

/*--- RESET ---*/
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font);color:var(--text);background:var(--bg);line-height:1.6;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}

/*--- UTILITY ---*/
.container{max-width:1100px;margin:0 auto;padding:0 24px}
.section{padding:80px 0}
.bg-light{background:linear-gradient(135deg,#fdf7f5 0%,#fff5f6 100%)}
.ctr{text-align:center;margin-top:32px}
.subtitle{text-align:center;color:var(--muted);font-size:14px;margin-bottom:24px}
.sec-head{text-align:center;margin-bottom:48px}
.sec-head span{display:inline-block;font-size:12px;font-weight:600;color:var(--rose);text-transform:uppercase;letter-spacing:2px;margin-bottom:8px}
.sec-head h2{font-family:var(--serif);font-size:36px;color:var(--dark);font-weight:700}

/*--- BUTTONS ---*/
.btn{display:inline-flex;align-items:center;gap:6px;padding:12px 28px;border-radius:50px;font-family:var(--font);font-size:14px;font-weight:600;cursor:pointer;transition:all .25s;border:none;text-decoration:none}
.btn-primary{background:var(--rose);color:#fff}
.btn-primary:hover{background:#b86a73;transform:translateY(-1px);box-shadow:0 4px 12px rgba(201,123,132,.3)}
.btn-outline{border:2px solid var(--rose);color:var(--rose);background:transparent}
.btn-outline:hover{background:var(--rose);color:#fff}
.btn-lg{padding:14px 36px;font-size:16px;width:100%;justify-content:center}

/*--- NAV ---*/
#nav{position:sticky;top:0;z-index:1000;background:rgba(255,255,255,.92);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);transition:box-shadow .3s}
#nav.scrolled{box-shadow:0 2px 20px rgba(0,0,0,.06)}
.nav-inner{max-width:1100px;margin:0 auto;padding:0 24px;display:flex;align-items:center;height:64px;gap:24px}
.nav-logo{display:flex;align-items:center;gap:10px;font-weight:700;font-size:18px;color:var(--dark);flex-shrink:0}
.logo-img{width:36px;height:36px;border-radius:8px;object-fit:cover}
.nav-links{display:flex;gap:24px;list-style:none;margin-left:auto}
.nav-links a{font-size:13px;font-weight:500;color:var(--muted);transition:color .2s;white-space:nowrap}
.nav-links a:hover{color:var(--rose)}
.theme-btn,.menu-btn{background:none;border:none;cursor:pointer;font-size:20px;padding:4px;line-height:1}
.menu-btn{display:none;flex-direction:column;gap:5px;padding:8px}
.menu-btn span{display:block;width:22px;height:2px;background:var(--dark);border-radius:2px;transition:.3s}
.menu-btn.active span:nth-child(1){transform:rotate(45deg) translate(5px,5px)}
.menu-btn.active span:nth-child(2){opacity:0}
.menu-btn.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-5px)}

/* Mobile nav */
@media(max-width:768px){
  .nav-links{position:fixed;top:64px;left:0;right:0;background:var(--white);flex-direction:column;padding:24px;gap:16px;border-bottom:1px solid var(--border);transform:translateY(-120%);transition:.3s;z-index:999;box-shadow:0 8px 24px rgba(0,0,0,.08)}
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:15px}
  .theme-btn{margin-left:auto}
  .menu-btn{display:flex}
  .nav-ddown{display:none !important}
}

/* Desktop: hamburger with 3 primary items visible */
@media(min-width:769px){
  .nav-links li:not(.nav-primary){display:none}
  .nav-links{gap:20px;margin-left:0}
  .theme-btn{margin-left:auto}
  .menu-btn{display:flex}
  .nav-ddown{
    display:none;
    position:absolute;
    top:72px;
    right:12px;
    background:var(--white);
    border-radius:12px;
    box-shadow:0 8px 32px rgba(0,0,0,.12);
    border:1px solid var(--border);
    min-width:220px;
    padding:8px;
    z-index:1001;
  }
  .nav-ddown.open{display:block;animation:fadeIn .2s}
  .nav-ddown a{
    display:block;
    padding:10px 16px;
    border-radius:8px;
    font-size:13px;
    font-weight:500;
    color:var(--muted);
    transition:background .15s,color .15s;
  }
  .nav-ddown a:hover{
    background:#fff5f6;
    color:var(--rose);
  }
  body.dark .nav-ddown{
    background:#1e1e36;
    border-color:rgba(255,255,255,.06);
  }
  body.dark .nav-ddown a:hover{background:#252540}
}

/*--- HERO ---*/
.hero{min-height:85vh;display:flex;align-items:center;text-align:center;background:linear-gradient(135deg,#fdf7f5 0%,#fff5f6 50%,#fdf0f2 100%);padding:120px 0 80px}
.hero-sub{font-size:14px;font-weight:500;color:var(--rose);text-transform:uppercase;letter-spacing:3px;margin-bottom:12px}
.hero-title{font-family:var(--serif);font-size:clamp(42px,8vw,72px);font-weight:800;color:var(--dark);margin-bottom:20px;line-height:1.1}
.hero-tagline{font-size:17px;color:var(--muted);max-width:500px;margin:0 auto 32px;line-height:1.7}
.hero-cta{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}

/*--- ABOUT ---*/
.about-grid{display:grid;grid-template-columns:320px 1fr;gap:56px;align-items:start}
.about-owner{text-align:center}
.owner-img{border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4;margin-bottom:20px}
.owner-img img{width:100%;height:100%;object-fit:cover}
.about-owner h3{font-size:20px;font-weight:700;color:var(--dark);margin-bottom:2px}
.about-owner h3 em{font-style:normal;font-weight:400;color:var(--rose);margin:0 4px}
.about-owner p{font-size:12px;color:var(--rose);font-weight:600;text-transform:uppercase;letter-spacing:1px;margin-bottom:8px}
.about-owner small{display:block;font-size:13px;color:var(--muted);margin-bottom:16px}
.about-owner blockquote{font-size:14px;color:var(--muted);line-height:1.7;font-style:italic;border-left:3px solid var(--rose);padding-left:16px;text-align:left}
.about-text p{font-size:14px;color:var(--muted);line-height:1.8;margin-bottom:16px}
.highlights{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:24px}
.hl-item{background:var(--white);padding:20px;border-radius:var(--radius);border:1px solid var(--border);text-align:center;transition:.3s}
.hl-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,.04)}
.hl-item span{font-size:24px;display:block;margin-bottom:8px}
.hl-item h4{font-size:14px;font-weight:700;color:var(--dark);margin-bottom:4px}
.hl-item p{font-size:12px;color:var(--muted);margin:0;line-height:1.5}
@media(max-width:768px){
  .about-grid{grid-template-columns:1fr;gap:32px}
  .about-owner{max-width:280px;margin:0 auto}
}

/*--- SERVICES ---*/
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.svc-card{background:var(--white);border-radius:var(--radius);padding:32px 24px;text-align:center;border:1px solid var(--border);transition:all .3s}
.svc-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px rgba(201,123,132,.1);border-color:rgba(201,123,132,.2)}
.svc-icon{font-size:32px;margin-bottom:14px}
.svc-card h3{font-size:15px;font-weight:700;color:var(--dark);margin-bottom:8px}
.svc-card p{font-size:13px;color:var(--muted);line-height:1.6}
@media(max-width:900px){.svc-grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.svc-grid{grid-template-columns:1fr}}

/*--- BOOKING ---*/
.booking-counter{text-align:center;margin-bottom:20px}
.booking-counter span{display:inline-block;background:var(--rose);color:#fff;padding:8px 24px;border-radius:24px;font-size:14px;font-weight:700}
.booking-form{max-width:600px;margin:0 auto;background:var(--white);border-radius:var(--radius);padding:32px;box-shadow:0 2px 16px rgba(0,0,0,.04);border:1px solid var(--border)}
.booking-note{text-align:center;background:#fff5f6;padding:12px;border-radius:8px;border:1px dashed var(--rose);margin-bottom:24px;font-size:13px;color:var(--muted)}
.booking-note strong{color:var(--rose)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.form-row.full{grid-template-columns:1fr}
.form-row label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:6px}
.form-row small{font-weight:400;color:#999}
.booking-form input,.booking-form select{width:100%;padding:11px 14px;border:2px solid var(--border);border-radius:8px;font-size:14px;font-family:var(--font);color:var(--text);background:var(--bg);transition:.2s}
.booking-form input:focus,.booking-form select:focus{outline:none;border-color:var(--rose);background:var(--white)}
.booking-form select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23c97b84' stroke-width='2.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.svc-list{max-height:280px;overflow-y:auto;border:2px solid var(--border);border-radius:8px;padding:8px;margin-top:4px;background:var(--white)}
.svc-list label{display:flex;align-items:center;gap:8px;padding:8px 10px;border-radius:6px;cursor:pointer;font-size:13px;font-weight:400;transition:.15s;margin:0}
.svc-list label:hover{background:#fff5f6}
.svc-list input[type=checkbox]{accent-color:var(--rose);width:15px;height:15px}
.svc-list .svc-price{margin-left:auto;font-weight:700;color:var(--rose);font-size:12px}
.booking-total{display:flex;justify-content:space-between;align-items:center;background:#fff5f6;padding:14px 16px;border-radius:8px;border:1px solid var(--rose);margin-bottom:16px;font-size:15px}
.booking-total strong{font-size:18px;color:var(--rose)}
.pay-options{display:flex;gap:8px;flex-wrap:wrap}
.pay-opt{flex:1;min-width:100px;display:flex;align-items:center;gap:6px;padding:12px 14px;border:2px solid var(--border);border-radius:8px;cursor:pointer;font-size:13px;font-weight:600;background:var(--bg);transition:.2s}
.pay-opt:has(input:checked){border-color:var(--rose);background:#fff5f6;color:var(--rose)}
.pay-opt input{display:none}
.pay-info{margin-top:12px;padding:12px 16px;background:#f0fdf4;border-radius:8px;border:1px solid #bbf7d0;font-size:13px}
.btn-copy{background:#25d366;color:#fff;border:none;padding:3px 10px;border-radius:6px;cursor:pointer;font-size:11px;font-weight:600}
.booking-warning{text-align:center;padding:10px;margin:16px 0;background:#fff8e1;border-radius:8px;border:1px solid #ffe082;font-size:12px;color:#8d6e00}
@media(max-width:500px){.booking-form{padding:20px}.form-row{grid-template-columns:1fr}}

/*--- PRODUCTS ---*/
.prod-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:16px}
.prod-card{background:var(--white);border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);transition:.3s;display:flex;flex-direction:column}
.prod-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(201,123,132,.1)}
.prod-img{aspect-ratio:3/4;overflow:hidden;background:#f5f0f2}
.prod-img img{width:100%;height:100%;object-fit:cover}
.prod-info{padding:14px 12px 12px;flex:1;display:flex;flex-direction:column}
.prod-info h4{font-size:13px;font-weight:700;color:var(--dark);margin-bottom:4px}
.prod-info p{font-size:11px;color:var(--muted);line-height:1.5;margin-bottom:8px;flex:1}
.prod-price{font-size:16px;font-weight:800;color:var(--rose);margin-bottom:8px}
.prod-badge{position:absolute;top:8px;left:8px;background:var(--rose);color:#fff;font-size:9px;font-weight:700;padding:3px 8px;border-radius:12px;text-transform:uppercase}
.prod-img-wrap{position:relative}

/*--- TESTIMONIALS ---*/
.testi-wrapper{position:relative;max-width:700px;margin:0 auto;overflow:hidden}
.testi-track{display:flex;transition:transform .5s ease}
.testi-card{min-width:100%;padding:36px 32px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border);text-align:center}
.testi-stars{font-size:20px;margin-bottom:16px;letter-spacing:2px}
.testi-text{font-size:15px;color:var(--muted);line-height:1.8;margin:0 auto 20px;max-width:520px;font-style:italic}
.testi-author strong{display:block;font-size:15px;font-weight:700;color:var(--dark)}
.testi-author span{display:block;font-size:12px;color:var(--rose);font-weight:600;margin-top:2px}
.testi-dots{display:flex;justify-content:center;gap:8px;margin-top:24px}
.testi-dot{width:8px;height:8px;border-radius:50%;background:var(--border);transition:.3s;cursor:pointer;border:none;padding:0}
.testi-dot.active{background:var(--rose);width:24px;border-radius:4px}
.testi-arrow{position:absolute;top:50%;transform:translateY(-50%);width:40px;height:40px;border-radius:50%;background:var(--white);border:1px solid var(--border);color:var(--rose);font-size:22px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:.3s;z-index:2}
.testi-arrow:hover{background:var(--rose);color:#fff;border-color:var(--rose)}
.testi-prev{left:0}
.testi-next{right:0}
@media(max-width:600px){
  .testi-card{padding:24px 20px}
  .testi-arrow{width:32px;height:32px;font-size:16px}
}

/*--- GALLERY ---*/
.gal-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;max-width:600px;margin:0 auto}
.gal-item{border-radius:var(--radius);overflow:hidden;aspect-ratio:3/4}
.gal-item img{width:100%;height:100%;object-fit:cover}
@media(max-width:600px){.gal-grid{max-width:100%;gap:10px}}

/*--- LIGHTBOX ---*/
.lightbox{display:none;position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.92);z-index:10000;justify-content:center;align-items:center;flex-direction:column;animation:fadeIn .2s}
.lightbox.active{display:flex}
.lightbox img{max-width:90vw;max-height:85vh;border-radius:8px;box-shadow:0 4px 40px rgba(0,0,0,.4);object-fit:contain}
.lightbox-close{position:fixed;top:18px;right:24px;font-size:40px;color:#fff;cursor:pointer;z-index:10001;line-height:1;transition:color .2s;width:44px;height:44px;display:flex;align-items:center;justify-content:center}
.lightbox-close:hover{color:var(--rose)}
.lightbox-nav{color:#fff;font-size:48px;cursor:pointer;padding:16px;user-select:none;transition:color .2s;position:fixed;top:50%;transform:translateY(-50%);z-index:10001}
.lightbox-nav:hover{color:var(--rose)}
.lightbox-prev{left:8px}
.lightbox-next{right:8px}
.lightbox-counter{color:#ccc;margin-top:14px;font-size:13px;font-family:'Plus Jakarta Sans',sans-serif}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@media(max-width:600px){.lightbox-nav{font-size:34px;padding:10px}.lightbox-close{top:10px;right:10px;font-size:32px}}

/*--- LOCATION ---*/
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:40px;align-items:start}
.loc-info h3{font-size:16px;font-weight:700;color:var(--dark);margin-bottom:6px;margin-top:24px}
.loc-info h3:first-child{margin-top:0}
.loc-info p{font-size:14px;color:var(--muted);line-height:1.7;margin-bottom:8px}
.loc-map iframe{border-radius:var(--radius);min-height:320px}
@media(max-width:768px){.loc-grid{grid-template-columns:1fr;gap:24px}}

/*--- CONTACT ---*/
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px}
.ct-card{display:flex;flex-direction:column;align-items:center;gap:8px;padding:28px 16px;background:var(--white);border-radius:var(--radius);border:1px solid var(--border);text-align:center;transition:.3s;text-decoration:none}
.ct-card:hover{transform:translateY(-3px);box-shadow:0 6px 20px rgba(201,123,132,.08);border-color:rgba(201,123,132,.2)}
.ct-card span{font-size:28px}
.ct-icon{width:28px;height:28px;border-radius:6px;object-fit:cover}
.ct-svg{width:32px;height:32px;flex-shrink:0}
.ct-card h4{font-size:14px;font-weight:700;color:var(--dark)}
.ct-card p{font-size:12px;color:var(--muted)}

/*--- FOOTER ---*/
footer{background:var(--dark);color:#c0b0b8;padding:48px 0 24px;margin-top:80px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr;gap:40px}
.footer-grid h3{font-family:var(--serif);font-size:20px;color:#e0d0d6;margin-bottom:8px}
.footer-grid h4{font-size:13px;font-weight:600;color:#a09098;text-transform:uppercase;letter-spacing:1px;margin-bottom:12px}
.footer-grid p,.footer-grid a{font-size:13px;line-height:1.8;color:#a09098}
.footer-grid a{display:block;transition:.2s}
.footer-grid a:hover{color:var(--rose)}
.footer-bottom{text-align:center;padding-top:24px;margin-top:24px;border-top:1px solid rgba(255,255,255,.06);font-size:12px;color:#6a5a62}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr;gap:24px;text-align:center}}

/*--- FLOATING WA ---*/
.wa-float{position:fixed;bottom:24px;right:24px;width:50px;height:50px;background:#25d366;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:22px;box-shadow:0 4px 16px rgba(37,211,102,.3);z-index:999;transition:.3s;text-decoration:none}
.wa-float:hover{transform:scale(1.1)}

/*--- DARK MODE ---*/
body.dark{background:#1a1a2e;color:#c8b5bb}
body.dark #nav{background:rgba(26,26,46,.92);border-color:rgba(255,255,255,.04)}
body.dark .bg-light{background:#16162a}
body.dark .hero{background:#1a1a2e}
body.dark .svc-card,body.dark .hl-item,body.dark .ct-card,body.dark .prod-card,body.dark .booking-form{background:#1e1e36;border-color:rgba(255,255,255,.06)}
body.dark .svc-card h3,body.dark .hl-item h4,body.dark .ct-card h4,body.dark .prod-info h4{color:#e0d0d6}
body.dark .svc-card p,body.dark .hl-item p,body.dark .ct-card p,body.dark .prod-info p{color:#a09098}
body.dark .sec-head h2,body.dark .about-owner h3{color:#e0d0d6}
body.dark .about-owner blockquote,body.dark .about-text p{color:#a09098}
body.dark .booking-form input,body.dark .booking-form select,body.dark .booking-form .svc-list{background:#252540;border-color:#2a2a3e;color:#d8c5cc}
body.dark .prod-img{background:#252540}
body.dark .footer-grid h3{color:#e0d0d6}
body.dark .btn-outline{border-color:var(--rose);color:var(--rose)}
body.dark .btn-outline:hover{background:var(--rose);color:#fff}
body.dark .testi-card{background:#1e1e36;border-color:rgba(255,255,255,.06)}

body.dark .testi-text{color:#a09098}

body.dark .testi-author strong{color:#e0d0d6}

body.dark .testi-arrow{background:#1e1e36;border-color:#2a2a3e;color:var(--rose)}

body.dark .testi-arrow:hover{background:var(--rose);color:#fff}

body.dark .gal-item{box-shadow:0 2px 12px rgba(0,0,0,.2)}

/*--- RESPONSIVE ---*/
@media(max-width:600px){
  .section{padding:56px 0}
  .sec-head h2{font-size:28px}
  .hero{min-height:70vh;padding:100px 0 60px}
  .highlights{grid-template-columns:1fr 1fr}
}

/*--- CART ---*/
.cart-btn{background:none;border:none;cursor:pointer;font-size:20px;padding:4px;line-height:1;position:relative}
.cart-badge{position:absolute;top:-4px;right:-6px;background:var(--rose);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:.3s}
.cart-badge.hide{opacity:0;transform:scale(0)}
.cart-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);z-index:2000;opacity:0;pointer-events:none;transition:opacity .3s}
.cart-overlay.open{opacity:1;pointer-events:auto}
.cart-panel{position:fixed;top:0;right:0;width:380px;max-width:90vw;height:100%;background:var(--white);z-index:2001;box-shadow:-4px 0 24px rgba(0,0,0,.1);display:flex;flex-direction:column;transform:translateX(100%);transition:transform .3s ease}
.cart-panel.open{transform:translateX(0)}
.cart-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}
.cart-header h3{font-size:18px;font-weight:700;color:var(--dark)}
.cart-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--muted);padding:0;line-height:1}
.cart-close:hover{color:var(--rose)}
.cart-items{flex:1;overflow-y:auto;padding:16px 24px}
.cart-empty{text-align:center;color:var(--muted);font-size:14px;margin-top:40px}
.cart-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--border)}
.cart-item-img{width:48px;height:48px;border-radius:8px;object-fit:cover;background:#f5f0f2;flex-shrink:0}
.cart-item-info{flex:1;min-width:0}
.cart-item-name{font-size:13px;font-weight:600;color:var(--dark);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cart-item-sku{font-size:11px;color:var(--muted)}
.cart-item-qty{display:flex;align-items:center;gap:6px;margin-top:4px}
.cart-item-qty button{width:24px;height:24px;border-radius:50%;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;color:var(--text);transition:.15s}
.cart-item-qty button:hover{background:var(--rose);color:#fff;border-color:var(--rose)}
.cart-item-qty span{font-size:13px;font-weight:600;min-width:18px;text-align:center}
.cart-item-del{background:none;border:none;cursor:pointer;color:#ccc;font-size:16px;padding:4px;transition:.15s}
.cart-item-del:hover{color:#e74c3c}
.cart-addr{margin-bottom:12px}
.cart-addr label{display:block;font-size:12px;font-weight:600;color:var(--text);margin-bottom:4px}
.cart-addr small{font-weight:400;color:#999;font-size:11px}
.cart-addr textarea{width:100%;padding:10px 12px;border:2px solid var(--border);border-radius:8px;font-size:13px;font-family:var(--font);color:var(--text);background:var(--bg);transition:.2s;resize:vertical;min-height:60px;line-height:1.5}
.cart-addr textarea:focus{outline:none;border-color:var(--rose);background:var(--white)}
body.dark .cart-addr label{color:#a09098}
body.dark .cart-addr textarea{background:#252540;border-color:#2a2a3e;color:#d8c5cc}
.cart-footer{padding:16px 24px 24px;border-top:1px solid var(--border)}
.cart-total{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}
.cart-total span{font-size:14px;color:var(--muted)}
.cart-total strong{font-size:20px;color:var(--rose)}

/*--- PRODUCT QTY ---*/
.prod-qty{display:flex;align-items:center;gap:4px;margin-top:8px}
.prod-qty button{width:28px;height:28px;border-radius:50%;border:1px solid var(--border);background:var(--bg);cursor:pointer;font-size:16px;line-height:1;display:flex;align-items:center;justify-content:center;color:var(--text);transition:.15s;padding:0}
.prod-qty button:hover{background:var(--rose);color:#fff;border-color:var(--rose)}
.prod-qty button:active{transform:scale(.9)}
.prod-qty span{font-size:14px;font-weight:700;min-width:24px;text-align:center;color:var(--dark)}
.prod-add{width:28px;height:28px;border-radius:50%;border:none;background:var(--rose);color:#fff;cursor:pointer;font-size:14px;line-height:1;display:flex;align-items:center;justify-content:center;transition:.15s;margin-left:auto;padding:0}
.prod-add:hover{background:#b86a73;transform:scale(1.05)}
.prod-add:active{transform:scale(.9)}
.prod-add.added{background:#22c55e;animation:pop .2s}

/*--- DARK MODE CART ---*/
body.dark .cart-panel{background:#1e1e36}
body.dark .cart-header{border-color:rgba(255,255,255,.06)}
body.dark .cart-header h3{color:#e0d0d6}
body.dark .cart-item{border-color:rgba(255,255,255,.06)}
body.dark .cart-item-name{color:#e0d0d6}
body.dark .cart-item-qty button{background:#252540;border-color:#2a2a3e;color:#d8c5cc}
body.dark .cart-item-del{color:#5a4a52}
body.dark .cart-footer{border-color:rgba(255,255,255,.06)}
body.dark .cart-empty{color:#8a7a82}
body.dark .prod-qty button{background:#252540;border-color:#2a2a3e;color:#d8c5cc}
body.dark .prod-qty span{color:#e0d0d6}

@keyframes pop{0%{transform:scale(1)}50%{transform:scale(1.2)}100%{transform:scale(1)}}
