*{margin:0;padding:0;box-sizing:border-box;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#faf8f5; --ink:#0a0a0a; --muted:#6b6b6b; --beige:#e8e0d3;
  --gold:#b8956a; --line:rgba(10,10,10,.08); --radius:14px;
  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Inter","Helvetica Neue",Arial,sans-serif;
}
html,body{background:var(--bg);color:var(--ink);font-family:var(--sans);font-size:15px;line-height:1.55;-webkit-font-smoothing:antialiased;overflow-x:hidden}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
button{font:inherit;cursor:pointer;border:none;background:none;color:inherit}
.container{max-width:1400px;margin:0 auto;padding:0 24px}
.serif{font-family:var(--serif);font-weight:400;letter-spacing:-.01em}
.eyebrow{font-size:11px;letter-spacing:.25em;text-transform:uppercase;color:var(--muted)}

/* Loader */
.loader{position:fixed;inset:0;background:var(--bg);z-index:9999;display:flex;align-items:center;justify-content:center;transition:opacity .8s,visibility .8s}
.loader.hide{opacity:0;visibility:hidden}
.loader .logo{font-family:var(--serif);font-size:42px;letter-spacing:.4em;animation:fadeUp 1.2s ease}
@keyframes fadeUp{from{opacity:0;transform:translateY(20px)}to{opacity:1}}

/* Navbar */
.nav{position:fixed;top:0;left:0;right:0;z-index:100;padding:18px 0;transition:all .4s ease;background:transparent}
.nav.scrolled{background:rgba(250,248,245,.85);backdrop-filter:blur(20px);border-bottom:1px solid var(--line);padding:12px 0}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:24px}
.nav-logo{font-family:var(--serif);font-size:26px;letter-spacing:.35em;font-weight:500}
.nav-menu{display:flex;gap:36px;font-size:13px;letter-spacing:.18em;text-transform:uppercase}
.nav-menu a{position:relative;padding:6px 0}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;background:var(--ink);transition:width .35s ease}
.nav-menu a:hover::after{width:100%}
.nav-icons{display:flex;gap:18px;align-items:center}
.nav-icons button{font-size:20px;transition:transform .25s}
.nav-icons button:hover{transform:translateY(-2px)}
.cart-count{position:absolute;top:-6px;right:-8px;background:var(--ink);color:#fff;font-size:10px;width:16px;height:16px;border-radius:50%;display:flex;align-items:center;justify-content:center}
.cart-btn{position:relative}
.hamburger{display:none;font-size:22px}

/* Mobile menu */
.mobile-menu{position:fixed;inset:0;background:var(--bg);z-index:99;transform:translateX(100%);transition:transform .5s cubic-bezier(.77,0,.18,1);padding:100px 32px}
.mobile-menu.open{transform:translateX(0)}
.mobile-menu a{display:block;font-family:var(--serif);font-size:42px;padding:14px 0;border-bottom:1px solid var(--line);opacity:0;transform:translateY(20px);transition:all .5s}
.mobile-menu.open a{opacity:1;transform:translateY(0)}
.mobile-menu.open a:nth-child(1){transition-delay:.15s}
.mobile-menu.open a:nth-child(2){transition-delay:.22s}
.mobile-menu.open a:nth-child(3){transition-delay:.29s}
.mobile-menu.open a:nth-child(4){transition-delay:.36s}
.mobile-menu.open a:nth-child(5){transition-delay:.43s}

/* Hero */
.hero{position:relative;height:100vh;min-height:600px;overflow:hidden;display:flex;align-items:flex-end}
.hero video,.hero .hero-img{position:absolute;inset:0;width:100%;height:100%;object-fit:fill}
.hero::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,0) 40%,rgba(0,0,0,.55) 100%)}
.hero-content{position:relative;z-index:2;color:#fff;padding:0 24px 80px;max-width:1400px;margin:0 auto;width:100%}
.hero-content .eyebrow{color:rgba(255,255,255,.85)}
.hero-content h1{font-family:var(--serif);font-size:clamp(48px,9vw,140px);line-height:.95;font-weight:400;margin:14px 0 28px;letter-spacing:-.02em}
.hero-cta{display:inline-flex;align-items:center;gap:12px;padding:16px 28px;border:1px solid rgba(255,255,255,.6);border-radius:50px;font-size:12px;letter-spacing:.25em;text-transform:uppercase;backdrop-filter:blur(10px);background:rgba(255,255,255,.08);transition:all .35s}
.hero-cta:hover{background:#fff;color:var(--ink)}

/* Sections */
section{padding:100px 0}
.sec-head{text-align:center;margin-bottom:60px}
.sec-head h2{font-family:var(--serif);font-size:clamp(36px,5vw,64px);margin-top:10px;letter-spacing:-.01em}

/* Product grid */
.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:30px}
.card{position:relative;cursor:pointer;overflow:hidden}
.card-img{position:relative;aspect-ratio:3/4;overflow:hidden;background:var(--beige);border-radius:8px}
.card-img img{width:100%;height:100%;object-fit:cover;transition:transform 1.2s cubic-bezier(.2,.8,.2,1),opacity .4s}
.card:hover .card-img img{transform:scale(1.06)}
.card-img .img2{position:absolute;inset:0;opacity:0}
.card:hover .img2{opacity:1}
.card-arrows{position:absolute;inset:0;display:flex;justify-content:space-between;align-items:center;padding:0 12px;opacity:0;transition:opacity .3s}
.card:hover .card-arrows{opacity:1}
.card-arrows button{width:36px;height:36px;border-radius:50%;background:rgba(255,255,255,.9);font-size:14px;backdrop-filter:blur(10px)}
.card-wish{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:50%;background:rgba(255,255,255,.9);backdrop-filter:blur(10px);font-size:15px;opacity:0;transform:translateY(-6px);transition:all .35s}
.card:hover .card-wish{opacity:1;transform:translateY(0)}
.card-wish.active{color:#c0392b}
.card-info{padding:16px 4px 4px}
.card-info h3{font-size:14px;font-weight:500;margin-bottom:4px}
.card-info .price{color:var(--muted);font-size:14px}

/* Editorial split */
.split{display:grid;grid-template-columns:1fr 1fr;gap:60px;align-items:center}
.split img{aspect-ratio:4/5;object-fit:cover;border-radius:8px}
.split h2{font-family:var(--serif);font-size:clamp(40px,5vw,72px);line-height:1;margin-bottom:24px}
.split p{color:var(--muted);margin-bottom:28px;font-size:16px;line-height:1.7}

/* Reviews */
.reviews{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.review{padding:36px;background:#fff;border-radius:var(--radius);border:1px solid var(--line)}
.review .stars{color:var(--gold);margin-bottom:14px}
.review p{font-family:var(--serif);font-size:20px;line-height:1.5;margin-bottom:18px}
.review .who{font-size:12px;letter-spacing:.2em;text-transform:uppercase;color:var(--muted)}

/* Newsletter */
.newsletter{background:var(--ink);color:#fff;padding:120px 24px;text-align:center;border-radius:var(--radius)}
.newsletter h2{font-family:var(--serif);font-size:clamp(36px,5vw,64px);margin-bottom:18px}
.newsletter form{display:flex;max-width:520px;margin:30px auto 0;gap:0;border-bottom:1px solid rgba(255,255,255,.3)}
.newsletter input{flex:1;background:none;border:none;color:#fff;padding:16px 0;font-size:15px;outline:none}
.newsletter button{padding:16px 24px;font-size:12px;letter-spacing:.2em;text-transform:uppercase}

/* Insta gallery */
.insta{display:grid;grid-template-columns:repeat(6,1fr);gap:6px}
.insta img{aspect-ratio:1;object-fit:fill;transition:opacity .3s}
.insta img:hover{opacity:.75}

/* Footer */
footer{background:#0a0a0a;color:#bdbdbd;padding:80px 0 30px;margin-top:80px}
.foot-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:50px;margin-bottom:50px}
.foot-grid h4{color:#fff;font-size:13px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:18px}
.foot-grid a{display:block;padding:6px 0;font-size:14px;transition:color .25s}
.foot-grid a:hover{color:#fff}
.foot-logo{font-family:var(--serif);font-size:32px;letter-spacing:.35em;color:#fff;margin-bottom:14px}
.foot-bottom{border-top:1px solid rgba(255,255,255,.1);padding-top:24px;text-align:center;font-size:12px;letter-spacing:.15em}

/* Cart drawer */
.drawer{position:fixed;top:0;right:0;width:440px;max-width:100%;height:100vh;background:var(--bg);z-index:200;transform:translateX(100%);transition:transform .55s cubic-bezier(.77,0,.18,1);display:flex;flex-direction:column}
.drawer.open{transform:translateX(0)}
.drawer-overlay{position:fixed;inset:0;background:rgba(0,0,0,.5);opacity:0;visibility:hidden;z-index:199;transition:.4s}
.drawer-overlay.open{opacity:1;visibility:visible}
.drawer-head{display:flex;justify-content:space-between;align-items:center;padding:24px;border-bottom:1px solid var(--line)}
.drawer-head h3{font-family:var(--serif);font-size:24px}
.drawer-body{flex:1;overflow-y:auto;padding:24px}
.cart-item{display:grid;grid-template-columns:90px 1fr auto;gap:16px;padding:16px 0;border-bottom:1px solid var(--line)}
.cart-item img{width:90px;height:120px;object-fit:cover;border-radius:6px}
.cart-item h4{font-size:14px;margin-bottom:4px}
.cart-item .meta{font-size:12px;color:var(--muted);margin-bottom:8px}
.qty{display:inline-flex;border:1px solid var(--line);border-radius:50px;overflow:hidden}
.qty button{width:28px;height:28px;font-size:14px}
.qty span{padding:0 12px;font-size:13px;display:flex;align-items:center}
.drawer-foot{padding:24px;border-top:1px solid var(--line)}
.drawer-foot .total{display:flex;justify-content:space-between;font-family:var(--serif);font-size:22px;margin-bottom:18px}
.btn{display:inline-flex;align-items:center;justify-content:center;width:100%;padding:18px;background:var(--ink);color:#fff;border-radius:50px;font-size:12px;letter-spacing:.25em;text-transform:uppercase;transition:transform .25s,background .25s}
.btn:hover{transform:translateY(-2px);background:#222}
.btn-outline{background:none;color:var(--ink);border:1px solid var(--ink)}

/* Modal */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.55);z-index:300;display:none;align-items:center;justify-content:center;padding:24px}
.modal.open{display:flex;animation:fadeUp .3s}
.modal-card{background:#fff;border-radius:var(--radius);padding:40px;max-width:420px;text-align:center}
.modal-card h3{font-family:var(--serif);font-size:28px;margin-bottom:12px}
.modal-card p{color:var(--muted);margin-bottom:24px}

/* Filters */
.shop-head{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:18px;margin-bottom:36px;padding-top:120px}
.filters{display:flex;gap:8px;flex-wrap:wrap}
.chip{padding:10px 18px;border:1px solid var(--line);border-radius:50px;font-size:12px;letter-spacing:.15em;text-transform:uppercase;transition:all .25s}
.chip.active,.chip:hover{background:var(--ink);color:#fff;border-color:var(--ink)}
select{padding:10px 18px;border:1px solid var(--line);border-radius:50px;background:transparent;font-size:13px}

/* Product detail */
/* ================= PDP LAYOUT ================= */

.pdp{
  display:grid;

  grid-template-columns:
  1.1fr .9fr;

  gap:80px;

  padding:120px 0;
}

.pdp-gallery{
  display:flex;
  flex-direction:column;
  gap:24px;
}

.pdp-main{
  position:relative;

  overflow:hidden;

  border-radius:24px;

  background:#f4f4f4;
}

.pdp-main img{
  width:100%;

  display:block;

  object-fit:cover;
}

.pdp-info{
  position:sticky;

  top:120px;

  align-self:start;
}

@media(max-width:1000px){

  .pdp{
    grid-template-columns:1fr;
    gap:50px;
  }

  .pdp-info{
    position:static;
  }

}
.pdp-gallery{position:relative}
.pdp-main{position:relative;aspect-ratio:3/4;overflow:hidden;border-radius:8px;background:var(--beige)}
.pdp-main img{
  width:100%;

  display:block;

  object-fit:cover;

  transition:
  transform 1.4s cubic-bezier(.19,1,.22,1);

  cursor:zoom-in;
}

.pdp-main:hover img{
  transform:scale(1.12);
}
.pdp-main img.zoom{transform:scale(1.6)}
.pdp-thumbs{display:flex;gap:10px;margin-top:14px;overflow-x:auto}
.pdp-thumbs img{width:90px;height:120px;object-fit:cover;border-radius:6px;cursor:pointer;border:2px solid transparent}
.pdp-thumbs img.active{border-color:var(--ink)}
.pdp-info h1{font-family:var(--serif);font-size:clamp(32px,4vw,52px);margin-bottom:10px}
.pdp-info .price{font-size:22px;margin-bottom:24px}
.pdp-info p.desc{color:var(--muted);margin-bottom:30px;line-height:1.7}
.size-row,.color-row{margin-bottom:24px}
.size-row label,.color-row label{display:block;font-size:12px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:12px}
.sizes{display:flex;gap:8px;flex-wrap:wrap}
.size{min-width:48px;height:48px;padding:0 14px;border:1px solid var(--line);border-radius:50px;font-size:13px;transition:.25s}
.size.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.colors{display:flex;gap:10px}
.color{width:32px;height:32px;border-radius:50%;border:2px solid var(--line);cursor:pointer}
.color.active{outline:2px solid var(--ink);outline-offset:2px}

.pdp-arrows{position:absolute;top:50%;transform:translateY(-50%);width:100%;display:flex;justify-content:space-between;padding:0 16px;pointer-events:none}
.pdp-arrows button{pointer-events:auto;width:44px;height:44px;border-radius:50%;background:rgba(255,255,255,.95);font-size:16px;backdrop-filter:blur(10px)}

/* Checkout */
.checkout{display:grid;grid-template-columns:1.3fr 1fr;gap:60px;padding-top:120px}
.form-row{margin-bottom:18px}
.form-row label{font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);display:block;margin-bottom:8px}
.form-row input,.form-row textarea,.form-row select{width:100%;padding:14px 18px;border:1px solid var(--line);border-radius:8px;font-size:15px;background:#fff;font-family:inherit}
.form-row input:focus{outline:none;border-color:var(--ink)}
.two{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.summary{background:#fff;padding:32px;border-radius:var(--radius);border:1px solid var(--line);position:sticky;top:120px;height:fit-content}

/* Scroll progress */
.progress{position:fixed;top:0;left:0;height:2px;background:var(--ink);width:0;z-index:101;transition:width .1s}

/* Page transition */
.page-trans{position:fixed;inset:0;background:var(--ink);z-index:9998;transform:scaleY(0);transform-origin:bottom;pointer-events:none}
.page-trans.in{animation:slideIn .8s cubic-bezier(.77,0,.18,1) forwards}
@keyframes slideIn{0%{transform:scaleY(0);transform-origin:bottom}50%{transform:scaleY(1);transform-origin:bottom}50.001%{transform-origin:top}100%{transform:scaleY(0);transform-origin:top}}

/* Reveal */
.reveal{
  opacity:1;
  transform:translateY(0);
transform:translateY(40px);transition:opacity .9s ease,transform .9s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:translateY(0)}

/* MOBILE */
@media (max-width:1024px){
  .grid{grid-template-columns:repeat(2,1fr);gap:18px}
  .reviews{grid-template-columns:1fr}
  .split,.pdp,.checkout{grid-template-columns:1fr;gap:36px}
  .insta{grid-template-columns:repeat(3,1fr)}
  .foot-grid{grid-template-columns:1fr 1fr;gap:36px}
}
@media (max-width:768px){
  section{padding:64px 0}
  .container{padding:0 18px}
  .nav-menu{display:none}
  .hamburger{display:block}
  .nav-icons .icon-search{display:none}
  .hero{height:88vh;min-height:520px}
  .hero-content{padding:0 18px 50px}
  .sec-head{margin-bottom:36px}
  .drawer{width:100%}
  .pdp-main{aspect-ratio:3/4}
  .summary{position:static}
  .modal-card{padding:30px 24px}
  .mobile-menu a{font-size:32px}
  .newsletter{padding:70px 22px}
  .nav-logo{font-size:20px;letter-spacing:.3em}
}
.card-wish{
  transition: transform 0.2s ease, color 0.2s ease;
}

.card-wish.active{
  color: #e11d48;
  transform: scale(1.2);
}

.card-wish.clicked{
  animation: pop 0.3s ease;
}

@keyframes pop{
  0%{ transform: scale(1); }
  50%{ transform: scale(1.4); }
  100%{ transform: scale(1.2); }
}
.toast{
  position: fixed;
  bottom: 30px;
  right: 30px;
  background: #111;
  color: #fff;
  padding: 14px 22px;
  border-radius: 999px;
  font-size: 13px;
  opacity: 0;
  transform: translateY(20px);
  transition: 0.3s ease;
  z-index: 9999;
}

.toast.show{
  opacity: 1;
  transform: translateY(0);
}
.cart-drawer{
  position: fixed;
  top: 0;
  right: -400px;
  width: 350px;
  height: 100%;
  background: #fff;
  box-shadow: -10px 0 30px rgba(0,0,0,0.1);
  transition: 0.4s ease;
  z-index: 9999;
  display: flex;
  flex-direction: column;
}

.cart-drawer.open{
  right: 0;
}

.cart-header{
  display: flex;
  justify-content: space-between;
  padding: 20px;
  border-bottom: 1px solid #eee;
}

.cart-items{
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}

.cart-item{
  display: flex;
  gap: 10px;
  margin-bottom: 15px;
}

.cart-item img{
  width: 60px;
  height: 60px;
  object-fit: cover;
}

.cart-footer{
  padding: 20px;
  border-top: 1px solid #eee;
}

.checkout-btn{
  width: 100%;
  padding: 12px;
  background: black;
  color: white;
  border: none;
}
.drawer{
  background:#fafafa;
  backdrop-filter: blur(10px);
}

.cart-item{
  display:flex;
  gap:14px;
  margin-bottom:20px;
  padding-bottom:15px;
  border-bottom:1px solid #eee;
}

.cart-item img{
  width:70px;
  height:90px;
  object-fit:cover;
  border-radius:6px;
}

.cart-item h4{
  font-size:14px;
  font-weight:500;
  margin-bottom:4px;
}

.cart-item .meta{
  font-size:12px;
  color:#777;
  margin-bottom:6px;
}

.qty{
  display:flex;
  align-items:center;
  gap:8px;
}

.qty button{
  width:26px;
  height:26px;
  border:1px solid #ddd;
  background:white;
  cursor:pointer;
}

.qty span{
  min-width:20px;
  text-align:center;
}

.drawer .total{
  display:flex;
  justify-content:space-between;
  font-size:16px;
  margin-bottom:15px;
}

.drawer button.checkout{
  width:100%;
  padding:14px;
  border:none;
  background:black;
  color:white;
  letter-spacing:2px;
}
.cart-btn.bounce{
  animation:bounce 0.4s;
}

@keyframes bounce{
  0%{transform:scale(1)}
  50%{transform:scale(1.2)}
  100%{transform:scale(1)}
}
.card-cart{
  position:absolute;
  bottom:10px;
  right:10px;
  background:black;
  color:white;
  padding:6px 10px;
  font-size:12px;
  cursor:pointer;
}
.modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,0.4);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:9999;
}

.modal.show{
  display:flex;
}

.modal-card{
  background:white;
  padding:30px;
  border-radius:10px;
  text-align:center;
}
/* ================= SHOP HERO ================= */

.shop-hero{
  position:relative;
  height:85vh;
  overflow:hidden;
}

.shop-hero img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.shop-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.28);
}

.shop-content{
  position:absolute;
  left:7%;
  bottom:10%;
  z-index:2;
  color:#fff;
}

.shop-content p{
  font-size:12px;
  letter-spacing:4px;
  margin-bottom:18px;
}

.shop-content h1{
  font-size:clamp(60px,8vw,120px);
  line-height:.95;
  font-weight:500;
  font-family:'Cormorant Garamond', serif;
}

/* ================= SHOP SECTION ================= */

.shop-head{
  display:flex;
  justify-content:space-between;
  align-items:end;
  padding:80px 0 40px;
}

.shop-title{
  font-size:clamp(44px,5vw,80px);
}

.filters{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-bottom:50px;
}

.chip{
  height:48px;
  padding:0 26px;
  border-radius:999px;
  border:1px solid #ddd;
  background:#fff;
  letter-spacing:2px;
  font-size:11px;
  cursor:pointer;
  transition:.4s;
}

.chip.active,
.chip:hover{
  background:#000;
  color:#fff;
  border-color:#000;
}

/* ================= PRODUCTS GRID ================= */

.products-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:70px 28px;
  padding-bottom:120px;
}

@media(max-width:1100px){
  .products-grid{
    grid-template-columns:repeat(3,1fr);
  }
}

@media(max-width:768px){

  .shop-hero{
    height:60vh;
  }

  .products-grid{
    grid-template-columns:repeat(2,1fr);
    gap:40px 16px;
  }

  .shop-head{
    flex-direction:column;
    align-items:flex-start;
    gap:20px;
  }

}
.product-card{
  position:relative;
}

.product-image{
  position:relative;
  overflow:hidden;
  border-radius:20px;
  background:#f5f5f5;
}

/* ================= HOVER IMAGE ================= */

.product-image{
  position:relative;
  overflow:hidden;
}

.product-image img{
  position:absolute;
  inset:0;

  width:100%;
  height:100%;

  object-fit:cover;

  transition:
  opacity .8s cubic-bezier(.19,1,.22,1),
  transform 1.2s cubic-bezier(.19,1,.22,1);
}

.main-img{
  opacity:1;
  z-index:1;
}

.hover-img{
  opacity:0;
  z-index:2;
}

.product-card:hover .main-img{
  opacity:0;
  transform:scale(1.04);
}

.product-card:hover .hover-img{
  opacity:1;
  transform:scale(1.04);
}

.product-card:hover img{
  transform:scale(1.06);
}

.product-info{
  padding-top:18px;
}

.product-title{
  font-size:17px;
  line-height:1.4;
  margin-bottom:8px;
  font-weight:500;
}

.product-price{
  color:#777;
  font-size:15px;
}

.quick-btn{
  position:absolute;
  left:18px;
  right:18px;
  bottom:18px;
  height:52px;
  border:none;
  border-radius:999px;
  background:#000;
  color:#fff;
  letter-spacing:3px;
  font-size:11px;
  opacity:0;
  transform:translateY(14px);
  transition:.5s;
}

.product-card:hover .quick-btn{
  opacity:1;
  transform:translateY(0);
}/* ================= QUICK VIEW ================= */

.quick-modal{
  position:fixed;
  inset:0;
  z-index:9999;
  opacity:0;
  pointer-events:none;
  transition:.4s;
}

.quick-modal.show{
  opacity:1;
  pointer-events:auto;
}

.quick-overlay{
  position:absolute;
  inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(6px);
}

.quick-box{
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%,-50%) scale(.96);

  width:min(1100px,92%);
  max-height:90vh;

  background:#fff;
  border-radius:26px;

  overflow-y:auto;
  overflow-x:hidden;

  transition:.5s cubic-bezier(.19,1,.22,1);
}

.quick-modal.show .quick-box{
  transform:translate(-50%,-50%) scale(1);
}

.quick-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  min-height:700px;
}

.quick-image-wrap{
  background:#f5f5f5;
}

.quick-image-wrap img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.quick-content{
  padding:70px;
}

.quick-label{
  font-size:11px;
  letter-spacing:4px;
  margin-bottom:20px;
  color:#777;
}

.quick-content h2{
  font-size:54px;
  line-height:1;
  margin-bottom:20px;
  font-family:'Cormorant Garamond',serif;
}

.quick-price{
  font-size:22px;
  margin-bottom:24px;
}

.quick-desc{
  color:#666;
  line-height:1.8;
  margin-bottom:36px;
}

.quick-sizes p{
  font-size:11px;
  letter-spacing:3px;
  margin-bottom:16px;
}

#quick-size-wrap{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-bottom:36px;
}

.size-pill{
  width:48px;
  height:48px;
  border-radius:999px;
  border:1px solid #ddd;
  background:#fff;
  cursor:pointer;
  transition:.3s;
}

.size-pill.active{
  background:#000;
  color:#fff;
  border-color:#000;
}

.quick-cart-btn{
  width:100%;
  height:58px;
  border:none;
  border-radius:999px;
  background:#000;
  color:#fff;
  letter-spacing:3px;
  font-size:11px;
  cursor:pointer;
}

.quick-close{
  position:absolute;
  top:22px;
  right:22px;
  width:42px;
  height:42px;
  border:none;
  border-radius:999px;
  background:#f5f5f5;
  cursor:pointer;
  font-size:22px;
  z-index:10;
}

@media(max-width:900px){
.quick-box{
  max-height:95vh;
}

.quick-grid{
  grid-template-columns:1fr;
  min-height:auto;
}
  .quick-grid{
    grid-template-columns:1fr;
  }

  .quick-content{
    padding:36px 24px;
  }

  .quick-content h2{
    font-size:40px;
  }

}
/* ================= CINEMATIC LOADER ================= */

.loader{
  position:fixed;
  inset:0;
  background:#f8f6f2;
  z-index:99999;

  display:flex;
  align-items:center;
  justify-content:center;
  flex-direction:column;

  transition:opacity 1.2s ease,
  visibility 1.2s ease;
}

.loader.hide{
  opacity:0;
  visibility:hidden;
}

.loader::before{
  content:'';
  position:absolute;
  width:140%;
  height:140%;
  background:
  radial-gradient(circle at center,
  rgba(255,255,255,.9),
  #f8f6f2 60%);
  animation:loaderGlow 4s ease infinite;
}

.loader-logo{
  position:relative;
  z-index:2;

  font-size:clamp(42px,5vw,72px);

  letter-spacing:14px;

  font-family:
  'Cormorant Garamond',serif;

  color:#111;

  animation:
  logoReveal 2s cubic-bezier(.19,1,.22,1);
}

.loader-line{
  width:0;
  height:1px;
  background:#111;

  margin-top:24px;

  position:relative;
  z-index:2;

  animation:
  lineGrow 1.8s ease forwards;

  animation-delay:.4s;
}

@keyframes logoReveal{

  0%{
    opacity:0;
    transform:translateY(40px);
    letter-spacing:30px;
    filter:blur(10px);
  }

  100%{
    opacity:1;
    transform:translateY(0);
    letter-spacing:14px;
    filter:blur(0);
  }

}

@keyframes lineGrow{

  to{
    width:220px;
  }

}

@keyframes loaderGlow{

  0%,100%{
    transform:scale(1);
  }

  50%{
    transform:scale(1.08);
  }

}
.product-image{
  position:relative;
  overflow:hidden;

  aspect-ratio:3/4;

  border-radius:18px;

  background:#eee;
}
.quick-btn{
  position:absolute;
  bottom:18px;
  left:50%;

  transform:translateX(-50%);

  z-index:10;
}
.product-image{
  position:relative;
}
/* ================= TEXT REVEAL ================= */

.reveal{
  opacity:0;

  transform:
  translateY(60px);

  transition:
  opacity 1s ease,
  transform 1s cubic-bezier(.19,1,.22,1);
}

.reveal.active{
  opacity:1;
  transform:translateY(0);
}
/* ================= LUXURY FOOTER ================= */

.lux-footer{
  background:#0f0f0f;
  color:#f5f1eb;

  margin-top:140px;

  padding:
  120px 7% 50px;
}

.footer-top{
  display:grid;
  grid-template-columns:1.1fr .9fr;

  gap:120px;

  padding-bottom:90px;

  border-bottom:
  1px solid rgba(255,255,255,.08);
}

.footer-label{
  font-size:11px;

  letter-spacing:5px;

  margin-bottom:24px;

  opacity:.7;
}

.footer-brand h2{
  font-size:
  clamp(42px,5vw,86px);

  line-height:.95;

  font-family:
  'Cormorant Garamond', serif;

  font-weight:500;
}

.footer-news p{
  font-size:16px;

  line-height:1.9;

  color:
  rgba(255,255,255,.72);

  margin-bottom:36px;
}

.newsletter{
  display:flex;
  gap:14px;
}

.newsletter input{
  flex:1;

  height:60px;

  border:none;

  background:
  rgba(255,255,255,.06);

  color:#fff;

  padding:0 22px;

  border-radius:999px;

  outline:none;

  font-size:14px;
}

.newsletter button{
  height:60px;

  padding:0 34px;

  border:none;

  border-radius:999px;

  background:#fff;

  color:#111;

  letter-spacing:3px;

  font-size:11px;

  cursor:pointer;

  transition:.4s ease;
}

.newsletter button:hover{
  background:#d6c2a3;
}

.footer-bottom{
  padding-top:42px;

  display:flex;
  align-items:center;
  justify-content:space-between;

  gap:30px;

  flex-wrap:wrap;
}

.footer-logo{
  font-size:28px;

  letter-spacing:10px;

  font-family:
  'Cormorant Garamond', serif;
}

.footer-links{
  display:flex;
  gap:34px;

  flex-wrap:wrap;
}

.footer-links a{
  color:
  rgba(255,255,255,.7);

  text-decoration:none;

  font-size:13px;

  letter-spacing:2px;

  transition:.35s ease;
}

.footer-links a:hover{
  color:#fff;
}

.footer-copy{
  font-size:12px;

  letter-spacing:3px;

  color:
  rgba(255,255,255,.45);
}

@media(max-width:900px){

  .footer-top{
    grid-template-columns:1fr;
    gap:70px;
  }

  .newsletter{
    flex-direction:column;
  }

  .newsletter button{
    width:100%;
  }

}
/* ================= PRODUCT HERO ================= */

.product-hero{
  height:90vh;

  background-image:
  url('../images/hero.jpg');

  background-size:cover;

  background-position:center center;

  background-repeat:no-repeat;

  position:relative;

  display:flex;

  align-items:flex-end;

  padding:80px;

  overflow:hidden;
}

/* MOBILE FIX */

@media(max-width:768px){

  .product-hero{

    height:75vh;

    padding:30px;

    background-size:contain;

    background-position:
    center top;

    background-color:#eae6df;
  }

}

.product-hero-overlay{
  position:absolute;
  inset:0;

  background:
  linear-gradient(
    to top,
    rgba(0,0,0,.25),
    rgba(0,0,0,.05)
  );

  z-index:1;
}

.product-hero-content{
  position:relative;
  z-index:2;

  color:#fff;
}

.product-hero-content p{
  letter-spacing:6px;

  font-size:12px;

  margin-bottom:26px;
}

.product-hero-content h1{
  font-size:
  clamp(70px,9vw,150px);

  line-height:.92;

  font-family:
  'Cormorant Garamond', serif;

  font-weight:500;
}

@media(max-width:768px){

  .product-hero{
    padding:40px;
    height:75vh;
  }

}
/* ================= GSAP REVEAL ================= */

.gsap-reveal{
  opacity:0;

  transform:
  translateY(120px);

  will-change:
  transform, opacity;
}

/* ================= FULLSCREEN MENU ================= */

.mobile-menu{
  position:fixed;

  inset:0;

  background:#f8f6f2;

  z-index:99999;

  display:flex;

  flex-direction:column;

  align-items:center;
  justify-content:center;

  gap:28px;

  transform:translateY(-100%);

  transition:
  transform 1s cubic-bezier(.19,1,.22,1);

  overflow:hidden;
}

.mobile-menu.open{
  transform:translateY(0);
}

.mobile-menu::before{
  content:'SHENOVA';

  position:absolute;

  font-size:18vw;

  font-family:
  'Cormorant Garamond', serif;

  color:rgba(0,0,0,.03);

  white-space:nowrap;

  letter-spacing:14px;
}

.mobile-menu a{
  position:relative;

  font-size:
  clamp(38px,5vw,72px);

  font-family:
  'Cormorant Garamond', serif;

  color:#111;

  text-decoration:none;

  transition:.4s ease;

  z-index:2;
}

.mobile-menu a:hover{
  transform:translateX(10px);

  opacity:.7;
}

.mobile-menu .menu-social{
  position:absolute;

  bottom:50px;

  display:flex;

  gap:24px;

  z-index:2;
}

.mobile-menu .menu-social a{
  font-size:12px;

  letter-spacing:3px;

  font-family:'Inter',sans-serif;
}

/* HAMBURGER */

.hamburger{
  position:relative;

  width:48px;
  height:48px;

  border:none;

  background:none;

  cursor:pointer;

  z-index:100000;
}

.hamburger span{
  position:absolute;

  left:10px;

  width:28px;
  height:1.5px;

  background:#111;

  transition:.5s ease;
}

.hamburger span:nth-child(1){
  top:17px;
}

.hamburger span:nth-child(2){
  top:24px;
}

.hamburger span:nth-child(3){
  top:31px;
}

/* OPEN */

.hamburger.active span:nth-child(1){
  transform:
  rotate(45deg);

  top:24px;
}

.hamburger.active span:nth-child(2){
  opacity:0;
}

.hamburger.active span:nth-child(3){
  transform:
  rotate(-45deg);

  top:24px;
  /* ===== FINAL MOBILE HERO FIX ===== */

@media(max-width:768px){

  .product-hero{
    height:78vh !important;

    padding:30px !important;

    background-size:cover !important;

    background-position:center top !important;

    background-repeat:no-repeat !important;
  }

  .product-hero-content h1{
    font-size:56px !important;

    line-height:.95 !important;
  }

}
}
/* ===== PRODUCT HERO ===== */

.product-hero{
  position:relative;

  height:90vh;

  overflow:hidden;

  display:flex;

  align-items:flex-end;

  padding:80px;
}

.product-hero-img{
  position:absolute;

  inset:0;

  width:100%;

  height:100%;

  object-fit:cover;

  z-index:0;
}

.product-hero-overlay{
  position:absolute;

  inset:0;

  background:
  linear-gradient(
    to top,
    rgba(0,0,0,.35),
    rgba(0,0,0,.08)
  );

  z-index:1;
}

.product-hero-content{
  position:relative;

  z-index:2;

  color:#fff;
}

.product-hero-content h1{
  font-size:
  clamp(70px,9vw,150px);

  line-height:.92;

  font-family:
  'Cormorant Garamond', serif;

  font-weight:500;
}

.product-hero-content p{
  letter-spacing:6px;

  font-size:12px;

  margin-bottom:26px;
}

/* MOBILE */

@media(max-width:768px){

  .product-hero{
    height:78vh;

    padding:30px;
  }

  .product-hero-content h1{
    font-size:56px;
  }

}
.product-card{
  transition:
  transform .8s cubic-bezier(.19,1,.22,1),
  box-shadow .8s ease;
}

.product-card:hover{
  transform:
  translateY(-12px);

  box-shadow:
  0 30px 60px rgba(0,0,0,.08);
}
.product-hero-overlay{
  background:
  linear-gradient(
    to top,
    rgba(0,0,0,.55),
    rgba(0,0,0,.12),
    transparent
  );
}
.btn{
  position:relative;
  overflow:hidden;
}

.btn::before{
  content:'';

  position:absolute;

  top:0;
  left:-120%;

  width:100%;
  height:100%;

  background:
  linear-gradient(
    120deg,
    transparent,
    rgba(255,255,255,.4),
    transparent
  );

  transition:1s;
}

.btn:hover::before{
  left:120%;
}
.sec-head{
  position:relative;
}

.sec-head::after{
  content:'';

  width:80px;
  height:1px;

  background:#111;

  display:block;

  margin-top:18px;
}
.spin-popup{
  justify-content:center;

  margin:30px 0;
}

.wheel{
  width:220px;
  height:220px;

  border-radius:50%;

  border:10px solid #111;

  position:relative;

  transition:
  transform 5s cubic-bezier(.19,1,.22,1);

  background:
  conic-gradient(
    #111 0deg 90deg,
    #d6c2a3 90deg 180deg,
    #111 180deg 270deg,
    #d6c2a3 270deg 360deg
  );
}

.wheel span{
  position:absolute;

  color:#fff;

  font-weight:600;
}



.spin-btn{
  width:100%;
  height:58px;

  border:none;

  background:#111;
  color:#fff;

  border-radius:999px;

  letter-spacing:3px;

  cursor:pointer;
}

#spin-result{
  margin-top:24px;

  font-size:15px;

  line-height:1.8;
}
/* ================= LUXURY SPIN WHEEL ================= */

.spin-popup{
  position:fixed;
  inset:0;

  background:
  rgba(0,0,0,.58);

  backdrop-filter:blur(12px);

  z-index:999999;

  display:none;

  align-items:center;
  justify-content:center;

  padding:20px;

  animation:
  fadeSpin .6s ease;
}

.spin-popup.show{
  display:flex;
}

@keyframes fadeSpin{

  from{
    opacity:0;
  }

  to{
    opacity:1;
  }

}

.spin-box{
  width:980px;

  max-width:100%;

  background:
  rgba(255,255,255,.94);

  border-radius:36px;

  overflow:hidden;

  box-shadow:
  0 40px 100px rgba(0,0,0,.18);

  animation:
  popupLuxury .8s
  cubic-bezier(.19,1,.22,1);
}

@keyframes popupLuxury{

  from{
    opacity:0;

    transform:
    translateY(60px)
    scale(.92);
  }

  to{
    opacity:1;

    transform:
    translateY(0)
    scale(1);
  }

}

.spin-close{
  position:absolute;

  top:18px;
  right:18px;

  width:42px;
  height:42px;

  border:none;

  background:none;

  font-size:22px;

  cursor:pointer;

  transition:.4s;
}

.spin-close:hover{
  transform:rotate(90deg);
}

.spin-label{
  font-size:11px;

  letter-spacing:6px;

  margin-bottom:20px;

  color:#777;
}

.spin-box h2{
  font-size:72px;

  line-height:.88;

  margin-bottom:32px;

  font-family:
  'Cormorant Garamond', serif;

  font-weight:500;
}

.spin-box input{
  width:100%;

  height:62px;

  border:
  1px solid rgba(0,0,0,.08);

  background:
  rgba(255,255,255,.75);

  margin-bottom:16px;

  padding:0 22px;

  border-radius:18px;

  font-size:15px;

  transition:.4s;
}

.spin-box input:focus{
  outline:none;

  border-color:#111;

  box-shadow:
  0 0 0 4px rgba(0,0,0,.05);
}

.wheel-wrap{
  display:flex;

  justify-content:center;

  margin:42px 0 36px;

  position:relative;
}

.wheel-wrap::before{
  content:'';

  position:absolute;

  top:-18px;

  width:0;
  height:0;

  border-left:16px solid transparent;
  border-right:16px solid transparent;
  border-top:28px solid #111;

  z-index:10;
}

.wheel{
  width:280px;
  height:280px;

  border-radius:50%;

  border:14px solid #111;

  position:relative;

  overflow:hidden;

  box-shadow:
  0 20px 60px rgba(0,0,0,.16);

  transition:
  transform 5s cubic-bezier(.19,1,.22,1);

  background:
  conic-gradient(
    #111 0deg 90deg,
    #d7c3a3 90deg 180deg,
    #111 180deg 270deg,
    #d7c3a3 270deg 360deg
  );
}

.wheel::after{
  content:'';

  position:absolute;

  inset:50% auto auto 50%;

  transform:
  translate(-50%,-50%);

  width:48px;
  height:48px;

  border-radius:50%;

  background:#fff;

  z-index:5;

  box-shadow:
  0 4px 20px rgba(0,0,0,.12);
}

.wheel span{
  position:absolute;

  color:#fff;

  font-size:26px;

  font-weight:700;

  z-index:2;
}



.spin-btn{
  width:100%;

  height:64px;

  border:none;

  background:#111;

  color:#fff;

  border-radius:999px;

  letter-spacing:5px;

  font-size:13px;

  cursor:pointer;

  transition:
  transform .5s ease,
  box-shadow .5s ease;
}

.spin-btn:hover{
  transform:
  translateY(-4px);

  box-shadow:
  0 18px 40px rgba(0,0,0,.18);
}

#spin-result{
  margin-top:28px;

  font-size:15px;

  line-height:2;
}

#spin-result strong{
  font-size:20px;
}

@media(max-width:768px){

  .spin-box{
    padding:32px 24px;
  }

  .spin-box h2{
    font-size:52px;
  }

  .wheel{
    width:240px;
    height:240px;
  }

  .wheel span{
    font-size:22px;
  }


}
/* ================= ULTRA LUXURY SPIN ================= */

.spin-popup{
  position:fixed;
  inset:0;

  background:
  rgba(0,0,0,.68);

  backdrop-filter:blur(10px);

  z-index:999999;

  display:none;

  align-items:center;
  justify-content:center;

  padding:24px;
}

.spin-popup.show{
  display:flex;
}

.spin-luxury{
  width:980px;
  max-width:100%;

  min-height:560px;

  border-radius:32px;

  overflow:hidden;

  display:grid;

  grid-template-columns:
  1fr 1fr;

  background:#050505;

  position:relative;

  box-shadow:
  0 40px 120px rgba(0,0,0,.45);

  animation:
  spinPopup .8s
  cubic-bezier(.19,1,.22,1);
}

@keyframes spinPopup{

  from{
    opacity:0;

    transform:
    translateY(50px)
    scale(.92);
  }

  to{
    opacity:1;

    transform:
    translateY(0)
    scale(1);
  }

}

.spin-close{
  position:absolute;

  top:24px;
  right:24px;

  width:46px;
  height:46px;

  border:none;

  background:none;

  color:#fff;

  font-size:34px;

  cursor:pointer;

  z-index:50;

  transition:.4s;
}

.spin-close:hover{
  transform:rotate(90deg);
}

.spin-wheel-side{
  display:flex;

  flex-direction:column;

  justify-content:center;

  align-items:center;

  background:
  radial-gradient(
    circle at center,
    #1b1b1b,
    #050505
  );

  padding:60px;
}

.wheel-wrap{
  position:relative;
}

.wheel{
  width:360px;
  height:360px; 

  border-radius:50%;

  position:relative;

  border:8px solid #d7bc87;

  background:
  conic-gradient(
    #efe1c3 0deg 45deg,
    #111 45deg 90deg,
    #d7bc87 90deg 135deg,
    #111 135deg 180deg,
    #efe1c3 180deg 225deg,
    #111 225deg 270deg,
    #d7bc87 270deg 315deg,
    #111 315deg 360deg
  );

  transition:
  transform 5s cubic-bezier(.19,1,.22,1);

  box-shadow:
    0 0 0 12px rgba(215,188,135,.08),
    0 30px 80px rgba(0,0,0,.5);
}

.wheel::before{
  content:'';

  position:absolute;

  inset:18px;

  border-radius:50%;

  border:
  2px solid rgba(255,255,255,.14);
}

.wheel span{
  position:absolute;

  font-size:20px;

  font-weight:600;

  text-align:center;

  width:90px;

  line-height:1.2;
}

.wheel span{
  position:absolute;

  left:50%;
  top:50%;

  width:90px;

  text-align:center;

  font-size:20px;

  font-weight:700;

  line-height:1.2;

  transform-origin:center;

  z-index:2;
}

/* 20% */
.wheel span:nth-child(1){
  transform:
    translate(-50%,-50%)
    rotate(0deg)
    translateY(-118px);

  color:#fff;
}

/* 15% */
.wheel span:nth-child(2){
  transform:
    translate(-50%,-50%)
    rotate(45deg)
    translateY(-118px)
    rotate(-45deg);

  color:#fff;
}

/* 10% */
.wheel span:nth-child(3){
  transform:
    translate(-50%,-50%)
    rotate(90deg)
    translateY(-118px)
    rotate(-90deg);

  color:#111;
}

/* 5% */
.wheel span:nth-child(4){
  transform:
    translate(-50%,-50%)
    rotate(135deg)
    translateY(-118px)
    rotate(-135deg);

  color:#fff;
}

/* FREE */
.wheel span:nth-child(5){
  transform:
    translate(-50%,-50%)
    rotate(180deg)
    translateY(-118px)
    rotate(-180deg);

  color:#fff;
}

/* 30% */
.wheel span:nth-child(6){
  transform:
    translate(-50%,-50%)
    rotate(225deg)
    translateY(-118px)
    rotate(-225deg);

  color:#111;
}

/* 25% */
.wheel span:nth-child(7){
  transform:
    translate(-50%,-50%)
    rotate(270deg)
    translateY(-118px)
    rotate(-270deg);

  color:#fff;
}

/* NO LUCK */
.wheel span:nth-child(8){
  transform:
    translate(-50%,-50%)
    rotate(315deg)
    translateY(-118px)
    rotate(-315deg);

  color:#111;
}

.wheel-center{
  position:absolute;

  inset:50% auto auto 50%;

  transform:
  translate(-50%,-50%);

  width:120px;
  height:120px;

  border-radius:50%;

  background:#0b0b0b;

  border:
  4px solid #d7bc87;

  display:flex;

  align-items:center;
  justify-content:center;

  color:#d7bc87;

  font-size:20px;

  letter-spacing:3px;

  z-index:5;

  box-shadow:
  0 10px 30px rgba(0,0,0,.45);
}

.wheel-pointer{
  position:absolute;

  top:50%;

  right:-24px;

  transform:
  translateY(-50%);

  width:0;
  height:0;

  border-top:24px solid transparent;
  border-bottom:24px solid transparent;

  border-left:42px solid #d7bc87;
}

.spin-note{
  margin-top:34px;

  color:#d7bc87;

  letter-spacing:1px;

  font-size:15px;
}

.spin-content-side{
  position:relative;

  background:
  linear-gradient(
    rgba(0,0,0,.55),
    rgba(0,0,0,.7)
  ),

  url('https://images.unsplash.com/photo-1515886657613-9f3515b0c78f?q=80&w=1600&auto=format&fit=crop')
  center/cover;

  display:flex;

  align-items:center;

  padding:50px;
}

.spin-content{
  position:relative;

  z-index:5;

  max-width:420px;

  color:#fff;
}

.spin-small{
  font-size:12px;

  letter-spacing:6px;

  margin-bottom:18px;

  color:#d7bc87;
}

.spin-content h2{
  font-size:110px;

  line-height:.82;

  font-family:
  'Cormorant Garamond', serif;

  font-weight:500;
}

.spin-content h2 span{
  color:#d7bc87;

  font-size:72px;

  font-style:italic;
}

.spin-content h3{
  margin-top:16px;

  font-size:24px;

  letter-spacing:2px;

  font-weight:500;
}

.spin-desc{
  margin:28px 0 34px;

  line-height:1.9;

  color:rgba(255,255,255,.8);
}

.spin-content input{
  width:100%;

  height:62px;

  background:
  rgba(255,255,255,.08);

  border:
  1px solid rgba(255,255,255,.12);

  margin-bottom:16px;

  padding:0 22px;

  color:#fff;

  border-radius:14px;

  font-size:15px;
}

.spin-content input::placeholder{
  color:rgba(255,255,255,.6);
}

.spin-content input:focus{
  outline:none;

  border-color:#d7bc87;
}

.spin-btn{
  width:100%;

  height:64px;

  border:none;

  background:#d7bc87;

  color:#111;

  font-size:15px;

  letter-spacing:4px;

  border-radius:14px;

  cursor:pointer;

  margin-top:10px;

  transition:.5s;
}

.spin-btn:hover{
  transform:
  translateY(-4px);

  box-shadow:
  0 20px 40px rgba(215,188,135,.25);
}

.spin-policy{
  margin-top:18px;

  color:rgba(255,255,255,.55);

  font-size:13px;
}

#spin-result{
  margin-top:20px;

  padding:16px;

  border-radius:16px;

  background:
  rgba(0,0,0,.32);

  border:
  1px solid rgba(255,255,255,.08);

  max-width:100%;

  overflow:hidden;

  line-height:1.7;

  font-size:15px;

  color:#fff;

  text-align:left;
}

#spin-result strong{
  font-size:18px !important;

  font-weight:600;

  line-height:1.4;

  color:#d7bc87;

  display:block;
}

#spin-result .coupon-code{
  margin-top:10px;

  display:inline-flex;

  align-items:center;

  justify-content:center;

  height:48px;

  padding:0 18px;

  border-radius:12px;

  background:#d7bc87;

  color:#111;

  font-size:16px;

  font-weight:700;

  letter-spacing:2px;
}

@media(max-width:900px){

  .spin-popup{
    padding:14px;
    overflow:auto;
  }

  .spin-luxury{
    grid-template-columns:1fr;

    min-height:auto;

    border-radius:24px;
  }

  .spin-wheel-side{
    padding:34px 18px 24px;
  }

  .wheel{
    width:260px;
    height:260px;
  }

  .wheel-center{
    width:82px;
    height:82px;

    font-size:14px;
  }

  .wheel span{
    font-size:13px;
    width:70px;
  }

  .wheel span:nth-child(1){
    top:22px;
    left:98px;
  }

  .wheel span:nth-child(2){
    top:66px;
    right:16px;
  }

  .wheel span:nth-child(3){
    top:118px;
    right:2px;
  }

  .wheel span:nth-child(4){
    bottom:66px;
    right:14px;
  }

  .wheel span:nth-child(5){
    bottom:20px;
    left:92px;
  }

  .wheel span:nth-child(6){
    bottom:66px;
    left:12px;
  }

  .wheel span:nth-child(7){
    top:118px;
    left:0;
  }

  .wheel span:nth-child(8){
    top:64px;
    left:10px;
  }

  .wheel-pointer{
    right:-16px;

    border-top:16px solid transparent;
    border-bottom:16px solid transparent;

    border-left:28px solid #d7bc87;
  }

  .spin-note{
    margin-top:24px;

    font-size:12px;

    text-align:center;
  }

  .spin-content-side{
    padding:34px 22px 40px;
  }

  .spin-content{
    max-width:100%;
  }

  .spin-small{
    font-size:10px;

    letter-spacing:4px;
  }

  .spin-content h2{
    font-size:58px;

    line-height:.9;
  }

  .spin-content h2 span{
    font-size:38px;
  }

  .spin-content h3{
    font-size:18px;

    margin-top:10px;
  }

  .spin-desc{
    font-size:14px;

    line-height:1.7;

    margin:18px 0 24px;
  }

  .spin-content input{
    height:56px;

    font-size:14px;

    border-radius:12px;
  }

  .spin-btn{
    height:58px;

    font-size:13px;

    letter-spacing:3px;
  }

  .spin-close{
    top:14px;
    right:14px;

    width:38px;
    height:38px;

    font-size:28px;
  }

}
/* ================= FINAL COMPACT LUXURY POPUP ================= */

.spin-luxury{
  width:860px !important;

  max-width:92vw !important;

  height:540px !important;

  border-radius:28px !important;

  overflow:hidden !important;

  display:grid !important;

  grid-template-columns:
  360px 1fr !important;

  background:#050505 !important;

  position:relative !important;

  box-shadow:
  0 40px 120px rgba(0,0,0,.45) !important;

  animation:
  spinPopup .6s
  cubic-bezier(.19,1,.22,1) !important;
}

/* LEFT */

.spin-wheel-side{
  display:flex !important;

  flex-direction:column !important;

  justify-content:center !important;

  align-items:center !important;

  background:
  radial-gradient(
    circle at center,
    #161616,
    #050505
  ) !important;

  padding:24px !important;
}

/* RIGHT */

.spin-content-side{
  position:relative !important;

  background:
  linear-gradient(
    rgba(0,0,0,.58),
    rgba(0,0,0,.68)
  ),

  url('https://images.unsplash.com/photo-1515886657613-9f3515b0c78f?q=80&w=1200&auto=format&fit=crop')
  center/cover !important;

  display:flex !important;

  align-items:center !important;

  padding:42px !important;
}

/* WHEEL */

.wheel{
  width:280px !important;
  height:280px !important;

  border-radius:50% !important;

  position:relative !important;

  border:6px solid #d7bc87 !important;

  background:
  conic-gradient(
    #efe1c3 0deg 45deg,
    #111 45deg 90deg,
    #d7bc87 90deg 135deg,
    #111 135deg 180deg,
    #efe1c3 180deg 225deg,
    #111 225deg 270deg,
    #d7bc87 270deg 315deg,
    #111 315deg 360deg
  ) !important;

  transition:
  transform 5s cubic-bezier(.19,1,.22,1) !important;

  box-shadow:
    0 0 0 10px rgba(215,188,135,.08),
    0 20px 60px rgba(0,0,0,.5) !important;
}

.wheel-center{
  width:82px !important;
  height:82px !important;

  font-size:14px !important;
}

/* TEXT */

.spin-content h2{
  font-size:72px !important;

  line-height:.84 !important;

  font-family:
  'Cormorant Garamond', serif !important;

  font-weight:500 !important;
}

.spin-content h2 span{
  font-size:52px !important;
}

/* INPUTS */

.spin-content input{
  width:100% !important;

  height:54px !important;

  margin-bottom:14px !important;

  padding:0 18px !important;

  border-radius:12px !important;

  font-size:14px !important;
}

/* BUTTON */

.spin-btn{
  width:100% !important;

  height:56px !important;

  border-radius:12px !important;

  font-size:14px !important;

  letter-spacing:3px !important;
}

/* RESULT */

#spin-result{
  margin-top:16px !important;

  padding:14px !important;

  border-radius:14px !important;

  font-size:14px !important;

  max-height:110px !important;

  overflow:auto !important;
}

/* MOBILE */

@media(max-width:900px){

  .spin-luxury{
    width:95vw !important;

    height:auto !important;

    grid-template-columns:1fr !important;
  }

  .spin-wheel-side{
    padding:30px 16px 10px !important;
  }

  .wheel{
    width:220px !important;
    height:220px !important;
  }

  .spin-content-side{
    padding:24px !important;
  }

  .spin-content h2{
    font-size:54px !important;
  }

  .spin-content h2 span{
    font-size:36px !important;
  }

}
/* SUCCESS POPUP */

.coupon-popup{
  position:fixed;

  inset:0;

  background:
  rgba(0,0,0,.72);

  backdrop-filter:blur(8px);

  z-index:99999999;

  display:none;

  align-items:center;

  justify-content:center;

  padding:20px;
}

.coupon-popup.show{
  display:flex;
}

.coupon-box{
  width:420px;

  max-width:100%;

  background:#fff;

  border-radius:28px;

  padding:50px 36px;

  text-align:center;

  position:relative;

  animation:
  couponPop .45s ease;
}

@keyframes couponPop{

  from{
    opacity:0;

    transform:
    scale(.85)
    translateY(20px);
  }

  to{
    opacity:1;

    transform:
    scale(1)
    translateY(0);
  }

}

.coupon-close{
  position:absolute;

  top:18px;
  right:18px;

  width:40px;
  height:40px;

  border:none;

  background:none;

  font-size:28px;

  cursor:pointer;
}

.coupon-small{
  letter-spacing:4px;

  font-size:11px;

  color:#b89a63;

  margin-bottom:18px;
}

.coupon-box h2{
  font-size:52px;

  font-family:
  'Cormorant Garamond', serif;

  margin-bottom:10px;
}

.coupon-text{
  color:#666;

  margin-bottom:28px;
}

.coupon-discount{
  font-size:42px;

  font-weight:700;

  color:#111;

  margin-bottom:24px;
}

.coupon-code-box{
  height:64px;

  border-radius:16px;

  background:#f5f5f5;

  display:flex;

  align-items:center;

  justify-content:space-between;

  padding:0 10px 0 22px;

  margin-bottom:20px;
}

.coupon-code-box span{
  font-size:20px;

  font-weight:600;

  letter-spacing:2px;
}

.coupon-code-box button{
  width:110px;

  height:48px;

  border:none;

  border-radius:12px;

  background:#111;

  color:#fff;

  cursor:pointer;

  letter-spacing:2px;
}

.coupon-note{
  font-size:14px;

  color:#777;
}
/* ================= MOBILE SPIN FIX ================= */

@media(max-width:768px){

  .spin-popup{
    padding:12px !important;

    overflow-y:auto !important;

    align-items:flex-start !important;
  }

  .spin-luxury{
    width:100% !important;

    height:auto !important;

    min-height:auto !important;

    display:flex !important;

    flex-direction:column !important;

    border-radius:22px !important;

    margin:20px 0 !important;
  }

  .spin-wheel-side{
    width:100% !important;

    padding:28px 14px 10px !important;
  }

  .wheel-wrap{
    transform:scale(.82) !important;
  }

  .wheel{
    width:260px !important;
    height:260px !important;
  }

  .wheel-center{
    width:74px !important;
    height:74px !important;

    font-size:13px !important;
  }

  .wheel-pointer{
    right:-18px !important;

    border-top:16px solid transparent !important;
    border-bottom:16px solid transparent !important;

    border-left:30px solid #d7bc87 !important;
  }

  .spin-note{
    margin-top:10px !important;

    font-size:12px !important;

    text-align:center !important;
  }

  .spin-content-side{
    width:100% !important;

    padding:26px 18px 30px !important;

    min-height:auto !important;
  }

  .spin-content{
    width:100% !important;

    max-width:100% !important;
  }

  .spin-small{
    font-size:10px !important;

    letter-spacing:3px !important;

    margin-bottom:12px !important;
  }

  .spin-content h2{
    font-size:52px !important;

    line-height:.88 !important;

    margin-bottom:10px !important;
  }

  .spin-content h2 span{
    font-size:34px !important;
  }

  .spin-content h3{
    font-size:16px !important;

    line-height:1.4 !important;

    margin-bottom:12px !important;
  }

  .spin-desc{
    font-size:13px !important;

    line-height:1.7 !important;

    margin-bottom:18px !important;
  }

  .spin-content input{
    height:52px !important;

    border-radius:12px !important;

    font-size:14px !important;

    margin-bottom:12px !important;
  }

  .spin-btn{
    height:54px !important;

    border-radius:12px !important;

    font-size:13px !important;

    letter-spacing:3px !important;
  }

  #spin-result{
    margin-top:14px !important;

    padding:12px !important;

    font-size:13px !important;

    max-height:none !important;
  }

  .coupon-popup{
    padding:16px !important;
  }

  .coupon-box{
    width:100% !important;

    border-radius:22px !important;

    padding:36px 20px !important;
  }

  .coupon-box h2{
    font-size:42px !important;
  }

  .coupon-discount{
    font-size:34px !important;
  }

  .coupon-code-box{
    height:auto !important;

    flex-direction:column !important;

    gap:12px !important;

    padding:18px !important;
  }

  .coupon-code-box button{
    width:100% !important;
  }

}
/* ===== SIZE GUIDE ===== */

.size-guide-overlay{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.45);
  backdrop-filter:blur(10px);
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;

  opacity:0;
  visibility:hidden;
  transition:.4s;
}

.size-guide-overlay.active{
  opacity:1;
  visibility:visible;
}

.size-guide-modal{
  width:min(92%,700px);
  background:#f8f6f1;
  border-radius:32px;
  padding:32px;
  position:relative;

  transform:translateY(40px);
  transition:.45s cubic-bezier(.19,1,.22,1);
}

.size-guide-overlay.active .size-guide-modal{
  transform:translateY(0);
}

.size-close{
  position:absolute;
  top:18px;
  right:18px;
  width:42px;
  height:42px;
  border:none;
  border-radius:50%;
  background:#111;
  color:#fff;
  font-size:24px;
  cursor:pointer;
}

.size-guide-head h2{
  font-size:42px;
  margin-bottom:8px;
}

.size-guide-head p{
  color:#777;
  margin-bottom:24px;
}

.size-guide-img{
  width:100%;
  border-radius:18px;
}

@media(max-width:768px){

  .size-guide-modal{
    padding:22px;
    border-radius:24px;
  }

  .size-guide-head h2{
    font-size:30px;
  }

}
.size-guide-modal{
  width:min(95%,900px);
  max-height:90vh;
  overflow:auto;
  background:#f8f6f1;
  border-radius:28px;
  padding:20px;
  position:relative;

  transform:translateY(40px);
  transition:.45s cubic-bezier(.19,1,.22,1);
}

.size-guide-img{
  width:100%;
  height:auto;
  max-height:75vh;
  object-fit:contain;
  border-radius:18px;
  display:block;
}