/* ===== LOCAL FONT FACES ===== */
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-300-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 300;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-300-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-400-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-500-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: italic;
  font-weight: 500;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-500-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Cormorant Garamond';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('../fonts/cormorant-garamond-latin-600-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Questrial';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/questrial-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Libre Baskerville';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/libre-baskerville-latin-400-normal.woff2') format('woff2');
}
@font-face {
  font-family: 'Libre Baskerville';
  font-style: italic;
  font-weight: 400;
  font-display: swap;
  src: url('../fonts/libre-baskerville-latin-400-italic.woff2') format('woff2');
}
@font-face {
  font-family: 'Libre Baskerville';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url('../fonts/libre-baskerville-latin-700-normal.woff2') format('woff2');
}

/* ===== CSS RESET & VARIABLES ===== */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
:root{
  --cream:#FAF7F2;
  --warm-white:#FFFCF7;
  --blush:#F2E4D8;
  --rose:#D4A99A;
  --dusty-rose:#C19383;
  --sage:#B5BFA1;
  --deep-sage:#8A9A6E;
  --charcoal:#2C2C2C;
  --soft-black:#1A1A1A;
  --taupe:#A89888;
  --gold:#C8A96E;
  --light-gold:#E8D5A8;
  --font-display:'Cormorant Garamond', serif;
  --font-body:'Questrial', sans-serif;
  --font-accent:'Libre Baskerville', serif;
  --ease-smooth:cubic-bezier(0.25, 0.46, 0.45, 0.94);
  --ease-out-expo:cubic-bezier(0.19, 1, 0.22, 1);
}
html{scroll-behavior:smooth;font-size:16px;overflow-x:hidden}
body{
  font-family:var(--font-body);
  background:var(--cream);
  color:var(--charcoal);
  line-height:1.7;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
button{border:none;background:none;cursor:pointer;font-family:inherit}
ul{list-style:none}

/* ===== CUSTOM CURSOR ===== */
.cursor-dot{
  position:fixed;width:8px;height:8px;background:var(--dusty-rose);
  border-radius:50%;pointer-events:none;z-index:10000;
  transition:transform 0.15s var(--ease-smooth);
  mix-blend-mode:difference;
}
.cursor-ring{
  position:fixed;width:40px;height:40px;border:1.5px solid var(--dusty-rose);
  border-radius:50%;pointer-events:none;z-index:10000;
  transition:transform 0.3s var(--ease-smooth), width 0.3s, height 0.3s, border-color 0.3s;
  transform:translate(-50%,-50%);
}
.cursor-ring.hovering{width:60px;height:60px;border-color:var(--gold)}

/* ===== PAGE TRANSITION ===== */
.page-transition{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:var(--soft-black);z-index:9999;
  transform:scaleY(0);transform-origin:bottom;
}

/* ===== LOADER ===== */
.loader{
  position:fixed;top:0;left:0;width:100%;height:100%;
  background:var(--soft-black);z-index:10001;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
}
.loader-text{
  font-family:var(--font-display);font-size:clamp(2rem,5vw,4.5rem);
  color:var(--cream);font-weight:300;letter-spacing:0.15em;
  overflow:hidden;
}
.loader-text span{display:inline-block;transform:translateY(100%)}
.loader-line{width:0;height:1px;background:var(--gold);margin-top:2rem}
.loader-sub{
  font-family:var(--font-body);font-size:0.75rem;color:var(--taupe);
  letter-spacing:0.35em;text-transform:uppercase;margin-top:1.5rem;
  opacity:0;
}

/* ===== NAVIGATION ===== */
.nav{
  position:fixed;top:0;left:0;width:100%;z-index:1000;
  padding:1.5rem 3rem;
  display:flex;align-items:center;justify-content:space-between;
  transition:background 0.5s, padding 0.4s, backdrop-filter 0.5s;
}
.nav.scrolled{
  background:rgba(250,247,242,0.92);
  backdrop-filter:blur(20px);
  padding:1rem 3rem;
  box-shadow:0 1px 30px rgba(0,0,0,0.04);
}
.nav-logo{
  font-family:var(--font-display);font-size:1.6rem;font-weight:300;
  letter-spacing:0.08em;color:var(--charcoal);
  cursor:pointer;transition:color 0.3s;
}
.nav-logo em{font-style:italic;font-weight:400;color:var(--dusty-rose)}
.nav-links{display:flex;gap:2.5rem;align-items:center}
.nav-links a{
  font-size:0.72rem;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--charcoal);position:relative;padding:0.3rem 0;
  transition:color 0.3s;
}
.nav-links a::after{
  content:'';position:absolute;bottom:0;left:0;width:0;height:1px;
  background:var(--dusty-rose);transition:width 0.4s var(--ease-out-expo);
}
.nav-links a:hover::after{width:100%}
.nav-links a:hover{color:var(--dusty-rose)}
.nav-links a.nav-cta{
  font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;
  padding:0.7rem 2.8rem;border:1px solid var(--charcoal);
  transition:all 0.4s var(--ease-smooth);
  color:var(--charcoal);
}
.nav-links a.nav-cta:hover{background:var(--charcoal);color:var(--cream)}
.nav-links a.nav-cta::after{display:none}

/* --- NAV ON DARK HERO BACKGROUNDS (revertable) --- */
.nav.dark-hero .nav-logo{color:var(--cream)}
.nav.dark-hero .nav-logo em{color:var(--light-gold)}
.nav.dark-hero .nav-links a{color:rgba(250,247,242,0.85)}
.nav.dark-hero .nav-links a:hover{color:var(--cream)}
.nav.dark-hero .nav-links a::after{background:var(--light-gold)}
.nav.dark-hero .nav-links a.nav-cta{border-color:rgba(250,247,242,0.5);color:var(--cream)}
.nav.dark-hero .nav-links a.nav-cta:hover{background:var(--cream);color:var(--soft-black);border-color:var(--cream)}
.nav.dark-hero .nav-hamburger span{background:var(--cream)}
.nav.scrolled.dark-hero .nav-logo{color:var(--charcoal)}
.nav.scrolled.dark-hero .nav-logo em{color:var(--dusty-rose)}
.nav.scrolled.dark-hero .nav-links a{color:var(--charcoal)}
.nav.scrolled.dark-hero .nav-links a.nav-cta{border-color:var(--charcoal);color:var(--charcoal)}
.nav.scrolled.dark-hero .nav-links a.nav-cta:hover{background:var(--charcoal);color:var(--cream)}
.nav.scrolled.dark-hero .nav-hamburger span{background:var(--charcoal)}
/* --- END NAV DARK HERO --- */

/* Mobile Nav */
.nav-hamburger{
  display:none;flex-direction:column;gap:5px;cursor:pointer;
  z-index:1002;padding:5px;
}
.nav-hamburger span{
  width:25px;height:1.5px;background:var(--charcoal);
  transition:all 0.4s var(--ease-smooth);display:block;
}
.nav-hamburger.active span:nth-child(1){transform:rotate(45deg) translate(5px,4px)}
.nav-hamburger.active span:nth-child(2){opacity:0}
.nav-hamburger.active span:nth-child(3){transform:rotate(-45deg) translate(5px,-4px)}
.mobile-menu{
  position:fixed;top:0;right:-100%;width:100%;height:100vh;
  background:var(--cream);z-index:1001;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  gap:2rem;transition:right 0.6s var(--ease-out-expo);
}
.mobile-menu.open{right:0}
.mobile-menu a{
  font-family:var(--font-display);font-size:2rem;font-weight:300;
  letter-spacing:0.1em;color:var(--charcoal);
}
.mobile-menu-close{
  position:absolute;top:1.8rem;right:2rem;
  width:44px;height:44px;display:flex;align-items:center;justify-content:center;
  cursor:pointer;color:var(--charcoal);z-index:1003;
}
.mobile-menu-close svg{width:24px;height:24px;stroke:var(--charcoal);stroke-width:1.5;fill:none}

/* ===== SHARED STYLES ===== */
.section-tag{
  font-size:0.65rem;letter-spacing:0.35em;text-transform:uppercase;
  color:var(--taupe);display:flex;align-items:center;gap:1rem;
  margin-bottom:1.5rem;
}
.section-tag::before{content:'';width:40px;height:1px;background:var(--taupe)}
.section-title{
  font-family:var(--font-display);font-size:clamp(2.2rem,4.5vw,4rem);
  font-weight:300;line-height:1.15;color:var(--soft-black);
  margin-bottom:1.5rem;letter-spacing:0.02em;
}
.section-title em{font-style:italic;color:var(--dusty-rose)}
.btn-primary{
  display:inline-flex;align-items:center;gap:0.8rem;
  font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;
  padding:1rem 2.5rem;border:1px solid var(--charcoal);
  color:var(--charcoal);position:relative;overflow:hidden;
  transition:color 0.4s;background:transparent;
}
.btn-primary::before{
  content:'';position:absolute;top:0;left:0;width:100%;height:100%;
  background:var(--charcoal);transform:scaleX(0);transform-origin:right;
  transition:transform 0.5s var(--ease-out-expo);z-index:-1;
}
.btn-primary:hover::before{transform:scaleX(1);transform-origin:left}
.btn-primary:hover{color:var(--cream)}
.btn-primary svg{width:16px;height:16px;transition:transform 0.3s}
.btn-primary:hover svg{transform:translateX(4px)}
.btn-filled{
  display:inline-flex;align-items:center;gap:0.8rem;
  font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;
  padding:1rem 2.5rem;background:var(--charcoal);color:var(--cream);
  border:1px solid var(--charcoal);
  transition:all 0.4s var(--ease-smooth);
}
.btn-filled:hover{background:transparent;color:var(--charcoal)}
.arrow-svg{
  display:inline-block;width:14px;height:14px;
  fill:none;stroke:currentColor;stroke-width:1.5;
}

/* ===== SOCIAL FLOAT ===== */
.social-float{
  position:fixed;right:2rem;top:50%;transform:translateY(-50%);
  z-index:100;display:flex;flex-direction:column;gap:1.5rem;
}
.social-float a{
  width:38px;height:38px;display:flex;align-items:center;justify-content:center;
  border:1px solid rgba(44,44,44,0.15);border-radius:50%;
  transition:all 0.4s var(--ease-smooth);
  color:var(--charcoal);font-size:0.75rem;
}
.social-float a:hover{
  background:var(--charcoal);color:var(--cream);
  border-color:var(--charcoal);transform:scale(1.1);
}

/* ===== HOME PAGE ===== */
.hero{height:100vh;position:relative;overflow:hidden;display:flex;align-items:center}
.hero-bg{position:absolute;inset:0}
.hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(0.7);transform:scale(1.1)}
.hero-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(26,26,26,0.4) 0%,rgba(26,26,26,0.1) 50%,rgba(26,26,26,0.3) 100%)}
.hero-content{position:relative;z-index:2;padding:0 8%;max-width:900px}
.hero-tag{font-size:0.65rem;letter-spacing:0.4em;text-transform:uppercase;color:var(--light-gold);margin-bottom:2rem;display:flex;align-items:center;gap:1rem}
.hero-tag::before{content:'';width:50px;height:1px;background:var(--gold)}
.hero-title{font-family:var(--font-display);font-size:clamp(3rem,7vw,6.5rem);font-weight:300;line-height:1.05;color:var(--cream);margin-bottom:1.5rem;letter-spacing:0.02em}
.hero-title em{font-style:italic;color:var(--light-gold)}
.hero-subtitle{font-family:var(--font-accent);font-size:1rem;font-style:italic;color:rgba(250,247,242,0.75);margin-bottom:3rem;max-width:500px;line-height:1.8;font-weight:400}
.hero-btn{display:inline-flex;align-items:center;gap:1rem;font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;padding:1.1rem 2.8rem;border:1px solid rgba(250,247,242,0.5);color:var(--cream);transition:all 0.4s var(--ease-smooth);cursor:pointer}
.hero-btn:hover{background:var(--cream);color:var(--soft-black);border-color:var(--cream)}
.hero-scroll{position:absolute;bottom:3rem;left:50%;transform:translateX(-50%);display:flex;flex-direction:column;align-items:center;gap:0.8rem;color:rgba(250,247,242,0.6);font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;z-index:2}
.hero-scroll-line{width:1px;height:50px;background:linear-gradient(to bottom,var(--gold),transparent);animation:scrollPulse 2s ease-in-out infinite}
@keyframes scrollPulse{0%,100%{opacity:0.3;transform:scaleY(0.6)}50%{opacity:1;transform:scaleY(1)}}

.home-intro{padding:10rem 8%;display:grid;grid-template-columns:1fr 1fr;gap:6rem;align-items:center}
.home-intro-images{position:relative;height:600px}
.home-intro-img1{position:absolute;top:0;left:0;width:65%;height:75%;overflow:hidden}
.home-intro-img1 img{width:100%;height:100%;object-fit:cover}
.home-intro-img2{position:absolute;bottom:0;right:0;width:55%;height:55%;overflow:hidden;box-shadow:20px 20px 60px rgba(0,0,0,0.08);border:6px solid var(--cream)}
.home-intro-img2 img{width:100%;height:100%;object-fit:cover}
.home-intro-text p{font-size:0.95rem;color:#666;line-height:1.9;margin-bottom:2rem}
.home-intro-signature{font-family:var(--font-display);font-size:2rem;font-style:italic;color:var(--dusty-rose);margin-top:2rem}

.featured{padding:8rem 8%;background:var(--warm-white)}
.featured-header{text-align:center;margin-bottom:5rem}
.featured-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem}
.featured-item{position:relative;overflow:hidden;cursor:pointer;aspect-ratio:3/4}
.featured-item:nth-child(2){aspect-ratio:3/5}
.featured-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.8s var(--ease-out-expo)}
.featured-item:hover img{transform:scale(1.08)}
.featured-item-overlay{position:absolute;inset:0;background:linear-gradient(to top,rgba(26,26,26,0.7),transparent 50%);opacity:0;transition:opacity 0.5s;display:flex;align-items:flex-end;padding:2rem}
.featured-item:hover .featured-item-overlay{opacity:1}
.featured-item-label{color:var(--cream);font-family:var(--font-display);font-size:1.3rem;font-weight:300;letter-spacing:0.05em}
.featured-cta{text-align:center;margin-top:4rem}

.testimonials{padding:10rem 8%;position:relative;overflow:hidden}
.testimonials-bg{position:absolute;top:0;right:0;width:40%;height:100%;background:var(--blush);opacity:0.3}
.testimonial-slider{max-width:800px;margin:0 auto;text-align:center;position:relative}
.testimonial-quote{font-family:var(--font-display);font-size:clamp(1.4rem,2.5vw,2rem);font-weight:300;font-style:italic;line-height:1.7;color:var(--charcoal);margin-bottom:2.5rem}
.testimonial-quote::before{content:'\201C';display:block;font-size:5rem;color:var(--rose);line-height:0.6;margin-bottom:1rem;font-family:var(--font-display)}
.testimonial-author{font-size:0.7rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--taupe)}
.testimonial-dots{display:flex;gap:0.8rem;justify-content:center;margin-top:2.5rem}
.testimonial-dots button{width:8px;height:8px;border-radius:50%;background:var(--taupe);opacity:0.3;transition:all 0.3s}
.testimonial-dots button.active{opacity:1;background:var(--dusty-rose);transform:scale(1.3)}

.as-seen{padding:5rem 8%;border-top:1px solid rgba(0,0,0,0.06);text-align:center}
.as-seen-title{font-size:0.65rem;letter-spacing:0.35em;text-transform:uppercase;color:var(--taupe);margin-bottom:3rem}
.as-seen-logos{display:flex;align-items:center;justify-content:center;gap:4rem;flex-wrap:wrap;opacity:0.4}
.as-seen-logos span{font-family:var(--font-display);font-size:1.5rem;font-weight:400;color:var(--charcoal);letter-spacing:0.05em}

.insta-section{padding:6rem 0}
.insta-header{text-align:center;margin-bottom:3rem}
.insta-handle{font-family:var(--font-display);font-size:1.3rem;font-style:italic;color:var(--dusty-rose);margin-top:0.5rem}
.insta-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:4px}
.insta-grid-item{aspect-ratio:1;overflow:hidden;cursor:pointer;position:relative}
.insta-grid-item img{width:100%;height:100%;object-fit:cover;transition:transform 0.6s var(--ease-out-expo)}
.insta-grid-item:hover img{transform:scale(1.1)}
.insta-grid-item::after{content:'';position:absolute;inset:0;background:rgba(193,147,131,0.3);opacity:0;transition:opacity 0.3s}
.insta-grid-item:hover::after{opacity:1}

/* ===== ABOUT PAGE ===== */
.about-hero{height:70vh;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center;text-align:center}
.about-hero-bg{position:absolute;inset:0}
.about-hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(0.55)}
.about-hero-content{position:relative;z-index:2}
.about-hero-content h1{font-family:var(--font-display);font-size:clamp(3rem,6vw,5rem);font-weight:300;color:var(--cream);letter-spacing:0.05em}
.about-hero-content p{font-family:var(--font-accent);font-style:italic;font-size:1rem;color:rgba(250,247,242,0.7);margin-top:1rem}

.about-story{padding:8rem 8%;display:grid;grid-template-columns:1fr 1.2fr;gap:6rem;align-items:center}
.about-portrait{position:relative}
.about-portrait img{width:100%;aspect-ratio:3/4;object-fit:cover}
.about-portrait-frame{position:absolute;top:-20px;left:-20px;right:20px;bottom:20px;border:1px solid var(--rose);pointer-events:none}
.about-text h2{font-family:var(--font-display);font-size:2.5rem;font-weight:300;margin-bottom:2rem;line-height:1.3}
.about-text h2 em{font-style:italic;color:var(--dusty-rose)}
.about-text p{font-size:0.95rem;color:#666;line-height:1.9;margin-bottom:1.5rem}

.about-values{padding:6rem 8%;background:var(--warm-white)}
.about-values-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:3rem;margin-top:4rem}
.about-value{text-align:center;padding:2rem}
.about-value-num{font-family:var(--font-display);font-size:3rem;color:var(--rose);font-weight:300;margin-bottom:1rem}
.about-value h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400;margin-bottom:1rem}
.about-value p{font-size:0.9rem;color:#888;line-height:1.8}

.about-fun{padding:8rem 8%}
.about-fun-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:4rem;margin-top:3rem}
.about-fun-item{display:flex;gap:1.5rem;align-items:flex-start}
.about-fun-icon{width:50px;height:50px;min-width:50px;border-radius:50%;background:var(--blush);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:1.2rem;color:var(--dusty-rose)}
.about-fun-item h4{font-family:var(--font-display);font-size:1.2rem;font-weight:400;margin-bottom:0.5rem}
.about-fun-item p{font-size:0.85rem;color:#888;line-height:1.7}

/* ===== PORTFOLIO PAGE ===== */
.portfolio-hero{padding:12rem 8% 4rem;text-align:center}
.portfolio-filters{display:flex;gap:1.5rem;justify-content:center;margin-top:3rem;flex-wrap:wrap}
.portfolio-filter{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;padding:0.6rem 1.5rem;border:1px solid transparent;color:var(--taupe);transition:all 0.3s;cursor:pointer;background:none}
.portfolio-filter.active,.portfolio-filter:hover{border-color:var(--charcoal);color:var(--charcoal)}
.portfolio-masonry{padding:4rem 4%;columns:3;column-gap:1.2rem}
.portfolio-item{break-inside:avoid;margin-bottom:1.2rem;overflow:hidden;position:relative;cursor:pointer}
.portfolio-item img{width:100%;display:block;transition:transform 0.7s var(--ease-out-expo)}
.portfolio-item:hover img{transform:scale(1.05)}
.portfolio-item-info{position:absolute;bottom:0;left:0;right:0;padding:2rem;background:linear-gradient(to top,rgba(26,26,26,0.75),transparent);transform:translateY(100%);transition:transform 0.5s var(--ease-out-expo)}
.portfolio-item:hover .portfolio-item-info{transform:translateY(0)}
.portfolio-item-info h3{font-family:var(--font-display);font-size:1.4rem;font-weight:300;color:var(--cream)}
.portfolio-item-info p{font-size:0.7rem;color:rgba(250,247,242,0.6);letter-spacing:0.15em;text-transform:uppercase;margin-top:0.3rem}

.lightbox{position:fixed;inset:0;background:rgba(26,26,26,0.95);z-index:9998;display:none;align-items:center;justify-content:center;opacity:0}
.lightbox.open{display:flex}
.lightbox img{max-width:85%;max-height:85vh;object-fit:contain}
.lightbox-close{position:absolute;top:2rem;right:2rem;color:var(--cream);font-size:1.5rem;cursor:pointer;width:50px;height:50px;display:flex;align-items:center;justify-content:center;border:1px solid rgba(250,247,242,0.3);border-radius:50%;transition:all 0.3s}
.lightbox-close:hover{background:var(--cream);color:var(--soft-black)}

/* ===== INVESTMENT PAGE ===== */
.invest-hero{padding:12rem 8% 4rem;text-align:center}
.invest-intro{max-width:700px;margin:0 auto;font-family:var(--font-accent);font-style:italic;font-size:1.05rem;color:#888;line-height:1.9;margin-top:1.5rem}
.invest-packages{padding:5rem 8%;display:grid;grid-template-columns:repeat(3,1fr);gap:2rem}
.invest-card{background:var(--warm-white);padding:3rem;border:1px solid rgba(0,0,0,0.05);transition:all 0.4s var(--ease-smooth);position:relative;overflow:hidden}
.invest-card::before{content:'';position:absolute;top:0;left:0;width:100%;height:3px;background:var(--rose);transform:scaleX(0);transform-origin:left;transition:transform 0.5s var(--ease-out-expo)}
.invest-card:hover::before{transform:scaleX(1)}
.invest-card:hover{box-shadow:0 20px 60px rgba(0,0,0,0.06);transform:translateY(-5px)}
.invest-card.featured{background:var(--soft-black);color:var(--cream);border-color:transparent}
.invest-card.featured::before{background:var(--gold)}
.invest-card-tag{font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--taupe);margin-bottom:1rem}
.invest-card.featured .invest-card-tag{color:var(--light-gold)}
.invest-card h3{font-family:var(--font-display);font-size:2rem;font-weight:300;margin-bottom:0.5rem}
.invest-card .price{font-family:var(--font-display);font-size:2.5rem;font-weight:400;color:var(--dusty-rose);margin-bottom:2rem}
.invest-card.featured .price{color:var(--light-gold)}
.invest-card ul{margin-bottom:2.5rem}
.invest-card li{font-size:0.85rem;color:#888;padding:0.6rem 0;border-bottom:1px solid rgba(0,0,0,0.04);display:flex;align-items:center;gap:0.8rem}
.invest-card.featured li{color:rgba(250,247,242,0.6);border-color:rgba(255,255,255,0.06)}
.invest-card li::before{content:'✦';font-size:0.5rem;color:var(--rose)}
.invest-card.featured li::before{color:var(--gold)}
.invest-card .btn-primary{width:100%;justify-content:center;margin-top:auto}
.invest-card.featured .btn-primary{border-color:var(--cream);color:var(--cream)}
.invest-card.featured .btn-primary::before{background:var(--cream)}
.invest-card.featured .btn-primary:hover{color:var(--soft-black)}
.invest-note{padding:5rem 8%;text-align:center}
.invest-note p{max-width:600px;margin:0 auto;font-size:0.9rem;color:#888;line-height:1.9}
.invest-note-highlight{font-family:var(--font-display);font-size:1.8rem;font-weight:300;color:var(--charcoal);margin-bottom:1.5rem}

/* ===== BLOG PAGE ===== */
.blog-hero{padding:12rem 8% 4rem;text-align:center}
.blog-grid{padding:4rem 8%;display:grid;grid-template-columns:repeat(3,1fr);gap:2.5rem}
.blog-card{cursor:pointer;transition:transform 0.4s var(--ease-smooth);display:block}
.blog-card:hover{transform:translateY(-5px)}
.blog-card-img{aspect-ratio:4/3;overflow:hidden;margin-bottom:1.5rem}
.blog-card-img img{width:100%;height:100%;object-fit:cover;transition:transform 0.7s var(--ease-out-expo)}
.blog-card:hover .blog-card-img img{transform:scale(1.06)}
.blog-card-cat{font-size:0.6rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--dusty-rose);margin-bottom:0.8rem;display:inline-block}
.blog-card h3{font-family:var(--font-display);font-size:1.5rem;font-weight:400;line-height:1.4;margin-bottom:0.8rem}
.blog-card p{font-size:0.85rem;color:#888;line-height:1.7;margin-bottom:1rem}
.blog-card-date{font-size:0.7rem;color:var(--taupe);letter-spacing:0.1em}
.blog-pagination{display:flex;gap:0.5rem;justify-content:center;padding:3rem}
.blog-pagination button{width:40px;height:40px;font-size:0.8rem;border:1px solid rgba(0,0,0,0.1);display:flex;align-items:center;justify-content:center;transition:all 0.3s;color:var(--charcoal)}
.blog-pagination button.active,.blog-pagination button:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal)}

/* ===== BLOG POST PAGE ===== */
.post-hero{height:60vh;position:relative;overflow:hidden;display:flex;align-items:flex-end}
.post-hero-bg{position:absolute;inset:0}
.post-hero-bg img{width:100%;height:100%;object-fit:cover;filter:brightness(0.5)}
.post-hero-content{position:relative;z-index:2;padding:4rem 8%;max-width:800px}
.post-hero-cat{font-size:0.6rem;letter-spacing:0.3em;text-transform:uppercase;color:var(--light-gold);margin-bottom:1rem}
.post-hero-content h1{font-family:var(--font-display);font-size:clamp(2.5rem,4vw,3.5rem);font-weight:300;color:var(--cream);line-height:1.2;margin-bottom:1rem}
.post-hero-meta{font-size:0.75rem;color:rgba(250,247,242,0.6);letter-spacing:0.1em}
.post-content{max-width:750px;margin:0 auto;padding:5rem 2rem}
.post-content p{font-size:1rem;color:#555;line-height:2;margin-bottom:1.8rem;font-family:var(--font-accent);font-size:0.95rem}
.post-content h2{font-family:var(--font-display);font-size:2rem;font-weight:400;margin:3rem 0 1.5rem;color:var(--charcoal)}
.post-content blockquote{font-family:var(--font-display);font-size:1.6rem;font-style:italic;color:var(--dusty-rose);border-left:2px solid var(--rose);padding-left:2rem;margin:2.5rem 0;line-height:1.6;font-weight:300}
.post-content-img{width:calc(100% + 6rem);margin:2rem -3rem;overflow:hidden}
.post-content-img img{width:100%;aspect-ratio:16/9;object-fit:cover}
.post-tags{display:flex;gap:0.8rem;flex-wrap:wrap;padding-top:2rem;border-top:1px solid rgba(0,0,0,0.06)}
.post-tag{font-size:0.65rem;letter-spacing:0.15em;text-transform:uppercase;padding:0.4rem 1rem;border:1px solid rgba(0,0,0,0.1);color:var(--taupe)}
.post-share{display:flex;gap:1rem;align-items:center;margin-top:2rem}
.post-share span{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe)}
.post-share a{width:36px;height:36px;border:1px solid rgba(0,0,0,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:0.7rem;transition:all 0.3s;color:var(--charcoal)}
.post-share a:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal)}

/* ===== CONTACT PAGE ===== */
.contact-hero{padding:12rem 8% 4rem;text-align:center}
.contact-section{padding:4rem 8% 8rem;display:grid;grid-template-columns:1fr 1fr;gap:6rem}
.contact-info h3{font-family:var(--font-display);font-size:1.8rem;font-weight:300;margin-bottom:2rem}
.contact-detail{display:flex;gap:1rem;align-items:flex-start;margin-bottom:2rem}
.contact-detail-icon{width:40px;height:40px;min-width:40px;border-radius:50%;background:var(--blush);display:flex;align-items:center;justify-content:center;font-size:0.8rem;color:var(--dusty-rose)}
.contact-detail h4{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:0.3rem}
.contact-detail p{font-size:0.95rem;color:var(--charcoal)}
.contact-social{margin-top:3rem}
.contact-social h4{font-size:0.7rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:1rem}
.contact-social-links{display:flex;gap:1rem}
.contact-social-links a{width:44px;height:44px;border:1px solid rgba(0,0,0,0.1);border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all 0.3s;font-size:0.8rem;color:var(--charcoal)}
.contact-social-links a:hover{background:var(--charcoal);color:var(--cream);border-color:var(--charcoal)}
.contact-form{background:var(--warm-white);padding:3rem;border:1px solid rgba(0,0,0,0.04)}
.form-group{margin-bottom:1.5rem}
.form-group label{display:block;font-size:0.65rem;letter-spacing:0.2em;text-transform:uppercase;color:var(--taupe);margin-bottom:0.6rem}
.form-group input,.form-group textarea,.form-group select{width:100%;padding:0.9rem 0;border:none;border-bottom:1px solid rgba(0,0,0,0.1);background:transparent;font-family:var(--font-body);font-size:0.9rem;color:var(--charcoal);outline:none;transition:border-color 0.3s}
.form-group input:focus,.form-group textarea:focus,.form-group select:focus{border-color:var(--dusty-rose)}
.form-group textarea{resize:vertical;min-height:120px}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}

/* ===== PRIVACY & TERMS PAGES ===== */
.legal-hero{padding:12rem 8% 4rem;text-align:center}
.legal-content{max-width:800px;margin:0 auto;padding:4rem 2rem 6rem}
.legal-content h2{font-family:var(--font-display);font-size:1.8rem;font-weight:400;margin:2.5rem 0 1rem;color:var(--charcoal)}
.legal-content p{font-size:0.9rem;color:#666;line-height:1.9;margin-bottom:1.2rem}
.legal-content ul{margin:1rem 0 1.5rem 1.5rem;list-style:disc}
.legal-content li{font-size:0.9rem;color:#666;line-height:1.8;margin-bottom:0.3rem}
.legal-updated{font-size:0.75rem;color:var(--taupe);letter-spacing:0.1em;margin-top:3rem;padding-top:2rem;border-top:1px solid rgba(0,0,0,0.06)}

/* ===== FOOTER ===== */
.footer{background:var(--soft-black);color:var(--cream);padding:6rem 8% 3rem}
.footer-top{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:4rem;padding-bottom:4rem;border-bottom:1px solid rgba(255,255,255,0.06)}
.footer-brand h3{font-family:var(--font-display);font-size:2rem;font-weight:300;letter-spacing:0.05em;margin-bottom:1rem}
.footer-brand h3 em{font-style:italic;color:var(--rose)}
.footer-brand p{font-size:0.85rem;color:rgba(250,247,242,0.4);line-height:1.8;max-width:320px}
.footer-col h4{font-size:0.65rem;letter-spacing:0.25em;text-transform:uppercase;color:var(--taupe);margin-bottom:1.5rem}
.footer-col a{display:block;font-size:0.85rem;color:rgba(250,247,242,0.5);padding:0.35rem 0;transition:color 0.3s}
.footer-col a:hover{color:var(--cream)}
.footer-bottom{display:flex;justify-content:space-between;align-items:center;padding-top:2rem}
.footer-bottom p{font-size:0.7rem;color:rgba(250,247,242,0.3);letter-spacing:0.1em}
.footer-bottom-links{display:flex;gap:2rem}
.footer-bottom-links a{font-size:0.65rem;color:rgba(250,247,242,0.3);letter-spacing:0.15em;text-transform:uppercase;transition:color 0.3s}
.footer-bottom-links a:hover{color:var(--cream)}

/* ===== REVEAL ANIMATIONS ===== */
.reveal{opacity:0;transform:translateY(40px);transition:all 0.8s var(--ease-out-expo)}
.reveal.visible{opacity:1;transform:translateY(0)}
.reveal-left{opacity:0;transform:translateX(-40px);transition:all 0.8s var(--ease-out-expo)}
.reveal-left.visible{opacity:1;transform:translateX(0)}
.reveal-right{opacity:0;transform:translateX(40px);transition:all 0.8s var(--ease-out-expo)}
.reveal-right.visible{opacity:1;transform:translateX(0)}
.reveal-scale{opacity:0;transform:scale(0.95);transition:all 0.8s var(--ease-out-expo)}
.reveal-scale.visible{opacity:1;transform:scale(1)}

/* ===== RESPONSIVE ===== */
@media(max-width:1024px){
  .nav-links{display:none}
  .nav-hamburger{display:flex}
  .home-intro{grid-template-columns:1fr;gap:3rem}
  .home-intro-images{height:400px}
  .featured-grid{grid-template-columns:1fr 1fr}
  .about-story{grid-template-columns:1fr;gap:3rem}
  .about-values-grid{grid-template-columns:1fr 1fr}
  .invest-packages{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr 1fr}
  .contact-section{grid-template-columns:1fr}
  .portfolio-masonry{columns:2}
  .footer-top{grid-template-columns:1fr 1fr}
  .social-float{display:none}
  .insta-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:600px){
  .nav{padding:1rem 1.5rem}
  .hero-content{padding:0 5%}
  .featured-grid{grid-template-columns:1fr}
  .about-values-grid{grid-template-columns:1fr}
  .about-fun-grid{grid-template-columns:1fr}
  .portfolio-masonry{columns:1}
  .blog-grid{grid-template-columns:1fr}
  .form-row{grid-template-columns:1fr}
  .footer-top{grid-template-columns:1fr;gap:2rem}
  .footer-bottom{flex-direction:column;gap:1rem;text-align:center}
  .insta-grid{grid-template-columns:repeat(2,1fr)}
  .post-content-img{width:100%;margin-left:0;margin-right:0}
}
