:root{
  --cream:#f8f5f1;
  --beige:#e8dfd6;
  --sand:#d4bfa9;
  --brown:#7a5c45;
  --black:#111111;
  --rose:#d9a58f;
  --white:#ffffff;
  --gray:#f2f2f2;
  --font-serif:'Playfair Display',serif;
  --font-sans:'Inter',sans-serif;
  --font-poppins:'Poppins',sans-serif;
  --font-mont:'Montserrat',sans-serif;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:var(--font-sans);
  background:var(--cream);
  color:var(--black);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}

img{display:block;max-width:100%;height:auto;}

/* Cursor Glow */
.cursor-glow{
  position:fixed;
  width:400px;height:400px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(217,165,143,0.15) 0%,transparent 70%);
  pointer-events:none;
  z-index:9999;
  transform:translate(-50%,-50%);
  transition:opacity 0.3s;
  mix-blend-mode:multiply;
}
@media(max-width:900px){.cursor-glow{display:none;}}

/* Header */
.site-header{
  position:fixed;top:0;left:0;right:0;
  z-index:1000;
  padding:22px 0;
  background:rgba(248,245,241,0.7);
  backdrop-filter:blur(20px);
  -webkit-backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(212,191,169,0.2);
  transition:all 0.4s ease;
}
.site-header.scrolled{
  padding:14px 0;
  background:rgba(248,245,241,0.92);
  box-shadow:0 8px 30px rgba(122,92,69,0.06);
}
.header-container{
  max-width:1400px;
  margin:0 auto;
  padding:0 40px;
  display:flex;
  align-items:center;
  justify-content:space-between;
}
.logo{
  font-family:var(--font-serif);
  font-size:1.6rem;
  font-weight:600;
  color:var(--black);
  text-decoration:none;
  letter-spacing:-0.5px;
}
.logo span{color:var(--brown);font-style:italic;}
.main-nav{display:flex;gap:36px;}
.main-nav a{
  font-family:var(--font-mont);
  font-size:0.82rem;
  font-weight:500;
  letter-spacing:1.5px;
  text-transform:uppercase;
  color:var(--black);
  text-decoration:none;
  position:relative;
  padding:6px 0;
  transition:color 0.3s;
}
.main-nav a::after{
  content:'';
  position:absolute;
  bottom:0;left:0;
  width:0;height:1px;
  background:var(--brown);
  transition:width 0.3s ease;
}
.main-nav a:hover::after,
.main-nav a.active::after{width:100%;}
.main-nav a:hover{color:var(--brown);}
.menu-toggle{
  display:none;
  background:none;border:none;cursor:pointer;
  flex-direction:column;gap:5px;
  padding:8px;
}
.menu-toggle span{
  width:24px;height:1.5px;background:var(--black);
  transition:0.3s;
}
.menu-toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.menu-toggle.active span:nth-child(2){opacity:0;}
.menu-toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media(max-width:900px){
  .menu-toggle{display:flex;}
  .main-nav{
    position:fixed;
    top:70px;left:0;right:0;
    flex-direction:column;
    background:rgba(248,245,241,0.98);
    backdrop-filter:blur(20px);
    padding:40px;
    gap:24px;
    transform:translateY(-150%);
    transition:transform 0.4s ease;
    border-bottom:1px solid var(--beige);
  }
  .main-nav.open{transform:translateY(0);}
}

/* Hero */
.hero{
  position:relative;
  min-height:100vh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  padding:120px 40px 60px;
}
.hero-bg{position:absolute;inset:0;z-index:1;}
.hero-bg img{width:100%;height:100%;object-fit:cover;}
.hero-overlay{
  position:absolute;inset:0;z-index:2;
  background:linear-gradient(135deg,rgba(248,245,241,0.85) 0%,rgba(232,223,214,0.6) 50%,rgba(217,165,143,0.4) 100%);
}
.hero-content{
  position:relative;
  z-index:3;
  max-width:900px;
  text-align:center;
  animation:fadeUp 1.2s ease;
}
.hero-tag{
  display:inline-block;
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--brown);
  margin-bottom:24px;
  padding:8px 20px;
  background:rgba(255,255,255,0.5);
  backdrop-filter:blur(10px);
  border-radius:50px;
  border:1px solid rgba(255,255,255,0.4);
}
.hero h1{
  font-family:var(--font-serif);
  font-size:clamp(2.5rem,6vw,5rem);
  font-weight:500;
  line-height:1.1;
  letter-spacing:-1.5px;
  color:var(--black);
  margin-bottom:24px;
}
.hero h1 em{font-style:italic;color:var(--brown);}
.hero p{
  font-size:1.1rem;
  max-width:600px;
  margin:0 auto 40px;
  color:#3a3a3a;
}
.hero-buttons{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;}
.hero-cta-note{
  font-size:0.85rem !important;
  color:#666 !important;
  margin:24px auto 0 !important;
  max-width:520px !important;
  font-family:var(--font-poppins);
  font-style:italic;
}
.btn-note{
  font-size:0.8rem;
  color:#777;
  margin-top:14px;
  font-family:var(--font-poppins);
  font-style:italic;
}
.form-intro{
  color:#666;
  font-size:0.9rem;
  margin-bottom:20px;
  font-family:var(--font-poppins);
}
.hero-scroll{
  position:absolute;
  bottom:30px;left:50%;
  transform:translateX(-50%);
  z-index:3;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:10px;
}
.hero-scroll span{
  font-family:var(--font-mont);
  font-size:0.7rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--brown);
}
.scroll-line{
  width:1px;height:50px;
  background:linear-gradient(to bottom,var(--brown),transparent);
  animation:scrollLine 2s infinite;
}
@keyframes scrollLine{0%,100%{opacity:0.3;}50%{opacity:1;}}
@keyframes fadeUp{from{opacity:0;transform:translateY(30px);}to{opacity:1;transform:translateY(0);}}

/* Buttons */
.btn{
  display:inline-block;
  padding:14px 32px;
  font-family:var(--font-mont);
  font-size:0.8rem;
  letter-spacing:2px;
  text-transform:uppercase;
  text-decoration:none;
  border-radius:50px;
  transition:all 0.4s ease;
  cursor:pointer;
  border:none;
}
.btn-primary{
  background:var(--black);
  color:var(--white);
  box-shadow:0 8px 25px rgba(17,17,17,0.2);
}
.btn-primary:hover{
  background:var(--brown);
  transform:translateY(-2px);
  box-shadow:0 12px 35px rgba(122,92,69,0.3);
}
.btn-secondary{
  background:rgba(255,255,255,0.4);
  backdrop-filter:blur(10px);
  color:var(--black);
  border:1px solid rgba(122,92,69,0.3);
}
.btn-secondary:hover{
  background:rgba(255,255,255,0.7);
  transform:translateY(-2px);
}

/* Section base */
.section{
  padding:100px 40px;
  max-width:1400px;
  margin:0 auto;
}
.section-header{
  text-align:center;
  margin-bottom:60px;
}
.eyebrow{
  display:inline-block;
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:3px;
  text-transform:uppercase;
  color:var(--brown);
  margin-bottom:16px;
}
.section-header h2,
h2{
  font-family:var(--font-serif);
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:500;
  line-height:1.15;
  letter-spacing:-1px;
  color:var(--black);
  margin-bottom:16px;
}
h2 em{font-style:italic;color:var(--brown);}
.section-header p{
  max-width:680px;
  margin:0 auto;
  color:#555;
}

/* Reveal */
.reveal{opacity:0;transform:translateY(40px);transition:opacity 0.9s ease,transform 0.9s ease;}
.reveal.in{opacity:1;transform:translateY(0);}

/* Card wrapper links — make full card clickable */
.article-card-link,
.trend-card-link,
.glass-card-link,
.masonry-link{
  display:block;
  text-decoration:none;
  color:inherit;
}

/* Trending Fashion Slider */
.card-slider{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:30px;
}
.trend-card{
  background:var(--white);
  border-radius:20px;
  overflow:hidden;
  box-shadow:0 10px 40px rgba(122,92,69,0.06);
  transition:transform 0.5s ease,box-shadow 0.5s ease;
  cursor:pointer;
  height:100%;
}
.trend-card-link:hover .trend-card,
.trend-card:hover{
  transform:translateY(-8px);
  box-shadow:0 25px 60px rgba(122,92,69,0.15);
}
.trend-image{
  height:340px;
  overflow:hidden;
}
.trend-image img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.8s ease;
}
.trend-card-link:hover .trend-image img,
.trend-card:hover .trend-image img{transform:scale(1.08);}
.trend-body{padding:28px;}
.trend-tag{
  font-family:var(--font-mont);
  font-size:0.7rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--rose);
  margin-bottom:12px;
  display:inline-block;
}
.trend-body h3{
  font-family:var(--font-serif);
  font-size:1.4rem;
  font-weight:500;
  margin-bottom:10px;
  color:var(--black);
}
.trend-body p{color:#666;font-size:0.95rem;margin-bottom:18px;}
.read-more{
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--brown);
  text-decoration:none;
  transition:color 0.3s;
  display:inline-block;
}
.read-more:hover,
.article-card-link:hover .read-more,
.trend-card-link:hover .read-more{color:var(--black);}

/* Split Layout */
.split-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
  align-items:center;
}
.split-layout.reverse .split-image{order:2;}
.split-image{
  border-radius:20px;
  overflow:hidden;
  height:600px;
}
.split-image img{width:100%;height:100%;object-fit:cover;transition:transform 1s;}
.split-image:hover img{transform:scale(1.05);}
.split-content h2{margin-bottom:20px;}
.split-content p{color:#555;margin-bottom:18px;}
.feature-list{
  list-style:none;
  margin:24px 0 32px;
}
.feature-list li{
  padding:12px 0;
  border-bottom:1px solid var(--beige);
  font-family:var(--font-poppins);
  font-size:0.95rem;
  position:relative;
  padding-left:24px;
}
.feature-list li::before{
  content:'◆';
  position:absolute;
  left:0;
  color:var(--rose);
  font-size:0.7rem;
  top:50%;transform:translateY(-50%);
}
@media(max-width:900px){
  .split-layout{grid-template-columns:1fr;gap:40px;}
  .split-layout.reverse .split-image{order:0;}
  .split-image{height:400px;}
}

/* Masonry */
.masonry{
  column-count:3;
  column-gap:24px;
}
.masonry-link{
  break-inside:avoid;
  display:block;
  margin-bottom:24px;
}
.masonry-link .masonry-item{margin-bottom:0;}
.masonry-item{
  break-inside:avoid;
  margin-bottom:24px;
  border-radius:18px;
  overflow:hidden;
  position:relative;
  cursor:pointer;
  height:280px;
}
.masonry-item.tall{height:420px;}
.masonry-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.7s ease;
}
.masonry-item:hover img,
.masonry-link:hover .masonry-item img{transform:scale(1.08);}
.masonry-overlay{
  position:absolute;
  inset:0;
  background:linear-gradient(to top,rgba(17,17,17,0.7) 0%,transparent 50%);
  display:flex;
  align-items:flex-end;
  padding:24px;
  opacity:0;
  transition:opacity 0.4s;
}
.masonry-item:hover .masonry-overlay,
.masonry-link:hover .masonry-overlay{opacity:1;}
.masonry-overlay span{
  color:var(--white);
  font-family:var(--font-serif);
  font-size:1.15rem;
  font-style:italic;
  line-height:1.4;
}
@media(max-width:900px){.masonry{column-count:2;}}
@media(max-width:600px){.masonry{column-count:1;}}

/* Glass Cards */
.glass-cards{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(240px,1fr));
  gap:24px;
}
.glass-card-link{display:block;height:100%;}
.glass-card{
  background:rgba(255,255,255,0.5);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.6);
  border-radius:22px;
  padding:36px 28px;
  text-align:center;
  transition:all 0.5s ease;
  box-shadow:0 8px 30px rgba(122,92,69,0.05);
  height:100%;
}
.glass-card:hover,
.glass-card-link:hover .glass-card{
  transform:translateY(-8px);
  background:rgba(255,255,255,0.8);
  box-shadow:0 20px 50px rgba(122,92,69,0.12);
}
.glass-icon{
  font-size:2rem;
  color:var(--rose);
  margin-bottom:18px;
}
.glass-card h3{
  font-family:var(--font-serif);
  font-size:1.3rem;
  font-weight:500;
  margin-bottom:12px;
}
.glass-card p{color:#666;font-size:0.9rem;}

/* Gallery */
.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:16px;
}
.gallery-item{
  position:relative;
  border-radius:16px;
  overflow:hidden;
  aspect-ratio:3/4;
  cursor:pointer;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s ease,filter 0.4s;
}
.gallery-item:hover img{transform:scale(1.1);filter:brightness(0.85);}
.save-btn{
  position:absolute;
  top:14px;right:14px;
  width:38px;height:38px;
  border-radius:50%;
  background:rgba(255,255,255,0.9);
  display:flex;align-items:center;justify-content:center;
  color:var(--rose);
  font-size:1.1rem;
  opacity:0;
  transform:scale(0.7);
  transition:all 0.3s;
}
.gallery-item:hover .save-btn{opacity:1;transform:scale(1);}
.save-btn:hover{background:var(--rose);color:var(--white);}
@media(max-width:900px){.gallery-grid{grid-template-columns:repeat(2,1fr);}}

/* Article Grid */
.article-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:30px;
}
.article-card-link{height:100%;}
.article-card{
  background:var(--white);
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 8px 30px rgba(122,92,69,0.05);
  transition:all 0.5s ease;
  height:100%;
  display:flex;
  flex-direction:column;
}
.article-card:hover,
.article-card-link:hover .article-card{
  transform:translateY(-6px);
  box-shadow:0 20px 50px rgba(122,92,69,0.12);
}
.article-img{height:240px;overflow:hidden;}
.article-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.7s;}
.article-card:hover .article-img img,
.article-card-link:hover .article-img img{transform:scale(1.08);}
.article-body{padding:24px;display:flex;flex-direction:column;flex:1;}
.article-cat{
  font-family:var(--font-mont);
  font-size:0.7rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--rose);
  margin-bottom:10px;
  display:inline-block;
}
.article-body h3{
  font-family:var(--font-serif);
  font-size:1.3rem;
  font-weight:500;
  margin-bottom:8px;
}
.article-body p{font-size:0.9rem;color:#666;margin-bottom:16px;flex:1;}

/* Social Section */
.social-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(220px,1fr));
  gap:20px;
}
.social-card{
  position:relative;
  border-radius:18px;
  overflow:hidden;
  aspect-ratio:1;
  cursor:pointer;
}
.social-card img{
  width:100%;height:100%;object-fit:cover;
  transition:transform 0.6s;
}
.social-card:hover img{transform:scale(1.08);}
.social-info{
  position:absolute;
  bottom:14px;left:14px;
  background:rgba(255,255,255,0.9);
  padding:6px 14px;
  border-radius:30px;
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:1px;
}
.quote-card{
  background:var(--beige);
  border-radius:18px;
  padding:36px 28px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  aspect-ratio:1;
}
.quote-card.dark{background:var(--black);color:var(--cream);}
.quote-card p{
  font-family:var(--font-serif);
  font-size:1.3rem;
  font-style:italic;
  line-height:1.4;
  margin-bottom:16px;
}
.quote-card span{
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:2px;
  text-transform:uppercase;
  opacity:0.7;
}

/* Testimonials */
.testimonials{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(280px,1fr));
  gap:24px;
}
.testimonial{
  background:rgba(255,255,255,0.6);
  backdrop-filter:blur(20px);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:22px;
  padding:36px;
  box-shadow:0 8px 30px rgba(122,92,69,0.05);
  transition:transform 0.4s;
}
.testimonial:hover{transform:translateY(-6px);}
.testimonial p{
  font-family:var(--font-serif);
  font-size:1.1rem;
  font-style:italic;
  color:#333;
  margin-bottom:24px;
  line-height:1.5;
}
.testimonial-author{
  display:flex;align-items:center;gap:14px;
}
.testimonial-author img{
  width:50px;height:50px;border-radius:50%;object-fit:cover;
}
.testimonial-author strong{
  display:block;
  font-family:var(--font-poppins);
  font-size:0.95rem;
}
.testimonial-author span{
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:1px;
  color:#888;
  text-transform:uppercase;
}

/* Newsletter */
.newsletter-section{padding:100px 40px;}
.newsletter-box{
  max-width:800px;
  margin:0 auto;
  text-align:center;
  background:linear-gradient(135deg,var(--beige) 0%,var(--sand) 100%);
  border-radius:30px;
  padding:80px 40px;
  position:relative;
  overflow:hidden;
}
.newsletter-box::before{
  content:'';
  position:absolute;
  top:-50%;right:-20%;
  width:400px;height:400px;
  background:radial-gradient(circle,rgba(255,255,255,0.4) 0%,transparent 70%);
  border-radius:50%;
}
.newsletter-box *{position:relative;z-index:2;}
.newsletter-box h2{color:var(--black);margin-bottom:14px;}
.newsletter-box p{color:#444;margin-bottom:30px;}
.newsletter-form{
  display:flex;
  max-width:480px;
  margin:0 auto;
  gap:10px;
  flex-wrap:wrap;
}
.newsletter-form input{
  flex:1;
  min-width:200px;
  padding:16px 24px;
  border:none;
  border-radius:50px;
  background:rgba(255,255,255,0.8);
  font-family:var(--font-sans);
  font-size:0.95rem;
  outline:none;
}
.newsletter-form button{
  padding:16px 32px;
  border:none;
  border-radius:50px;
  background:var(--black);
  color:var(--white);
  font-family:var(--font-mont);
  font-size:0.8rem;
  letter-spacing:2px;
  text-transform:uppercase;
  cursor:pointer;
  transition:all 0.3s;
}
.newsletter-form button:hover{background:var(--brown);}

/* Page Hero */
.page-hero{
  position:relative;
  min-height:60vh;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:140px 40px 80px;
  overflow:hidden;
}
.page-hero.short{min-height:45vh;}
.page-hero-bg{
  position:absolute;inset:0;
  width:100%;height:100%;
  object-fit:cover;
  z-index:1;
}
.page-hero::after{
  content:'';
  position:absolute;inset:0;
  background:linear-gradient(135deg,rgba(248,245,241,0.85),rgba(232,223,214,0.7));
  z-index:2;
}
.page-hero-content{
  position:relative;
  z-index:3;
  text-align:center;
  max-width:800px;
}
.page-hero-content h1{
  font-family:var(--font-serif);
  font-size:clamp(2.5rem,5vw,4.5rem);
  font-weight:500;
  line-height:1.1;
  margin:16px 0;
  letter-spacing:-1px;
}
.page-hero-content h1 em{font-style:italic;color:var(--brown);}
.page-hero-content p{color:#555;font-size:1.05rem;}

/* Contact */
.contact-layout{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:60px;
}
.contact-info h2{margin-bottom:16px;}
.contact-info p{color:#555;margin-bottom:30px;}
.contact-details{margin-bottom:30px;}
.contact-details>div{
  padding:16px 0;
  border-bottom:1px solid var(--beige);
}
.contact-details strong{
  display:block;
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--brown);
  margin-bottom:6px;
}
.contact-details span{font-family:var(--font-poppins);color:var(--black);}
.contact-form{
  background:rgba(255,255,255,0.7);
  backdrop-filter:blur(20px);
  border-radius:24px;
  padding:40px;
  box-shadow:0 10px 40px rgba(122,92,69,0.06);
}
.contact-form h3{
  font-family:var(--font-serif);
  font-size:1.6rem;
  margin-bottom:12px;
}
.contact-form label{
  display:block;
  margin-bottom:18px;
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:2px;
  text-transform:uppercase;
  color:var(--brown);
}
.contact-form input,
.contact-form textarea{
  width:100%;
  margin-top:6px;
  padding:14px 18px;
  border:1px solid var(--beige);
  border-radius:12px;
  font-family:var(--font-sans);
  font-size:0.95rem;
  background:var(--white);
  outline:none;
  transition:border 0.3s;
}
.contact-form input:focus,
.contact-form textarea:focus{border-color:var(--brown);}
.contact-form button{width:100%;margin-top:10px;}
.map-embed{
  border-radius:24px;
  overflow:hidden;
  box-shadow:0 10px 40px rgba(122,92,69,0.08);
}
@media(max-width:900px){.contact-layout{grid-template-columns:1fr;}}

/* Footer */
.site-footer{
  background:var(--black);
  color:var(--cream);
  padding:80px 40px 30px;
  margin-top:80px;
}
.footer-grid{
  max-width:1400px;
  margin:0 auto;
  display:grid;
  grid-template-columns:1.5fr 1fr 1fr 1.2fr;
  gap:50px;
}
.footer-col .logo{color:var(--cream);}
.footer-col .logo span{color:var(--rose);}
.footer-col p{
  color:#bbb;
  font-size:0.9rem;
  margin-top:14px;
  line-height:1.7;
}
.footer-col h4{
  font-family:var(--font-serif);
  font-size:1.1rem;
  font-weight:500;
  margin-bottom:18px;
  color:var(--white);
}
.footer-col a{
  display:block;
  color:#bbb;
  text-decoration:none;
  font-family:var(--font-poppins);
  font-size:0.88rem;
  padding:6px 0;
  transition:color 0.3s;
}
.footer-col a:hover{color:var(--rose);}
.mini-form{display:flex;gap:6px;margin-top:10px;}
.mini-form input{
  flex:1;
  padding:12px 16px;
  border:1px solid rgba(255,255,255,0.15);
  background:rgba(255,255,255,0.05);
  color:var(--cream);
  border-radius:30px;
  font-family:var(--font-sans);
  font-size:0.85rem;
  outline:none;
}
.mini-form input::placeholder{color:#888;}
.mini-form button{
  width:44px;height:44px;
  border-radius:50%;
  background:var(--rose);
  color:var(--black);
  border:none;
  cursor:pointer;
  font-size:1.1rem;
  transition:background 0.3s;
}
.mini-form button:hover{background:var(--cream);}
.footer-bottom{
  max-width:1400px;
  margin:50px auto 0;
  padding-top:30px;
  border-top:1px solid rgba(255,255,255,0.1);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:20px;
}
.footer-bottom p{color:#999;font-size:0.82rem;}
.legal-links{display:flex;gap:24px;}
.legal-links a{
  color:#999;
  text-decoration:none;
  font-family:var(--font-mont);
  font-size:0.75rem;
  letter-spacing:1.5px;
  text-transform:uppercase;
  transition:color 0.3s;
}
.legal-links a:hover{color:var(--rose);}
@media(max-width:900px){
  .footer-grid{grid-template-columns:1fr 1fr;gap:40px;}
}
@media(max-width:600px){
  .footer-grid{grid-template-columns:1fr;}
  .footer-bottom{flex-direction:column;text-align:center;}
}

/* Legal Pages */
.legal-page{
  padding:160px 40px 80px;
  max-width:900px;
  margin:0 auto;
}
.legal-container h1{
  font-family:var(--font-serif);
  font-size:clamp(2rem,4vw,3.5rem);
  font-weight:500;
  margin:14px 0 8px;
  letter-spacing:-1px;
}
.legal-container h1 em{font-style:italic;color:var(--brown);}
.legal-container .updated{
  color:#888;
  font-size:0.85rem;
  margin-bottom:40px;
  font-family:var(--font-mont);
}
.legal-container h2{
  font-family:var(--font-serif);
  font-size:1.4rem;
  font-weight:500;
  margin:36px 0 14px;
  color:var(--black);
}
.legal-container p{
  color:#444;
  margin-bottom:14px;
  font-size:0.95rem;
}

/* ============================================
   Article Detail Pages
============================================ */
.article-page{
  background:var(--cream);
}
.article-hero{
  position:relative;
  height:70vh;
  min-height:500px;
  overflow:hidden;
  margin-top:0;
}
.article-hero-img{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  object-fit:cover;
  z-index:1;
}
.article-hero-overlay{
  position:absolute;
  inset:0;
  z-index:2;
  background:linear-gradient(to bottom,rgba(17,17,17,0.15) 0%,rgba(17,17,17,0.55) 70%,rgba(17,17,17,0.75) 100%);
  display:flex;
  align-items:flex-end;
  padding:80px 40px;
}
.article-hero-content{
  max-width:900px;
  margin:0 auto;
  width:100%;
  color:var(--white);
}
.article-hero-content .article-cat{
  color:var(--rose);
  font-family:var(--font-mont);
  font-size:0.8rem;
  letter-spacing:3px;
  text-transform:uppercase;
  display:inline-block;
  margin-bottom:18px;
  background:rgba(255,255,255,0.1);
  backdrop-filter:blur(10px);
  padding:8px 16px;
  border-radius:50px;
  border:1px solid rgba(255,255,255,0.2);
}
.article-hero-content h1{
  font-family:var(--font-serif);
  font-size:clamp(2.2rem,5vw,4.2rem);
  font-weight:500;
  line-height:1.1;
  letter-spacing:-1px;
  margin-bottom:18px;
  color:var(--white);
}
.article-hero-content h1 em{
  font-style:italic;
  color:var(--rose);
}
.article-meta{
  font-family:var(--font-mont);
  font-size:0.8rem;
  letter-spacing:2px;
  text-transform:uppercase;
  opacity:0.85;
  color:var(--cream);
}

.article-content{
  max-width:760px;
  margin:0 auto;
  padding:80px 40px 60px;
}
.article-content .lead{
  font-family:var(--font-serif);
  font-size:1.4rem;
  line-height:1.55;
  color:#333;
  font-style:italic;
  margin-bottom:40px;
  padding-bottom:32px;
  border-bottom:1px solid var(--beige);
}
.article-content h2{
  font-family:var(--font-serif);
  font-size:clamp(1.6rem,3vw,2.2rem);
  font-weight:500;
  margin:40px 0 18px;
  line-height:1.2;
  letter-spacing:-0.5px;
}
.article-content h2 em{
  font-style:italic;
  color:var(--brown);
}
.article-content p{
  font-size:1.05rem;
  line-height:1.85;
  color:#3a3a3a;
  margin-bottom:20px;
  font-family:var(--font-sans);
}
.article-content .feature-list{
  margin:24px 0 36px;
  background:rgba(255,255,255,0.5);
  border:1px solid var(--beige);
  border-radius:18px;
  padding:24px 28px;
}
.article-content .feature-list li{
  padding:14px 0 14px 28px;
  border-bottom:1px solid rgba(212,191,169,0.4);
  font-family:var(--font-poppins);
  font-size:1rem;
  color:#333;
}
.article-content .feature-list li:last-child{border-bottom:none;}
.article-content .feature-list li::before{
  content:'◆';
  color:var(--rose);
  left:4px;
}

.article-cta{
  margin-top:80px;
  padding-top:60px;
  border-top:1px solid var(--beige);
}
.article-cta .eyebrow{
  display:block;
  margin-bottom:10px;
}
.article-cta h3{
  font-family:var(--font-serif);
  font-size:1.8rem;
  font-weight:500;
  margin-bottom:30px;
}
.related-grid{
  display:grid;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
  gap:24px;
}

@media(max-width:700px){
  .article-hero{height:60vh;min-height:420px;}
  .article-hero-overlay{padding:40px 24px;}
  .article-content{padding:50px 24px 40px;}
  .article-content .lead{font-size:1.2rem;}
}

/* Section spacing tweaks */
@media(max-width:700px){
  .section{padding:60px 20px;}
  .hero{padding:120px 20px 60px;}
  .page-hero{padding:140px 20px 60px;}
  .header-container{padding:0 20px;}
  .site-footer{padding:60px 20px 30px;}
  .newsletter-box{padding:50px 24px;}
  .contact-form{padding:28px;}
}