/* ===== LUXORA — style.css ===== */
@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;1,400&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --black:#0a0a0a;
  --charcoal:#1c1a17;
  --white:#ffffff;
  --ivory:#f7f4ee;
  --beige:#ece4d6;
  --beige-dark:#d8c9ad;
  --gold:#b8975a;
  --gold-light:#d4af6a;
  --gold-pale:#f4e2b8;
  --line: rgba(184,151,90,0.35);
  --shadow: 0 20px 60px rgba(0,0,0,0.12);
  --ease: cubic-bezier(.65,.05,.2,1);
}

*,*::before,*::after{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  font-family:'Jost', sans-serif;
  font-weight:300;
  color:var(--black);
  background:var(--ivory);
  line-height:1.6;
  -webkit-font-smoothing:antialiased;
}
h1,h2,h3,h4,.font-display{
  font-family:'Cormorant Garamond', serif;
  font-weight:500;
  letter-spacing:0.5px;
  margin:0 0 .5em;
}
h1{font-size:clamp(2.6rem,5vw,4.4rem); line-height:1.05;}
h2{font-size:clamp(2rem,3.4vw,2.9rem);}
h3{font-size:1.5rem;}
p{margin:0 0 1em; color:#3a3530;}
a{color:inherit; text-decoration:none;}
img,svg{max-width:100%; display:block;}
ul{list-style:none; margin:0; padding:0;}
button{font-family:inherit; cursor:pointer;}
input,select,textarea{font-family:inherit; font-size:1rem;}
.container{max-width:1280px; margin:0 auto; padding:0 32px;}
.eyebrow{
  display:inline-block; font-size:0.72rem; letter-spacing:4px; text-transform:uppercase;
  color:var(--gold); margin-bottom:14px; font-weight:500;
}
.section{padding:96px 0;}
.section-tight{padding:56px 0;}
.center{text-align:center;}
.muted{color:#8a8074;}

/* reveal animation */
.reveal{opacity:0; transform:translateY(28px); transition:opacity .9s var(--ease), transform .9s var(--ease);}
.reveal.is-visible{opacity:1; transform:translateY(0);}

/* Buttons */
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  padding:16px 38px; font-size:0.78rem; letter-spacing:3px; text-transform:uppercase;
  border:1px solid var(--black); background:var(--black); color:var(--white);
  transition:all .4s var(--ease); white-space:nowrap;
}
.btn:hover{background:var(--gold); border-color:var(--gold); color:var(--black);}
.btn-outline{background:transparent; color:var(--black); border:1px solid var(--black);}
.btn-outline:hover{background:var(--black); color:var(--white);}
.btn-gold{background:var(--gold); border-color:var(--gold); color:var(--black);}
.btn-gold:hover{background:var(--black); border-color:var(--black); color:var(--gold);}
.btn-light{background:var(--ivory); border-color:var(--ivory); color:var(--black);}
.btn-light:hover{background:var(--gold); border-color:var(--gold);}
.btn-block{width:100%;}
.btn:disabled{opacity:0.45; cursor:not-allowed;}

/* ===== HEADER ===== */
.announce-bar{
  background:var(--black); color:var(--beige); text-align:center; font-size:0.72rem;
  letter-spacing:2px; padding:9px 14px; text-transform:uppercase;
}
.site-header{
  position:sticky; top:0; z-index:1000; background:rgba(247,244,238,0.92);
  backdrop-filter:blur(10px); border-bottom:1px solid var(--line);
}
.nav-wrap{display:flex; align-items:center; justify-content:space-between; padding:18px 32px; max-width:1280px; margin:0 auto;}
.logo-link{color:var(--black); flex-shrink:0;}
.logo-link svg{height:38px; width:auto;}
.main-nav{display:flex; gap:34px;}
.main-nav a{
  font-size:0.8rem; letter-spacing:1.5px; text-transform:uppercase; position:relative; padding:6px 0;
}
.main-nav a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--gold);
  transition:width .35s var(--ease);
}
.main-nav a:hover::after, .main-nav a.active::after{width:100%;}
.main-nav a.active{color:var(--gold-light);}
.nav-actions{display:flex; align-items:center; gap:20px;}
.icon-btn{position:relative; display:inline-flex; color:var(--black); transition:color .3s;}
.icon-btn:hover{color:var(--gold);}
.icon-btn svg{width:21px; height:21px;}
.badge{
  position:absolute; top:-8px; right:-9px; background:var(--gold); color:var(--black);
  font-size:0.62rem; width:17px; height:17px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  font-weight:600;
}
.menu-toggle{display:none; flex-direction:column; gap:5px; background:none; border:none;}
.menu-toggle span{width:24px; height:1.5px; background:var(--black);}

.search-overlay{
  position:fixed; inset:0; background:rgba(10,10,10,0.96); z-index:2000;
  display:flex; align-items:flex-start; justify-content:center; padding-top:14vh;
  opacity:0; pointer-events:none; transition:opacity .4s var(--ease);
}
.search-overlay.open{opacity:1; pointer-events:auto;}
.search-overlay form{width:90%; max-width:640px; border-bottom:1px solid var(--gold); display:flex; align-items:center; gap:14px;}
.search-overlay input{
  flex:1; background:none; border:none; color:var(--white); font-size:1.6rem; padding:14px 0;
  font-family:'Cormorant Garamond',serif;
}
.search-overlay input::placeholder{color:#666;}
.search-overlay input:focus{outline:none;}
.search-overlay button{background:none; border:none; color:var(--gold);}
.search-close{position:absolute; top:34px; right:5%; color:var(--white); background:none; border:none; font-size:1rem; letter-spacing:2px;}

/* ===== HERO ===== */
.hero{position:relative; overflow:hidden; background:var(--black);}
.hero img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0;}
.hero-inner{position:relative; min-height:78vh; display:flex; align-items:flex-end; padding:0 0 80px;}
.hero-content{max-width:560px; color:var(--ivory);}
.hero-content .eyebrow{color:var(--gold-light);}
.hero-content h1{color:var(--white);}
.hero-content p{color:#cfc8bb;}
.hero-btns{display:flex; gap:16px; margin-top:28px; flex-wrap:wrap;}
.hero-small{min-height:42vh;}
.page-banner{position:relative; background:var(--black); color:var(--white);}
.page-banner img{width:100%; height:100%; object-fit:cover; position:absolute; inset:0; opacity:0.85;}
.page-banner .container{position:relative; padding:70px 32px;}
.breadcrumb{font-size:0.75rem; letter-spacing:2px; color:var(--gold-light); text-transform:uppercase; margin-bottom:10px;}

/* ===== PRODUCT GRID ===== */
.grid{display:grid; gap:36px;}
.grid-4{grid-template-columns:repeat(4,1fr);}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}

.product-card{position:relative; cursor:pointer;}
.product-thumb{position:relative; overflow:hidden; background:var(--beige); aspect-ratio:7/9;}
.product-thumb img{width:100%; height:100%; object-fit:cover; transition:transform .7s var(--ease);}
.product-card:hover .product-thumb img{transform:scale(1.06);}
.product-tag{
  position:absolute; top:14px; left:14px; background:var(--gold); color:var(--black);
  font-size:0.65rem; letter-spacing:2px; text-transform:uppercase; padding:5px 10px;
}
.product-wish{
  position:absolute; top:12px; right:12px; background:rgba(255,255,255,0.85); border:none;
  width:36px; height:36px; border-radius:50%; display:flex; align-items:center; justify-content:center;
  color:var(--black); transition:all .3s;
}
.product-wish svg{width:17px; height:17px;}
.product-wish.active{color:var(--gold);}
.product-wish.active svg{fill:var(--gold);}
.product-quickadd{
  position:absolute; left:0; right:0; bottom:0; background:var(--black); color:var(--white);
  text-align:center; padding:13px; font-size:0.72rem; letter-spacing:2px; text-transform:uppercase;
  transform:translateY(100%); transition:transform .4s var(--ease); border:none; width:100%;
}
.product-card:hover .product-quickadd{transform:translateY(0);}
.product-info{padding-top:16px; display:flex; justify-content:space-between; align-items:flex-start;}
.product-info h4{margin:0 0 4px; font-size:1.05rem; font-weight:500; font-family:'Jost',sans-serif; letter-spacing:0.3px;}
.product-info .cat{font-size:0.7rem; letter-spacing:1.5px; text-transform:uppercase; color:#a39a8c;}
.product-price{font-family:'Cormorant Garamond',serif; font-size:1.15rem; color:var(--gold-dark,#8a6f3a); white-space:nowrap;}
.price-strike{text-decoration:line-through; color:#b3aa9c; font-size:0.95rem; margin-right:6px;}

/* ===== FILTER / TOOLBAR ===== */
.shop-toolbar{
  display:flex; flex-wrap:wrap; gap:18px; align-items:center; justify-content:space-between;
  padding-bottom:34px; border-bottom:1px solid var(--line); margin-bottom:48px;
}
.filter-group{display:flex; gap:10px; flex-wrap:wrap;}
.chip{
  padding:9px 18px; border:1px solid #d7cdb9; font-size:0.72rem; letter-spacing:1.5px;
  text-transform:uppercase; background:transparent; transition:all .3s;
}
.chip.active, .chip:hover{background:var(--black); border-color:var(--black); color:var(--white);}
.sort-select{padding:10px 16px; border:1px solid #d7cdb9; background:var(--ivory); letter-spacing:1px; font-size:0.8rem;}
.search-mini{display:flex; align-items:center; border:1px solid #d7cdb9; padding:0 14px;}
.search-mini input{border:none; background:none; padding:10px 6px; width:180px;}
.search-mini input:focus{outline:none;}
.empty-state{padding:80px 0; text-align:center; color:#9a907f;}

/* ===== SECTIONS GENERIC ===== */
.section-head{display:flex; justify-content:space-between; align-items:flex-end; margin-bottom:50px; gap:24px; flex-wrap:wrap;}
.section-head .eyebrow{margin-bottom:6px;}

.feature-split{display:grid; grid-template-columns:1fr 1fr; gap:0; align-items:stretch;}
.feature-split .media img{width:100%; height:100%; object-fit:cover; min-height:480px;}
.feature-split .copy{display:flex; flex-direction:column; justify-content:center; padding:60px 80px; background:var(--beige);}

.testimonials{background:var(--black); color:var(--white);}
.testimonials .eyebrow{color:var(--gold-light);}
.t-card{padding:0 20px; text-align:center;}
.t-stars{color:var(--gold); letter-spacing:3px; margin-bottom:18px; font-size:1.1rem;}
.t-quote{font-family:'Cormorant Garamond',serif; font-size:1.5rem; font-style:italic; color:#ece6da; max-width:700px; margin:0 auto 22px;}
.t-name{font-size:0.78rem; letter-spacing:2px; text-transform:uppercase; color:var(--gold-light);}
.t-dots{display:flex; gap:8px; justify-content:center; margin-top:34px;}
.t-dots button{width:8px; height:8px; border-radius:50%; background:#4a463e; border:none;}
.t-dots button.active{background:var(--gold);}

.insta-grid{display:grid; grid-template-columns:repeat(6,1fr); gap:4px;}
.insta-grid a{position:relative; overflow:hidden; aspect-ratio:1; display:block;}
.insta-grid img{width:100%; height:100%; object-fit:cover; transition:transform .5s;}
.insta-grid a:hover img{transform:scale(1.08);}

.newsletter{background:var(--beige); text-align:center;}
.newsletter-form{display:flex; max-width:480px; margin:28px auto 0; border-bottom:1px solid var(--black);}
.newsletter-form input{flex:1; background:none; border:none; padding:14px 4px; font-size:1rem;}
.newsletter-form input:focus{outline:none;}
.newsletter-form button{background:none; border:none; padding:14px 6px; letter-spacing:2px; font-size:0.75rem; text-transform:uppercase;}
.form-msg{margin-top:14px; font-size:0.85rem; color:var(--gold-dark,#8a6f3a); min-height:1.2em;}

/* ===== FOOTER ===== */
.site-footer{background:var(--black); color:#cfc8bb; padding-top:80px;}
.footer-grid{display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr 1.3fr; gap:40px; padding-bottom:56px; border-bottom:1px solid #2a2722;}
.footer-grid h5{color:var(--white); font-family:'Jost',sans-serif; font-size:0.8rem; letter-spacing:2px; text-transform:uppercase; margin-bottom:20px; font-weight:500;}
.footer-grid li{margin-bottom:11px;}
.footer-grid a{font-size:0.88rem; color:#a39a8c; transition:color .3s;}
.footer-grid a:hover{color:var(--gold-light);}
.footer-logo svg{height:34px; margin-bottom:18px; color:var(--white);}
.footer-grid p{color:#8a8074; font-size:0.88rem;}
.social-row{display:flex; gap:14px; margin-top:18px;}
.social-row a{width:38px; height:38px; border:1px solid #3a3631; border-radius:50%; display:flex; align-items:center; justify-content:center; transition:all .3s;}
.social-row a:hover{background:var(--gold); border-color:var(--gold); color:var(--black);}
.social-row svg{width:16px; height:16px;}
.footer-bottom{display:flex; justify-content:space-between; align-items:center; padding:26px 0; font-size:0.78rem; color:#7d756a; flex-wrap:wrap; gap:12px;}
.payment-icons{display:flex; gap:10px;}
.payment-icons span{border:1px solid #3a3631; padding:4px 10px; font-size:0.68rem; letter-spacing:1px;}

/* ===== CART / CHECKOUT ===== */
.cart-table{width:100%; border-collapse:collapse;}
.cart-table th{text-align:left; font-size:0.72rem; letter-spacing:2px; text-transform:uppercase; color:#a39a8c; padding-bottom:18px; border-bottom:1px solid var(--line); font-weight:500;}
.cart-table td{padding:24px 0; border-bottom:1px solid #ece4d6;}
.cart-item{display:flex; gap:18px; align-items:center;}
.cart-item img{width:84px; height:104px; object-fit:cover;}
.cart-item-info h4{margin:0 0 4px; font-size:1rem;}
.qty-control{display:flex; align-items:center; border:1px solid #d7cdb9; width:fit-content;}
.qty-control button{background:none; border:none; width:32px; height:32px;}
.qty-control input{width:38px; text-align:center; border:none; background:none;}
.remove-link{font-size:0.75rem; color:#b3402f; text-decoration:underline; background:none; border:none; cursor:pointer; padding:0; margin-top:6px;}
.cart-summary{background:var(--beige); padding:36px; align-self:flex-start;}
.summary-row{display:flex; justify-content:space-between; padding:10px 0; font-size:0.92rem;}
.summary-row.total{font-family:'Cormorant Garamond',serif; font-size:1.4rem; border-top:1px solid #c9bda3; margin-top:10px; padding-top:18px;}
.cart-layout{display:grid; grid-template-columns:2fr 1fr; gap:56px; align-items:start;}
.coupon-row{display:flex; gap:10px; margin:20px 0;}
.coupon-row input{flex:1; padding:11px; border:1px solid #d7cdb9; background:none;}
.empty-cart{text-align:center; padding:90px 0;}

.checkout-layout{display:grid; grid-template-columns:1.4fr 1fr; gap:60px; align-items:start;}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px; margin-bottom:16px;}
.form-group{margin-bottom:16px;}
.form-group label{display:block; font-size:0.75rem; letter-spacing:1.5px; text-transform:uppercase; margin-bottom:7px; color:#6b6258;}
.form-group input, .form-group select, .form-group textarea{
  width:100%; padding:13px 14px; border:1px solid #d7cdb9; background:var(--ivory); transition:border-color .3s;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus{outline:none; border-color:var(--gold);}
fieldset{border:none; padding:0; margin:0 0 30px;}
fieldset legend{font-family:'Cormorant Garamond',serif; font-size:1.3rem; margin-bottom:18px; padding:0;}
.pay-options{display:flex; gap:14px; margin-bottom:20px; flex-wrap:wrap;}
.pay-option{flex:1; min-width:140px; border:1px solid #d7cdb9; padding:14px; text-align:center; font-size:0.8rem; letter-spacing:1px; cursor:pointer;}
.pay-option input{margin-right:8px;}
.pay-option.selected{border-color:var(--gold); background:#fbf6ea;}
.order-confirm{text-align:center; padding:100px 0; max-width:560px; margin:0 auto;}
.order-confirm .check-circle{width:84px; height:84px; border:1px solid var(--gold); border-radius:50%; display:flex; align-items:center; justify-content:center; margin:0 auto 28px; color:var(--gold);}
.order-confirm .check-circle svg{width:38px; height:38px;}
.field-error{color:#b3402f; font-size:0.78rem; margin-top:5px; display:none;}
.form-group.error input, .form-group.error textarea, .form-group.error select{border-color:#b3402f;}
.form-group.error .field-error{display:block;}

/* ===== PRODUCT DETAIL ===== */
.pd-layout{display:grid; grid-template-columns:90px 1fr 1fr; gap:24px;}
.pd-thumbs{display:flex; flex-direction:column; gap:14px;}
.pd-thumbs img{cursor:pointer; aspect-ratio:7/9; object-fit:cover; border:1px solid transparent; opacity:0.6; transition:all .3s;}
.pd-thumbs img.active{opacity:1; border-color:var(--gold);}
.pd-main img{width:100%; aspect-ratio:7/9; object-fit:cover;}
.pd-info h1{font-size:2.1rem;}
.pd-price{font-family:'Cormorant Garamond',serif; font-size:1.7rem; color:var(--gold-dark,#8a6f3a); margin-bottom:18px;}
.pd-rating{display:flex; align-items:center; gap:8px; color:var(--gold); font-size:0.95rem; margin-bottom:18px;}
.pd-rating span{color:#7a7164; font-size:0.85rem;}
.swatches{display:flex; gap:10px; margin-bottom:6px;}
.swatch{width:30px; height:30px; border-radius:50%; border:2px solid transparent; cursor:pointer;}
.swatch.selected{border-color:var(--black);}
.size-row{display:flex; gap:10px; margin-bottom:24px; flex-wrap:wrap;}
.size-box{width:46px; height:42px; display:flex; align-items:center; justify-content:center; border:1px solid #d7cdb9; font-size:0.82rem; cursor:pointer;}
.size-box.selected{background:var(--black); color:var(--white); border-color:var(--black);}
.pd-actions{display:flex; gap:14px; margin:26px 0;}
.pd-actions .btn{flex:1;}
.pd-meta{border-top:1px solid var(--line); margin-top:30px; padding-top:24px;}
.pd-meta-row{display:flex; gap:10px; font-size:0.85rem; padding:6px 0; color:#5a5247;}
.accordion-item{border-bottom:1px solid var(--line);}
.accordion-trigger{width:100%; display:flex; justify-content:space-between; align-items:center; background:none; border:none; padding:18px 0; font-size:0.95rem; text-align:left; letter-spacing:0.5px;}
.accordion-trigger .plus{font-size:1.2rem; transition:transform .3s;}
.accordion-item.open .plus{transform:rotate(45deg);}
.accordion-panel{max-height:0; overflow:hidden; transition:max-height .4s var(--ease);}
.accordion-panel p{padding-bottom:18px;}

/* ===== LOOKBOOK ===== */
.lookbook-grid{columns:3; column-gap:24px;}
.lookbook-grid figure{margin:0 0 24px; break-inside:avoid; position:relative; overflow:hidden;}
.lookbook-grid img{width:100%; transition:transform .6s var(--ease);}
.lookbook-grid figure:hover img{transform:scale(1.04);}
.lookbook-grid figcaption{position:absolute; bottom:0; left:0; right:0; padding:18px; color:#fff; background:linear-gradient(transparent,rgba(0,0,0,0.65)); font-size:0.78rem; letter-spacing:2px; text-transform:uppercase;}

/* ===== BLOG ===== */
.blog-card img{aspect-ratio:8/5; object-fit:cover; margin-bottom:18px;}
.blog-meta{font-size:0.72rem; letter-spacing:1.5px; text-transform:uppercase; color:var(--gold-dark,#a3873f); margin-bottom:10px;}
.blog-article img{width:100%; aspect-ratio:16/8; object-fit:cover; margin-bottom:36px;}
.article-body{max-width:760px; margin:0 auto;}
.article-body p{font-size:1.05rem; margin-bottom:1.4em;}
.article-body h3{margin-top:1.6em;}

/* ===== FAQ ===== */
.faq-cats{display:flex; gap:10px; flex-wrap:wrap; margin-bottom:40px;}

/* ===== LEGAL ===== */
.legal-body{max-width:820px; margin:0 auto;}
.legal-body h2{margin-top:1.8em; font-size:1.5rem;}
.legal-body p, .legal-body li{font-size:0.98rem; color:#4a443c;}
.legal-body ul{list-style:disc; padding-left:22px; margin-bottom:1.2em;}
.legal-body li{margin-bottom:6px;}
.toc{background:var(--beige); padding:26px 30px; margin-bottom:40px;}
.toc a{display:block; padding:4px 0; font-size:0.88rem;}

/* ===== 404 ===== */
.error-page{text-align:center; padding:140px 0; background:var(--black); color:var(--white);}
.error-page h1{font-size:8rem; color:var(--gold); margin-bottom:0;}

/* ===== ABOUT ===== */
.stats-row{display:grid; grid-template-columns:repeat(4,1fr); text-align:center; gap:30px; background:var(--beige); padding:60px 40px;}
.stats-row strong{display:block; font-family:'Cormorant Garamond',serif; font-size:2.6rem; color:var(--black);}
.stats-row span{font-size:0.75rem; letter-spacing:2px; text-transform:uppercase; color:#7a7164;}
.team-grid{display:grid; grid-template-columns:repeat(2,1fr); gap:40px;}
.team-card img{aspect-ratio:7/9; object-fit:cover; margin-bottom:16px;}
.values-grid{display:grid; grid-template-columns:repeat(3,1fr); gap:36px;}
.value-card{padding:36px; border:1px solid var(--line); text-align:center;}
.value-card .num{font-family:'Cormorant Garamond',serif; color:var(--gold); font-size:1.1rem; margin-bottom:14px;}

/* toast */
.toast{
  position:fixed; bottom:30px; left:50%; transform:translate(-50%,30px); background:var(--black); color:var(--white);
  padding:16px 28px; font-size:0.85rem; letter-spacing:1px; z-index:3000; opacity:0; transition:all .4s var(--ease); pointer-events:none;
  border-left:3px solid var(--gold);
}
.toast.show{opacity:1; transform:translate(-50%,0);}

.skip-link{position:absolute; left:-999px; top:0; background:var(--gold); color:var(--black); padding:10px 16px; z-index:5000;}
.skip-link:focus{left:10px; top:10px;}
:focus-visible{outline:2px solid var(--gold); outline-offset:2px;}

@media (prefers-reduced-motion: reduce){
  *{animation:none !important; transition:none !important;}
}
