*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --ivory:#FAF8F5;--warm:#F5F3EF;--sand:#E8E2D9;--stone:#C9BFB2;
  --espresso:#2C2420;--char:#3A3530;--muted:#7A7268;--accent:#B89E84;--gold:#C9A96E;
  --fd:'Cormorant Garamond',serif;--fb:'Jost',sans-serif;
  --ease:cubic-bezier(.25,.46,.45,.94);
}
html{scroll-behavior:smooth}
body{background:var(--ivory);color:var(--espresso);font-family:var(--fb);font-weight:300;overflow-x:hidden}

/* ── ANNOUNCEMENT ── */
.banner{background:var(--espresso);color:var(--ivory);text-align:center;padding:11px;font-size:.68rem;letter-spacing:.22em;text-transform:uppercase}

/* ── NAV ── */
nav{position:fixed;top:38px;left:0;right:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 3.5rem;height:74px;transition:background .4s,border-color .4s}
nav.scrolled{background:rgba(250,248,245,.96);backdrop-filter:blur(16px);border-bottom:1px solid var(--sand)}
.nav-logo img{height:26px;width:auto;filter:brightness(0) invert(1);transition:filter .4s}
nav.scrolled .nav-logo img{filter:none}
.nav-links{display:flex;gap:2.8rem;list-style:none}
.nav-links a{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;color:rgba(250,248,245,.9);transition:color .3s}
nav.scrolled .nav-links a{color:var(--char)}
.nav-links a:hover{color:var(--accent)}
.nav-right{display:flex;align-items:center;gap:1.2rem}
.nav-socials{display:flex;gap:.9rem}
.nav-socials a{color:rgba(250,248,245,.8);transition:color .3s}
nav.scrolled .nav-socials a{color:var(--char)}
.nav-socials a:hover{color:var(--accent)}
.nav-socials svg{width:15px;height:15px;fill:currentColor}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:4px}
.hamburger span{display:block;width:22px;height:1px;background:rgba(250,248,245,.9);transition:background .4s}
nav.scrolled .hamburger span{background:var(--espresso)}
.nav-spacer{height:112px}

/* ── MOBILE MENU ── */
.mobile-menu{display:none;position:fixed;top:112px;left:0;right:0;bottom:0;background:var(--ivory);z-index:99;padding:3rem 2rem;flex-direction:column;gap:2rem}
.mobile-menu.open{display:flex}
.mobile-menu a{font-size:2rem;font-family:var(--fd);font-weight:300;text-decoration:none;color:var(--espresso)}

/* ── FULL-BLEED HERO ── */
.hero{position:relative;height:100vh;min-height:700px;overflow:hidden}
.hero-bg{position:absolute;inset:0;display:grid;grid-template-columns:1fr 1fr}
.hero-bg-img{width:100%;height:100%;object-fit:cover}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(44,36,32,.55) 0%,rgba(44,36,32,.1) 60%,transparent 100%)}
.hero-content{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:center;padding:0 6rem;max-width:700px}
.hero-eyebrow{font-size:.65rem;letter-spacing:.3em;text-transform:uppercase;color:var(--accent);margin-bottom:1.8rem;opacity:0;transform:translateY(20px);animation:fadeUp .8s var(--ease) .3s forwards}
.hero-title{font-family:var(--fd);font-size:clamp(4rem,7vw,7rem);font-weight:300;line-height:.95;color:#fff;margin-bottom:2rem;opacity:0;transform:translateY(30px);animation:fadeUp .9s var(--ease) .5s forwards}
.hero-title em{font-style:italic;color:var(--gold)}
.hero-sub{font-size:.88rem;line-height:1.9;color:rgba(255,255,255,.78);margin-bottom:3rem;max-width:380px;opacity:0;transform:translateY(20px);animation:fadeUp .8s var(--ease) .7s forwards}
.hero-actions{display:flex;align-items:center;gap:2rem;opacity:0;transform:translateY(20px);animation:fadeUp .8s var(--ease) .9s forwards}
.btn-primary{display:inline-block;padding:15px 40px;background:var(--ivory);color:var(--espresso);font-size:.7rem;letter-spacing:.2em;text-transform:uppercase;text-decoration:none;font-family:var(--fb);font-weight:400;transition:background .3s,color .3s;border:none;cursor:pointer}
.btn-primary:hover{background:var(--gold);color:#fff}
.btn-ghost-white{font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.85);text-decoration:none;border-bottom:1px solid rgba(255,255,255,.4);padding-bottom:2px;transition:color .3s,border-color .3s}
.btn-ghost-white:hover{color:#fff;border-color:#fff}
.hero-scroll{position:absolute;bottom:2.5rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:.6rem;opacity:0;animation:fadeUp .8s var(--ease) 1.2s forwards}
.hero-scroll span{font-size:.6rem;letter-spacing:.2em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.scroll-line{width:1px;height:50px;background:rgba(255,255,255,.3);position:relative;overflow:hidden}
.scroll-line::after{content:'';position:absolute;top:0;left:0;width:100%;background:rgba(255,255,255,.8);animation:scrollLine 2s ease-in-out infinite;height:30px}
@keyframes scrollLine{0%{transform:translateY(-100%)}100%{transform:translateY(200%)}}
@keyframes fadeUp{to{opacity:1;transform:translateY(0)}}

/* ── MARQUEE ── */
.marquee-bar{background:var(--espresso);padding:.9rem 0;overflow:hidden}
.marquee-track{display:flex;gap:2.5rem;animation:marquee 25s linear infinite;white-space:nowrap}
.marquee-track span{font-size:.6rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(250,248,245,.6);display:flex;align-items:center;gap:.7rem}
.marquee-track span::before{content:"✦";color:var(--gold);font-size:.45rem}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ── SECTION HELPERS ── */
.eyebrow{font-size:.62rem;letter-spacing:.28em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}
.sec-title{font-family:var(--fd);font-size:clamp(2rem,4vw,3.5rem);font-weight:300;line-height:1.05;color:var(--espresso);margin-bottom:1.5rem}
.sec-title em{font-style:italic}
.sec-body{font-size:.87rem;line-height:1.95;color:var(--muted)}
.divider{width:44px;height:1px;background:var(--accent);margin:2rem 0}
.link-arrow{display:inline-block;font-size:.67rem;letter-spacing:.18em;text-transform:uppercase;text-decoration:none;border-bottom:1px solid var(--stone);padding-bottom:2px;color:var(--espresso);transition:color .2s,border-color .2s}
.link-arrow:hover{color:var(--accent);border-color:var(--accent)}

/* ── EDITORIAL INTRO ── */
.editorial{display:grid;grid-template-columns:1fr 1fr;min-height:80vh}
.editorial-img{overflow:hidden;position:relative}
.editorial-img img{width:100%;height:100%;object-fit:cover;transition:transform 8s var(--ease)}
.editorial-img:hover img{transform:scale(1.04)}
.editorial-text{background:var(--espresso);display:flex;flex-direction:column;justify-content:center;padding:7rem 6rem}
.editorial-text .eyebrow{color:var(--gold)}
.editorial-text .sec-title{color:var(--ivory)}
.editorial-text .sec-body{color:rgba(250,248,245,.68);max-width:420px}
.editorial-text .divider{background:var(--gold)}
.editorial-text .link-arrow{color:rgba(250,248,245,.75);border-color:rgba(250,248,245,.3)}
.editorial-text .link-arrow:hover{color:var(--ivory);border-color:var(--ivory)}

/* ── PRODUCT CARDS ── */
.products-section{padding:8rem 4rem;background:var(--warm)}
.products-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:4.5rem;padding:0 1rem}
.products-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.card{cursor:pointer;position:relative}
.card-img-wrap{overflow:hidden;background:var(--sand);margin-bottom:1.8rem;position:relative}
.card-img-wrap img{width:100%;aspect-ratio:3/4;object-fit:cover;transition:transform .7s var(--ease)}
.card:hover .card-img-wrap img{transform:scale(1.06)}
.card-tag{position:absolute;top:1.2rem;left:1.2rem;background:var(--espresso);color:var(--ivory);font-size:.58rem;letter-spacing:.16em;text-transform:uppercase;padding:5px 12px}
.card-name{font-family:var(--fd);font-size:1.5rem;font-weight:400;letter-spacing:.02em;color:var(--espresso);margin-bottom:.4rem}
.card-sub{font-size:.72rem;color:var(--muted);letter-spacing:.08em;margin-bottom:.9rem}
.card-footer{display:flex;justify-content:space-between;align-items:center}
.card-price{font-size:.85rem;letter-spacing:.1em;color:var(--espresso);font-weight:400}

/* ── TEXTURE FEATURE (full-width image) ── */
.texture-feature{position:relative;height:60vh;overflow:hidden}
.texture-feature img{width:100%;height:100%;object-fit:cover;object-position:center}
.texture-feature-overlay{position:absolute;inset:0;display:flex;align-items:flex-end;justify-content:center;padding:4rem;background:linear-gradient(to top,rgba(44,36,32,.5) 0%,transparent 60%)}
.texture-feature-text{text-align:center;color:var(--ivory)}
.texture-feature-text .sec-title{color:var(--ivory);font-size:clamp(2.5rem,5vw,4.5rem)}

/* ── MODEL FEATURE ── */
.model-feature{display:grid;grid-template-columns:5fr 4fr;min-height:90vh}
.model-img{overflow:hidden;position:relative}
.model-img img{width:100%;height:100%;object-fit:cover;object-position:top center}
.model-text{display:flex;flex-direction:column;justify-content:center;padding:6rem 5rem;background:var(--ivory)}
.model-text .sec-title{font-size:clamp(2rem,3.5vw,3.2rem)}

/* ── INGREDIENTS ── */
.ingredients-section{padding:8rem 6rem;background:var(--espresso)}
.ing-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:5rem}
.ing-header .sec-title{color:var(--ivory)}
.ing-header .eyebrow{color:var(--gold)}
.ing-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:2rem}
.ing-item{text-align:center;border-top:1px solid rgba(255,255,255,.12);padding-top:2rem}
.ing-item img{width:70px;height:70px;object-fit:cover;border-radius:50%;margin-bottom:1.2rem;filter:grayscale(10%)}
.ing-item h4{font-family:var(--fd);font-size:1rem;font-weight:400;color:var(--ivory);margin-bottom:.5rem}
.ing-item p{font-size:.7rem;color:rgba(250,248,245,.5);line-height:1.6}

/* ── DUAL IMAGE FEATURE ── */
.dual-feature{display:grid;grid-template-columns:1fr 1fr;height:70vh}
.dual-feature-img{overflow:hidden;position:relative}
.dual-feature-img img{width:100%;height:100%;object-fit:cover;transition:transform 8s var(--ease)}
.dual-feature-img:hover img{transform:scale(1.04)}
.dual-label{position:absolute;bottom:2rem;left:2rem;background:rgba(250,248,245,.9);padding:.6rem 1.2rem}
.dual-label p{font-size:.65rem;letter-spacing:.15em;text-transform:uppercase;color:var(--espresso)}

/* ── REVIEWS ── */
.reviews-section{padding:8rem 6rem;background:var(--warm)}
.reviews-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:2rem;margin-top:4rem}
.review-card{background:var(--ivory);padding:2.5rem 2rem;border:1px solid var(--sand);position:relative}
.review-stars{color:var(--gold);font-size:.85rem;margin-bottom:1.2rem}
.review-text{font-family:var(--fd);font-size:1.05rem;font-weight:300;font-style:italic;line-height:1.75;color:var(--char);margin-bottom:1.5rem}
.review-author{font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted)}

/* ── FAQ ── */
.faq-section{padding:8rem 6rem;background:var(--ivory)}
.faq-layout{display:grid;grid-template-columns:1fr 2fr;gap:6rem}
.faq-grid{display:flex;flex-direction:column;gap:.5rem}
.faq-item{border-bottom:1px solid var(--sand)}
.faq-q{display:flex;justify-content:space-between;align-items:center;padding:1.3rem 0;cursor:pointer;font-size:.82rem;color:var(--char);font-weight:400}
.faq-q:hover{color:var(--accent)}
.faq-a{font-size:.8rem;line-height:1.8;color:var(--muted);padding-bottom:1.3rem;display:none}
.faq-a.open{display:block}
.plus{font-size:1rem;color:var(--accent);transition:transform .3s}
.plus.open{transform:rotate(45deg)}

/* ── FULL BLEED CLOSER ── */
.closer{position:relative;height:70vh;overflow:hidden}
.closer img{width:100%;height:100%;object-fit:cover}
.closer-overlay{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;background:rgba(44,36,32,.42)}
.closer-overlay .sec-title{color:#fff;font-size:clamp(3rem,6vw,5.5rem);margin-bottom:2rem}
.closer-overlay .sec-title em{color:var(--gold)}

/* ── MODAL ── */
.overlay{display:none;position:fixed;inset:0;z-index:200;background:rgba(44,36,32,.7);backdrop-filter:blur(6px);align-items:center;justify-content:center;padding:2rem}
.overlay.open{display:flex}
.modal{background:var(--ivory);max-width:1000px;width:100%;max-height:92vh;overflow-y:auto;display:grid;grid-template-columns:1fr 1fr;position:relative}
.modal-gallery{background:var(--sand);position:sticky;top:0;height:fit-content}
.modal-main img{width:100%;aspect-ratio:1/1;object-fit:cover}
.modal-thumbs{display:flex;gap:8px;padding:.8rem}
.modal-thumbs img{width:60px;height:60px;object-fit:cover;cursor:pointer;border:2px solid transparent;opacity:.7;transition:opacity .2s,border-color .2s}
.modal-thumbs img.active{border-color:var(--accent);opacity:1}
.modal-close{position:absolute;top:1rem;right:1rem;cursor:pointer;background:var(--ivory);border:none;width:38px;height:38px;display:flex;align-items:center;justify-content:center;z-index:10;font-size:1.1rem;color:var(--muted)}
.modal-close:hover{color:var(--espresso)}
.modal-info{padding:3rem 2.5rem}
.modal-tag{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--accent);margin-bottom:.8rem}
.modal-name{font-family:var(--fd);font-size:2.4rem;font-weight:300;margin-bottom:.5rem}
.modal-size{font-size:.72rem;color:var(--muted);margin-bottom:1.5rem}
.modal-price{font-size:1.1rem;letter-spacing:.1em;font-weight:400;margin-bottom:2rem}
.modal-desc{font-size:.84rem;line-height:1.9;color:var(--char);margin-bottom:2rem}
.modal-attrs{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:2rem}
.attr{font-size:.62rem;letter-spacing:.12em;text-transform:uppercase;padding:5px 11px;border:1px solid var(--sand);color:var(--muted)}
.buy-btn{display:block;width:100%;padding:17px;background:var(--espresso);color:var(--ivory);font-size:.7rem;letter-spacing:.22em;text-transform:uppercase;text-decoration:none;text-align:center;border:none;cursor:pointer;font-family:var(--fb);margin-bottom:1rem;transition:background .3s}
.buy-btn:hover{background:var(--gold)}
.modal-note{font-size:.68rem;color:var(--muted);text-align:center}
.accordion{border-top:1px solid var(--sand);margin-top:2rem}
.acc-item{border-bottom:1px solid var(--sand)}
.acc-h{display:flex;justify-content:space-between;align-items:center;padding:1rem 0;cursor:pointer;font-size:.7rem;letter-spacing:.15em;text-transform:uppercase;color:var(--char)}
.acc-h:hover{color:var(--accent)}
.acc-b{font-size:.81rem;line-height:1.8;color:var(--muted);padding-bottom:1rem;display:none}
.acc-b.open{display:block}
.acc-b p{margin-bottom:.5rem}

/* ── ABOUT ── */
.about-hero{position:relative;height:65vh;overflow:hidden}
.about-hero img{width:100%;height:100%;object-fit:cover}
.about-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(44,36,32,.65) 0%,transparent 60%)}
.about-hero-text{position:absolute;bottom:4rem;left:6rem;color:var(--ivory)}
.about-hero-text h1{font-family:var(--fd);font-size:clamp(3rem,5vw,5rem);font-weight:300}
.about-content{max-width:760px;margin:0 auto;padding:6rem 2rem}
.about-content h2{font-family:var(--fd);font-size:2rem;font-weight:300;margin:3rem 0 1rem}
.about-content p{font-size:.88rem;line-height:1.9;color:var(--muted);margin-bottom:1.2rem}

/* ── CONTACT ── */
.contact-page{display:grid;grid-template-columns:1fr 1fr;min-height:80vh}
.contact-info{background:var(--espresso);padding:6rem;display:flex;flex-direction:column;justify-content:center}
.contact-info h1{font-family:var(--fd);font-size:3rem;font-weight:300;color:var(--ivory);margin-bottom:2rem}
.contact-info p{font-size:.85rem;line-height:1.8;color:rgba(250,248,245,.65);margin-bottom:2rem}
.contact-detail{margin-bottom:1.5rem}
.contact-detail span{display:block;font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:.4rem}
.contact-detail a,.contact-detail p{font-size:.88rem;color:var(--ivory);text-decoration:none}
.contact-form-area{padding:6rem;display:flex;flex-direction:column;justify-content:center}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:.62rem;letter-spacing:.18em;text-transform:uppercase;color:var(--muted);margin-bottom:.5rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:12px 0;background:transparent;border:none;border-bottom:1px solid var(--sand);font-family:var(--fb);font-size:.88rem;color:var(--espresso);outline:none;transition:border-color .2s}
.form-group input:focus,.form-group textarea:focus{border-color:var(--accent)}
.form-group textarea{height:100px;resize:none}

/* ── FOOTER ── */
footer{background:var(--espresso);color:var(--ivory);padding:5rem 6rem 2.5rem}
.footer-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:3rem;margin-bottom:4rem}
.footer-brand img{height:22px;filter:brightness(0) invert(1);margin-bottom:1.5rem}
.footer-brand p{font-size:.76rem;line-height:1.7;color:rgba(250,248,245,.45);max-width:220px}
.footer-socials{display:flex;gap:1rem;margin-top:1.5rem}
.footer-socials a{color:rgba(250,248,245,.45);transition:color .2s}
.footer-socials a:hover{color:var(--ivory)}
.footer-socials svg{width:17px;height:17px;fill:currentColor}
.footer-col h5{font-size:.6rem;letter-spacing:.22em;text-transform:uppercase;color:var(--gold);margin-bottom:1.2rem}
.footer-col ul{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer-col ul li a{font-size:.76rem;color:rgba(250,248,245,.45);text-decoration:none;transition:color .2s}
.footer-col ul li a:hover{color:var(--ivory)}
.footer-bottom{border-top:1px solid rgba(250,248,245,.1);padding-top:2rem;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem}
.footer-bottom p{font-size:.7rem;color:rgba(250,248,245,.35)}
.anpc{display:flex;gap:1rem}
.anpc img{height:28px;opacity:.45;transition:opacity .2s}
.anpc img:hover{opacity:.8}

/* ── PAGE SYSTEM ── */
.page{display:none}.page.active{display:block}

/* ── SHOP PAGE ── */
.shop-hero{position:relative;height:45vh;overflow:hidden}
.shop-hero img{width:100%;height:100%;object-fit:cover}
.shop-hero-overlay{position:absolute;inset:0;background:rgba(44,36,32,.45);display:flex;align-items:flex-end;padding:4rem 6rem}
.shop-hero-text .sec-title{color:var(--ivory);font-size:clamp(2.5rem,4vw,4rem)}

/* ── RESPONSIVE ── */
@media(max-width:1024px){
  nav{padding:0 2rem}
  .hero-content{padding:0 3rem}
  .editorial{grid-template-columns:1fr}
  .editorial-img{height:60vh}
  .editorial-text{padding:5rem 3rem}
  .products-section{padding:5rem 2rem}
  .model-feature{grid-template-columns:1fr}
  .model-img{height:60vh}
  .model-text{padding:4rem 3rem}
  .ingredients-section{padding:5rem 3rem}
  .ing-grid{grid-template-columns:repeat(3,1fr)}
  .faq-layout{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media(max-width:768px){
  nav{padding:0 1.5rem}
  .nav-links{display:none}
  .hamburger{display:flex}
  .hero-content{padding:0 2rem;max-width:100%}
  .hero-title{font-size:clamp(3rem,10vw,5rem)}
  .hero-bg{grid-template-columns:1fr}
  .hero-bg .hero-bg-img:last-child{display:none}
  .products-grid{grid-template-columns:1fr}
  .dual-feature{grid-template-columns:1fr;height:auto}
  .dual-feature-img{height:55vw}
  .reviews-grid{grid-template-columns:1fr}
  .ing-grid{grid-template-columns:repeat(2,1fr)}
  .modal{grid-template-columns:1fr}
  .modal-gallery{position:static}
  .contact-page{grid-template-columns:1fr}
  .contact-info,.contact-form-area{padding:3rem 1.5rem}
  .about-hero-text{left:2rem}
  .products-header{flex-direction:column;align-items:flex-start;gap:1rem}
  footer{padding:4rem 2rem 2rem}
  .footer-grid{grid-template-columns:1fr}
  .shop-hero-overlay{padding:3rem 2rem}
  .texture-feature{height:45vh}
  .faq-section{padding:5rem 2rem}
  .reviews-section{padding:5rem 2rem}
  .ingredients-section{padding:5rem 2rem}
  .about-content{padding:4rem 2rem}
  .contact-form-area h2{font-size:2rem}
}
