/* Safa Modest House – Main Stylesheet */
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&family=Inter:wght@300;400;500;600&display=swap');

/* Light Theme */
:root,[data-theme="light"]{--bg:#FAF9F5;--bg-alt:#F5F0E1;--bg-card:#FFFFFF;--bg-header:rgba(250,249,245,0.95);--bg-footer:#2C2118;--border:#EDE4D9;--text:#1A1A1A;--text-muted:#8B7D6B;--text-light:#B7A99A;--color-primary:#6F4E37;--color-primary-light:#A0785A;--color-accent:#D4AF37;--color-accent-dark:#C9A96E;--color-danger:#C0392B;--color-success:#27AE60;--color-warning:#F39C12;--color-info:#2980B9;--shadow-sm:0 1px 4px rgba(0,0,0,.08);--shadow-md:0 4px 20px rgba(0,0,0,.10);--shadow-lg:0 8px 40px rgba(0,0,0,.14);--radius:12px;--radius-sm:8px;--radius-lg:20px;--transition:.25s ease;--font-body:'Inter',sans-serif;--font-heading:'Playfair Display',serif}

/* Dark Theme */
[data-theme="dark"],.theme-dark{--bg:#1A1410;--bg-alt:#231C16;--bg-card:#2C2118;--bg-header:rgba(26,20,16,0.97);--bg-footer:#0F0C09;--border:#3D3028;--text:#F5F0E1;--text-muted:#B7A99A;--text-light:#8B7D6B;--color-primary-light:#C29A6E;--shadow-sm:0 1px 4px rgba(0,0,0,.3);--shadow-md:0 4px 20px rgba(0,0,0,.4);--shadow-lg:0 8px 40px rgba(0,0,0,.5)}

/* Reset */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.65;transition:background var(--transition),color var(--transition);overflow-x:hidden}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none;transition:color var(--transition)}
button{cursor:pointer;font-family:inherit;border:none;background:none}
ul{list-style:none}
h1,h2,h3,h4,h5,h6{font-family:var(--font-heading);line-height:1.25}

/* Layout */
.container{max-width:1280px;margin:0 auto;padding:0 20px}
.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}
.gap-2{gap:16px}.mt-4{margin-top:32px}.text-center{text-align:center}.text-danger{color:var(--color-danger)}

/* Buttons */
.btn{display:inline-flex;align-items:center;gap:8px;padding:11px 26px;border-radius:50px;font-size:.9rem;font-weight:600;letter-spacing:.3px;transition:all var(--transition);white-space:nowrap}
.btn-primary{background:var(--color-primary);color:#fff;box-shadow:0 4px 14px rgba(111,78,55,.35)}
.btn-primary:hover{background:var(--color-primary-light);transform:translateY(-1px);box-shadow:0 6px 20px rgba(111,78,55,.45)}
.btn-accent{background:var(--color-accent);color:#1A1A1A;box-shadow:0 4px 14px rgba(212,175,55,.3)}
.btn-accent:hover{background:var(--color-accent-dark);transform:translateY(-1px)}
.btn-outline{border:2px solid var(--color-primary);color:var(--color-primary)}.btn-outline:hover{background:var(--color-primary);color:#fff}
.btn-ghost{border:1.5px solid var(--border);color:var(--text-muted)}.btn-ghost:hover{border-color:var(--color-primary);color:var(--color-primary)}
.btn-danger{background:var(--color-danger);color:#fff}
.btn-sm{padding:7px 18px;font-size:.82rem}.btn-lg{padding:14px 36px;font-size:1rem}.btn-full{width:100%;justify-content:center}
.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}

/* Icon Buttons & Badge */
.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:50%;color:var(--text);position:relative;transition:all var(--transition)}
.icon-btn svg{width:20px;height:20px}
.icon-btn:hover{background:var(--bg-alt);color:var(--color-primary)}
.badge{position:absolute;top:2px;right:2px;min-width:18px;height:18px;background:var(--color-accent);color:#1A1A1A;font-size:.68rem;font-weight:700;border-radius:50%;display:flex;align-items:center;justify-content:center;padding:0 4px;pointer-events:none}

/* Announcement Bar */
.announcement-bar{background:var(--color-primary);color:#fff;text-align:center;padding:8px 48px;font-size:.82rem;position:relative}
.ann-close{position:absolute;right:14px;top:50%;transform:translateY(-50%);color:#fff;font-size:1.2rem;opacity:.7;line-height:1}
.ann-close:hover{opacity:1}

/* Header */
.site-header{background:var(--bg-header);backdrop-filter:blur(12px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:1000;transition:background var(--transition),box-shadow var(--transition)}
.site-header.scrolled{box-shadow:var(--shadow-md)}
.header-inner{display:flex;align-items:center;gap:24px;padding-top:12px;padding-bottom:12px}

/* Logo */
.logo,.footer-logo{display:flex;align-items:center;gap:10px;flex-shrink:0}
.logo-icon{width:44px;height:44px;border-radius:12px;background:linear-gradient(135deg,var(--color-primary),var(--color-primary-light));display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.4rem;font-family:'Georgia',serif;box-shadow:0 4px 12px rgba(111,78,55,.4)}
.logo-text{display:flex;flex-direction:column;line-height:1}
.logo-brand{font-family:var(--font-heading);font-size:1.15rem;font-weight:700;color:var(--color-primary)}
.logo-sub{font-size:.65rem;letter-spacing:.12em;text-transform:uppercase;color:var(--text-muted)}

/* Nav */
.main-nav{display:flex;align-items:center;gap:4px;flex:1;justify-content:center}
.nav-link{padding:8px 14px;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;color:var(--text);transition:all var(--transition)}
.nav-link:hover{color:var(--color-primary);background:var(--bg-alt)}
.nav-dropdown{position:relative}
.dropdown-menu{position:absolute;top:calc(100% + 8px);left:0;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-lg);min-width:180px;padding:8px;opacity:0;visibility:hidden;transform:translateY(-8px);transition:all var(--transition);z-index:200}
.dropdown-right{left:auto;right:0}
.nav-dropdown:hover .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-item{display:block;padding:9px 14px;border-radius:var(--radius-sm);font-size:.88rem;color:var(--text);transition:all var(--transition)}
.dropdown-item:hover{background:var(--bg-alt);color:var(--color-primary)}
.dropdown-divider{height:1px;background:var(--border);margin:6px 0}
.dropdown-header{padding:8px 14px;font-size:.78rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em}
.header-actions{display:flex;align-items:center;gap:4px;margin-left:auto}

/* Theme toggle */
.theme-toggle .sun-icon{display:block}.theme-toggle .moon-icon{display:none}
[data-theme="dark"] .theme-toggle .sun-icon{display:none}[data-theme="dark"] .theme-toggle .moon-icon{display:block}

/* Search */
.search-bar-wrap{background:var(--bg-alt);border-top:1px solid var(--border);padding:14px 0;display:none;animation:slideDown .2s ease}
.search-bar-wrap.open{display:block}
@keyframes slideDown{from{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}
.search-form{display:flex;gap:10px}
.search-input{flex:1;padding:11px 18px;border:1.5px solid var(--border);border-radius:50px;background:var(--bg-card);color:var(--text);font-family:inherit;font-size:.9rem;transition:border-color var(--transition)}
.search-input:focus{outline:none;border-color:var(--color-primary)}
.search-suggestions{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);margin-top:6px;display:none;overflow:hidden}
.search-suggestions.open{display:block}
.suggestion-item{padding:10px 16px;font-size:.88rem;cursor:pointer;transition:background var(--transition)}
.suggestion-item:hover{background:var(--bg-alt)}

/* Mobile Nav */
.mobile-menu-toggle{display:none}
.mobile-nav{display:none;flex-direction:column;background:var(--bg-card);border-top:1px solid var(--border);padding:12px 0;animation:slideDown .2s ease}
.mobile-nav.open{display:flex}
.mobile-nav-link{padding:12px 20px;font-size:.95rem;color:var(--text);border-bottom:1px solid var(--border)}
.mobile-nav-link:hover{color:var(--color-primary);background:var(--bg-alt)}

/* Alerts */
.flash-container{max-width:900px;margin:0 auto;padding:0 20px}
.alert{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-radius:var(--radius-sm);margin:10px 0;font-size:.9rem;gap:12px;animation:slideDown .3s ease}
.alert-success{background:#EAFBF0;color:#1A6335;border:1px solid #A8DFB8}.alert-error{background:#FDF0F0;color:#8B1A1A;border:1px solid #F5AAAA}
.alert-warning{background:#FEF9E7;color:#7D5700;border:1px solid #F0D060}.alert-info{background:#EAF4FB;color:#1A4B6B;border:1px solid #9DCCF0}
.alert-close{background:none;border:none;cursor:pointer;opacity:.6;font-size:1.2rem;padding:0 4px}.alert-close:hover{opacity:1}

/* Sections */
.section{padding:72px 0}.section-sm{padding:40px 0}
.section-title{font-family:var(--font-heading);font-size:2rem;font-weight:700;color:var(--text);margin-bottom:10px}
.section-subtitle{color:var(--text-muted);font-size:1rem;margin-bottom:40px}
.section-header{text-align:center}
.section-header .section-title::after{content:'';display:block;width:60px;height:3px;background:linear-gradient(90deg,var(--color-primary),var(--color-accent));margin:12px auto 0;border-radius:2px}

/* Carousel */
.carousel-wrap{position:relative;overflow:hidden;aspect-ratio:16/6;background:var(--bg-alt)}
.carousel-track{display:flex;transition:transform .6s cubic-bezier(.4,0,.2,1);height:100%}
.carousel-slide{min-width:100%;position:relative;overflow:hidden}
.carousel-slide img{width:100%;height:100%;object-fit:cover}
.carousel-overlay{position:absolute;inset:0;background:linear-gradient(to right,rgba(0,0,0,.55) 0%,rgba(0,0,0,.1) 60%,transparent 100%);display:flex;align-items:center;padding:0 8%}
.carousel-content{color:#fff;max-width:520px}
.carousel-content h2{font-family:var(--font-heading);font-size:clamp(1.6rem,4vw,3rem);margin-bottom:12px;text-shadow:0 2px 8px rgba(0,0,0,.4)}
.carousel-content p{font-size:clamp(.9rem,1.8vw,1.15rem);margin-bottom:28px;opacity:.9}
.carousel-btn{position:absolute;top:50%;transform:translateY(-50%);width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.2);backdrop-filter:blur(8px);border:1.5px solid rgba(255,255,255,.4);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.3rem;transition:all var(--transition);z-index:10}
.carousel-btn:hover{background:rgba(255,255,255,.35)}
.carousel-prev{left:20px}.carousel-next{right:20px}
.carousel-dots{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);display:flex;gap:8px}
.carousel-dot{width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,.5);transition:all var(--transition);cursor:pointer}
.carousel-dot.active{background:#fff;width:24px;border-radius:4px}

/* Product Cards */
.products-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:24px}
.product-card{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;transition:all var(--transition);position:relative}
.product-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg)}
.product-img-wrap{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--bg-alt)}
.product-img-wrap img{width:100%;height:100%;object-fit:cover;transition:transform .5s ease}
.product-card:hover .product-img-wrap img{transform:scale(1.06)}
.product-badges{position:absolute;top:10px;left:10px;display:flex;flex-direction:column;gap:4px}
.badge-chip{padding:3px 10px;border-radius:50px;font-size:.7rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}
.badge-new{background:var(--color-primary);color:#fff}.badge-sale{background:var(--color-danger);color:#fff}.badge-trending{background:var(--color-accent);color:#1A1A1A}
.product-actions{position:absolute;top:10px;right:10px;display:flex;flex-direction:column;gap:6px;opacity:0;transform:translateX(10px);transition:all var(--transition)}
.product-card:hover .product-actions{opacity:1;transform:translateX(0)}
.product-action-btn{width:36px;height:36px;border-radius:50%;background:var(--bg-card);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;color:var(--text);font-size:.85rem;transition:all var(--transition);box-shadow:var(--shadow-sm)}
.product-action-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}
.product-action-btn svg{width:16px;height:16px}
.product-info{padding:16px}
.product-category{font-size:.75rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.08em;margin-bottom:4px}
.product-name{font-weight:600;font-size:.95rem;color:var(--text);margin-bottom:10px;line-height:1.3}
.product-name a:hover{color:var(--color-primary)}
.product-footer-row{display:flex;align-items:center;justify-content:space-between;gap:8px}
.price{font-size:1.1rem;font-weight:700;color:var(--color-primary)}
.price-sale{font-size:1.1rem;font-weight:700;color:var(--color-danger)}
.price-original{font-size:.85rem;color:var(--text-muted);text-decoration:line-through;margin-left:6px}
.stars{display:flex;gap:2px}.star{color:var(--border);font-size:.9rem}.star.filled{color:var(--color-accent)}.star.half{color:var(--color-accent);opacity:.6}
.review-count{font-size:.75rem;color:var(--text-muted);margin-left:4px}
.cart-add-btn{width:36px;height:36px;border-radius:50%;background:var(--color-primary);color:#fff;display:flex;align-items:center;justify-content:center;transition:all var(--transition);border:none;flex-shrink:0}
.cart-add-btn:hover{background:var(--color-accent);color:#1A1A1A;transform:scale(1.1)}
.cart-add-btn svg{width:18px;height:18px}

/* Tabs */
.tabs-wrap{display:flex;gap:8px;justify-content:center;flex-wrap:wrap;margin-bottom:36px}
.tab-btn{padding:9px 24px;border-radius:50px;font-size:.88rem;font-weight:500;border:1.5px solid var(--border);color:var(--text-muted);transition:all var(--transition);background:transparent}
.tab-btn.active,.tab-btn:hover{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

/* Newsletter Section */
.newsletter-section{background:linear-gradient(135deg,var(--color-primary) 0%,#A0785A 100%);padding:64px 20px;text-align:center;color:#fff}
.newsletter-section h2{font-family:var(--font-heading);font-size:2rem;margin-bottom:10px}
.newsletter-section p{opacity:.85;margin-bottom:30px}
.newsletter-row{display:flex;gap:10px;max-width:480px;margin:0 auto}
.newsletter-input-hero{flex:1;padding:13px 20px;border-radius:50px;border:none;font-family:inherit;font-size:.95rem;background:rgba(255,255,255,.15);color:#fff;backdrop-filter:blur(8px)}
.newsletter-input-hero::placeholder{color:rgba(255,255,255,.6)}
.newsletter-input-hero:focus{outline:2px solid rgba(255,255,255,.5)}
.newsletter-note{margin-top:10px;font-size:.82rem;opacity:.75;min-height:20px}

/* Testimonials */
.testimonials-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:24px}
.testimonial-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:relative;transition:box-shadow var(--transition)}
.testimonial-card::before{content:'"';font-size:4rem;color:var(--color-accent);position:absolute;top:10px;right:20px;line-height:1;opacity:.5}
.testimonial-card:hover{box-shadow:var(--shadow-md)}
.testimonial-body{font-size:.92rem;color:var(--text-muted);line-height:1.7;margin-bottom:20px}
.testimonial-author{display:flex;align-items:center;gap:12px}
.testimonial-avatar{width:44px;height:44px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:1rem;flex-shrink:0}
.testimonial-name{font-weight:600;font-size:.9rem}.testimonial-role{font-size:.78rem;color:var(--text-muted)}

/* Shop Filters */
.shop-layout{display:grid;grid-template-columns:240px 1fr;gap:32px;align-items:start}
.filters-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:24px;position:sticky;top:90px}
.filter-section{margin-bottom:28px}.filter-section:last-child{margin-bottom:0}
.filter-title{font-weight:600;font-size:.9rem;margin-bottom:14px;color:var(--text)}
.filter-option{display:flex;align-items:center;gap:10px;padding:6px 0;cursor:pointer;font-size:.88rem}
.filter-option input{accent-color:var(--color-primary);width:16px;height:16px}
.filter-option:hover{color:var(--color-primary)}
.shop-header-row{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:24px}
.shop-count{font-size:.88rem;color:var(--text-muted)}
.sort-select{padding:8px 14px;border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-card);color:var(--text);font-family:inherit;font-size:.88rem;cursor:pointer}
.sort-select:focus{outline:none;border-color:var(--color-primary)}

/* Product Detail */
.product-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start}
.product-gallery .main-image{aspect-ratio:3/4;border-radius:var(--radius);overflow:hidden;border:1px solid var(--border);cursor:zoom-in}
.product-gallery .main-image img{width:100%;height:100%;object-fit:cover;transition:transform .3s}
.gallery-thumbs{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap}
.gallery-thumb{width:72px;height:72px;border-radius:var(--radius-sm);overflow:hidden;border:2px solid transparent;cursor:pointer;transition:border-color var(--transition)}
.gallery-thumb.active,.gallery-thumb:hover{border-color:var(--color-primary)}
.gallery-thumb img{width:100%;height:100%;object-fit:cover}
.product-detail-info{display:flex;flex-direction:column;gap:20px}
.product-detail-category{color:var(--text-muted);font-size:.82rem;text-transform:uppercase;letter-spacing:.1em}
.product-detail-name{font-family:var(--font-heading);font-size:1.9rem;font-weight:700;line-height:1.2}
.product-detail-price{font-size:1.6rem;font-weight:700;color:var(--color-primary)}
.product-divider{height:1px;background:var(--border)}
.variant-label{font-size:.88rem;font-weight:600;margin-bottom:10px;color:var(--text)}
.size-options{display:flex;gap:8px;flex-wrap:wrap}
.size-btn{min-width:44px;height:40px;padding:0 12px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.85rem;color:var(--text);transition:all var(--transition)}
.size-btn.active,.size-btn:hover{border-color:var(--color-primary);color:var(--color-primary);background:rgba(111,78,55,.07)}
.color-options{display:flex;gap:8px;flex-wrap:wrap}
.color-dot{width:30px;height:30px;border-radius:50%;cursor:pointer;border:2.5px solid transparent;transition:all var(--transition);outline:2px solid transparent;outline-offset:3px}
.color-dot.active,.color-dot:hover{outline-color:var(--color-primary)}
.qty-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.qty-control{display:flex;align-items:center;border:1.5px solid var(--border);border-radius:var(--radius-sm);overflow:hidden}
.qty-btn{width:38px;height:38px;display:flex;align-items:center;justify-content:center;font-size:1.1rem;transition:background var(--transition)}.qty-btn:hover{background:var(--bg-alt)}
.qty-input{width:50px;height:38px;text-align:center;border:none;border-left:1px solid var(--border);border-right:1px solid var(--border);background:var(--bg-card);color:var(--text);font-size:.95rem;font-family:inherit}
.action-row{display:flex;gap:12px;flex-wrap:wrap}
.wishlist-toggle{width:48px;height:48px;border-radius:50%;border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;transition:all var(--transition)}
.wishlist-toggle:hover,.wishlist-toggle.active{border-color:var(--color-danger);color:var(--color-danger);background:#FDF0F0}
.wishlist-toggle svg{width:20px;height:20px}

/* Cart */
.cart-layout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start}
.cart-table{background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden}
.cart-row{display:grid;grid-template-columns:auto 1fr auto auto auto;gap:16px;align-items:center;padding:20px;border-bottom:1px solid var(--border)}
.cart-row:last-child{border-bottom:none}
.cart-img{width:80px;height:80px;border-radius:var(--radius-sm);overflow:hidden;background:var(--bg-alt)}
.cart-img img{width:100%;height:100%;object-fit:cover}
.cart-name{font-weight:600;font-size:.95rem;margin-bottom:4px}
.cart-variant{font-size:.8rem;color:var(--text-muted)}
.order-summary{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:28px;position:sticky;top:90px}
.summary-row{display:flex;justify-content:space-between;font-size:.92rem;padding:8px 0;border-bottom:1px solid var(--border)}
.summary-row:last-child{border-bottom:none}
.summary-total{font-size:1.1rem;font-weight:700;color:var(--color-primary);margin-top:6px}
.coupon-form{display:flex;gap:8px;margin-bottom:20px}
.coupon-input{flex:1;padding:10px 14px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text);font-family:inherit}
.coupon-input:focus{outline:none;border-color:var(--color-primary)}

/* Forms */
.form-group{margin-bottom:20px}
.form-label{display:block;font-size:.88rem;font-weight:600;margin-bottom:7px;color:var(--text)}
.form-control{width:100%;padding:12px 16px;border:1.5px solid var(--border);border-radius:var(--radius-sm);background:var(--bg-card);color:var(--text);font-family:inherit;font-size:.95rem;transition:border-color var(--transition)}
.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px rgba(111,78,55,.12)}
.form-control::placeholder{color:var(--text-light)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-hint{font-size:.78rem;color:var(--text-muted);margin-top:5px}
textarea.form-control{resize:vertical;min-height:100px}
select.form-control{cursor:pointer}
.checkbox-wrap{display:flex;align-items:flex-start;gap:10px;font-size:.88rem;line-height:1.5}
.checkbox-wrap input{accent-color:var(--color-primary);width:17px;height:17px;margin-top:2px;flex-shrink:0}
.checkbox-wrap a{color:var(--color-primary);text-decoration:underline}

/* Auth */
.auth-wrap{min-height:80vh;display:flex;align-items:center;justify-content:center;padding:40px 20px}
.auth-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:44px 40px;width:100%;max-width:460px;box-shadow:var(--shadow-lg)}
.auth-logo{text-align:center;margin-bottom:28px}
.auth-title{font-family:var(--font-heading);font-size:1.7rem;text-align:center;margin-bottom:6px}
.auth-subtitle{text-align:center;font-size:.88rem;color:var(--text-muted);margin-bottom:32px}
.auth-footer-text{text-align:center;font-size:.88rem;color:var(--text-muted);margin-top:20px}
.auth-footer-text a{color:var(--color-primary);font-weight:600}

/* Checkout */
.checkout-layout{display:grid;grid-template-columns:1fr 340px;gap:32px;align-items:start}
.checkout-section-title{font-size:1.1rem;font-weight:700;margin-bottom:20px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.payment-options{display:flex;flex-direction:column;gap:12px}
.payment-option{display:flex;align-items:flex-start;gap:14px;padding:18px;border:1.5px solid var(--border);border-radius:var(--radius);cursor:pointer;transition:all var(--transition)}
.payment-option:hover,.payment-option.selected{border-color:var(--color-primary);background:rgba(111,78,55,.04)}
.payment-option input[type=radio]{accent-color:var(--color-primary);margin-top:3px;flex-shrink:0}
.payment-icon{font-size:1.6rem}.payment-name{font-weight:600;font-size:.95rem}.payment-desc{font-size:.8rem;color:var(--text-muted);margin-top:2px}
.payment-extra{margin-top:14px;padding-top:14px;border-top:1px solid var(--border);display:none}
.payment-extra.show{display:block}

/* Account */
.account-layout{display:grid;grid-template-columns:220px 1fr;gap:32px;align-items:start}
.account-sidebar{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:16px;position:sticky;top:90px}
.account-nav-link{display:flex;align-items:center;gap:10px;padding:11px 14px;border-radius:var(--radius-sm);font-size:.9rem;color:var(--text);transition:all var(--transition);margin-bottom:2px}
.account-nav-link.active{background:var(--color-primary);color:#fff}
.account-nav-link:hover:not(.active){background:var(--bg-alt);color:var(--color-primary)}
.account-nav-link svg{width:17px;height:17px;flex-shrink:0}
.user-card{text-align:center;padding:20px 0 16px;border-bottom:1px solid var(--border);margin-bottom:12px}
.user-avatar{width:64px;height:64px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;color:#fff;font-size:1.5rem;font-weight:700;margin:0 auto 10px}
.user-name-sm{font-weight:600;font-size:.95rem}.user-email-sm{font-size:.78rem;color:var(--text-muted)}
.account-content{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:32px}

/* Orders Table */
.orders-table{width:100%;border-collapse:collapse;font-size:.88rem}
.orders-table th{padding:12px 16px;text-align:left;border-bottom:2px solid var(--border);font-size:.78rem;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}
.orders-table td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle}
.orders-table tr:last-child td{border-bottom:none}
.orders-table tr:hover td{background:var(--bg-alt)}
.order-status{display:inline-block;padding:4px 12px;border-radius:50px;font-size:.72rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}
.status-pending{background:#FEF9E7;color:#7D5700}.status-processing{background:#EAF4FB;color:#1A4B6B}
.status-shipped{background:#EAF5FB;color:#1A5276}.status-delivered{background:#EAFBF0;color:#1A6335}
.status-cancelled{background:#FDF0F0;color:#8B1A1A}.status-paid{background:#EAFBF0;color:#1A6335}

/* Reviews */
.reviews-list{display:flex;flex-direction:column;gap:20px}
.review-card{background:var(--bg-alt);border-radius:var(--radius);padding:20px}
.review-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:10px;flex-wrap:wrap}
.review-author{font-weight:600;font-size:.9rem}.review-date{font-size:.78rem;color:var(--text-muted)}
.review-title{font-weight:600;margin-bottom:6px;font-size:.92rem}
.review-body{font-size:.88rem;color:var(--text-muted);line-height:1.65}
.review-form{background:var(--bg-alt);border-radius:var(--radius);padding:24px;margin-top:32px}
.star-rating-input{display:flex;gap:6px;font-size:1.8rem;cursor:pointer}
.star-rating-input span{color:var(--border);transition:color var(--transition)}
.star-rating-input span.active,.star-rating-input span:hover{color:var(--color-accent)}

/* Pagination */
.pagination{display:flex;gap:6px;flex-wrap:wrap;margin-top:36px;justify-content:center}
.page-btn{width:38px;height:38px;border-radius:var(--radius-sm);border:1.5px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:.88rem;color:var(--text);transition:all var(--transition)}
.page-btn.active,.page-btn:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}

/* Category Hero */
.category-hero{background:linear-gradient(135deg,var(--bg-alt) 0%,var(--bg) 100%);padding:48px 20px;text-align:center;border-bottom:1px solid var(--border)}
.category-hero h1{font-family:var(--font-heading);font-size:2.2rem;margin-bottom:8px}
.category-hero p{color:var(--text-muted);font-size:.95rem}
.category-tags{display:flex;gap:10px;justify-content:center;margin-top:16px;flex-wrap:wrap}
.category-tag{padding:7px 20px;border-radius:50px;border:1.5px solid var(--border);font-size:.82rem;font-weight:500;color:var(--text-muted);transition:all var(--transition)}
.category-tag:hover,.category-tag.active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}

/* Footer */
.site-footer{background:var(--bg-footer);color:rgba(255,255,255,.8);position:relative}
.footer-wave{color:var(--bg-footer);line-height:0;margin-top:-1px}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 2fr;gap:40px;padding:60px 20px 40px}
.footer-brand .logo-brand{color:var(--color-accent)}.footer-brand .logo-sub{color:rgba(255,255,255,.5)}
.footer-brand .logo-icon{background:linear-gradient(135deg,var(--color-accent),var(--color-accent-dark));color:#1A1A1A}
.footer-desc{font-size:.87rem;color:rgba(255,255,255,.6);margin-top:14px;line-height:1.7}
.footer-heading{font-family:var(--font-heading);font-size:1.05rem;font-weight:600;color:#fff;margin-bottom:18px}
.footer-sub-heading{font-size:.88rem;font-weight:600;color:#fff;margin-bottom:10px}
.footer-links{display:flex;flex-direction:column;gap:8px}.footer-links a{font-size:.87rem;color:rgba(255,255,255,.6);transition:color var(--transition)}
.footer-links a:hover{color:var(--color-accent)}
.footer-contact{display:flex;flex-direction:column;gap:10px}
.footer-contact li{display:flex;align-items:flex-start;gap:10px;font-size:.87rem;color:rgba(255,255,255,.65)}
.footer-contact li svg{width:16px;height:16px;flex-shrink:0;margin-top:2px;color:var(--color-accent)}
.footer-contact a{color:inherit}.footer-contact a:hover{color:var(--color-accent)}
.social-links{display:flex;gap:10px;margin-top:20px}
.social-btn{width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.1);display:flex;align-items:center;justify-content:center;color:rgba(255,255,255,.7);transition:all var(--transition)}
.social-btn svg{width:17px;height:17px}.social-btn:hover{background:var(--color-accent);color:#1A1A1A}
.newsletter-form{display:flex;gap:8px}.newsletter-note{font-size:.78rem;color:rgba(255,255,255,.5);margin-top:8px;min-height:18px}
.newsletter-input{flex:1;padding:10px 14px;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,.2);background:rgba(255,255,255,.1);color:#fff;font-family:inherit;font-size:.87rem}
.newsletter-input::placeholder{color:rgba(255,255,255,.45)}.newsletter-input:focus{outline:none;border-color:var(--color-accent)}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1)}
.footer-bottom-inner{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;font-size:.82rem;color:rgba(255,255,255,.5);flex-wrap:wrap;gap:12px}
.payment-icons{display:flex;gap:8px}
.payment-badge{padding:4px 12px;border-radius:6px;font-size:.72rem;font-weight:700;letter-spacing:.05em;background:rgba(255,255,255,.15);color:rgba(255,255,255,.8)}
.payment-badge.bkash{background:#E2136E;color:#fff}.payment-badge.nagad{background:#F05A28;color:#fff}

/* Breadcrumb */
.breadcrumb{display:flex;align-items:center;gap:6px;font-size:.82rem;color:var(--text-muted);padding:8px 0;flex-wrap:wrap}
.breadcrumb a:hover{color:var(--color-primary)}.breadcrumb-sep{color:var(--text-light)}

/* Empty State */
.empty-state{text-align:center;padding:64px 20px}
.empty-icon{font-size:4rem;margin-bottom:16px}
.empty-state h3{font-family:var(--font-heading);margin-bottom:10px}
.empty-state p{color:var(--text-muted);margin-bottom:24px}

/* Spinner */
.spinner{width:36px;height:36px;border:3px solid var(--border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .7s linear infinite;margin:0 auto}
@keyframes spin{to{transform:rotate(360deg)}}

/* Reveal animation */
.reveal{opacity:0;transform:translateY(24px);transition:opacity .55s ease,transform .55s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Responsive */
@media(max-width:1024px){.shop-layout{grid-template-columns:1fr}.filters-sidebar{position:static}.footer-grid{grid-template-columns:1fr 1fr}.product-detail-grid{grid-template-columns:1fr}.checkout-layout{grid-template-columns:1fr}.cart-layout{grid-template-columns:1fr}.account-layout{grid-template-columns:1fr}}
@media(max-width:768px){.main-nav{display:none}.mobile-menu-toggle{display:flex}.section{padding:48px 0}.section-title{font-size:1.6rem}.footer-grid{grid-template-columns:1fr;gap:28px}.carousel-wrap{aspect-ratio:16/9}.form-row{grid-template-columns:1fr}.auth-card{padding:28px 22px}.products-grid{grid-template-columns:repeat(auto-fill,minmax(170px,1fr));gap:14px}.newsletter-row{flex-direction:column}}
@media(max-width:480px){.header-inner{gap:10px}.logo-sub{display:none}.products-grid{grid-template-columns:repeat(2,1fr);gap:10px}}

.visually-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}
