/* Floral Premium — Static Multi-Page Bundle (Luxury Light + Signature Dark, Transitions) */
:root{
  --bg:#f4f1ec; --bg2:#ebe6df; --text:#1c1a17; --muted:#6f6a63;
  --accent:#8f9b84; --accent2:#2e3428; --border:#ded7ce; --elev:#ffffff;
  --serif:"Playfair Display","Times New Roman",serif; --sans:"Inter",system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  --radius-md:16px; --radius-lg:22px;
  --shadow-soft:0 20px 40px rgba(0,0,0,.05); --shadow-hover:0 30px 60px rgba(0,0,0,.08);
  --max:1120px; --pad:1.25rem; --section:clamp(3.5rem,5vw,6rem); --ease:cubic-bezier(.2,.8,.2,1);
  --brass:#b59a61;
  --announce-h: 0px;
  --header-h: 0px;
}
html[data-theme="dark"]{
  --bg:#0e1110; --bg2:#111615; --text:#f3efe7; --muted:#b9b2a7;
  --accent:#8f9b84; --accent2:#d7c59a; --border:rgba(255,255,255,.14); --elev:rgba(255,255,255,.06);
  --shadow-soft:0 24px 60px rgba(0,0,0,.40); --shadow-hover:0 36px 90px rgba(0,0,0,.55);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; font-family:var(--sans); color:var(--text); line-height:1.7;
  background:
    radial-gradient(1200px 600px at 15% 5%, rgba(143,155,132,.14), transparent 60%),
    radial-gradient(900px 500px at 85% 10%, rgba(46,52,40,.08), transparent 55%),
    var(--bg);
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
html[data-theme="dark"] body{
  background:
    radial-gradient(1100px 580px at 15% 5%, rgba(143,155,132,.16), transparent 60%),
    radial-gradient(900px 560px at 85% 10%, rgba(181,154,97,.12), transparent 55%),
    var(--bg);
}
img{max-width:100%; display:block}
a{color:inherit; text-decoration:none}
p{margin:0 0 1rem; color:rgba(28,26,23,.92)}
html[data-theme="dark"] p{color:rgba(243,239,231,.92)}
small{color:var(--muted)}
h1,h2,h3{font-family:var(--serif); font-weight:600; letter-spacing:.01em; margin:0 0 1rem}
h1{font-size:clamp(2.1rem,4vw,3.1rem); line-height:1.15}
h2{font-size:clamp(1.8rem,3vw,2.4rem); line-height:1.2}
h3{font-size:1.2rem; line-height:1.25}
a:focus-visible,button:focus-visible,input:focus-visible,textarea:focus-visible,select:focus-visible{
  outline:none; box-shadow:0 0 0 3px rgba(143,155,132,.18); border-radius:12px;
}
.container{max-width:var(--max); margin:0 auto; padding:0 var(--pad)}
.section{padding:var(--section) 0}
.section--alt{background:linear-gradient(180deg, rgba(235,230,223,.85), rgba(235,230,223,.45))}
html[data-theme="dark"] .section--alt{background:linear-gradient(180deg, rgba(17,22,21,.92), rgba(17,22,21,.55))}
.grid-2{display:grid; grid-template-columns:1fr; gap:clamp(1.25rem,3vw,3rem)}
@media (min-width:860px){.grid-2{grid-template-columns:1.2fr .8fr; align-items:center}}
.split{display:flex; flex-direction:column; gap:clamp(1.5rem,4vw,3.5rem)}
@media (min-width:860px){.split{flex-direction:row}}

.header.scrolled{background:rgba(244,241,236,.88); border-bottom-color:rgba(28,26,23,.10)}
html[data-theme="dark"] .header{background:rgba(14,17,16,.72); border-bottom-color:rgba(255,255,255,.10)}
html[data-theme="dark"] .header.scrolled{background:rgba(14,17,16,.86)}
.header__inner{display:flex; align-items:center; justify-content:space-between; padding:.9rem 0; gap:1rem}
.brand{display:flex; align-items:center; gap:.7rem; letter-spacing:.14em; text-transform:uppercase; font-family:var(--serif); font-weight:600; font-size:.95rem}
.brand__dot{width:10px;height:10px;border-radius:50%; background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.75), rgba(143,155,132,.95)); box-shadow:0 10px 20px rgba(143,155,132,.25)}
html[data-theme="dark"] .brand__dot{background:radial-gradient(circle at 30% 30%, rgba(255,255,255,.55), rgba(181,154,97,.95)); box-shadow:0 10px 25px rgba(181,154,97,.18)}
.nav{display:flex; align-items:center; gap:1rem}
.nav__toggle{display:inline-flex; flex-direction:column; gap:5px; background:none; border:none; padding:.5rem; cursor:pointer}
.nav__toggle span{width:22px;height:2px;background:rgba(28,26,23,.85);border-radius:2px}
html[data-theme="dark"] .nav__toggle span{background:rgba(243,239,231,.85)}
.nav__list{
  position:fixed; inset:64px var(--pad) auto var(--pad);
  background:rgba(255,255,255,.75); backdrop-filter:blur(14px);
  border:1px solid rgba(28,26,23,.10); border-radius:18px; padding:1rem;
  display:none; box-shadow:var(--shadow-soft);
}
html[data-theme="dark"] .nav__list{background:rgba(18,22,21,.70); border-color:rgba(255,255,255,.14)}
.nav__list.open{display:block}
.nav__list a{
  display:flex; justify-content:space-between; align-items:center;
  padding:.75rem .75rem; border-radius:14px;
  font-size:.85rem; letter-spacing:.14em; text-transform:uppercase;
  color:rgba(28,26,23,.86);
}
html[data-theme="dark"] .nav__list a{color:rgba(243,239,231,.90)}
.nav__list a:hover{background:rgba(143,155,132,.10)}
html[data-theme="dark"] .nav__list a:hover{background:rgba(181,154,97,.10)}
@media (min-width:980px){
  .nav__toggle{display:none}
  .nav__list{position:static; display:flex !important; background:transparent; border:none; padding:0; box-shadow:none; gap:.25rem}
  .nav__list a{padding:.55rem .75rem}
}
.actions{display:flex; align-items:center; gap:.6rem}
.iconbtn{
  width:40px;height:40px;border-radius:999px;
  border:1px solid rgba(28,26,23,.12); background:rgba(255,255,255,.55);
  display:grid; place-items:center; cursor:pointer;
  transition:transform .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
}
html[data-theme="dark"] .iconbtn{border-color:rgba(255,255,255,.14); background:rgba(255,255,255,.06)}
.iconbtn:hover{transform:translateY(-1px); background:rgba(255,255,255,.75)}
html[data-theme="dark"] .iconbtn:hover{background:rgba(255,255,255,.10)}
.hero{padding:calc(var(--section) + .75rem) 0 var(--section)}
.hero__media{border-radius:var(--radius-lg); overflow:hidden; box-shadow:var(--shadow-soft); border:1px solid rgba(28,26,23,.10)}
html[data-theme="dark"] .hero__media{border-color:rgba(255,255,255,.14)}
.hero__media img{width:100%; height:100%; object-fit:cover}
.kicker{display:inline-flex; align-items:center; gap:.5rem; font-size:.78rem; letter-spacing:.18em; text-transform:uppercase; color:rgba(28,26,23,.72)}
html[data-theme="dark"] .kicker{color:rgba(243,239,231,.75)}
.kicker:before{content:""; width:34px; height:1px; background:rgba(28,26,23,.22)}
html[data-theme="dark"] .kicker:before{background:rgba(243,239,231,.22)}
.hero__lead{color:rgba(28,26,23,.80); font-size:1.03rem; max-width:60ch}
html[data-theme="dark"] .hero__lead{color:rgba(243,239,231,.80)}
.hero__cta{display:flex; flex-wrap:wrap; gap:.75rem; margin-top:1.25rem}
.btn{
  display:inline-flex; align-items:center; justify-content:center; gap:.5rem;
  padding:.85rem 1.25rem; border-radius:999px; border:1px solid transparent;
  font-size:.82rem; letter-spacing:.14em; text-transform:uppercase; cursor:pointer;
  transition:transform .2s var(--ease), background .2s var(--ease), border-color .2s var(--ease);
}
.btn:hover{transform:translateY(-1px)}
.btn--primary{background:var(--text); color:#fbfaf7}
html[data-theme="dark"] .btn--primary{background:var(--accent2); color:#0e1110}
.btn--primary:hover{background:#000}
html[data-theme="dark"] .btn--primary:hover{filter:brightness(1.05)}
.btn--ghost{background:rgba(255,255,255,.45); border-color:rgba(28,26,23,.12)}
html[data-theme="dark"] .btn--ghost{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.14)}
.btn--ghost:hover{background:rgba(255,255,255,.70)}
html[data-theme="dark"] .btn--ghost:hover{background:rgba(255,255,255,.10)}
.btn--link{padding:0; border:none; border-radius:0; background:none; font-size:1rem; letter-spacing:.02em; text-transform:none; color:rgba(28,26,23,.78)}
html[data-theme="dark"] .btn--link{color:rgba(243,239,231,.78)}
.btn--link:hover{color:rgba(28,26,23,.95)}
html[data-theme="dark"] .btn--link:hover{color:rgba(243,239,231,.95)}
.textlink{border-bottom:1px solid rgba(28,26,23,.22); padding-bottom:2px}
html[data-theme="dark"] .textlink{border-bottom-color:rgba(243,239,231,.22)}
.cards{display:grid; grid-template-columns:1fr; gap:1rem}
@media (min-width:820px){.cards{grid-template-columns:repeat(3, minmax(0,1fr)); gap:1.25rem}}
.card{
  background:rgba(255,255,255,.62); border:1px solid rgba(28,26,23,.10);
  border-radius:var(--radius-md); overflow:hidden; box-shadow:var(--shadow-soft);
  transition:transform .35s var(--ease), box-shadow .35s var(--ease);width: 400px;
}
html[data-theme="dark"] .card{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.12)}
.card:hover{transform:translateY(-6px); box-shadow:var(--shadow-hover)}
.card__media{aspect-ratio:4/3; overflow:hidden}
.card__media img{width:100%; height:100%; object-fit:cover; transition:transform .6s var(--ease)}
.card:hover .card__media img{transform:scale(1.04)}
.card__body{padding:1rem 1rem 1.1rem}
.card__title{margin:0 0 .25rem; font-size:1.15rem}
.card__meta{display:flex; justify-content:space-between; gap:.75rem; flex-wrap:wrap; color:var(--muted); font-size:.9rem}
.price{font-family:var(--serif); color:rgba(28,26,23,.92)}
html[data-theme="dark"] .price{color:rgba(243,239,231,.92)}
.tag{display:inline-flex; align-items:center; font-size:.72rem; letter-spacing:.14em; text-transform:uppercase; padding:.25rem .55rem; border-radius:999px; border:1px solid rgba(28,26,23,.14); background:rgba(255,255,255,.40)}
html[data-theme="dark"] .tag{border-color:rgba(255,255,255,.14); background:rgba(255,255,255,.06)}
.panel{background:rgba(255,255,255,.60); border:1px solid rgba(28,26,23,.10); border-radius:var(--radius-lg); padding:1.25rem 1.25rem 1.4rem; box-shadow:var(--shadow-soft)}
html[data-theme="dark"] .panel{background:rgba(255,255,255,.06); border-color:rgba(255,255,255,.12)}
.line{height:1px; background:rgba(28,26,23,.10)}
html[data-theme="dark"] .line{background:rgba(255,255,255,.12)}
.filters{display:flex; flex-wrap:wrap; gap:.5rem}
.pill{border:1px solid rgba(28,26,23,.16); background:rgba(255,255,255,.35); padding:.45rem .8rem; border-radius:999px; font-size:.74rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(28,26,23,.75); cursor:pointer; transition:background .2s var(--ease), transform .2s var(--ease)}
html[data-theme="dark"] .pill{border-color:rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:rgba(243,239,231,.78)}
.pill:hover{transform:translateY(-1px); background:rgba(255,255,255,.65)}
html[data-theme="dark"] .pill:hover{background:rgba(255,255,255,.10)}
.pill.active{background:var(--text); color:#fbfaf7; border-color:var(--text)}
html[data-theme="dark"] .pill.active{background:var(--accent2); color:#0e1110; border-color:var(--accent2)}
.detail{display:grid; grid-template-columns:1fr; gap:2rem}
@media (min-width:960px){.detail{grid-template-columns:1.4fr 1.9fr; align-items:start}}
.detail__media{border-radius:var(--radius-lg); overflow:hidden; border:1px solid rgba(28,26,23,.10); box-shadow:var(--shadow-soft)}
html[data-theme="dark"] .detail__media{border-color:rgba(255,255,255,.14)}
.kv{display:grid; gap:.6rem; margin:1rem 0 1.25rem}
.kv div{display:flex; justify-content:space-between; gap:1rem; color:rgba(28,26,23,.80)}
html[data-theme="dark"] .kv div{color:rgba(243,239,231,.80)}
.kv b{color:rgba(28,26,23,.92)}
html[data-theme="dark"] .kv b{color:rgba(243,239,231,.92)}
.form{display:grid; gap:.85rem}
.field{display:grid; gap:.35rem}
label{font-size:.78rem; letter-spacing:.14em; text-transform:uppercase; color:rgba(28,26,23,.75)}
html[data-theme="dark"] label{color:rgba(243,239,231,.72)}
input,textarea,select{
  width:100%; border-radius:12px; padding:.9rem 1rem;
  border:1px solid rgba(28,26,23,.16); background:rgba(255,255,255,.80);
  font:inherit; color:var(--text);
}
html[data-theme="dark"] input,html[data-theme="dark"] textarea,html[data-theme="dark"] select{
  border-color:rgba(255,255,255,.14); background:rgba(255,255,255,.06); color:var(--text);
}
textarea{min-height:140px; resize:vertical}
.helper{font-size:.92rem; color:var(--muted)}
.footer{border-top:1px solid rgba(28,26,23,.08); padding:2.5rem 0; color:rgba(28,26,23,.70)}
html[data-theme="dark"] .footer{border-top-color:rgba(255,255,255,.12); color:rgba(243,239,231,.70)}
.footer__inner{display:flex; flex-direction:column; gap:.75rem}
@media (min-width:860px){.footer__inner{flex-direction:row; justify-content:space-between; align-items:center}}
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .transition{display:none}
  .card,.btn,.iconbtn{transition:none !important}
}

/* =========================================================
   V2 Premium Upgrades
   - Header: social icons, cleaner nav, better mobile
   - Hero: full-width carousel with push transition + indicators
   - Footer: richer layout
   - Typography polish
   ========================================================= */

/* Typography polish */
:root{
  --tracking: .16em;
  --tracking-tight: .10em;
  --headline-weight: 600;
}
h1,h2,h3{font-weight: var(--headline-weight)}
p, .helper{letter-spacing: 0.01em}
.brand{letter-spacing: var(--tracking); font-weight: 650}
.nav__list a{letter-spacing: var(--tracking-tight)}
html[data-theme="dark"] .brand{letter-spacing: var(--tracking)}

/* Header premium tweaks */
.header__inner{padding: .95rem 0}
.header{
  border-bottom: 1px solid rgba(28,26,23,.07);
}
html[data-theme="dark"] .header{border-bottom-color: rgba(255,255,255,.10)}
.nav__list a{
  position: relative;
}
@media (min-width: 980px){
  .nav__list a{
    border-radius: 999px;
  }
  .nav__list a:after{
    content:"";
    position:absolute;
    left: 12px;
    right: 12px;
    bottom: 8px;
    height: 1px;
    background: linear-gradient(90deg, transparent, rgba(181,154,97,.65), transparent);
    opacity: 0;
    transform: translateY(2px);
    transition: opacity .25s var(--ease), transform .25s var(--ease);
  }
  .nav__list a:hover:after{
    opacity: 1;
    transform: translateY(0);
  }
}

/* Social icons */
.social{
  display:none;
  gap:.45rem;
  align-items:center;
}
@media (min-width: 980px){
  .social{display:flex}
}

/* Mobile menu improvements */
.nav__list{
  inset: 70px var(--pad) auto var(--pad);
}
.nav__list a{
  justify-content: flex-start;
  gap:.6rem;
}
.nav__list a .dot{
  width:6px; height:6px; border-radius:999px;
  background: rgba(28,26,23,.22);
}
html[data-theme="dark"] .nav__list a .dot{background: rgba(243,239,231,.20)}

/* Full-width hero carousel */
.hero{
  padding: 0;
}
.hero-carousel{
  position:relative;
  width:100%;
  overflow:hidden;
  border-bottom: 1px solid rgba(28,26,23,.06);
}
html[data-theme="dark"] .hero-carousel{
  border-bottom-color: rgba(255,255,255,.10);
}
.hero-track{
  display:flex;
  will-change: transform;
  transition: transform .55s var(--ease);
  touch-action: pan-y;
}
.hero-slide{
  min-width:100%;
  position:relative;
  height: min(78vh, 720px);
  display:grid;
  align-items:end;
}
@media (max-width: 860px){
  .hero-slide{height: min(78vh, 680px)}
}
.hero-slide__bg{
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  transform: scale(1.02);
}
.hero-slide__bg:after{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 600px at 20% 20%, rgba(255,255,255,.10), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.45));
}
html[data-theme="dark"] .hero-slide__bg:after{
  background:
    radial-gradient(900px 600px at 20% 20%, rgba(181,154,97,.10), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,0.00), rgba(0,0,0,0.62));
}
.hero-slide__content{
  position:relative;
  padding: clamp(2.25rem, 5vw, 4rem) 0;
}
.hero-slide__panel{
  max-width: 1120px;
  margin: 0 auto;
  padding: 0 var(--pad);
  display:grid;
  gap:.9rem;
}
.hero-slide__kicker{
  display:inline-flex;
  align-items:center;
  gap:.6rem;
  font-size:.74rem;
  letter-spacing:.18em;
  text-transform:uppercase;
  color: rgba(255,255,255,.85);
}
.hero-slide__kicker:before{
  content:"";
  width: 34px; height: 1px;
  background: rgba(255,255,255,.35);
}
.hero-slide__title{
  color: #fff;
  margin:0;
  max-width: 18ch;
  font-size: clamp(2.15rem, 4.2vw, 3.5rem);
  line-height: 1.1;
}
.hero-slide__lead{
  color: rgba(255,255,255,.86);
  max-width: 62ch;
  margin:0;
  font-size: 1.05rem;
}
.hero-slide__actions{
  display:flex;
  gap:.75rem;
  flex-wrap:wrap;
  align-items:center;
  margin-top:.4rem;
}

/* Hero controls + animated indicators */
.hero-controls{
  position:absolute;
  left:0; right:0;
  bottom: 18px;
  z-index: 2;
  pointer-events:none;
}
.hero-controls__inner{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap: 1rem;
}
.hero-dots{
  display:flex;
  gap:.55rem;
  align-items:center;
  pointer-events:auto;
}
.hero-dot{
  width: 34px;
  height: 4px;
  border-radius: 999px;
  background: rgba(255,255,255,.28);
  border: 1px solid rgba(255,255,255,.12);
  overflow:hidden;
  cursor:pointer;
  position:relative;
  transform: translateY(0);
  transition: transform .25s var(--ease);
}
.hero-dot:hover{transform: translateY(-1px)}
.hero-dot__fill{
  position:absolute; inset:0;
  width:0%;
  background: linear-gradient(90deg, rgba(181,154,97,.92), rgba(255,255,255,.85));
  border-radius: 999px;
  transform-origin:left;
}
.hero-dot.active .hero-dot__fill{
  width:100%;
}
.hero-dot.animating .hero-dot__fill{
  animation: dotProgress var(--dotDur, 5200ms) linear forwards;
}
@keyframes dotProgress{
  from{width:0%}
  to{width:100%}
}

/* Arrow buttons (minimal, premium) */
.hero-arrows{
  display:flex;
  gap:.5rem;
  pointer-events:auto;
}
.hero-arrow{
  width:42px; height:42px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(10px);
  display:grid; place-items:center;
  cursor:pointer;
  transition: transform .2s var(--ease), background .2s var(--ease);
}
.hero-arrow:hover{transform: translateY(-1px); background: rgba(0,0,0,.28)}
.hero-arrow svg{color:#fff}
@media (max-width: 680px){
  .hero-arrows{display:none}
}

/* Footer richer */
.footer{
  padding: 3.25rem 0;
}
.footer-grid{
  display:grid;
  gap: 1.25rem;
}
@media (min-width: 860px){
  .footer-grid{
    grid-template-columns: 1.4fr 1fr 1fr;
    align-items:start;
    gap: 2rem;
  }
}
.footer-title{
  font-family: var(--serif);
  letter-spacing: .10em;
  text-transform: uppercase;
  font-size: .92rem;
  margin: 0 0 .4rem;
}
.footer-links{
  display:grid;
  gap:.55rem;
  margin-top:.35rem;
}
.footer-links a{
  color: rgba(28,26,23,.78);
}
html[data-theme="dark"] .footer-links a{color: rgba(243,239,231,.78)}
.footer-links a:hover{color: rgba(28,26,23,.95)}
html[data-theme="dark"] .footer-links a:hover{color: rgba(243,239,231,.95)}
.footer-bottom{
  margin-top: 1.75rem;
  padding-top: 1.25rem;
  border-top: 1px solid rgba(28,26,23,.08);
  display:flex;
  flex-direction:column;
  gap:.5rem;
}
html[data-theme="dark"] .footer-bottom{border-top-color: rgba(255,255,255,.12)}
@media (min-width: 860px){
  .footer-bottom{flex-direction:row; justify-content:space-between; align-items:center}
}

/* =========================================================
   V3 Motion + Readability
   - Remove old page overlay transition
   - Add elegant page fade-in
   - Add scroll/in-view reveals
   - Improve hero overlay readability in light + Signature Dark
   ========================================================= */

body{opacity:0; transition: opacity .35s var(--ease);}
body.page-ready{opacity:1;}

.reveal{
  opacity:0;
  transform: translateY(14px);
  transition: opacity .55s var(--ease), transform .55s var(--ease);
  will-change: opacity, transform;
  transition-delay: var(--d, 0ms);
}
.reveal.in-view{opacity:1; transform: translateY(0);}

.hero-slide__bg:after{
  background:
    radial-gradient(1000px 680px at 20% 20%, rgba(255,255,255,.12), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,0.02), rgba(0,0,0,0.56));
}
.hero-slide--bright .hero-slide__bg:after{
  background:
    radial-gradient(1000px 680px at 20% 20%, rgba(0,0,0,.10), transparent 55%),
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(0,0,0,0.64));
}
html[data-theme="dark"] .hero-slide__bg:after{
  background:
    radial-gradient(1000px 680px at 20% 20%, rgba(181,154,97,.10), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,0.10), rgba(0,0,0,0.72));
}
html[data-theme="dark"] .hero-slide--bright .hero-slide__bg:after{
  background:
    radial-gradient(1000px 680px at 20% 20%, rgba(181,154,97,.14), transparent 56%),
    linear-gradient(180deg, rgba(0,0,0,0.18), rgba(0,0,0,0.78));
}

.hero-slide__content .hero-slide__panel.has-back{
  background: rgba(0,0,0,.12);
  backdrop-filter: blur(10px);
  padding: 1.15rem var(--pad);
  border: 1px solid rgba(255,255,255,.12);
}
html[data-theme="dark"] .hero-slide__content .hero-slide__panel.has-back{
  background: rgba(0,0,0,.22);
  border-color: rgba(255,255,255,.14);
}

@media (prefers-reduced-motion: reduce){
  body{transition:none !important; opacity:1 !important}
  .reveal{transition:none !important; opacity:1 !important; transform:none !important}
  .hero-track{transition:none !important}
}


/* ================= PRELOADER ================= */
.preloader{
  position:fixed;
  inset:0;
  background:#0e1110;
  display:flex;
  align-items:center;
  justify-content:center;
  z-index:9999;
  transition:opacity .6s ease, visibility .6s ease;
}
.preloader.hidden{
  opacity:0;
  visibility:hidden;
}
.loader-ring{
  width:60px;
  height:60px;
  border:3px solid rgba(255,255,255,.15);
  border-top:3px solid #b59a61;
  border-radius:50%;
  animation:spin 1s linear infinite;
}
@keyframes spin{
  to{transform:rotate(360deg)}
}

/* ================= FULL WIDTH HERO FIX ================= */
.hero-carousel{
  width:100vw;
  margin-left:calc(50% - 50vw);
  overflow:hidden;
}

.hero-track{
  display:flex;
}

.hero-slide{
  min-width:100vw;
}

/* Ensure swipe is smooth */
.hero-track{
  touch-action:pan-y;
  cursor:grab;
}
.hero-track:active{
  cursor:grabbing;
}


/* ================= PARALLAX HERO ================= */

.hero-slide{
  position:relative;
  overflow:hidden;
}

.hero-layer{
  position:absolute;
  inset:0;
  pointer-events:none;
  will-change:transform;
}



.hero-layer--bg{
  background-size:cover;
  background-position:center;
}

.hero-layer,
.hero-slide,
.hero-track{
  backface-visibility: hidden;
  will-change: transform;
}

.hero-layer--bg{
  background-size: cover;
  background-position: center;
}


.hero-layer--mid{
  background:radial-gradient(circle at 70% 30%, rgba(181,154,97,.18), transparent 60%);
  mix-blend-mode:overlay;
}

.hero-layer--grain{
  background-image:url("https://www.transparenttextures.com/patterns/canvas.png");
  opacity:.08;
}

.hero-slide__content{
  position:relative;
  z-index:3;
}

/* ================= SELECTED WORKS HORIZONTAL CAROUSEL ================= */

.works-carousel{
  display:flex;
  gap:1.5rem;
  overflow:hidden;
  cursor:grab;
  scroll-behavior:smooth;
}

.works-carousel:active{
  cursor:grabbing;
}

.works-track{
  display:flex;
  gap:1.5rem;
}

.works-item{
  min-width:320px;
  flex:0 0 auto;
}


/* ===== Selected Works - 3 Visible + Scroll Indicator ===== */

.works-carousel{
  overflow-x:auto;
  scroll-snap-type:x mandatory;
  padding-bottom:10px;
  position:relative;
}

.works-track{
  display:flex;
  gap:2rem;
}

.works-item{
  flex:0 0 calc((100% - 4rem)/3);
  scroll-snap-align:start;
}

@media(max-width:1024px){
  .works-item{
    flex:0 0 70%;
  }
}

.works-carousel::after{
  content:"";
  position:absolute;
  top:0;
  right:0;
  width:80px;
  height:100%;
  pointer-events:none;
}

/* Scrollbar Styling */
.works-carousel::-webkit-scrollbar{
  height:6px;
}
.works-carousel::-webkit-scrollbar-track{
  background:rgba(0,0,0,.05);
}
.works-carousel::-webkit-scrollbar-thumb{
  background:#b59a61;
  border-radius:10px;
}


/* =========================================================
   V7 Hero: Cinematic + Parallax + Autoplay Progress
   ========================================================= */
.hero{padding:0}
.hero-carousel{
  width:100vw;
  margin-left:calc(50% - 50vw);
  position:relative;
  overflow:hidden;
  border-bottom:1px solid rgba(28,26,23,.06);
}
html[data-theme="dark"] .hero-carousel{border-bottom-color:rgba(255,255,255,.10)}

.hero-track{
  display:flex;
  will-change:transform;
  transition:transform .6s var(--ease);
  touch-action: pan-y;
  cursor: grab;
}
.hero-track:active{cursor: grabbing}

.hero-slide{
  min-width:100vw;
  height:min(84vh, 760px);
  position:relative;
  display:grid;
  align-items:end;
  overflow:hidden;
}
@media (max-width:860px){ .hero-slide{height:min(82vh, 700px);} }

.hero-layer{position:absolute; inset:-3%; will-change:transform; pointer-events:none; transform: translate3d(0,0,0);}
.hero-layer--bg{
  background-size:cover;
  background-position:center;
  filter:saturate(1.02) contrast(1.03);
  transform: scale(1.05);
}
.hero-layer--bloom{
  background:
    radial-gradient(800px 520px at 70% 22%, rgba(181,154,97,.22), transparent 60%),
    radial-gradient(900px 600px at 20% 80%, rgba(143,155,132,.16), transparent 62%);
  mix-blend-mode: overlay;
  opacity:.85;
}
html[data-theme="dark"] .hero-layer--bloom{
  opacity:.95;
  background:
    radial-gradient(860px 560px at 70% 22%, rgba(181,154,97,.24), transparent 60%),
    radial-gradient(900px 620px at 20% 80%, rgba(143,155,132,.14), transparent 62%);
}
.hero-layer--grain{
  background-image:url("https://www.transparenttextures.com/patterns/canvas.png");
  opacity:.10;
}
.hero-layer--vignette{
  inset:0;
  background:
    radial-gradient(1000px 720px at 22% 20%, rgba(255,255,255,.12), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,0.08), rgba(0,0,0,0.62));
}
.hero-slide[data-tone="bright"] .hero-layer--vignette{
  background:
    radial-gradient(1000px 720px at 22% 20%, rgba(0,0,0,.10), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,0.12), rgba(0,0,0,0.68));
}
html[data-theme="dark"] .hero-layer--vignette{
  background:
    radial-gradient(1000px 720px at 22% 20%, rgba(181,154,97,.12), transparent 58%),
    linear-gradient(180deg, rgba(0,0,0,0.16), rgba(0,0,0,0.78));
}

.hero-slide__content{position:relative; z-index:3; padding: clamp(2.1rem, 5vw, 4.1rem) 0;}
.hero-slide__inner{
  max-width: 440px;
  margin: 0 0px 1em 2em;
  padding: 1.1rem var(--pad);
  border-radius: 22px;
  color:#fff;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.18);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 60px rgba(0,0,0,.18);
}
html[data-theme="dark"] .hero-slide__inner{background: rgba(0,0,0,.28);}
.hero-slide__inner .kicker{color: rgba(255,255,255,.88)}
.hero-slide__inner .kicker:before{background: rgba(255,255,255,.35)}
.hero-slide__inner h1,.hero-slide__inner h2{color:#fff; margin: .2rem 0 .35rem; max-width: 20ch;}
.hero-slide__lead{color: rgba(255,255,255,.88); margin:0; max-width: 64ch; font-size: 1.05rem;}

.hero-controls{
  position:absolute;
  left:0; right:0;
  bottom: 18px;
  z-index:4;
  display:flex;
  justify-content:center;
  gap: 1rem;
  align-items:center;
  pointer-events:none;
  display: none;
}
.hero-dots, .hero-arrow{pointer-events:auto;}
.hero-arrow--glass{
  width:46px; height:46px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.10);
  backdrop-filter: blur(12px);
  display:grid; place-items:center;
  color:#fff;
  transition: transform .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease);
  box-shadow: 0 14px 40px rgba(0,0,0,.22);
}
.hero-arrow--glass:hover{transform: translateY(-1px); background: rgba(255,255,255,.14); border-color: rgba(255,255,255,.28);}
@media (max-width:680px){ .hero-arrow--glass{display:none;} }

.hero-dots{display:flex; gap:.55rem; align-items:center;}
.hero-dot{
  width: 26px; height: 4px;
  border-radius:999px;
  background: rgba(255,255,255,.28);
  border:1px solid rgba(255,255,255,.12);
  cursor:pointer;
  transition: transform .2s var(--ease), background .2s var(--ease);
}
.hero-dot:hover{transform: translateY(-1px); background: rgba(255,255,255,.38);}
.hero-dot.active{background: rgba(181,154,97,.92); border-color: rgba(181,154,97,.28);}

.hero-progress{
  position:absolute;
  left:0; right:0;
  bottom: 8px;
  z-index:4;
  pointer-events:none;
}
.hero-progress__track{
  max-width: var(--max);
  margin: 0 auto;
  padding: 0 var(--pad);
}
.hero-progress__track:before{
  content:"";
  display:block;
  height: 3px;
  border-radius:999px;
  background: rgba(255,255,255,.18);
}
.hero-progress__fill{
  height: 3px;
  margin-top: -3px;
  border-radius:999px;
  width: 0%;
  background: linear-gradient(90deg, rgba(181,154,97,.92), rgba(255,255,255,.65));
  transform-origin:left;
}
.hero-progress__fill.anim{
  animation: heroProgress var(--heroAuto, 5200ms) linear forwards;
}
@keyframes heroProgress{from{width:0%}to{width:100%}}

.hero-animate{opacity:0; transform: translateY(10px);}
.hero-slide.is-active .hero-animate{
  animation: heroIn .7s var(--ease) forwards;
  animation-delay: var(--d, 0ms);
}
@keyframes heroIn{to{opacity:1; transform: translateY(0);}}

.hero-cinematic{position:absolute; inset:0; z-index:2; pointer-events:none; overflow:hidden;}
.hero-curtain{
  position:absolute; top:0; bottom:0;
  width: 56%;
  background: linear-gradient(90deg, rgba(0,0,0,.82), rgba(0,0,0,.62));
  transform: translateX(0);
}
.hero-curtain--left{left:0;}
.hero-curtain--right{right:0; background: linear-gradient(270deg, rgba(0,0,0,.82), rgba(0,0,0,.62));}
.hero-slide.is-active .hero-curtain--left{animation: curtainLeft .85s var(--ease) forwards;}
.hero-slide.is-active .hero-curtain--right{animation: curtainRight .85s var(--ease) forwards;}
@keyframes curtainLeft{to{transform: translateX(-110%);}}
@keyframes curtainRight{to{transform: translateX(110%);}}

@media (prefers-reduced-motion: reduce){
  .hero-track{transition:none !important}
  .hero-animate{opacity:1 !important; transform:none !important; animation:none !important}
  .hero-progress__fill{animation:none !important; width:100% !important}
  .hero-curtain{display:none !important}
}



/* ================= Luxury Divider ================= */
.luxury-divider {
  position: relative;
}
.luxury-divider:before {
  content: "";
  display: block;
  width: 80px;
  height: 1px;
  background: linear-gradient(to right, transparent, #b59a61, transparent);
  margin: 0 auto 3rem;
  opacity: .6;
}

/* ================= Gold Underline Animation ================= */
.gold-underline {
  position: relative;
  display: inline-block;
  padding-bottom: .5rem;
}
.gold-underline:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 0%;
  height: 2px;
  background: linear-gradient(90deg, #b59a61, #e6d3a3);
  transition: width .8s ease;
}
.gold-underline.reveal-visible:after {
  width: 100%;
}


@media (max-width: 1024px) {
  .seasonal-grid {
    grid-template-columns: 1fr;
  }
}

.seasonal-card {
  background: rgba(255,255,255,0.65);
  backdrop-filter: blur(12px);
  border-radius: 20px;
  overflow: hidden;
  transition: transform .35s ease, box-shadow .35s ease;
  border: 1px solid rgba(0,0,0,0.05);
}

html[data-theme="dark"] .seasonal-card {
  background: rgba(30,30,30,0.6);
  border: 1px solid rgba(255,255,255,0.08);
}

.seasonal-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 20px 60px rgba(0,0,0,0.12);
}

.seasonal-media img {
  width: 100%;
  height: 260px;
  object-fit: cover;
}

.seasonal-content {
  padding: 1.5rem;
}

.seasonal-content h3 {
  margin-bottom: .75rem;
}

.seasonal-content p {
  font-size: .95rem;
  line-height: 1.6;
  opacity: .85;
}



/* ================= Seasonal Section Clean ================= */

.luxury-divider {
  position: relative;
  padding-top: 3rem;
}

.luxury-divider:before {
  content: "";
  display: block;
  width: 80px;
  height: 1px;
  margin: 0 auto 3rem;
  background: linear-gradient(to right, transparent, #b59a61, transparent);
  opacity: .6;
}

.gold-underline {
  position: relative;
  display: inline-block;
  padding-bottom: .5rem;
}

.gold-underline:after {
  content: "";
  position: absolute;
  left: 0;
  bottom: 0;
  width: 100%;
  height: 2px;
  background: linear-gradient(90deg, #b59a61, #e6d3a3);
  opacity: .85;
}

.seasonal-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 2rem;
  margin-top: 2.5rem;
}

@media (max-width: 1024px) {
  .seasonal-grid {
    grid-template-columns: 1fr;
  }
}

.seasonal-card {
  border-radius: 18px;
  overflow: hidden;
  background: rgba(255,255,255,0.75);
  border: 1px solid rgba(0,0,0,0.05);
  transition: transform .3s ease, box-shadow .3s ease;
}

html[data-theme="dark"] .seasonal-card {
  background: rgba(28,28,28,0.6);
  border: 1px solid rgba(255,255,255,0.08);
}

.seasonal-card:hover {
  transform: translateY(-6px);
  box-shadow: 0 18px 50px rgba(0,0,0,0.12);
}

.seasonal-media img {
  width: 100%;
  height: 260px;
  object-fit: cover;
}

.seasonal-content {
  padding: 1.5rem;
}

.seasonal-content h3 {
  margin-bottom: .75rem;
}

.seasonal-content p {
  font-size: .95rem;
  line-height: 1.6;
  opacity: .85;
}


/* ================= CLEAN ANNOUNCEMENT + HEADER ================= */
/* ================= ANNOUNCEMENT ================= */

:root{
  --announce-h: 0px;
  --header-h: 0px;
}

/* Highlight gradient */
.announcement{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 998;
  background: linear-gradient(90deg, #b79b6c, #d8c29c);
  color: #1a1815;
  font-size: .85rem;
  text-align: center;
  padding: .65rem 1rem;
  transform: translateY(0);
  transition: transform .4s cubic-bezier(.2,.6,.2,1), opacity .4s;
  will-change: transform;
}

.announcement__link{
  font-weight: 600;
  text-decoration: underline;
  transition: opacity .3s ease;
}

.announcement__link:hover{
  opacity: .7;
}

.announcement.hidden{
  transform: translateY(calc(var(--announce-h) * -1));
  opacity: 0;
}

/* ================= HEADER ================= */

.header{
  position: fixed;
  top: var(--announce-h);
  left: 0;
  right: 0;
  width: 100%;
  z-index: 999;
  transition:
    top .4s cubic-bezier(.2,.6,.2,1),
    background .3s ease,
    backdrop-filter .3s ease,
    border-color .3s ease;
}

/* Glass effect when scrolled */
.header.scrolled{
  backdrop-filter: blur(14px);
  background: rgba(255,255,255,.85);
}

html[data-theme="dark"] .header.scrolled{
  background: rgba(15,15,15,.85);
}

/* Prevent content overlap */
body{
  padding-top: calc(var(--announce-h) + var(--header-h));
}
.grids-auto .card{width: auto;}
@media (max-width: 502px) {
  .hero-slide__inner{
    width: 100%;
    margin: auto;
    
  }
}
