:root{
  --gold:#C9A84C;--gold-light:#E8D5A3;--gold-dark:#9A7B2F;
  --cream:#FAF6F0;--cream-dark:#F0E8DC;
  --charcoal:#1A1614;--charcoal-mid:#2D2520;--charcoal-light:#4A3F38;
  --rose:#B8697A;--sage:#7A9E8E;
  --white:#FFFFFF;--shadow:rgba(0,0,0,0.12);
  --font-display:'Cormorant Garamond',serif;
  --font-body:'Jost',sans-serif;
  --radius:4px;--radius-lg:12px;
  --transition:all 0.3s cubic-bezier(0.4,0,0.2,1);
}
*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{font-family:var(--font-body);background:var(--cream);color:var(--charcoal);overflow-x:hidden;}

/* ANNOUNCEMENT BAR */
#announcement-bar{
  background:white;color:var(--charcoal);
  font-family:var(--font-body);font-size:12px;letter-spacing:2px;
  text-transform:uppercase;padding:8px 0;text-align:center;
  position:relative;overflow:hidden;font-weight: bolder;
}
#announcement-bar .ticker{
  display:inline-block;white-space:nowrap;
  animation:ticker 20s linear infinite;
}
@keyframes ticker{0%{transform:translateX(100vw);}100%{transform:translateX(-100%);}}

/* NAVBAR */
#navbar{
  position:sticky;top:0;z-index:1000;
  background:rgba(41, 32, 3, 0.97);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--gold-light);
  padding:0 48px;height:70px;
  display:flex;align-items:center;justify-content:space-between;
  transition:var(--transition);
}
#navbar.scrolled{box-shadow:0 2px 20px var(--shadow);}
.nav-logo{
  font-family:var(--font-display);font-size:28px;font-weight:300;
  color:var(--charcoal);letter-spacing:2px;cursor:pointer;
  display:flex;align-items:center;gap:8px;flex:1;
}
.nav-logo span{color:var(--gold);}
.nav-links{
  display:flex;gap:32px;align-items:center;flex:1;justify-content:center;
}
.nav-link{
  font-family:var(--font-body);font-size:13px;font-weight:500;
  letter-spacing:1.5px;text-transform:uppercase;
  color:var(--charcoal-light);cursor:pointer;
  position:relative;padding:4px 0;transition:var(--transition);
  background:none;border:none;
  color: #F0E8DC;
}
.nav-link::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
  background:var(--gold);transition:var(--transition);
}
.nav-link:hover,.nav-link.active{color: #F0E8DC;}
.nav-link:hover::after,.nav-link.active::after{width:100%;}
.nav-right{display:flex;align-items:center;gap:20px;flex:1;justify-content:flex-end;}

/* SEARCH BAR */
.search-container{position:relative;}
.search-input{
  border:1px solid var(--gold-light);border-radius:20px;
  padding:6px 36px 6px 14px;font-family:var(--font-body);
  font-size:13px;background:transparent;color:var(--charcoal);
  width:180px;transition:var(--transition);outline:none;
}
.search-input:focus{border-color:var(--gold);width:220px;}
.search-btn{
  position:absolute;right:10px;top:50%;transform:translateY(-50%);
  background:none;border:none;cursor:pointer;color:var(--gold);font-size:14px;
}
.search-dropdown{
  position:absolute;top:calc(100% + 8px);left:0;right:0;
  background:var(--white);border:1px solid var(--gold-light);
  border-radius:var(--radius-lg);box-shadow:0 8px 24px var(--shadow);
  z-index:200;overflow:hidden;display:none;
}
.search-dropdown.show{display:block;}
.search-item{
  padding:10px 14px;cursor:pointer;font-size:13px;
  border-bottom:1px solid var(--cream-dark);transition:var(--transition);
}
.search-item:hover{background:var(--cream);}
.search-item:last-child{border-bottom:none;}

.nav-icon-btn{
  position:relative;background:none;border:none;cursor:pointer;
  color:var(--charcoal-light);font-size:18px;transition:var(--transition);
  width:36px;height:36px;display:flex;align-items:center;justify-content:center;
  border-radius:50%;
}
.nav-icon-btn:hover{color:var(--gold);background:var(--cream-dark);}
.cart-badge{
  position:absolute;top:-2px;right:-2px;
  background:var(--gold);color:var(--white);
  font-size:9px;font-weight:600;border-radius:50%;
  width:16px;height:16px;display:flex;align-items:center;justify-content:center;
}

/* PAGES */
.page{display:none;animation:fadeIn 0.4s ease;}
.page.active{display:block;}
@keyframes fadeIn{from{opacity:0;transform:translateY(8px);}to{opacity:1;transform:translateY(0);}}

/* ===== HOME PAGE ===== */
/* CAROUSEL */
.hero-carousel{
  position:relative;height:560px;overflow:hidden;
}
.carousel-slides{display:flex;height:100%;transition:transform 0.7s cubic-bezier(0.4,0,0.2,1);}
.carousel-slide{
  min-width:100%;height:100%;position:relative;
  display:flex;align-items:center;justify-content:center;
  background:var(--charcoal);overflow:hidden;
}
.carousel-slide-content{
  position:relative;z-index:2;text-align:center;color:var(--white);
  padding:40px;
}
.carousel-slide h1{
  font-family:var(--font-display);font-size:clamp(36px,5vw,64px);
  font-weight:300;letter-spacing:4px;line-height:1.2;
  margin-bottom:16px;
}
.carousel-slide p{
  font-size:14px;letter-spacing:2px;opacity:0.8;margin-bottom:28px;
}
.carousel-slide .btn-outline{
  border:1px solid var(--gold);color:var(--gold);
  padding:12px 32px;letter-spacing:2px;font-size:12px;
  text-transform:uppercase;cursor:pointer;background:transparent;
  transition:var(--transition);font-family:var(--font-body);
}
.carousel-slide .btn-outline:hover{background:var(--gold);color:var(--charcoal);}
.carousel-bg{
  position:absolute;inset:0;background-size:cover;background-position:center;
  opacity:0.4;transition:transform 8s ease;
}
.carousel-slide:hover .carousel-bg{transform:scale(1.05);}
.carousel-dots{
  position:absolute;bottom:20px;left:50%;transform:translateX(-50%);
  display:flex;gap:8px;z-index:3;
}
.carousel-dot{
  width:8px;height:8px;border-radius:50%;background:rgba(255,255,255,0.4);
  cursor:pointer;transition:var(--transition);border:none;
}
.carousel-dot.active{background:var(--gold);width:24px;border-radius:4px;}
.carousel-btn{
  position:absolute;top:50%;transform:translateY(-50%);
  background:rgba(255,255,255,0.1);backdrop-filter:blur(4px);
  border:1px solid rgba(255,255,255,0.2);color:var(--white);
  width:44px;height:44px;border-radius:50%;cursor:pointer;
  font-size:18px;transition:var(--transition);z-index:3;
}
.carousel-btn:hover{background:var(--gold);border-color:var(--gold);}
.carousel-btn.prev{left:24px;}
.carousel-btn.next{right:24px;}
.btn-outline{
    border-radius: 25px;
    font-weight: bolder;
}

/* SECTIONS */
.section{padding:80px 48px;}
.section-header{text-align:center;margin-bottom:52px;}
.section-title{
  font-family:var(--font-display);font-size:clamp(28px,4vw,44px);
  font-weight:300;letter-spacing:3px;color:var(--charcoal);
  margin-bottom:12px;
}
.section-subtitle{
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  color:var(--gold);margin-bottom:8px;
}
.section-line{
  width:48px;height:1px;background:var(--gold);
  margin:16px auto 0;
}

/* CATEGORIES */
.categories-grid{
  display:flex;gap:24px;justify-content:center;flex-wrap:wrap;
}
.category-item{
  display:flex;flex-direction:column;align-items:center;gap:12px;
  cursor:pointer;transition:var(--transition);
}
.category-item:hover{transform:translateY(-4px);}
.category-circle{
  width:100px;height:100px;border-radius:50%;overflow:hidden;
  border:2px solid var(--gold-light);transition:var(--transition);
  background:var(--cream-dark);position:relative;
}
.category-item:hover .category-circle{border-color:var(--gold);box-shadow:0 8px 24px rgba(201,168,76,0.2);}
.category-circle img{width:100%;height:100%;object-fit:cover;}
.category-name{
  font-size:11px;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--charcoal-light);font-weight:500;
}

/* PRODUCT CARDS */
.products-grid{
  display:grid;grid-template-columns:repeat(4,1fr);gap:24px;
}
.product-card{
  background:var(--white);border-radius:var(--radius-lg);
  overflow:hidden;cursor:pointer;transition:var(--transition);
  border:1px solid var(--cream-dark);position:relative;
}
.product-card:hover{
  transform:translateY(-6px);
  box-shadow:0 16px 40px rgba(0,0,0,0.1);
  border-color:var(--gold-light);
}
.product-image-wrap{
  height:240px;overflow:hidden;position:relative;background:var(--cream);
}
.product-image-wrap img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s ease;
}
.product-card:hover .product-image-wrap img.main-img{opacity:0;}
.product-card:hover .product-image-wrap img.hover-img{opacity:1;}
.product-image-wrap img.hover-img{
  position:absolute;inset:0;opacity:0;transition:opacity 0.4s ease;
}
.product-info{padding:16px;}
.product-name{
  font-family:var(--font-display);font-size:16px;font-weight:400;
  color:var(--charcoal);margin-bottom:6px;letter-spacing:0.5px;
}
.product-rating{
  display:flex;align-items:center;gap:6px;margin-bottom:8px;
}
.stars{color:var(--gold);font-size:12px;}
.rating-count{font-size:11px;color:var(--charcoal-light);}
.product-price{
  font-family:var(--font-display);font-size:20px;font-weight:600;
  color:var(--charcoal);margin-bottom:12px;
}
.price-original{
  font-size:13px;color:var(--charcoal-light);text-decoration:line-through;margin-left:6px;
  font-weight:300;
}
.price-off{font-size:11px;color:var(--rose);font-weight:600;margin-left:4px;}
.add-to-cart-btn{
  width:100%;padding:10px;
  background:var(--charcoal);color:var(--gold-light);
  border:none;cursor:pointer;font-family:var(--font-body);
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  transition:var(--transition);border-radius:var(--radius);
}
.add-to-cart-btn:hover{background:var(--gold);color:var(--charcoal);}
.qty-control{
  display:flex;align-items:center;justify-content:center;gap:0;
  border:1px solid var(--gold);border-radius:var(--radius);overflow:hidden;
}
.qty-btn{
  width:36px;height:36px;background:var(--charcoal);color:var(--gold-light);
  border:none;cursor:pointer;font-size:18px;transition:var(--transition);
}
.qty-btn:hover{background:var(--gold);color:var(--charcoal);}
.qty-display{
  flex:1;text-align:center;font-weight:600;font-size:14px;
  padding:0 12px;color:var(--charcoal);
}
.wishlist-btn{
  position:absolute;top:12px;right:12px;
  background:rgba(255,255,255,0.9);border:none;cursor:pointer;
  width:32px;height:32px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:14px;transition:var(--transition);
  box-shadow:0 2px 8px var(--shadow);
}
.wishlist-btn:hover{background:var(--rose);color:var(--white);}
.wishlist-btn.liked{color:var(--rose);}

/* VIEW ALL BTN */
.view-all-wrap{text-align:center;margin-top:40px;}
.btn-primary{
  background:var(--charcoal);color:var(--gold-light);
  border:none;padding:14px 48px;font-family:var(--font-body);
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:var(--transition);border-radius:var(--radius);
  display:inline-block;
}
.btn-primary:hover{background:var(--gold);color:var(--charcoal);}
.btn-secondary{
  background:transparent;color:var(--charcoal);
  border:1px solid var(--charcoal);padding:12px 40px;font-family:var(--font-body);
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:var(--transition);border-radius:var(--radius);
}
.btn-secondary:hover{background:var(--charcoal);color:var(--gold-light);}

/* ABOUT SECTION ON HOME */
.about-section-home{
  background:var(--charcoal);padding:80px 48px;
  display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center;
}
.about-text-side{color:var(--cream);}
.about-text-side .section-subtitle{color:var(--gold);}
.about-text-side .section-title{color:var(--cream);}
.about-text-side p{
  font-size:15px;line-height:1.9;color:rgba(250,246,240,0.75);
  margin-bottom:28px;font-weight:300;
}
.about-graphic{
  position:relative;height:400px;
}
.about-graphic-inner{
  position:relative;width:100%;height:100%;
}
.about-img-main{
  width:70%;height:85%;object-fit:cover;
  position:absolute;right:0;bottom:0;
  border-radius:var(--radius-lg);
}
.about-img-accent{
  width:45%;height:55%;object-fit:cover;
  position:absolute;left:0;top:0;
  border-radius:var(--radius-lg);
  border:4px solid var(--charcoal);
  box-shadow:0 8px 32px rgba(0,0,0,0.4);
}
.about-tag{
  position:absolute;bottom:16px;left:16px;
  background:var(--gold);color:var(--charcoal);
  padding:8px 16px;font-size:11px;letter-spacing:2px;
  text-transform:uppercase;font-weight:600;border-radius:var(--radius);
}

/* PLATFORMS */
.platforms-section{padding:60px 0;background:var(--cream-dark);overflow:hidden;}
.platforms-section .section-header{padding:0 48px;}
.platforms-track{
  display:flex;gap:48px;align-items:center;
  animation:scrollLeft 20s linear infinite;
  width:max-content;
}
.platforms-track:hover{animation-play-state:paused;}
@keyframes scrollLeft{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.platform-logo{
  font-family:var(--font-display);font-size:24px;font-weight:400;
  letter-spacing:2px;color:var(--charcoal-light);padding:16px 32px;
  border:1px solid var(--gold-light);border-radius:var(--radius);
  white-space:nowrap;transition:var(--transition);background:var(--white);
}
.platform-logo:hover{border-color:var(--gold);color:var(--charcoal);}

/* REVIEWS */
.reviews-section{padding:80px 0;overflow:hidden;}
.reviews-section .section-header{padding:0 48px;margin-bottom:40px;}
.reviews-track{
  display:flex;gap:24px;
  animation:scrollLeft 30s linear infinite;
  width:max-content;padding:16px 0;
}
.reviews-track:hover{animation-play-state:paused;}
.review-card{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:28px;width:320px;flex-shrink:0;
  transition:var(--transition);
}
.review-card:hover{border-color:var(--gold-light);box-shadow:0 8px 24px var(--shadow);}
.review-header{display:flex;align-items:center;gap:12px;margin-bottom:16px;}
.reviewer-avatar{
  width:44px;height:44px;border-radius:50%;
  background:var(--gold);display:flex;align-items:center;justify-content:center;
  color:var(--white);font-weight:600;font-size:16px;flex-shrink:0;
}
.reviewer-name{font-weight:500;font-size:14px;color:var(--charcoal);}
.reviewer-date{font-size:11px;color:var(--charcoal-light);}
.review-stars{color:var(--gold);font-size:13px;margin-bottom:10px;}
.review-text{font-size:13px;line-height:1.7;color:var(--charcoal-light);}
.verified-badge{
  font-size:10px;color:var(--sage);letter-spacing:1px;
  text-transform:uppercase;font-weight:600;margin-top:10px;
}

/* FOOTER */
footer{
  background:var(--charcoal);color:var(--cream);
  padding:60px 48px 24px;
}
.footer-grid{
  display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:48px;
  margin-bottom:48px;
}
.footer-brand{font-family:var(--font-display);font-size:28px;font-weight:300;letter-spacing:2px;margin-bottom:16px;}
.footer-brand span{color:var(--gold);}
.footer-desc{font-size:13px;line-height:1.8;color:rgba(250,246,240,0.6);margin-bottom:24px;}
.footer-heading{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:500;}
.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px;}
.footer-links a{font-size:13px;color:rgba(250,246,240,0.6);cursor:pointer;transition:var(--transition);}
.footer-links a:hover{color:var(--gold);}
.footer-social{display:flex;gap:12px;margin-top:4px;}
.social-btn{
  width:36px;height:36px;border-radius:50%;
  border:1px solid rgba(250,246,240,0.2);
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;transition:var(--transition);font-size:14px;
  color:rgba(250,246,240,0.6);
}
.social-btn:hover{border-color:var(--gold);color:var(--gold);}
.footer-bottom{
  border-top:1px solid rgba(250,246,240,0.1);padding-top:24px;
  display:flex;justify-content:space-between;align-items:center;
}
.footer-bottom p{font-size:12px;color:rgba(250,246,240,0.4);}

/* ===== PRODUCTS PAGE ===== */
.products-hero{
  height:240px;background:var(--charcoal);
  display:flex;align-items:center;justify-content:center;
  text-align:center;position:relative;overflow:hidden;
}
.products-hero h1{
  font-family:var(--font-display);font-size:56px;font-weight:300;
  color:var(--cream);letter-spacing:6px;position:relative;z-index:1;
}
.products-hero::before{
  content:'';position:absolute;inset:0;
  background:radial-gradient(ellipse at center, rgba(201,168,76,0.15) 0%, transparent 70%);
}
.products-toolbar{
  padding:24px 48px;display:flex;justify-content:space-between;
  align-items:center;border-bottom:1px solid var(--cream-dark);
  background:var(--white);
}
.products-count{font-size:13px;color:var(--charcoal-light);}
.sort-wrapper{position:relative;}
.sort-btn{
  border:1px solid var(--cream-dark);background:var(--white);
  padding:8px 16px;border-radius:var(--radius);cursor:pointer;
  font-family:var(--font-body);font-size:13px;display:flex;align-items:center;gap:8px;
  transition:var(--transition);
}
.sort-btn:hover{border-color:var(--gold);}
.sort-dropdown{
  position:absolute;right:0;top:calc(100%+4px);
  background:var(--white);border:1px solid var(--gold-light);
  border-radius:var(--radius-lg);min-width:160px;z-index:100;
  box-shadow:0 8px 24px var(--shadow);display:none;overflow:hidden;
}
.sort-dropdown.show{display:block;}
.sort-option{
  padding:10px 16px;cursor:pointer;font-size:13px;transition:var(--transition);
}
.sort-option:hover{background:var(--cream);color:var(--gold);}
.products-content{padding:40px 48px;}
.products-sub-section{margin-bottom:60px;}
.products-sub-title{
  font-family:var(--font-display);font-size:32px;font-weight:300;
  letter-spacing:2px;margin-bottom:32px;color:var(--charcoal);
  display:flex;align-items:center;gap:16px;
}
.products-sub-title::after{content:'';flex:1;height:1px;background:var(--cream-dark);}

/* GRAB LIST */
.grab-tabs{display:flex;gap:0;margin-bottom:32px;border-bottom:2px solid var(--cream-dark);}
.grab-tab{
  padding:12px 24px;font-size:13px;letter-spacing:1.5px;text-transform:uppercase;
  cursor:pointer;color:var(--charcoal-light);background:none;border:none;
  position:relative;transition:var(--transition);font-family:var(--font-body);
}
.grab-tab.active{color:var(--charcoal);font-weight:500;}
.grab-tab.active::after{
  content:'';position:absolute;bottom:-2px;left:0;right:0;height:2px;
  background:var(--gold);
}
.grab-list-items{display:flex;gap:16px;flex-wrap:wrap;}
.grab-item{
  display:flex;flex-direction:column;align-items:center;gap:8px;
  cursor:pointer;transition:var(--transition);width:120px;
}
.grab-item:hover{transform:translateY(-4px);}
.grab-img{
  width:110px;height:110px;border-radius:var(--radius);overflow:hidden;
  border:1px solid var(--cream-dark);transition:var(--transition);
}
.grab-item:hover .grab-img{border-color:var(--gold);}
.grab-img img{width:100%;height:100%;object-fit:cover;}
.grab-name{font-size:11px;text-align:center;color:var(--charcoal-light);}

/* ===== PRODUCT DETAILS PAGE ===== */
.product-detail-layout{
  padding:60px 48px;display:grid;
  grid-template-columns:1fr 1fr;gap:64px;
}
.product-detail-images{position:sticky;top:90px;align-self:start;}
.product-main-img{
  width:100%;height:500px;object-fit:cover;border-radius:var(--radius-lg);
  margin-bottom:16px;transition:var(--transition);
}
.product-thumbnails{display:flex;gap:10px;}
.product-thumb{
  width:72px;height:72px;object-fit:cover;border-radius:var(--radius);
  cursor:pointer;border:2px solid transparent;transition:var(--transition);
}
.product-thumb.active,.product-thumb:hover{border-color:var(--gold);}
.product-detail-info{}
.product-detail-name{
  font-family:var(--font-display);font-size:36px;font-weight:300;
  letter-spacing:2px;color:var(--charcoal);margin-bottom:16px;line-height:1.2;
}
.product-detail-rating{display:flex;align-items:center;gap:10px;margin-bottom:20px;}
.product-detail-price{
  font-family:var(--font-display);font-size:32px;font-weight:600;
  color:var(--charcoal);margin-bottom:8px;
}
.product-detail-desc{
  font-size:14px;line-height:1.9;color:var(--charcoal-light);
  margin-bottom:28px;font-weight:300;
}
.color-options-label{
  font-size:11px;letter-spacing:2px;text-transform:uppercase;
  color:var(--charcoal-light);margin-bottom:12px;font-weight:500;
}
.color-options{display:flex;gap:10px;margin-bottom:28px;flex-wrap:wrap;}
.color-option{
  width:36px;height:36px;border-radius:50%;cursor:pointer;
  border:2px solid transparent;transition:var(--transition);
  position:relative;
}
.color-option.active,.color-option:hover{border-color:var(--charcoal);transform:scale(1.1);}
.color-option .color-name-tip{
  position:absolute;bottom:-24px;left:50%;transform:translateX(-50%);
  font-size:10px;white-space:nowrap;color:var(--charcoal-light);opacity:0;
  transition:var(--transition);
}
.color-option:hover .color-name-tip{opacity:1;}
.detail-actions{display:flex;gap:12px;margin-bottom:32px;}
.btn-add-cart{
  flex:1;background:var(--charcoal);color:var(--gold-light);
  border:none;padding:16px;font-family:var(--font-body);
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:var(--transition);border-radius:var(--radius);
}
.btn-add-cart:hover{background:var(--gold);color:var(--charcoal);}
.btn-buy-now{
  flex:1;background:transparent;color:var(--charcoal);
  border:1px solid var(--charcoal);padding:16px;font-family:var(--font-body);
  font-size:12px;letter-spacing:2px;text-transform:uppercase;
  cursor:pointer;transition:var(--transition);border-radius:var(--radius);
}
.btn-buy-now:hover{background:var(--charcoal);color:var(--gold-light);}
.product-meta{
  border-top:1px solid var(--cream-dark);padding-top:24px;
  display:flex;flex-direction:column;gap:10px;
}
.meta-row{display:flex;gap:8px;font-size:13px;}
.meta-label{color:var(--charcoal-light);width:80px;flex-shrink:0;}
.meta-value{color:var(--charcoal);font-weight:500;}

/* WRITE REVIEW */
.write-review{padding:40px 48px;border-top:1px solid var(--cream-dark);}
.write-review h3{
  font-family:var(--font-display);font-size:28px;font-weight:300;
  letter-spacing:2px;margin-bottom:24px;
}
.review-form{display:flex;flex-direction:column;gap:16px;max-width:600px;margin-bottom:40px;}
.star-picker{display:flex;gap:4px;font-size:24px;color:var(--cream-dark);cursor:pointer;}
.star-picker .star{transition:var(--transition);}
.star-picker .star.active,.star-picker .star:hover{color:var(--gold);}
.form-input,.form-textarea{
  border:1px solid var(--cream-dark);padding:12px 16px;
  font-family:var(--font-body);font-size:13px;background:var(--white);
  border-radius:var(--radius);outline:none;color:var(--charcoal);
  transition:var(--transition);
}
.form-input:focus,.form-textarea:focus{border-color:var(--gold);}
.form-textarea{height:100px;resize:vertical;}
.reviews-list{display:flex;flex-direction:column;gap:20px;}
.review-item{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:24px;
}

/* ===== CART PAGE ===== */
.cart-layout{
  padding:60px 48px;display:grid;
  grid-template-columns:1fr 360px;gap:40px;
}
.cart-empty{
  text-align:center;padding:80px 0;
}
.cart-empty h2{
  font-family:var(--font-display);font-size:36px;font-weight:300;
  color:var(--charcoal-light);margin-bottom:16px;
}
.cart-items-list{display:flex;flex-direction:column;gap:16px;}
.cart-item{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:20px;
  display:flex;gap:16px;align-items:center;
}
.cart-item-img{width:90px;height:90px;object-fit:cover;border-radius:var(--radius);}
.cart-item-details{flex:1;}
.cart-item-name{font-family:var(--font-display);font-size:18px;font-weight:400;margin-bottom:4px;}
.cart-item-color{font-size:12px;color:var(--charcoal-light);margin-bottom:10px;}
.cart-item-price{font-family:var(--font-display);font-size:20px;font-weight:600;color:var(--charcoal);}
.cart-item-remove{background:none;border:none;cursor:pointer;color:var(--charcoal-light);font-size:16px;padding:4px;transition:var(--transition);}
.cart-item-remove:hover{color:var(--rose);}
.cart-summary{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:28px;align-self:start;
  position:sticky;top:90px;
}
.cart-summary h3{font-family:var(--font-display);font-size:24px;font-weight:300;margin-bottom:24px;letter-spacing:1px;}
.summary-row{display:flex;justify-content:space-between;margin-bottom:14px;font-size:14px;}
.summary-row.total{
  border-top:1px solid var(--cream-dark);padding-top:16px;margin-top:8px;
  font-weight:600;font-family:var(--font-display);font-size:20px;
}
.promo-input{display:flex;gap:8px;margin:20px 0;}
.promo-field{
  flex:1;border:1px solid var(--cream-dark);padding:10px 14px;
  border-radius:var(--radius);font-family:var(--font-body);font-size:13px;outline:none;
}
.promo-field:focus{border-color:var(--gold);}
.promo-apply{
  background:var(--charcoal);color:var(--gold-light);border:none;
  padding:10px 16px;border-radius:var(--radius);cursor:pointer;
  font-size:12px;letter-spacing:1px;transition:var(--transition);
}
.promo-apply:hover{background:var(--gold);color:var(--charcoal);}

/* ===== CHECKOUT PAGE ===== */
.checkout-layout{
  padding:60px 48px;max-width:800px;margin:0 auto;
}
.checkout-step{margin-bottom:40px;}
.step-title{
  font-family:var(--font-display);font-size:26px;font-weight:300;
  letter-spacing:2px;margin-bottom:24px;
  padding-bottom:12px;border-bottom:1px solid var(--cream-dark);
}
.payment-methods{display:flex;flex-direction:column;gap:12px;}
.payment-method{
  border:1px solid var(--cream-dark);border-radius:var(--radius-lg);
  padding:18px 20px;cursor:pointer;transition:var(--transition);
  display:flex;align-items:center;gap:14px;
}
.payment-method.selected{border-color:var(--gold);background:rgba(201,168,76,0.04);}
.payment-radio{
  width:18px;height:18px;border-radius:50%;border:2px solid var(--cream-dark);
  transition:var(--transition);flex-shrink:0;
}
.payment-method.selected .payment-radio{border-color:var(--gold);background:var(--gold);}
.payment-icon{font-size:22px;}
.payment-label{font-weight:500;font-size:14px;}
.payment-sub{font-size:12px;color:var(--charcoal-light);}
.address-form{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.form-group{display:flex;flex-direction:column;gap:6px;}
.form-group.full{grid-column:1/-1;}
.form-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--charcoal-light);font-weight:500;}

/* ===== BILLING PAGE ===== */
.billing-page{padding:60px 48px;max-width:700px;margin:0 auto;}
.billing-success{
  text-align:center;padding:40px 0;
  animation:fadeIn 0.6s ease;
}
.success-icon{
  font-size:64px;margin-bottom:20px;
  animation:popIn 0.5s cubic-bezier(0.34,1.56,0.64,1);
}
@keyframes popIn{from{transform:scale(0);}to{transform:scale(1);}}
.billing-success h1{
  font-family:var(--font-display);font-size:42px;font-weight:300;
  letter-spacing:3px;color:var(--charcoal);margin-bottom:8px;
}
.billing-success p{color:var(--charcoal-light);font-size:14px;margin-bottom:40px;}
.order-details-card{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:32px;text-align:left;margin-bottom:32px;
}
.order-detail-row{
  display:flex;justify-content:space-between;padding:10px 0;
  border-bottom:1px solid var(--cream-dark);font-size:14px;
}
.order-detail-row:last-child{border-bottom:none;}
.tracking-section{background:var(--cream-dark);border-radius:var(--radius-lg);padding:28px;margin-bottom:32px;}
.tracking-title{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:20px;font-weight:500;}
.tracking-steps{display:flex;align-items:flex-start;gap:0;}
.track-step{flex:1;display:flex;flex-direction:column;align-items:center;position:relative;}
.track-step:not(:last-child)::after{
  content:'';position:absolute;top:16px;left:50%;width:100%;height:2px;
  background:var(--cream-dark);z-index:0;
}
.track-step.done:not(:last-child)::after{background:var(--gold);}
.track-dot{
  width:32px;height:32px;border-radius:50%;border:2px solid var(--cream-dark);
  background:var(--white);z-index:1;display:flex;align-items:center;justify-content:center;
  font-size:14px;margin-bottom:8px;transition:var(--transition);
}
.track-step.done .track-dot{border-color:var(--gold);background:var(--gold);color:var(--white);}
.track-step.active .track-dot{border-color:var(--gold);color:var(--gold);}
.track-label{font-size:11px;text-align:center;color:var(--charcoal-light);letter-spacing:0.5px;}

/* ===== PROFILE PAGE ===== */
.profile-page{padding:60px 48px;max-width:900px;margin:0 auto;}
.profile-header{
  display:flex;align-items:center;gap:28px;
  padding:32px;background:var(--white);border-radius:var(--radius-lg);
  border:1px solid var(--cream-dark);margin-bottom:32px;
}
.profile-avatar{
  width:80px;height:80px;border-radius:50%;
  background:var(--gold);display:flex;align-items:center;justify-content:center;
  font-size:32px;color:var(--white);font-weight:300;font-family:var(--font-display);
  flex-shrink:0;
}
.profile-name{font-family:var(--font-display);font-size:28px;font-weight:300;letter-spacing:1px;margin-bottom:4px;}
.profile-email{font-size:13px;color:var(--charcoal-light);}
.profile-section-title{
  font-family:var(--font-display);font-size:24px;font-weight:300;
  letter-spacing:1px;margin-bottom:20px;
}
.orders-list{display:flex;flex-direction:column;gap:16px;margin-bottom:40px;}
.order-card{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:20px;
  display:flex;justify-content:space-between;align-items:center;
}
.order-id{font-size:12px;color:var(--charcoal-light);margin-bottom:4px;}
.order-items-summary{font-weight:500;margin-bottom:4px;}
.order-date{font-size:12px;color:var(--charcoal-light);}
.order-status{
  padding:6px 14px;border-radius:20px;font-size:11px;
  letter-spacing:1px;text-transform:uppercase;font-weight:500;
}
.status-delivered{background:rgba(122,158,142,0.15);color:var(--sage);}
.status-processing{background:rgba(201,168,76,0.15);color:var(--gold-dark);}
.status-shipped{background:rgba(74,63,56,0.1);color:var(--charcoal-light);}
.info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;}
.info-card{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:20px;
}
.info-label{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--charcoal-light);margin-bottom:6px;}
.info-value{font-size:15px;color:var(--charcoal);font-weight:500;}

/* ===== AUTH PAGES ===== */
.auth-page{
  min-height:calc(100vh - 110px);display:flex;
  align-items:center;justify-content:center;
  background:var(--cream);padding:60px 24px;
}
.auth-card{
  background:var(--white);border:1px solid var(--cream-dark);
  border-radius:var(--radius-lg);padding:48px;width:100%;max-width:440px;
  box-shadow:0 8px 40px rgba(0,0,0,0.06);
}
.auth-title{
  font-family:var(--font-display);font-size:36px;font-weight:300;
  letter-spacing:2px;text-align:center;margin-bottom:8px;
}
.auth-subtitle{font-size:13px;color:var(--charcoal-light);text-align:center;margin-bottom:36px;}
.auth-form{display:flex;flex-direction:column;gap:16px;}
.auth-link{text-align:center;font-size:13px;color:var(--charcoal-light);margin-top:16px;}
.auth-link a{color:var(--gold);cursor:pointer;font-weight:500;}
.auth-link a:hover{text-decoration:underline;}
.divider{display:flex;align-items:center;gap:12px;color:var(--charcoal-light);font-size:12px;}
.divider::before,.divider::after{content:'';flex:1;height:1px;background:var(--cream-dark);}
.error-msg{color:var(--rose);font-size:12px;margin-top:-8px;}
.success-msg{color:var(--sage);font-size:12px;margin-top:-8px;}

/* ABOUT PAGE */
.about-hero{
  height:360px;background:var(--charcoal);
  display:flex;align-items:center;justify-content:center;
  position:relative;overflow:hidden;
}
.about-hero h1{
  font-family:var(--font-display);font-size:56px;font-weight:300;
  color:var(--cream);letter-spacing:6px;text-align:center;position:relative;z-index:1;
}
.about-hero p{
  color:rgba(250,246,240,0.6);font-size:13px;letter-spacing:2px;
  text-align:center;margin-top:12px;position:relative;z-index:1;
}
.about-content{padding:80px 48px;}
.about-story-grid{display:grid;grid-template-columns:1fr 1fr;gap:64px;margin-bottom:80px;align-items:center;}
.about-story-img{width:100%;height:440px;object-fit:cover;border-radius:var(--radius-lg);}
.about-story-text .section-title{text-align:left;}
.about-story-text p{font-size:15px;line-height:1.9;color:var(--charcoal-light);margin-bottom:16px;font-weight:300;}
.team-section{text-align:center;margin-bottom:80px;}
.team-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:40px;margin-top:48px;}
.team-card{text-align:center;}
.team-photo{
  width:180px;height:180px;border-radius:50%;object-fit:cover;
  margin:0 auto 20px;border:4px solid var(--gold-light);
  display:block;background:var(--cream-dark);
  display:flex;align-items:center;justify-content:center;
  font-family:var(--font-display);font-size:48px;font-weight:300;color:var(--gold);
}
.team-name{font-family:var(--font-display);font-size:22px;font-weight:300;margin-bottom:4px;}
.team-role{font-size:11px;letter-spacing:2px;text-transform:uppercase;color:var(--gold);margin-bottom:12px;}
.team-bio{font-size:13px;line-height:1.7;color:var(--charcoal-light);}
.values-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;}
.value-card{
  text-align:center;padding:32px 20px;
  border:1px solid var(--cream-dark);border-radius:var(--radius-lg);
  transition:var(--transition);
}
.value-card:hover{border-color:var(--gold);transform:translateY(-4px);}
.value-icon{font-size:36px;margin-bottom:16px;}
.value-title{font-family:var(--font-display);font-size:18px;margin-bottom:8px;}
.value-text{font-size:13px;color:var(--charcoal-light);line-height:1.6;}

/* POPUPS */
.popup-overlay{
  position:fixed;inset:0;background:rgba(0,0,0,0.5);z-index:2000;
  display:flex;align-items:center;justify-content:center;
  animation:fadeIn 0.3s ease;
}
.popup-overlay.hidden{display:none;}
.promo-popup{
  background:var(--charcoal);border-radius:var(--radius-lg);
  width:90%;max-width:500px;position:relative;overflow:hidden;
  animation:popIn 0.4s cubic-bezier(0.34,1.56,0.64,1);
}
.promo-popup-body{
  padding:48px;text-align:center;
}
.promo-popup h2{
  font-family:var(--font-display);font-size:48px;font-weight:300;
  color:var(--gold);letter-spacing:4px;margin-bottom:8px;
}
.promo-popup h3{
  font-family:var(--font-display);font-size:24px;font-weight:300;
  color:var(--cream);letter-spacing:2px;margin-bottom:16px;
}
.promo-popup p{font-size:13px;color:rgba(250,246,240,0.6);margin-bottom:28px;}
.promo-code-box{
  background:rgba(201,168,76,0.1);border:1px dashed var(--gold);
  padding:12px 24px;border-radius:var(--radius);margin-bottom:24px;
  font-family:var(--font-display);font-size:28px;color:var(--gold);letter-spacing:4px;
}
.popup-close{
  position:absolute;top:16px;right:16px;
  background:rgba(255,255,255,0.1);border:none;color:var(--cream);
  width:32px;height:32px;border-radius:50%;cursor:pointer;font-size:18px;
  display:flex;align-items:center;justify-content:center;transition:var(--transition);
}
.popup-close:hover{background:rgba(255,255,255,0.2);}
.popup-timer{
  font-size:11px;color:rgba(250,246,240,0.4);letter-spacing:1px;
}

/* GIFT CARD */
.gift-card-popup{
  position:fixed;bottom:24px;left:24px;z-index:1500;
  background:var(--charcoal);color:var(--cream);
  border-radius:var(--radius-lg);padding:20px;width:260px;
  border:1px solid rgba(201,168,76,0.3);
  box-shadow:0 8px 32px rgba(0,0,0,0.3);
  animation:slideUp 0.4s cubic-bezier(0.34,1.56,0.64,1);
  transition:var(--transition);
}
.gift-card-popup.hidden{display:none;}
@keyframes slideUp{from{transform:translateY(100px);opacity:0;}to{transform:translateY(0);opacity:1;}}
.gift-title{font-family:var(--font-display);font-size:18px;font-weight:300;color:var(--gold);margin-bottom:6px;}
.gift-desc{font-size:12px;color:rgba(250,246,240,0.6);margin-bottom:14px;line-height:1.5;}
.gift-code{
  background:rgba(201,168,76,0.1);border:1px dashed var(--gold);
  padding:8px 12px;border-radius:var(--radius);
  font-family:var(--font-display);font-size:18px;color:var(--gold);
  letter-spacing:3px;text-align:center;margin-bottom:12px;
}
.gift-close{
  position:absolute;top:10px;right:10px;
  background:none;border:none;color:rgba(250,246,240,0.4);
  cursor:pointer;font-size:16px;transition:var(--transition);
}
.gift-close:hover{color:var(--cream);}

/* SIMILAR PRODUCTS */
.similar-section{padding:60px 48px;background:var(--cream-dark);}
.similar-section h3{
  font-family:var(--font-display);font-size:32px;font-weight:300;
  letter-spacing:2px;margin-bottom:32px;
}
.similar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;}

/* NOTIFICATIONS */
.toast{
  position:fixed;bottom:24px;right:24px;z-index:3000;
  background:var(--charcoal);color:var(--cream);
  padding:14px 20px;border-radius:var(--radius-lg);
  border-left:3px solid var(--gold);
  font-size:13px;display:flex;align-items:center;gap:10px;
  box-shadow:0 8px 24px rgba(0,0,0,0.2);
  animation:slideUp 0.3s ease;
  display:none;
}
.toast.show{display:flex;}

/* RESPONSIVE */
@media(max-width:1024px){
  .products-grid,.similar-grid{grid-template-columns:repeat(3,1fr);}
  .footer-grid{grid-template-columns:1fr 1fr;}
  .values-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:768px){
  #navbar{padding:0 20px;}
  .nav-links{display:none;}
  .section,.products-content,.product-detail-layout,.billing-page,.profile-page,.checkout-layout,.about-content{padding:40px 20px;}
  .products-grid{grid-template-columns:repeat(2,1fr);}
  .product-detail-layout{grid-template-columns:1fr;}
  .about-section-home,.about-story-grid{grid-template-columns:1fr;}
  .team-grid{grid-template-columns:1fr 1fr;}
  .values-grid{grid-template-columns:1fr 1fr;}
  .cart-layout{grid-template-columns:1fr;}
  .footer-grid{grid-template-columns:1fr;}
  .address-form{grid-template-columns:1fr;}
  .info-grid{grid-template-columns:1fr;}
}
@media(max-width:480px){
  .products-grid{grid-template-columns:1fr 1fr;}
  .team-grid{grid-template-columns:1fr;}
}

/* LOADING SKELETON */
.skeleton{
  background:linear-gradient(90deg,var(--cream-dark) 25%,var(--cream) 50%,var(--cream-dark) 75%);
  background-size:200% 100%;
  animation:shimmer 1.5s infinite;
  border-radius:var(--radius);
}
@keyframes shimmer{0%{background-position:200% 0;}100%{background-position:-200% 0;}}