@font-face { font-family:'Cormorant Garamond'; src:url('fonts/cg-300.woff2') format('woff2'); font-weight:300; font-style:normal; }
@font-face { font-family:'Cormorant Garamond'; src:url('fonts/cg-400.woff2') format('woff2'); font-weight:400; font-style:normal; }
@font-face { font-family:'Cormorant Garamond'; src:url('fonts/cg-500.woff2') format('woff2'); font-weight:500; font-style:normal; }
@font-face { font-family:'Cormorant Garamond'; src:url('fonts/cg-500-italic.woff2') format('woff2'); font-weight:500; font-style:italic; }
@font-face { font-family:'Cormorant Garamond'; src:url('fonts/cg-600.woff2') format('woff2'); font-weight:600; font-style:normal; }
@font-face { font-family:'Montserrat'; src:url('fonts/mt-300.woff2') format('woff2'); font-weight:300; font-style:normal; }
@font-face { font-family:'Montserrat'; src:url('fonts/mt-400.woff2') format('woff2'); font-weight:400; font-style:normal; }
@font-face { font-family:'Montserrat'; src:url('fonts/mt-500.woff2') format('woff2'); font-weight:500; font-style:normal; }
@font-face { font-family:'Montserrat'; src:url('fonts/mt-600.woff2') format('woff2'); font-weight:600; font-style:normal; }

:root{
  --ivoire:      #FBF8F2;
  --ivoire-2:    #F3ECE0;
  --paper:       #FFFFFF;
  --noir:        #221D17;
  --umbra:       #6B5A45;
  --or:          #A9814C;
  --or-deep:     #8C6B3E;
  --line:        rgba(34,29,23,0.12);
  --line-soft:   rgba(34,29,23,0.07);
  --max: 1180px;
}

*{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  font-family:'Montserrat',sans-serif;
  background:var(--ivoire);
  color:var(--noir);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}
.serif{font-family:'Cormorant Garamond',serif;}

.wrap{max-width:var(--max);margin:0 auto;padding:0 48px;}

.eyebrow{
  font-family:'Montserrat',sans-serif;
  font-weight:600;
  font-size:12.5px;
  letter-spacing:4px;
  text-transform:uppercase;
  color:var(--or-deep);
}

.hairline{width:56px;height:1px;background:var(--or);}

/* reveal-on-scroll */
.reveal{opacity:0;transform:translateY(28px);transition:opacity .9s cubic-bezier(.22,.61,.36,1), transform .9s cubic-bezier(.22,.61,.36,1);}
.reveal.in{opacity:1;transform:translateY(0);}
.reveal-delay-1{transition-delay:.1s;}
.reveal-delay-2{transition-delay:.2s;}
.reveal-delay-3{transition-delay:.3s;}

/* ---------- NAV ---------- */
.nav{
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:26px 48px;
  transition:background .4s ease, padding .4s ease, box-shadow .4s ease;
}
.nav.scrolled{
  background:rgba(251,248,242,0.92);
  backdrop-filter:blur(10px);
  padding:16px 48px;
  box-shadow:0 1px 0 var(--line);
}
.nav .brand img{height:30px;}
.nav ul{display:flex;gap:38px;list-style:none;}
.nav ul li a{
  font-size:12px; letter-spacing:1.8px; text-transform:uppercase;
  font-weight:500; color:var(--noir); opacity:.75;
  position:relative; padding-bottom:4px;
}
.nav ul li a:hover{opacity:1;}
.nav ul li a::after{
  content:''; position:absolute; left:0; bottom:0; width:0; height:1px; background:var(--or);
  transition:width .3s ease;
}
.nav ul li a:hover::after{width:100%;}
.nav .cta-btn{
  font-size:11.5px; letter-spacing:1.6px; text-transform:uppercase; font-weight:600;
  border:1px solid var(--noir); padding:11px 22px; color:var(--noir);
  transition:background .3s ease, color .3s ease;
}
.nav .cta-btn:hover{background:var(--noir); color:var(--ivoire);}
.nav-toggle{display:none;}

/* ---------- HERO ---------- */
.hero{
  position:relative; height:100vh; min-height:760px;
  display:flex; align-items:flex-end;
  overflow:hidden;
}
.hero-bg{
  position:absolute; inset:0;
  background-size:cover; background-position:center 28%;
  transform:scale(1.08);
  animation:heroin 2.2s cubic-bezier(.22,.61,.36,1) forwards;
}
@keyframes heroin{ to{ transform:scale(1); } }
.hero-scrim{
  position:absolute; inset:0;
  background:linear-gradient(180deg, rgba(20,16,12,0.18) 0%, rgba(20,16,12,0.02) 30%, rgba(15,12,9,0.55) 78%, rgba(12,10,7,0.78) 100%);
}
.hero-inner{
  position:relative; z-index:2; width:100%;
  padding:0 48px 96px 48px;
  display:flex; flex-direction:column; align-items:center; text-align:center;
}
.hero-eyebrow{
  color:#EBDFC7; font-size:13px; letter-spacing:5px; text-transform:uppercase; font-weight:500;
  margin-bottom:22px; opacity:0; animation:fadeup 1s ease .6s forwards;
}
.hero h1{
  font-family:'Cormorant Garamond',serif; font-weight:400;
  font-size:clamp(56px,9vw,118px); line-height:.98; letter-spacing:6px;
  color:#FFFDF8;
  opacity:0; animation:fadeup 1.1s ease .8s forwards;
}
.hero .sub{
  font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:500;
  font-size:clamp(18px,2.2vw,26px); color:#E7DCC7; margin-top:22px;
  opacity:0; animation:fadeup 1.1s ease 1.05s forwards;
}
@keyframes fadeup{ from{opacity:0; transform:translateY(18px);} to{opacity:1; transform:translateY(0);} }

.scrollcue{
  position:absolute; bottom:34px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:10px;
  color:#EFE6D2; z-index:2; opacity:0; animation:fadeup 1s ease 1.4s forwards;
}
.scrollcue .line{width:1px;height:40px;background:linear-gradient(180deg, rgba(239,230,210,.9), rgba(239,230,210,0));
  animation:scrolldown 1.8s ease-in-out infinite;}
@keyframes scrolldown{ 0%{transform:scaleY(0); transform-origin:top;} 50%{transform:scaleY(1); transform-origin:top;} 51%{transform-origin:bottom;} 100%{transform:scaleY(0); transform-origin:bottom;} }
.scrollcue span{font-size:10px; letter-spacing:3px; text-transform:uppercase;}

/* ---------- SECTION generic ---------- */
section{position:relative;}
.section-pad{padding:150px 0;}
.section-head{text-align:center; margin-bottom:70px;}
.section-head .eyebrow{display:block; margin-bottom:18px;}
.section-head h2{
  font-family:'Cormorant Garamond',serif; font-weight:400;
  font-size:clamp(36px,4.6vw,58px); line-height:1.15; color:var(--noir);
}
.section-head .lede{
  font-family:'Cormorant Garamond',serif; font-style:italic; font-size:22px;
  color:var(--umbra); margin-top:18px; max-width:560px; margin-left:auto; margin-right:auto;
}

/* ---------- INTRO ---------- */
.intro{background:var(--ivoire);}
.intro .grid{
  display:grid; grid-template-columns:1fr 1.15fr; gap:80px; align-items:center;
}
.intro .txt h2{
  font-family:'Cormorant Garamond',serif; font-weight:400; font-size:clamp(34px,3.8vw,48px);
  line-height:1.18; margin-bottom:28px;
}
.intro .txt p{
  font-family:'Cormorant Garamond',serif; font-size:21px; line-height:1.7;
  color:#3a3226; margin-bottom:20px; max-width:520px;
}
.intro .signoff{
  font-family:'Cormorant Garamond',serif; font-style:italic; font-weight:500; font-size:24px;
  margin-top:8px; color:var(--noir);
}
.intro .photo{position:relative;}
.intro .photo img{width:100%; height:620px; object-fit:cover; object-position:center 25%;}
.intro .photo .frame{
  position:absolute; top:22px; left:22px; right:-22px; bottom:-22px;
  border:1px solid var(--or); z-index:-1;
}
.intro .photo-wrap{position:relative; padding-right:22px; padding-bottom:22px;}

.stat-row{display:flex; gap:0; margin-top:56px; border-top:1px solid var(--line);}
.stat{flex:1; text-align:center; padding:28px 10px 0 10px; border-right:1px solid var(--line);}
.stat:last-child{border-right:none;}
.stat .n{font-family:'Cormorant Garamond',serif; font-size:38px; color:var(--or-deep);}
.stat .l{font-size:11px; letter-spacing:1.3px; text-transform:uppercase; color:var(--umbra); margin-top:6px; line-height:1.5;}

/* ---------- GALLERY ---------- */
.gallery{background:var(--paper);}
.gmasonry{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  grid-auto-rows:120px;
  gap:14px;
}
.gmasonry .g-item{overflow:hidden; position:relative;}
.gmasonry img{width:100%; height:100%; object-fit:cover; transition:transform .8s cubic-bezier(.22,.61,.36,1);}
.gmasonry .g-item:hover img{transform:scale(1.06);}
.g1{grid-column:1/4; grid-row:1/6;}
.g2{grid-column:4/7; grid-row:1/4;}
.g3{grid-column:4/6; grid-row:4/8;}
.g4{grid-column:6/7; grid-row:4/8;}
.g5{grid-column:1/3; grid-row:6/9;}
.g6{grid-column:3/4; grid-row:6/9;}

/* ---------- PACKAGES ---------- */
.packages{background:var(--ivoire-2);}
.pkg-grid{
  display:grid; grid-template-columns:repeat(4,1fr); gap:22px;
}
.pkg{
  background:var(--paper); border:1px solid var(--line); padding:40px 28px;
  display:flex; flex-direction:column;
  transition:transform .35s ease, box-shadow .35s ease, border-color .35s ease;
  position:relative;
}
.pkg:hover{ transform:translateY(-8px); box-shadow:0 26px 50px rgba(34,29,23,0.10); border-color:rgba(169,129,76,0.4); }
.pkg .tag{
  position:absolute; top:-13px; left:28px; background:var(--or); color:#fff;
  font-size:10.5px; letter-spacing:1.5px; text-transform:uppercase; font-weight:600;
  padding:6px 12px;
}
.pkg.feat{ background:var(--noir); border-color:var(--noir); }
.pkg.feat .name, .pkg.feat .price{color:var(--ivoire);}
.pkg.feat li{color:#DCD2C1;}
.pkg.feat li::before{background:var(--or);}
.pkg .name{
  font-family:'Cormorant Garamond',serif; font-weight:500; font-size:26px; letter-spacing:1px;
  margin-bottom:10px;
}
.pkg .price{
  font-family:'Cormorant Garamond',serif; font-size:34px; color:var(--or-deep); margin-bottom:22px;
}
.pkg .price sup{font-family:'Montserrat',sans-serif; font-size:12px; color:var(--umbra); font-weight:500;}
.pkg.feat .price sup{color:#B7A98C;}
.pkg ul{list-style:none; flex:1;}
.pkg li{
  font-size:13.5px; line-height:1.5; color:#3a3226; padding-left:16px; position:relative; margin-bottom:11px;
}
.pkg li::before{content:'';position:absolute; left:0; top:6px; width:5px; height:5px; border-radius:50%; background:var(--or);}
.pkg .cta{
  margin-top:26px; text-align:center; font-size:11.5px; letter-spacing:1.6px; text-transform:uppercase;
  font-weight:600; padding:13px; border:1px solid var(--noir); color:var(--noir);
  transition:background .3s ease, color .3s ease;
}
.pkg .cta:hover{background:var(--noir); color:var(--ivoire);}
.pkg.feat .cta{border-color:var(--or); color:var(--ivoire);}
.pkg.feat .cta:hover{background:var(--or); color:var(--noir);}

.pkg-note{
  text-align:center; margin-top:44px; font-size:12.5px; line-height:1.8; color:var(--umbra);
  max-width:720px; margin-left:auto; margin-right:auto;
}

/* ---------- ALBUM ---------- */
.album{background:var(--paper); overflow:hidden;}
.album .grid{display:grid; grid-template-columns:1fr 1fr; gap:70px; align-items:center;}
.album .txt p{
  font-family:'Cormorant Garamond',serif; font-size:21px; line-height:1.7; color:#3a3226; margin-bottom:20px; max-width:480px;
}
.album .feat-list{margin-top:30px; display:flex; flex-direction:column; gap:14px;}
.album .feat-list div{display:flex; align-items:center; gap:14px; font-size:14px; color:var(--noir);}
.album .feat-list .dot{width:6px;height:6px;background:var(--or);flex-shrink:0;}

.book-stage{
  perspective:2000px; display:flex; align-items:center; justify-content:center; height:560px;
}
.book{
  position:relative; width:380px; height:380px; transform-style:preserve-3d;
  transform:rotateY(-24deg) rotateX(4deg);
  transition:transform .6s ease;
}
.book-stage:hover .book{ transform:rotateY(-16deg) rotateX(2deg); }
.book .cover{
  position:absolute; width:380px; height:380px; overflow:hidden;
  box-shadow:0 50px 90px rgba(34,29,23,0.28);
  border:1px solid rgba(169,129,76,0.5);
  background:var(--paper);
}
.book .cover img{position:absolute; inset:18px; width:calc(100% - 36px); height:calc(100% - 36px); object-fit:cover;}
.book .cover .cap{
  position:absolute; bottom:30px; left:0; right:0; text-align:center;
  font-family:'Cormorant Garamond',serif; font-style:italic; font-size:16px; color:#fff;
  text-shadow:0 2px 10px rgba(0,0,0,.5); z-index:2;
}
.book .spine{
  position:absolute; width:40px; height:380px; left:-40px;
  background:linear-gradient(90deg, #d8cdb8, #f3ece0);
  transform:rotateY(90deg); transform-origin:right;
  box-shadow:inset -6px 0 12px rgba(34,29,23,0.12);
}
.book .edge{
  position:absolute; width:14px; height:372px; right:-14px; top:4px;
  background:repeating-linear-gradient(180deg,#f3ece0 0px,#e6dcc6 2px,#f3ece0 4px);
  transform:rotateY(-90deg); transform-origin:left;
}

/* ---------- WHY ---------- */
.why{background:var(--ivoire-2);}
.why-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:70px; align-items:center;}
.reasons{display:flex; flex-direction:column;}
.reason{
  display:flex; gap:20px; padding:26px 0; border-bottom:1px solid var(--line);
}
.reason:first-child{padding-top:0;}
.reason .ic{
  width:44px; height:44px; border:1px solid var(--or); border-radius:50%;
  display:flex; align-items:center; justify-content:center; flex-shrink:0;
  color:var(--or-deep); font-family:'Cormorant Garamond',serif; font-size:19px;
}
.reason .t b{display:block; font-size:16.5px; margin-bottom:4px; color:var(--noir);}
.reason .t span{font-size:14px; line-height:1.6; color:var(--umbra);}
.why-photos{display:grid; grid-template-columns:1fr 1fr; gap:14px;}
.why-photos img{width:100%; height:300px; object-fit:cover;}
.why-photos img:nth-child(1){height:420px; grid-column:1/2; grid-row:1/3;}
.why-photos img:nth-child(2){height:200px;}
.why-photos img:nth-child(3){height:200px;}

/* ---------- CTA ---------- */
.cta-section{
  position:relative; padding:190px 0; text-align:center; overflow:hidden;
}
.cta-bg{position:absolute; inset:0; background-size:cover; background-position:center 30%;}
.cta-scrim{position:absolute; inset:0; background:linear-gradient(180deg, rgba(15,12,9,.55), rgba(10,8,6,.82));}
.cta-section .content{position:relative; z-index:2;}
.cta-section .eyebrow{color:#E7D9B8;}
.cta-section h2{
  font-family:'Cormorant Garamond',serif; font-weight:400; font-size:clamp(40px,5.5vw,64px);
  color:#FFFDF8; margin:20px 0 22px 0;
}
.cta-section p{
  font-family:'Cormorant Garamond',serif; font-style:italic; font-size:22px; color:#E7DCC7;
  max-width:600px; margin:0 auto 42px auto; line-height:1.5;
}
.cta-buttons{display:flex; gap:18px; justify-content:center; flex-wrap:wrap;}
.btn{
  font-size:12px; letter-spacing:2px; text-transform:uppercase; font-weight:600;
  padding:17px 34px; transition:all .3s ease;
}
.btn-primary{background:var(--or); color:#1c1712;}
.btn-primary:hover{background:#c39a5e;}
.btn-outline{border:1px solid rgba(255,253,248,.6); color:#FFFDF8;}
.btn-outline:hover{background:rgba(255,253,248,.12);}

/* ---------- FOOTER ---------- */
footer{background:var(--noir); color:#CFC4AE; padding:70px 0 34px 0;}
footer .top{display:flex; justify-content:space-between; align-items:flex-start; flex-wrap:wrap; gap:40px; padding-bottom:50px; border-bottom:1px solid rgba(207,196,174,0.15);}
footer .top img{height:30px; margin-bottom:18px;}
footer .top .tagline{font-family:'Cormorant Garamond',serif; font-style:italic; font-size:18px; color:#B7A98C;}
footer .cols{display:flex; gap:70px;}
footer .col h4{font-size:11px; letter-spacing:2px; text-transform:uppercase; color:#8C7D63; margin-bottom:16px;}
footer .col div, footer .col a{display:block; font-size:14px; line-height:2; color:#CFC4AE;}
footer .bottom{display:flex; justify-content:space-between; padding-top:26px; font-size:11.5px; color:#7C6E58; flex-wrap:wrap; gap:10px;}

/* ---------- RESPONSIVE ---------- */
@media (max-width: 980px){
  .wrap{padding:0 26px;}
  .nav{padding:20px 26px;}
  .nav ul{display:none;}
  .intro .grid, .album .grid, .why-grid{grid-template-columns:1fr; gap:44px;}
  .intro .photo img{height:420px;}
  .pkg-grid{grid-template-columns:1fr 1fr;}
  .gmasonry{grid-template-columns:repeat(2,1fr); grid-auto-rows:160px;}
  .g1{grid-column:1/3; grid-row:1/3;}
  .g2{grid-column:1/2; grid-row:3/5;}
  .g3{grid-column:2/3; grid-row:3/5;}
  .g4{grid-column:1/2; grid-row:5/7;}
  .g5{grid-column:2/3; grid-row:5/7;}
  .g6{grid-column:1/3; grid-row:7/9;}
  .why-photos img:nth-child(1){height:260px;}
  footer .top{flex-direction:column;}
  footer .cols{gap:40px;}
}
@media (max-width: 620px){
  .pkg-grid{grid-template-columns:1fr;}
  .section-pad{padding:100px 0;}
  .stat-row{flex-direction:column;}
  .stat{border-right:none; border-bottom:1px solid var(--line); padding-bottom:20px;}
}
