/* ===== RESET & BASE ===== */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; }
body { font-family:'Poppins',sans-serif; color:#2d2d2d; background:#fff; font-size:15px; line-height:1.6; -webkit-font-smoothing:antialiased; }
a { text-decoration:none; color:inherit; transition:all .3s ease; }
img { max-width:100%; height:auto; display:block; }
ul { list-style:none; }
button, input, select, textarea { font-family:inherit; font-size:inherit; outline:none; }
.container { max-width:1280px; margin:0 auto; padding:0 24px; }
.serif { font-family:'Playfair Display',Georgia,serif; }

/* ===== COLORS ===== */
:root {
    --pink: #d4a0b9;
    --pink-soft: #f0d4e1;
    --pink-pale: #fdf2f6;
    --pink-dark: #b8728d;
    --pink-deep: #9e5c75;
    --cream: #fefcfb;
    --white: #ffffff;
    --text: #2d2d2d;
    --text-mid: #6b6b6b;
    --text-light: #9a9a9a;
    --border: #f0eaed;
    --border-light: #f7f3f5;
    --shadow-sm: 0 1px 8px rgba(180,130,150,0.06);
    --shadow-md: 0 4px 24px rgba(180,130,150,0.1);
    --shadow-lg: 0 12px 48px rgba(180,130,150,0.14);
    --radius: 16px;
    --radius-sm: 10px;
    --transition: all .35s cubic-bezier(.4,0,.2,1);
}

/* ===== TOP BAR ===== */
.top-bar {
    background:var(--text);
    color:rgba(255,255,255,0.7);
    font-size:11px;
    letter-spacing:0.3px;
}
.top-bar-inner {
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:38px;
}
.top-bar-left { display:flex; align-items:center; gap:6px; }
.top-bar-left a { display:flex; align-items:center; gap:5px; color:rgba(255,255,255,0.7); font-size:11px; }
.top-bar-left a:hover { color:#fff; }
.top-bar-divider { width:1px; height:12px; background:rgba(255,255,255,0.15); margin:0 10px; }
.top-bar-center { position:absolute; left:50%; transform:translateX(-50%); }
.top-bar-marquee { display:flex; align-items:center; gap:8px; color:rgba(255,255,255,0.85); font-size:11px; letter-spacing:0.5px; white-space:nowrap; }
.top-bar-dot { width:3px; height:3px; border-radius:50%; background:var(--pink); flex-shrink:0; }
.top-bar-right { display:flex; align-items:center; gap:14px; }
.top-bar-right a { color:rgba(255,255,255,0.6); display:flex; }
.top-bar-right a:hover { color:#fff; }

/* ===== HEADER ===== */
.site-header {
    background:rgba(255,255,255,0.97);
    backdrop-filter:blur(24px);
    -webkit-backdrop-filter:blur(24px);
    border-bottom:1px solid var(--border-light);
    position:sticky;
    top:0;
    z-index:100;
    transition:box-shadow .3s;
}
.site-header.scrolled { box-shadow:0 2px 20px rgba(0,0,0,0.05); }
.header-inner {
    display:flex;
    align-items:center;
    justify-content:space-between;
    height:170px;
}
.logo img { height:160px; width:auto; }

/* Navigation */
.main-nav { display:flex; gap:32px; align-items:center; }
.main-nav > a, .nav-dropdown-trigger {
    font-size:13px;
    font-weight:500;
    color:var(--text-mid);
    text-transform:uppercase;
    letter-spacing:1.2px;
    position:relative;
    padding:4px 0;
    display:inline-flex;
    align-items:center;
    gap:4px;
    background:none;
    border:none;
    cursor:pointer;
}
.main-nav > a:hover, .nav-dropdown-trigger:hover { color:var(--pink-deep); }
.main-nav > a.active, .nav-dropdown-trigger.active { color:var(--pink-deep); }
.main-nav > a::after, .nav-dropdown-trigger::after {
    content:'';
    position:absolute;
    bottom:-2px; left:50%;
    transform:translateX(-50%);
    width:0; height:1.5px;
    background:var(--pink-dark);
    transition:width .3s ease;
}
.main-nav > a:hover::after, .nav-dropdown-trigger:hover::after,
.main-nav > a.active::after, .nav-dropdown-trigger.active::after { width:100%; }

/* Dropdown */
.nav-dropdown { position:relative; }
.nav-dropdown-menu {
    position:absolute;
    top:100%;
    left:50%;
    transform:translateX(-50%) translateY(10px);
    background:var(--white);
    border:1px solid var(--border);
    border-radius:var(--radius-sm);
    padding:12px 0;
    min-width:200px;
    box-shadow:var(--shadow-lg);
    opacity:0;
    visibility:hidden;
    transition:all .25s ease;
    z-index:50;
}
.nav-dropdown:hover .nav-dropdown-menu {
    opacity:1; visibility:visible;
    transform:translateX(-50%) translateY(0);
}
.nav-dropdown-menu a {
    display:block;
    padding:10px 24px;
    font-size:13px;
    color:var(--text-mid);
    text-transform:none;
    letter-spacing:0;
}
.nav-dropdown-menu a:hover { background:var(--pink-pale); color:var(--pink-deep); }

/* Header actions */
.header-actions { display:flex; align-items:center; gap:8px; }
.header-search-btn {
    background:none; border:none; cursor:pointer;
    color:var(--text-mid);
    padding:8px; border-radius:50%;
    transition:var(--transition); display:flex;
}
.header-search-btn:hover { color:var(--pink-deep); background:var(--pink-pale); }
.cart-icon {
    position:relative; color:var(--text-mid);
    padding:8px; border-radius:50%;
    transition:var(--transition); display:flex;
}
.cart-icon:hover { color:var(--pink-deep); background:var(--pink-pale); }
.cart-count {
    position:absolute; top:0; right:0;
    background:var(--pink-dark); color:#fff;
    font-size:10px; font-weight:600;
    width:18px; height:18px; border-radius:50%;
    display:flex; align-items:center; justify-content:center;
    border:2px solid #fff;
}

/* Search Overlay */
.search-overlay {
    position:absolute; top:100%; left:0; right:0;
    background:var(--white);
    border-bottom:1px solid var(--border);
    padding:20px 0;
    transform:translateY(-10px);
    opacity:0; visibility:hidden;
    transition:all .25s ease;
    box-shadow:var(--shadow-md);
}
.search-overlay.active { opacity:1; visibility:visible; transform:translateY(0); }
.search-form {
    display:flex; align-items:center; gap:14px;
    max-width:600px; margin:0 auto;
}
.search-form input {
    flex:1; border:none; font-size:16px;
    padding:8px 0; color:var(--text);
    background:transparent;
}
.search-form input::placeholder { color:var(--text-light); }
.search-close { background:none; border:none; cursor:pointer; color:var(--text-light); display:flex; padding:4px; }
.search-close:hover { color:var(--text); }

/* Mobile menu button */
.mobile-menu-btn {
    display:none; background:none; border:none;
    cursor:pointer; padding:10px; flex-direction:column;
    gap:5px; border-radius:var(--radius-sm);
    transition:var(--transition);
    z-index:102;
}
.mobile-menu-btn:hover { background:var(--pink-pale); }
.mobile-menu-btn span { display:block; width:22px; height:2px; background:var(--text); transition:all .3s; border-radius:2px; }
.mobile-menu-btn.active span:nth-child(1) { transform:rotate(45deg) translate(5px,5px); }
.mobile-menu-btn.active span:nth-child(2) { opacity:0; }
.mobile-menu-btn.active span:nth-child(3) { transform:rotate(-45deg) translate(5px,-5px); }

/* Mobile overlay backdrop */
.mobile-overlay {
    display:none;
    position:fixed; inset:0;
    background:rgba(0,0,0,0.4);
    z-index:98;
    opacity:0;
    transition:opacity .35s ease;
}
.mobile-overlay.active { display:block; opacity:1; }

/* ===== HERO BANNER ===== */
.hero-banner {
    position:relative;
    min-height:85vh;
    display:flex;
    align-items:center;
    overflow:hidden;
    background:var(--pink-pale);
}
.hero-banner-bg {
    position:absolute; inset:0;
    background:linear-gradient(135deg, #fdf2f6 0%, #f8e4ed 25%, #fdf2f6 50%, #fce8f0 75%, #fff 100%);
}
.hero-banner-bg::before {
    content:'';
    position:absolute; top:-20%; right:-10%;
    width:700px; height:700px;
    background:radial-gradient(circle, rgba(212,160,185,0.2) 0%, transparent 70%);
    border-radius:50%;
}
.hero-banner-bg::after {
    content:'';
    position:absolute; bottom:-20%; left:10%;
    width:500px; height:500px;
    background:radial-gradient(circle, rgba(240,212,225,0.3) 0%, transparent 70%);
    border-radius:50%;
}
.hero-banner .container { position:relative; z-index:2; }
.hero-banner-grid {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:60px;
    align-items:center;
}
.hero-banner-content { max-width:520px; }
.hero-badge {
    display:inline-flex;
    align-items:center;
    gap:6px;
    font-size:11px;
    font-weight:600;
    text-transform:uppercase;
    letter-spacing:2.5px;
    color:var(--pink-deep);
    margin-bottom:24px;
    padding:8px 18px;
    background:rgba(158,92,117,0.08);
    border-radius:30px;
    border:1px solid rgba(158,92,117,0.12);
}
.hero-badge-dot { width:6px; height:6px; border-radius:50%; background:var(--pink-dark); animation:pulse 2s infinite; }
@keyframes pulse { 0%,100% { opacity:1; } 50% { opacity:0.4; } }

.hero-banner h1 {
    font-family:'Playfair Display',serif;
    font-size:58px;
    font-weight:400;
    color:var(--text);
    line-height:1.15;
    margin-bottom:20px;
    letter-spacing:-0.5px;
}
.hero-banner h1 strong { font-weight:700; font-style:italic; color:var(--pink-deep); }
.hero-banner p {
    font-size:16px; color:var(--text-mid);
    line-height:1.8; margin-bottom:36px; max-width:420px;
}
.hero-buttons { display:flex; gap:14px; flex-wrap:wrap; }
.hero-stats {
    display:flex; gap:40px; margin-top:50px;
    padding-top:30px;
    border-top:1px solid var(--border);
}
.hero-stat-num { font-family:'Playfair Display',serif; font-size:32px; font-weight:600; color:var(--pink-deep); }
.hero-stat-label { font-size:12px; color:var(--text-light); text-transform:uppercase; letter-spacing:1px; margin-top:4px; }

.hero-banner-visual {
    position:relative;
    display:flex;
    justify-content:center;
}
.hero-image-grid {
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:16px;
    max-width:500px;
}
.hero-img-card {
    border-radius:20px;
    overflow:hidden;
    aspect-ratio:3/4;
    background:var(--pink-soft);
    box-shadow:var(--shadow-lg);
    position:relative;
}
.hero-img-card:nth-child(2) { margin-top:40px; }
.hero-img-card img { width:100%; height:100%; object-fit:cover; }
.hero-img-card .hero-img-tag {
    position:absolute;
    bottom:16px; left:16px;
    background:rgba(255,255,255,0.92);
    backdrop-filter:blur(10px);
    padding:8px 16px;
    border-radius:30px;
    font-size:12px;
    font-weight:500;
    color:var(--text);
}

/* ===== MARQUEE ===== */
.marquee-strip {
    background:var(--text);
    padding:14px 0;
    overflow:hidden;
    white-space:nowrap;
}
.marquee-inner {
    display:inline-flex;
    animation:marqueeScroll 30s linear infinite;
}
.marquee-inner span {
    color:rgba(255,255,255,0.7);
    font-size:12px;
    text-transform:uppercase;
    letter-spacing:3px;
    font-weight:500;
    padding:0 30px;
}
.marquee-inner .marquee-dot {
    color:var(--pink);
    padding:0;
}
@keyframes marqueeScroll {
    0% { transform:translateX(0); }
    100% { transform:translateX(-50%); }
}

/* ===== BUTTONS ===== */
.btn {
    display:inline-flex; align-items:center; justify-content:center; gap:8px;
    padding:15px 40px; border-radius:50px;
    font-weight:500; font-size:13px; cursor:pointer;
    transition:var(--transition); border:none;
    text-transform:uppercase; letter-spacing:1px;
}
.btn-primary {
    background:var(--pink-dark); color:#fff;
    box-shadow:0 4px 20px rgba(184,114,141,0.25);
}
.btn-primary:hover {
    background:var(--pink-deep);
    transform:translateY(-2px);
    box-shadow:0 8px 30px rgba(184,114,141,0.35);
}
.btn-outline { background:transparent; color:var(--text); border:1.5px solid var(--border); }
.btn-outline:hover { border-color:var(--pink-dark); color:var(--pink-dark); background:var(--pink-pale); }
.btn-white { background:var(--white); color:var(--text); box-shadow:var(--shadow-sm); }
.btn-white:hover { transform:translateY(-2px); box-shadow:var(--shadow-md); }
.btn-sm { padding:10px 24px; font-size:12px; }
.btn-block { display:flex; width:100%; }

/* ===== SECTIONS ===== */
.section { padding:90px 0; }
.section-header { text-align:center; margin-bottom:55px; }
.section-header .label {
    display:inline-block; font-size:11px; font-weight:600;
    text-transform:uppercase; letter-spacing:2.5px;
    color:var(--pink-dark); margin-bottom:14px;
}
.section-header h2 {
    font-family:'Playfair Display',serif;
    font-size:38px; font-weight:400;
    color:var(--text); letter-spacing:-0.3px;
}
.section-header h2 strong { font-weight:700; }
.section-header p { color:var(--text-light); margin-top:12px; font-size:15px; max-width:500px; margin-left:auto; margin-right:auto; }

/* ===== PRODUCT GRID ===== */
.product-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:24px; }
.product-card {
    background:var(--white);
    border-radius:var(--radius);
    overflow:hidden;
    transition:var(--transition);
    border:1px solid var(--border-light);
    position:relative;
}
.product-card:hover { transform:translateY(-6px); box-shadow:var(--shadow-lg); border-color:transparent; }
.product-card-img { position:relative; overflow:hidden; aspect-ratio:3/4; background:var(--cream); }
.product-card-img img { width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.4,0,.2,1); }
.product-card:hover .product-card-img img { transform:scale(1.06); }
.product-badge {
    position:absolute; top:14px; left:14px;
    background:var(--pink-deep); color:#fff;
    padding:5px 14px; border-radius:30px;
    font-size:11px; font-weight:600;
    letter-spacing:0.5px; text-transform:uppercase;
}
.product-card-info { padding:20px; }
.product-card-info h3 { font-size:14px; font-weight:500; margin-bottom:10px; color:var(--text); line-height:1.4; }
.product-card-info .price { font-size:16px; font-weight:600; color:var(--pink-deep); }
.product-card-info .price .old-price { text-decoration:line-through; color:var(--text-light); font-weight:400; font-size:13px; margin-left:8px; }
.product-card-info .product-colors-mini { display:flex; gap:6px; margin-top:12px; }
.product-card-info .color-dot-mini { width:16px; height:16px; border-radius:50%; border:2px solid var(--border); transition:var(--transition); }
.product-card:hover .color-dot-mini { border-color:var(--pink-soft); }

/* Quick view on hover */
.product-card-actions {
    position:absolute;
    bottom:0; left:0; right:0;
    padding:16px;
    transform:translateY(100%);
    transition:var(--transition);
    background:linear-gradient(to top, rgba(255,255,255,0.95), transparent);
}
.product-card:hover .product-card-actions { transform:translateY(0); }

/* ===== CATEGORY CARDS ===== */
.category-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
.category-card {
    position:relative; border-radius:var(--radius);
    overflow:hidden; aspect-ratio:4/3;
    background:var(--pink-pale); cursor:pointer;
}
.category-card img { width:100%; height:100%; object-fit:cover; transition:transform .6s cubic-bezier(.4,0,.2,1), filter .4s; }
.category-card:hover img { transform:scale(1.08); filter:brightness(0.95); }
.category-card .category-overlay {
    position:absolute; inset:0;
    background:linear-gradient(to top, rgba(45,45,45,0.6) 0%, rgba(45,45,45,0.1) 50%, transparent 100%);
    display:flex; align-items:flex-end; padding:28px;
    transition:var(--transition);
}
.category-card:hover .category-overlay { background:linear-gradient(to top, rgba(45,45,45,0.7) 0%, rgba(45,45,45,0.15) 50%, transparent 100%); }
.category-card .category-overlay h3 { color:#fff; font-size:20px; font-weight:500; letter-spacing:0.5px; }
.category-card .category-overlay .cat-count { display:block; font-size:12px; font-weight:300; opacity:0.8; margin-top:4px; }

/* ===== FEATURES ROW ===== */
.features-row { display:grid; grid-template-columns:repeat(4,1fr); gap:0; border:1px solid var(--border); border-radius:var(--radius); overflow:hidden; }
.feature-item {
    text-align:center; padding:36px 24px;
    border-right:1px solid var(--border);
    transition:var(--transition);
}
.feature-item:last-child { border-right:none; }
.feature-item:hover { background:var(--pink-pale); }
.feature-item .feature-icon {
    width:50px; height:50px; background:var(--pink-pale);
    border-radius:50%; display:flex; align-items:center;
    justify-content:center; margin:0 auto 16px;
    transition:var(--transition);
}
.feature-item:hover .feature-icon { background:var(--white); }
.feature-item h4 { font-size:13px; font-weight:600; margin-bottom:6px; }
.feature-item p { font-size:12px; color:var(--text-light); line-height:1.5; }

/* ===== CTA BANNER ===== */
.cta-banner {
    background:linear-gradient(135deg, var(--pink-pale) 0%, #fce8f0 50%, var(--pink-soft) 100%);
    padding:80px 0;
    position:relative;
    overflow:hidden;
}
.cta-banner::before {
    content:'';
    position:absolute; top:-50%; right:-20%;
    width:600px; height:600px;
    background:radial-gradient(circle, rgba(212,160,185,0.15) 0%, transparent 70%);
}
.cta-banner-inner {
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:40px;
    position:relative; z-index:1;
}
.cta-banner-content h2 {
    font-family:'Playfair Display',serif;
    font-size:36px; font-weight:400;
    margin-bottom:12px;
}
.cta-banner-content h2 strong { font-weight:700; }
.cta-banner-content p { color:var(--text-mid); max-width:400px; }

/* ===== SHIPPING BANNER ===== */
.shipping-banner { padding:80px 0; text-align:center; }
.shipping-banner .shipping-box {
    background:var(--cream); border-radius:24px;
    padding:60px 40px; max-width:650px; margin:0 auto;
    border:1px solid var(--border-light);
    position:relative;
    overflow:hidden;
}
.shipping-banner .shipping-box::before {
    content:'';
    position:absolute; top:-40px; right:-40px;
    width:200px; height:200px;
    background:radial-gradient(circle, var(--pink-pale) 0%, transparent 70%);
}
.shipping-banner .shipping-icon {
    width:70px; height:70px; background:var(--pink-pale);
    border-radius:50%; display:flex; align-items:center;
    justify-content:center; margin:0 auto 22px;
    position:relative;
}
.shipping-banner h3 {
    font-family:'Playfair Display',serif;
    font-size:24px; font-weight:400; margin-bottom:10px;
}
.shipping-banner p { color:var(--text-light); font-size:14px; margin-bottom:20px; }
.shipping-banner .shipping-price {
    font-family:'Playfair Display',serif;
    font-size:44px; font-weight:400; color:var(--pink-deep); letter-spacing:-1px;
}
.shipping-banner .shipping-price strong { font-weight:700; }

/* ===== NEWSLETTER ===== */
.newsletter-section { padding:0; margin-top:80px; }
.newsletter-box {
    background:var(--text);
    border-radius:20px;
    padding:50px 60px;
    display:flex;
    align-items:center;
    justify-content:space-between;
    gap:40px;
    margin-bottom:-60px;
    position:relative;
    z-index:2;
}
.newsletter-label {
    font-size:11px; text-transform:uppercase;
    letter-spacing:2px; color:var(--pink);
    font-weight:600; margin-bottom:10px; display:block;
}
.newsletter-content h3 {
    font-family:'Playfair Display',serif;
    font-size:24px; font-weight:400; color:#fff;
    margin-bottom:6px;
}
.newsletter-content p { font-size:13px; color:rgba(255,255,255,0.5); }
.newsletter-form { display:flex; gap:10px; flex-shrink:0; }
.newsletter-form input {
    padding:14px 22px; border:1px solid rgba(255,255,255,0.15);
    border-radius:50px; background:rgba(255,255,255,0.08);
    color:#fff; width:280px; font-size:13px;
}
.newsletter-form input::placeholder { color:rgba(255,255,255,0.35); }
.newsletter-form input:focus { border-color:var(--pink); }

/* ===== PRODUCT DETAIL ===== */
.product-detail { padding:30px 0 80px; }
.product-detail-grid { display:grid; grid-template-columns:1.1fr 0.9fr; gap:60px; align-items:start; }
.product-gallery { position:relative; }
.product-main-img {
    border-radius:var(--radius); overflow:hidden;
    aspect-ratio:3/4; background:var(--cream);
    box-shadow:var(--shadow-sm); margin-bottom:14px;
}
.product-main-img img { width:100%; height:100%; object-fit:cover; transition:opacity .3s; }
.product-thumbnails { display:flex; gap:10px; }
.product-thumbnails .thumb {
    width:75px; height:95px; border-radius:var(--radius-sm);
    overflow:hidden; cursor:pointer; border:2px solid transparent;
    transition:var(--transition); background:var(--cream); opacity:0.6;
}
.product-thumbnails .thumb.active, .product-thumbnails .thumb:hover { border-color:var(--pink-dark); opacity:1; }
.product-thumbnails .thumb img { width:100%; height:100%; object-fit:cover; }

.product-info { padding-top:10px; }
.product-info .product-category {
    font-size:11px; text-transform:uppercase; letter-spacing:2px;
    color:var(--pink-dark); font-weight:600; margin-bottom:10px;
}
.product-info h1 {
    font-family:'Playfair Display',serif;
    font-size:32px; font-weight:400; margin-bottom:16px;
    line-height:1.3; letter-spacing:-0.3px;
}
.product-info .product-price { font-size:26px; font-weight:600; color:var(--pink-deep); margin-bottom:24px; }
.product-info .product-price .old-price { text-decoration:line-through; color:var(--text-light); font-weight:300; font-size:20px; margin-left:12px; }
.product-info .divider { height:1px; background:var(--border); margin:24px 0; }
.product-info .product-desc { color:var(--text-mid); margin-bottom:28px; line-height:1.85; font-size:14px; }

.option-label { font-size:11px; font-weight:600; margin-bottom:12px; display:block; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-mid); }

/* Color circles */
.color-options { display:flex; gap:14px; margin-bottom:28px; flex-wrap:wrap; }
.color-option-wrap {
    display:flex; flex-direction:column; align-items:center; gap:6px; cursor:pointer;
}
.color-option-wrap input { display:none; }
.color-circle {
    width:42px; height:42px; border-radius:50%;
    border:3px solid var(--border);
    transition:var(--transition);
    position:relative;
    box-shadow:inset 0 0 0 2px #fff, 0 2px 8px rgba(0,0,0,0.08);
}
.color-circle:hover { transform:scale(1.12); border-color:var(--text-light); }
.color-circle.selected { border-color:var(--pink-deep); transform:scale(1.12); box-shadow:inset 0 0 0 2px #fff, 0 0 0 2px var(--pink-soft), 0 2px 8px rgba(0,0,0,0.08); }
.color-check { width:18px; height:18px; position:absolute; top:50%; left:50%; transform:translate(-50%,-50%); opacity:0; transition:opacity .2s; filter:drop-shadow(0 1px 2px rgba(0,0,0,0.3)); }
.color-circle.selected .color-check { opacity:1; }
.color-name { font-size:11px; color:var(--text-light); font-weight:500; }

/* Shipping info box */
.shipping-info-box {
    background:var(--cream); border:1px solid var(--border-light);
    border-radius:var(--radius-sm); padding:20px; margin-top:24px;
}
.shipping-countries { display:flex; flex-direction:column; gap:0; }
.shipping-country-row {
    display:flex; justify-content:space-between; align-items:center;
    padding:8px 0; border-bottom:1px solid var(--border-light);
    font-size:13px; color:var(--text-mid);
}
.shipping-country-row:last-child { border-bottom:none; }
.shipping-country-row strong { color:var(--pink-deep); font-size:14px; }

/* Lightbox */
.lightbox {
    position:fixed; inset:0; z-index:9999;
    background:rgba(0,0,0,0.92);
    display:flex; align-items:center; justify-content:center;
    opacity:0; visibility:hidden;
    transition:all .3s ease;
}
.lightbox.active { opacity:1; visibility:visible; }
.lightbox-img-wrap {
    max-width:90vw; max-height:85vh;
    display:flex; align-items:center; justify-content:center;
}
.lightbox-img-wrap img {
    max-width:100%; max-height:85vh;
    object-fit:contain; border-radius:4px;
    animation:lightboxFadeIn .3s ease;
}
@keyframes lightboxFadeIn { from { opacity:0; transform:scale(0.95); } to { opacity:1; transform:scale(1); } }
.lightbox-close {
    position:absolute; top:20px; right:24px;
    background:none; border:none; color:#fff;
    font-size:36px; cursor:pointer; opacity:0.7;
    transition:opacity .2s; line-height:1; z-index:10;
}
.lightbox-close:hover { opacity:1; }
.lightbox-prev, .lightbox-next {
    position:absolute; top:50%; transform:translateY(-50%);
    background:rgba(255,255,255,0.1); border:none; color:#fff;
    font-size:40px; cursor:pointer; width:50px; height:70px;
    display:flex; align-items:center; justify-content:center;
    border-radius:8px; opacity:0.6; transition:all .2s; z-index:10;
}
.lightbox-prev { left:16px; }
.lightbox-next { right:16px; }
.lightbox-prev:hover, .lightbox-next:hover { opacity:1; background:rgba(255,255,255,0.2); }
.lightbox-counter {
    position:absolute; bottom:24px; left:50%; transform:translateX(-50%);
    color:rgba(255,255,255,0.6); font-size:14px; font-weight:500;
}
.size-options { display:flex; gap:10px; margin-bottom:28px; flex-wrap:wrap; }
.size-option {
    padding:10px 22px; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); cursor:pointer; font-size:13px;
    font-weight:500; transition:var(--transition);
    background:var(--white); color:var(--text-mid);
}
.size-option:hover { border-color:var(--pink); color:var(--pink-dark); }
.size-option.selected { border-color:var(--pink-dark); background:var(--pink-pale); color:var(--pink-deep); font-weight:600; }
.quantity-wrap { display:flex; align-items:center; gap:4px; margin-bottom:28px; }
.qty-btn {
    width:40px; height:40px; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); background:var(--white);
    cursor:pointer; font-size:18px; display:flex;
    align-items:center; justify-content:center;
    transition:var(--transition); color:var(--text-mid);
}
.qty-btn:hover { border-color:var(--pink); background:var(--pink-pale); color:var(--pink-dark); }
.qty-input {
    width:56px; text-align:center; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); padding:8px;
    font-weight:500; height:40px; color:var(--text);
}
.qty-input:focus { border-color:var(--pink-dark); }
.shipping-note {
    background:var(--pink-pale); padding:16px 22px;
    border-radius:var(--radius-sm); margin-top:24px;
    font-size:13px; color:var(--text-mid);
    display:flex; align-items:center; gap:12px;
    border:1px solid var(--pink-soft);
}
.shipping-note svg { flex-shrink:0; color:var(--pink-dark); }

/* ===== CART ===== */
.cart-section { padding:40px 0 80px; }
.cart-table { width:100%; border-collapse:collapse; }
.cart-table th {
    text-align:left; padding:14px 16px;
    border-bottom:1.5px solid var(--border);
    font-size:11px; text-transform:uppercase;
    letter-spacing:1.5px; color:var(--text-light); font-weight:600;
}
.cart-table td { padding:18px 16px; border-bottom:1px solid var(--border-light); vertical-align:middle; }
.cart-item-img { width:70px; height:90px; border-radius:var(--radius-sm); overflow:hidden; background:var(--cream); }
.cart-item-img img { width:100%; height:100%; object-fit:cover; }
.cart-item-name { font-weight:500; font-size:14px; }
.cart-item-meta { font-size:12px; color:var(--text-light); margin-top:3px; }
.cart-remove { color:var(--text-light); cursor:pointer; font-size:12px; transition:var(--transition); background:none; border:none; padding:6px 14px; border-radius:6px; }
.cart-remove:hover { color:#c0392b; background:#fef0f0; }
.cart-summary {
    background:var(--cream); border-radius:var(--radius);
    padding:32px; margin-top:30px; max-width:420px;
    margin-left:auto; border:1px solid var(--border-light);
}
.cart-summary-row { display:flex; justify-content:space-between; margin-bottom:14px; font-size:14px; color:var(--text-mid); }
.cart-summary-row.total { font-size:20px; font-weight:600; border-top:1.5px solid var(--border); padding-top:16px; margin-top:16px; color:var(--pink-deep); }
.cart-empty { text-align:center; padding:100px 20px; }
.cart-empty h2 { font-family:'Playfair Display',serif; font-weight:400; font-size:26px; margin-bottom:12px; }
.cart-empty p { color:var(--text-light); margin-bottom:30px; }

/* ===== CHECKOUT ===== */
.checkout-section { padding:40px 0 80px; }
.checkout-grid { display:grid; grid-template-columns:1.1fr 0.9fr; gap:60px; }
.form-group { margin-bottom:22px; }
.form-group label { display:block; font-size:11px; font-weight:600; margin-bottom:8px; text-transform:uppercase; letter-spacing:1px; color:var(--text-mid); }
.form-group input, .form-group textarea, .form-group select {
    width:100%; padding:13px 18px; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); background:var(--white);
    transition:var(--transition); color:var(--text);
}
.form-group input:focus, .form-group textarea:focus { border-color:var(--pink-dark); box-shadow:0 0 0 3px rgba(212,160,185,0.12); }
.form-group textarea { height:100px; resize:vertical; }
.form-group input::placeholder, .form-group textarea::placeholder { color:var(--text-light); }
.order-summary-box {
    background:var(--cream); border-radius:var(--radius);
    padding:32px; position:sticky; top:130px;
    border:1px solid var(--border-light);
}
.order-summary-box h3 { font-size:16px; font-weight:600; margin-bottom:22px; padding-bottom:16px; border-bottom:1px solid var(--border); }
.order-item { display:flex; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--border-light); font-size:14px; color:var(--text-mid); }

/* ===== BREADCRUMB ===== */
.breadcrumb { padding:16px 0; font-size:12px; color:var(--text-light); letter-spacing:0.3px; }
.breadcrumb a { color:var(--text-light); }
.breadcrumb a:hover { color:var(--pink-dark); }
.breadcrumb span { margin:0 10px; opacity:0.5; }

/* ===== SHOP ===== */
.shop-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:35px; flex-wrap:wrap; gap:15px; }
.shop-header p { color:var(--text-light); font-size:14px; }
.filter-bar select {
    padding:10px 18px; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); background:var(--white);
    cursor:pointer; color:var(--text-mid); font-size:13px;
    appearance:none; -webkit-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239a9a9a' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 14px center;
    padding-right:38px;
}
.filter-bar select:focus { border-color:var(--pink-dark); }

/* ===== PAGE HEADER ===== */
.page-header {
    background:linear-gradient(165deg, var(--pink-pale) 0%, #fff 60%);
    padding:48px 0; text-align:center;
}
.page-header h1 {
    font-family:'Playfair Display',serif;
    font-size:32px; font-weight:400; letter-spacing:-0.3px;
}
.page-header h1 strong { font-weight:700; }

/* ===== SUCCESS ===== */
.success-page { text-align:center; padding:100px 20px; }
.success-page .check-circle {
    width:88px; height:88px;
    background:linear-gradient(135deg, var(--pink) 0%, var(--pink-dark) 100%);
    border-radius:50%; display:flex; align-items:center;
    justify-content:center; margin:0 auto 28px;
    box-shadow:0 8px 32px rgba(184,114,141,0.25);
}
.success-page .check-circle svg { color:#fff; }
.success-page h1 { font-family:'Playfair Display',serif; font-weight:400; font-size:28px; margin-bottom:12px; }
.success-page p { color:var(--text-light); margin-bottom:20px; line-height:1.7; }

/* ===== ALERT ===== */
.alert { padding:14px 22px; border-radius:var(--radius-sm); margin-bottom:24px; font-size:13px; }
.alert-success { background:#ecf8ef; color:#1d6f37; border:1px solid #c8e6cf; }
.alert-error { background:#fef0f0; color:#a93226; border:1px solid #f5d0cd; }

/* ===== PAGINATION ===== */
.pagination { display:flex; justify-content:center; gap:8px; margin-top:50px; }
.pagination a, .pagination span { padding:10px 16px; border-radius:var(--radius-sm); font-size:13px; border:1.5px solid var(--border); transition:var(--transition); font-weight:500; }
.pagination span.current { background:var(--pink-dark); color:#fff; border-color:var(--pink-dark); }
.pagination a:hover { border-color:var(--pink); background:var(--pink-pale); }

/* ===== FOOTER ===== */
.site-footer {
    background:#1e1e2d;
    color:rgba(255,255,255,0.65);
    padding:100px 0 0;
    margin-top:0;
}
.footer-grid { display:grid; grid-template-columns:1.4fr 1fr 1fr 1.2fr; gap:50px; }
.footer-about {}
.footer-logo { height:35px; margin-bottom:18px; filter:brightness(0) invert(1); opacity:0.9; }
.footer-col h4 {
    color:#fff; font-size:12px; font-weight:600;
    text-transform:uppercase; letter-spacing:2px;
    margin-bottom:22px;
}
.footer-col p { font-size:13px; line-height:1.8; }
.footer-col ul li { margin-bottom:10px; }
.footer-col ul a { font-size:13px; opacity:0.65; transition:var(--transition); }
.footer-col ul a:hover { opacity:1; color:var(--pink-soft); }
.footer-social { display:flex; gap:12px; margin-top:20px; }
.footer-social a {
    width:38px; height:38px; border-radius:50%;
    border:1px solid rgba(255,255,255,0.12);
    display:flex; align-items:center; justify-content:center;
    color:rgba(255,255,255,0.6);
    transition:var(--transition);
}
.footer-social a:hover { border-color:var(--pink); color:var(--pink); background:rgba(212,160,185,0.1); }
.footer-contact li {
    display:flex; align-items:center; gap:10px;
    margin-bottom:14px; font-size:13px;
}
.footer-contact svg { opacity:0.5; flex-shrink:0; }
.footer-shipping-badge {
    display:inline-flex; align-items:center; gap:8px;
    background:rgba(255,255,255,0.06);
    padding:10px 18px; border-radius:var(--radius-sm);
    margin-top:16px; font-size:13px;
}
.footer-shipping-badge svg { opacity:0.6; }
.footer-bottom {
    border-top:1px solid rgba(255,255,255,0.06);
    margin-top:55px; padding:22px 0;
    display:flex; justify-content:space-between; align-items:center;
    font-size:12px; opacity:0.4;
}
.footer-payment { letter-spacing:0.5px; }

/* ===== ADMIN ===== */
.admin-layout { display:flex; min-height:100vh; }
.admin-sidebar { width:260px; background:#1e1e2d; color:#fff; padding:0; flex-shrink:0; }
.admin-sidebar .admin-logo { padding:28px 28px 24px; font-size:17px; font-weight:600; border-bottom:1px solid rgba(255,255,255,0.06); }
.admin-sidebar .admin-logo small { display:block; font-size:10px; font-weight:400; opacity:0.4; text-transform:uppercase; letter-spacing:2px; margin-top:4px; }
.admin-sidebar nav { padding:16px 0; }
.admin-sidebar nav a { display:flex; align-items:center; gap:12px; padding:13px 28px; color:rgba(255,255,255,0.55); font-size:14px; transition:var(--transition); border-left:3px solid transparent; }
.admin-sidebar nav a:hover { background:rgba(255,255,255,0.04); color:rgba(255,255,255,0.9); }
.admin-sidebar nav a.active { background:rgba(212,160,185,0.08); color:var(--pink); border-left-color:var(--pink); }
.admin-content { flex:1; background:#f7f7fa; padding:32px; }
.admin-header { display:flex; justify-content:space-between; align-items:center; margin-bottom:32px; }
.admin-header h1 { font-size:22px; font-weight:600; }
.admin-card { background:var(--white); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow-sm); margin-bottom:24px; border:1px solid #eeeef2; }
.admin-card h3 { font-size:15px; font-weight:600; margin-bottom:18px; color:var(--text); }
.admin-table { width:100%; border-collapse:collapse; }
.admin-table th { text-align:left; padding:12px 16px; background:#f9f9fc; font-size:11px; text-transform:uppercase; letter-spacing:1px; color:var(--text-light); font-weight:600; border-bottom:1px solid #eeeef2; }
.admin-table td { padding:14px 16px; border-bottom:1px solid #f4f4f7; vertical-align:middle; font-size:14px; }
.admin-table tr:hover { background: #fdfdfff; }
.admin-table .thumb-sm { width:48px; height:60px; border-radius:8px; object-fit:cover; }
.admin-stats { display:grid; grid-template-columns:repeat(4,1fr); gap:20px; margin-bottom:32px; }
.stat-card { background:var(--white); border-radius:var(--radius); padding:28px; box-shadow:var(--shadow-sm); border:1px solid #eeeef2; }
.stat-card .stat-num { font-size:30px; font-weight:600; color:var(--pink-deep); }
.stat-card .stat-label { font-size:12px; color:var(--text-light); margin-top:6px; text-transform:uppercase; letter-spacing:1px; }
.actions { display:flex; gap:8px; }
.btn-edit { padding:7px 16px; background:var(--pink-pale); color:var(--pink-dark); border:none; border-radius:8px; cursor:pointer; font-size:12px; transition:var(--transition); font-weight:500; }
.btn-edit:hover { background:var(--pink-dark); color:#fff; }
.btn-delete { padding:7px 16px; background:#fef0f0; color:#c0392b; border:none; border-radius:8px; cursor:pointer; font-size:12px; transition:var(--transition); font-weight:500; }
.btn-delete:hover { background:#c0392b; color:#fff; }
.admin-form { max-width:720px; }
.admin-form .form-row { display:grid; grid-template-columns:1fr 1fr; gap:20px; }
.admin-login { display:flex; align-items:center; justify-content:center; min-height:100vh; background:linear-gradient(165deg, var(--pink-pale), #fff); }
.login-box { background:var(--white); padding:48px; border-radius:20px; box-shadow:var(--shadow-lg); width:100%; max-width:400px; text-align:center; border:1px solid var(--border-light); }
.login-box h1 { font-family:'Playfair Display',serif; font-size:24px; font-weight:500; margin-bottom:6px; }
.login-box p { color:var(--text-light); margin-bottom:32px; font-size:13px; }
.admin-mobile-toggle { display:none; }

/* Admin nav cards (visible on all screens) */
.admin-nav-cards {
    display:grid;
    grid-template-columns:repeat(4,1fr);
    gap:16px;
    margin-top:24px;
}
.admin-nav-card {
    background:var(--white);
    border:1px solid #eeeef2;
    border-radius:var(--radius);
    padding:24px 20px;
    text-align:center;
    transition:var(--transition);
    display:flex;
    flex-direction:column;
    align-items:center;
    gap:6px;
}
.admin-nav-card:hover { border-color:var(--pink); box-shadow:var(--shadow-md); transform:translateY(-3px); }
.admin-nav-card-icon { font-size:28px; }
.admin-nav-card span { font-size:14px; font-weight:600; color:var(--text); }
.admin-nav-card small { font-size:12px; color:var(--text-light); }

/* ===== SHOP LAYOUT (Sidebar + Grid) ===== */
.shop-layout { display:grid; grid-template-columns:260px 1fr; gap:40px; }
.shop-sidebar {}
.sidebar-block { margin-bottom:28px; }
.sidebar-title {
    font-size:12px; font-weight:600; text-transform:uppercase;
    letter-spacing:1.5px; color:var(--text); margin-bottom:14px;
    padding-bottom:12px; border-bottom:1.5px solid var(--border);
}
.sidebar-categories li a {
    display:flex; justify-content:space-between; align-items:center;
    padding:10px 14px; font-size:13px; color:var(--text-mid);
    border-radius:8px; transition:var(--transition); margin-bottom:2px;
}
.sidebar-categories li a:hover { background:var(--pink-pale); color:var(--pink-deep); }
.sidebar-categories li a.active { background:var(--pink-pale); color:var(--pink-deep); font-weight:600; }
.cat-num { font-size:11px; color:var(--text-light); background:var(--border-light); padding:2px 8px; border-radius:10px; }
.sidebar-categories li a.active .cat-num { background:var(--pink-soft); color:var(--pink-deep); }
.sidebar-shipping {
    background:var(--pink-pale); border-radius:var(--radius-sm);
    padding:20px; display:flex; align-items:center; gap:14px;
    border:1px solid var(--pink-soft);
}
.sidebar-shipping strong { display:block; font-size:13px; color:var(--text); }
.sidebar-shipping p { font-size:18px; font-weight:600; color:var(--pink-deep); margin:2px 0; }
.sidebar-shipping small { font-size:11px; color:var(--text-light); }
.shop-main {}
.shop-topbar { display:flex; justify-content:space-between; align-items:center; margin-bottom:24px; flex-wrap:wrap; gap:12px; }
.shop-topbar p { color:var(--text-light); font-size:14px; }
.shop-topbar-right { display:flex; align-items:center; gap:10px; }
.mobile-filter-btn { display:none !important; }
.product-grid-3 { grid-template-columns:repeat(3,1fr); }

/* ===== STATIC PAGES ===== */
.static-page { max-width:900px; margin:0 auto; }
.static-intro { text-align:center; margin-bottom:50px; }
.static-intro h2 {
    font-family:'Playfair Display',serif;
    font-size:32px; font-weight:400; margin-bottom:16px;
}
.static-intro h2 strong { font-weight:700; }
.static-intro .lead { font-size:16px; color:var(--text-mid); line-height:1.8; max-width:600px; margin:0 auto; }
.static-grid { display:grid; grid-template-columns:1fr 1fr; gap:24px; margin-bottom:50px; }
.static-card {
    background:var(--cream); border:1px solid var(--border-light);
    border-radius:var(--radius); padding:32px; transition:var(--transition);
}
.static-card:hover { box-shadow:var(--shadow-md); }
.static-card-icon {
    width:56px; height:56px; background:var(--pink-pale);
    border-radius:50%; display:flex; align-items:center;
    justify-content:center; margin-bottom:18px;
}
.static-card h3 { font-size:16px; font-weight:600; margin-bottom:10px; }
.static-card p { font-size:14px; color:var(--text-mid); line-height:1.7; }
.static-contact-box {
    background:var(--pink-pale); border-radius:var(--radius);
    padding:40px; border:1px solid var(--pink-soft);
}
.static-contact-box h3 {
    font-family:'Playfair Display',serif;
    font-size:22px; font-weight:500; margin-bottom:24px; text-align:center;
}
.static-contact-grid {
    display:grid; grid-template-columns:repeat(3,1fr); gap:24px;
}
.static-contact-grid > div {
    display:flex; align-items:flex-start; gap:12px;
    background:var(--white); padding:20px; border-radius:var(--radius-sm);
}
.static-contact-grid strong { display:block; font-size:13px; margin-bottom:2px; }
.static-contact-grid p { font-size:13px; color:var(--text-mid); }

/* Static text content (privacy, terms, cookies) */
.static-text-content { max-width:760px; margin:0 auto; }
.static-updated {
    font-size:12px; color:var(--text-light);
    text-transform:uppercase; letter-spacing:1px;
    margin-bottom:30px; padding-bottom:20px;
    border-bottom:1px solid var(--border);
}
.static-text-content h2 {
    font-family:'Playfair Display',serif;
    font-size:22px; font-weight:500;
    margin-top:36px; margin-bottom:14px;
    color:var(--text);
}
.static-text-content h3 { font-size:16px; font-weight:600; margin-top:24px; margin-bottom:10px; }
.static-text-content p { font-size:14px; color:var(--text-mid); line-height:1.8; margin-bottom:14px; }
.static-text-content ul { padding-left:20px; margin-bottom:16px; }
.static-text-content ul li {
    font-size:14px; color:var(--text-mid); line-height:1.8;
    margin-bottom:6px; list-style:disc;
}
.static-text-content a { color:var(--pink-dark); border-bottom:1px solid var(--pink-soft); }
.static-text-content a:hover { color:var(--pink-deep); }
.static-text-content code {
    background:var(--pink-pale); padding:2px 8px;
    border-radius:4px; font-size:13px; color:var(--pink-deep);
}

/* Cookie table */
.cookie-table { margin:20px 0; overflow-x:auto; }
.cookie-table table { width:100%; border-collapse:collapse; font-size:13px; }
.cookie-table th {
    text-align:left; padding:12px 16px; background:var(--pink-pale);
    font-size:11px; text-transform:uppercase; letter-spacing:1px;
    color:var(--text-mid); font-weight:600;
}
.cookie-table td { padding:12px 16px; border-bottom:1px solid var(--border-light); color:var(--text-mid); }

/* ===== CONTACT PAGE ===== */
.contact-page { max-width:1000px; margin:0 auto; }
.contact-grid { display:grid; grid-template-columns:1fr 1.3fr; gap:40px; margin-bottom:80px; }
.contact-info-card {
    background:var(--pink-pale); border-radius:var(--radius);
    padding:36px; border:1px solid var(--pink-soft); height:100%;
    display:flex; flex-direction:column;
}
.contact-info-card h3 {
    font-family:'Playfair Display',serif;
    font-size:22px; font-weight:500; margin-bottom:10px;
}
.contact-info-card > p { font-size:14px; color:var(--text-mid); line-height:1.7; margin-bottom:28px; }
.contact-info-list { flex:1; }
.contact-info-item { display:flex; align-items:flex-start; gap:14px; margin-bottom:22px; }
.contact-info-icon {
    width:44px; height:44px; border-radius:50%;
    background:var(--white); display:flex;
    align-items:center; justify-content:center; flex-shrink:0;
    box-shadow:var(--shadow-sm);
}
.contact-info-item strong { display:block; font-size:13px; margin-bottom:2px; color:var(--text); }
.contact-info-item p { font-size:13px; color:var(--text-mid); line-height:1.5; }
.contact-social { padding-top:20px; border-top:1px solid var(--pink-soft); margin-top:auto; }
.contact-social span { font-size:12px; color:var(--text-light); text-transform:uppercase; letter-spacing:1px; font-weight:600; display:block; margin-bottom:12px; }
.contact-social-links { display:flex; gap:10px; }
.contact-social-links a {
    width:40px; height:40px; border-radius:50%;
    background:var(--white); display:flex;
    align-items:center; justify-content:center;
    color:var(--text-mid); transition:var(--transition);
    box-shadow:var(--shadow-sm);
}
.contact-social-links a:hover { color:var(--pink-deep); background:var(--white); transform:translateY(-2px); box-shadow:var(--shadow-md); }

.contact-form {
    background:var(--white); border-radius:var(--radius);
    padding:36px; border:1px solid var(--border-light);
    box-shadow:var(--shadow-sm);
}
.contact-form h3 {
    font-family:'Playfair Display',serif;
    font-size:22px; font-weight:500; margin-bottom:24px;
}
.form-row-2 { display:grid; grid-template-columns:1fr 1fr; gap:16px; }
.contact-form select {
    width:100%; padding:13px 18px; border:1.5px solid var(--border);
    border-radius:var(--radius-sm); background:var(--white);
    color:var(--text); cursor:pointer; transition:var(--transition);
    appearance:none; -webkit-appearance:none;
    background-image:url("data:image/svg+xml,%3Csvg width='10' height='6' viewBox='0 0 10 6' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M1 1L5 5L9 1' stroke='%239a9a9a' stroke-width='1.5' stroke-linecap='round'/%3E%3C/svg%3E");
    background-repeat:no-repeat; background-position:right 14px center; padding-right:38px;
}
.contact-form select:focus { border-color:var(--pink-dark); }

/* FAQ */
.contact-faq { padding-top:20px; }
.faq-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.faq-item {
    background:var(--cream); border:1px solid var(--border-light);
    border-radius:var(--radius); padding:28px;
    transition:var(--transition);
}
.faq-item:hover { box-shadow:var(--shadow-md); border-color:transparent; }
.faq-item h4 { font-size:14px; font-weight:600; margin-bottom:10px; color:var(--text); }
.faq-item p { font-size:13px; color:var(--text-mid); line-height:1.7; }

/* ===== COOKIE CONSENT BAR ===== */
.cookie-bar {
    position:fixed; bottom:0; left:0; right:0;
    background:var(--white);
    border-top:1px solid var(--border);
    box-shadow:0 -4px 30px rgba(0,0,0,0.08);
    z-index:9999;
    transform:translateY(100%);
    transition:transform .4s cubic-bezier(.4,0,.2,1);
}
.cookie-bar.active { transform:translateY(0); }
.cookie-bar-inner {
    display:flex; align-items:center; justify-content:space-between;
    gap:24px; padding:20px 24px;
}
.cookie-bar-text strong { font-size:14px; display:block; margin-bottom:4px; }
.cookie-bar-text p { font-size:12px; color:var(--text-light); line-height:1.5; }
.cookie-bar-text a { color:var(--pink-dark); text-decoration:underline; }
.cookie-bar-actions { display:flex; gap:10px; flex-shrink:0; }

/* ===== RESPONSIVE ===== */
/* ===== TABLET — 1024px ===== */
@media (max-width: 1024px) {
    .product-grid { grid-template-columns:repeat(3,1fr); }
    .product-grid-3 { grid-template-columns:repeat(2,1fr); }
    .hero-banner h1 { font-size:44px; }
    .hero-banner-grid { gap:40px; }
    .features-row { grid-template-columns:repeat(2,1fr); }
    .feature-item:nth-child(2) { border-right:none; }
    .admin-stats { grid-template-columns:repeat(2,1fr); }
    .shop-layout { grid-template-columns:220px 1fr; gap:30px; }
    .static-contact-grid { grid-template-columns:1fr; }
}

/* ===== MOBILE — 768px ===== */
@media (max-width: 768px) {
    /* Top bar */
    .top-bar-left, .top-bar-right { display:none; }
    .top-bar-center { position:static; transform:none; text-align:center; width:100%; }
    .top-bar-marquee { font-size:10px; }

    /* Header */
    .header-inner { height:110px; }
    .logo img { height:100px; }

    /* Burger button visible */
    .mobile-menu-btn { display:flex; }

    /* Mobile nav panel */
    .main-nav {
        position:fixed;
        top:0; left:-100%;
        width:85%; max-width:340px;
        height:100vh; height:100dvh;
        background:var(--white);
        flex-direction:column;
        padding:80px 28px 40px;
        gap:0;
        z-index:99;
        overflow-y:auto;
        box-shadow:var(--shadow-lg);
        transition:left .35s cubic-bezier(.4,0,.2,1);
    }
    .main-nav.active { left:0; }
    .main-nav > a, .nav-dropdown {
        padding:16px 0;
        border-bottom:1px solid var(--border-light);
        width:100%;
        font-size:15px;
        letter-spacing:0.5px;
    }
    .main-nav > a::after, .nav-dropdown-trigger::after {
        display:none;
    }
    .nav-dropdown-trigger {
        width:100%;
        justify-content:space-between;
        font-size:15px;
        letter-spacing:0.5px;
    }
    .nav-dropdown-trigger svg {
        transition:transform .3s ease;
    }
    .nav-dropdown.open .nav-dropdown-trigger svg {
        transform:rotate(180deg);
    }
    .nav-dropdown-menu {
        position:static; transform:none; opacity:1; visibility:visible;
        box-shadow:none; border:none; border-radius:0;
        padding:0 0 8px 16px; min-width:auto;
        max-height:0; overflow:hidden;
        transition:max-height .3s ease, padding .3s ease;
    }
    .nav-dropdown.open .nav-dropdown-menu {
        max-height:500px;
        padding:8px 0 8px 16px;
    }
    .nav-dropdown-menu a {
        padding:12px 16px;
        font-size:14px;
    }

    /* Mobile nav close button inside panel */
    .main-nav::before {
        content:'';
        position:absolute;
        top:28px; right:24px;
        width:24px; height:24px;
    }

    /* Body scroll lock when menu open */
    body.menu-open { overflow:hidden; }

    /* Hero */
    .hero-banner { min-height:auto; padding:50px 0 60px; }
    .hero-banner-grid { grid-template-columns:1fr; gap:40px; text-align:center; }
    .hero-banner-content { max-width:100%; }
    .hero-banner h1 { font-size:34px; }
    .hero-banner p { margin-left:auto; margin-right:auto; font-size:15px; }
    .hero-buttons { justify-content:center; }
    .hero-stats { justify-content:center; gap:28px; }
    .hero-stat-num { font-size:26px; }
    .hero-image-grid { max-width:350px; margin:0 auto; }
    .marquee-strip { display:none; }

    /* Products */
    .product-grid { grid-template-columns:repeat(2,1fr); gap:14px; }
    .product-grid-3 { grid-template-columns:repeat(2,1fr); }
    .product-card:hover { transform:none; }
    .product-card-actions { transform:translateY(0); }

    /* Categories */
    .category-grid { grid-template-columns:1fr 1fr; }

    /* Features */
    .features-row { grid-template-columns:1fr; border:none; border-radius:0; gap:12px; }
    .feature-item { border:1px solid var(--border); border-radius:var(--radius-sm); border-right:1px solid var(--border) !important; }

    /* Product detail & checkout */
    .product-detail-grid { grid-template-columns:1fr; gap:30px; }
    .checkout-grid { grid-template-columns:1fr; }

    /* Shop sidebar as mobile drawer */
    .shop-layout { grid-template-columns:1fr; }
    .shop-sidebar {
        position:fixed; top:0; left:-300px; bottom:0; width:280px;
        background:var(--white); z-index:300; padding:24px;
        box-shadow:var(--shadow-lg); overflow-y:auto;
        transition:left .35s cubic-bezier(.4,0,.2,1);
    }
    .shop-sidebar.active { left:0; }
    .mobile-filter-btn { display:inline-flex !important; }
    .filter-bar { display:none; }

    /* Static pages */
    .static-grid { grid-template-columns:1fr; }
    .contact-grid { grid-template-columns:1fr; }
    .faq-grid { grid-template-columns:1fr; }
    .form-row-2 { grid-template-columns:1fr; }

    /* Sections */
    .section { padding:60px 0; }
    .section-header { margin-bottom:36px; }
    .section-header h2 { font-size:30px; }

    /* Cookie bar */
    .cookie-bar-inner { flex-direction:column; text-align:center; }
    .cookie-bar-text { margin-bottom:4px; }

    /* CTA banner */
    .cta-banner { padding:50px 0; }
    .cta-banner-inner { flex-direction:column; text-align:center; }
    .cta-banner-content h2 { font-size:28px; }
    .cta-banner-content p { margin:0 auto; }

    /* Newsletter */
    .newsletter-box { flex-direction:column; text-align:center; padding:36px 28px; }
    .newsletter-form { width:100%; }
    .newsletter-form input { width:100%; }

    /* Cart table */
    .cart-table thead { display:none; }
    .cart-table tr { display:flex; flex-wrap:wrap; padding:16px 0; border-bottom:1px solid var(--border-light); align-items:center; gap:10px; }
    .cart-table td { padding:4px 8px; border:none; }

    /* Admin */
    .admin-sidebar { position:fixed; left:-260px; top:0; bottom:0; z-index:200; transition:left .3s; }
    .admin-sidebar.active { left:0; box-shadow:100vw 0 0 rgba(0,0,0,0.4); }
    .admin-mobile-toggle {
        display:flex; align-items:center; justify-content:center;
        background:var(--pink-pale); border:1.5px solid var(--pink-soft);
        font-size:20px; cursor:pointer; width:40px; height:40px;
        border-radius:var(--radius-sm); flex-shrink:0;
    }
    .admin-nav-cards { grid-template-columns:repeat(2,1fr); }
    .admin-stats { grid-template-columns:1fr 1fr; }
    .admin-form .form-row { grid-template-columns:1fr; }

    /* Footer */
    .footer-grid { grid-template-columns:1fr 1fr; gap:30px; }
    .footer-logo { height:40px !important; }
    .footer-bottom { flex-direction:column; gap:8px; text-align:center; }

    /* Buttons */
    .btn { padding:13px 32px; font-size:12px; }
    .hero-buttons .btn { width:100%; max-width:280px; }

    /* Shipping banner */
    .shipping-banner { padding:50px 0; }
    .shipping-banner .shipping-box { padding:40px 24px; }
}

/* ===== SMALL MOBILE — 480px ===== */
@media (max-width: 480px) {
    .container { padding:0 16px; }
    .header-inner { height:95px; }
    .logo img { height:80px; }

    .product-grid { grid-template-columns:repeat(2,1fr); gap:10px; }
    .product-card-info { padding:12px; }
    .product-card-info h3 { font-size:13px; }
    .product-card-info .price { font-size:14px; }

    .hero-banner { padding:36px 0 44px; }
    .hero-banner h1 { font-size:26px; }
    .hero-banner p { font-size:14px; }
    .hero-stats { gap:20px; flex-wrap:wrap; }
    .hero-stat-num { font-size:22px; }

    .section-header h2 { font-size:24px; }
    .section { padding:44px 0; }

    .footer-grid { grid-template-columns:1fr; gap:24px; }
    .admin-stats { grid-template-columns:1fr; }
    .category-grid { grid-template-columns:1fr; }
    .checkout-grid { gap:24px; }
    .hero-image-grid { max-width:260px; gap:10px; }

    .cta-banner-content h2 { font-size:24px; }
    .shipping-banner .shipping-price { font-size:34px; }

    .main-nav { width:90%; padding:70px 20px 30px; }

    .newsletter-box { padding:28px 20px; }
    .newsletter-content h3 { font-size:20px; }
}
