/* ══════════════════════════════════════
   Samsara — Peisagistică & Design Grădini
   ══════════════════════════════════════ */

:root {
  --padure:  #3D5A3A;
  --sienna:  #8B6F47;
  --ocru:    #C4A265;
  --nisip:   #D4C5A0;
  --in:      #F5F0E6;
  --carbune: #2C2C2C;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
@media (prefers-reduced-motion: no-preference) { html { scroll-behavior: smooth; } }
body {
  background: var(--in);
  color: var(--carbune);
  font-family: var(--font-jost), sans-serif;
  font-weight: 300;
  line-height: 1.7;
  overflow-x: hidden;
}
img { display: block; width: 100%; height: 100%; object-fit: cover; }

/* GRAIN */
body::after {
  content: '';
  position: fixed; inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
  pointer-events: none; z-index: 9999; opacity: 0.3;
}

/* ── NAV ── */
nav {
  position: fixed; top: 0; left: 0; right: 0; z-index: 500;
  display: flex; justify-content: space-between; align-items: center;
  padding: 1.4rem 4rem;
  background: linear-gradient(to bottom, rgba(0,0,0,0.45) 0%, transparent 100%);
  transition: background 0.4s, box-shadow 0.4s, padding 0.4s;
}
nav.scrolled {
  background: rgba(245,240,230,0.96);
  box-shadow: 0 1px 0 rgba(44,44,44,0.08);
  padding: 0.9rem 4rem;
  backdrop-filter: blur(10px);
}
.nav-logo { text-decoration: none; display: flex; align-items: center; gap: 0.7rem; }
.nav-logo-img { height: 44px; width: 44px; object-fit: contain; opacity: 0.7; }
img.nav-logo-green { display: none; }
nav.scrolled img.nav-logo-white { display: none; }
nav.scrolled img.nav-logo-green { display: block; }
nav.scrolled .nav-logo-img { height: 40px; width: 40px; }
.nav-logo-text { font-family: var(--font-cormorant), serif; font-size: 1.15rem; font-weight: 400; letter-spacing: 0.04em; color: var(--in); transition: color 0.3s; }
nav.scrolled .nav-logo-text { color: var(--padure); }
.nav-links { display: flex; gap: 2.5rem; list-style: none; }
.nav-links a {
  font-size: 0.82rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 400;
  color: rgba(245,240,230,0.95); text-decoration: none; transition: color 0.3s;
}
nav.scrolled .nav-links a { color: rgba(44,44,44,0.6); }
.nav-links a:hover, .nav-links a.active { color: var(--ocru) !important; }
.nav-cta {
  font-size: 0.82rem; letter-spacing: 0.14em; text-transform: uppercase; font-weight: 400;
  padding: 0.6rem 1.6rem; border: 1px solid rgba(245,240,230,0.6);
  color: var(--in); text-decoration: none; transition: all 0.3s;
}
nav.scrolled .nav-cta { border-color: var(--padure); color: var(--padure); }
.nav-cta:hover { background: var(--ocru); border-color: var(--ocru); color: var(--carbune); }
.hamburger { display: none; }

/* ── HERO ── */
.hero {
  height: 100vh; min-height: 680px;
  position: relative; overflow: hidden;
  display: flex; align-items: flex-end;
}
.hero-bg {
  position: absolute; inset: 0;
  background: url('/assets/images/hero.webp') center/cover no-repeat;
  transform: scale(1.06);
  animation: heroZoom 14s ease-out forwards;
}
@keyframes heroZoom { to { transform: scale(1); } }
.hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(20,20,18,0.95) 0%, rgba(25,25,22,0.75) 45%, rgba(30,30,25,0.5) 75%, rgba(30,30,25,0.4) 100%);
}
.hero-content {
  position: relative; z-index: 2;
  padding: 0 4rem 5.5rem; width: 100%;
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: end; gap: 4rem;
}
.hero-left h1 {
  font-family: var(--font-cormorant), serif;
  font-size: clamp(3.5rem, 6.5vw, 6rem);
  font-weight: 300; line-height: 1; color: var(--in);
  margin-bottom: 1.5rem;
  animation: fadeUp 1s 0.3s both;
}
.hero-left h1 em { font-style: italic; color: var(--ocru); }
.hero-badges { display: flex; gap: 1rem; flex-wrap: wrap; animation: fadeUp 1s 0.5s both; }
.badge {
  font-size: 0.65rem; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 0.4rem 0.9rem; border: 1px solid rgba(196,162,101,0.5); color: var(--nisip);
}
.hero-right { animation: fadeUp 1s 0.7s both; text-align: right; }
.hero-right p {
  font-family: var(--font-cormorant), serif;
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  font-style: italic; color: rgba(245,240,230,0.82); line-height: 1.65; margin-bottom: 1.5rem;
}
.hero-right a {
  display: inline-block; padding: 1rem 2.8rem;
  background: var(--ocru); color: var(--carbune);
  font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none; font-weight: 500; transition: background 0.3s, transform 0.3s;
}
.hero-right a:hover { background: var(--nisip); transform: translateY(-2px); }

/* ── STATS BAR ── */
.stats {
  background: var(--padure);
  display: grid; grid-template-columns: repeat(4,1fr);
  border-top: 1px solid rgba(196,162,101,0.15);
}
.stat {
  padding: 2.2rem 2.5rem;
  border-right: 1px solid rgba(255,255,255,0.07);
  display: flex; flex-direction: column; gap: 0.3rem;
}
.stat:last-child { border-right: none; }
.stat-num {
  font-family: var(--font-cormorant), serif;
  font-size: 2.7rem; font-weight: 300; line-height: 1; color: var(--ocru);
}
.stat-label { font-size: 0.68rem; letter-spacing: 0.15em; text-transform: uppercase; color: rgba(245,240,230,0.5); }

/* ── SHARED ── */
.section-label {
  font-size: 0.68rem; letter-spacing: 0.25em; text-transform: uppercase;
  color: var(--sienna); margin-bottom: 1.5rem;
  display: flex; align-items: center; gap: 1rem;
}
/* Lines only on .section-label--lines */
.section-label--lines::before, .section-label--lines::after {
  content: ''; width: 28px; height: 1px; background: var(--sienna); flex-shrink: 0;
}
.display {
  font-family: var(--font-cormorant), serif;
  font-size: clamp(2.4rem, 4.5vw, 3.8rem);
  font-weight: 300; line-height: 1.1; color: var(--padure);
}
.display em { font-style: italic; color: var(--sienna); }
.see-all {
  font-size: 0.72rem; letter-spacing: 0.15em; text-transform: uppercase;
  color: var(--sienna); text-decoration: none;
  display: flex; align-items: center; gap: 0.6rem; white-space: nowrap;
  transition: gap 0.3s;
}
.see-all:hover { gap: 1.2rem; }
.see-all::after { content: '\2192'; }

/* ── PORTFOLIO ── */
.portfolio { padding: 7rem 4rem; background: var(--in); }
.portfolio-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 3.5rem; }
.p-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(44,44,44,0.75) 0%, transparent 55%);
  opacity: 0; transition: opacity 0.4s;
  display: flex; flex-direction: column; justify-content: flex-end; padding: 1.5rem;
}
.p-item:hover .p-overlay, .p-scroll-item:hover .p-overlay { opacity: 1; }
.p-overlay h3 { font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-weight:400; color:var(--in); margin-bottom:0.2rem; }
.p-overlay span { font-size:0.62rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--ocru); }

/* ── PORTFOLIO HORIZONTAL SCROLL ── */
.portfolio-scroll {
  margin-bottom: 12px;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
  scrollbar-color: var(--nisip) transparent;
  scroll-snap-type: x mandatory;
}
.portfolio-scroll::-webkit-scrollbar { height: 6px; }
.portfolio-scroll::-webkit-scrollbar-track { background: transparent; }
.portfolio-scroll::-webkit-scrollbar-thumb { background: var(--nisip); border-radius: 3px; }
.portfolio-scroll-track {
  display: flex;
  gap: 12px;
  width: max-content;
  align-items: stretch;
  height: 320px;
}
.p-scroll-item {
  position: relative;
  height: 100%;
  flex-shrink: 0;
  overflow: hidden;
  cursor: pointer;
  background: var(--nisip);
  scroll-snap-align: start;
}
.p-scroll-item img {
  width: 100%; height: 100%; object-fit: cover;
  transition: transform 0.7s cubic-bezier(0.25,0.46,0.45,0.94), filter 0.5s;
  filter: saturate(0.82);
}
.p-scroll-item:hover img { transform: scale(1.06); filter: saturate(1); }
.p-scroll-item.sz-wide { width: 480px; }
.p-scroll-item.sz-normal { width: 360px; }
.p-scroll-item.sz-portrait { width: 240px; }
.p-scroll-item.sz-large { width: 520px; }

/* ── BEFORE/AFTER ── */
.ba-section { padding: 7rem 4rem; background: var(--nisip); }
.ba-header { text-align: center; margin-bottom: 4rem; }
.ba-header p { font-size: 0.85rem; opacity: 0.6; font-style: italic; }
.ba-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.ba-card-label {
  font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--sienna); margin-bottom: 0.8rem; text-align: center;
}
.ba-slider-wrap {
  position: relative; height: 380px; overflow: hidden; cursor: col-resize; user-select: none;
}
.ba-img-after { position: absolute; inset: 0; background-size: cover; background-position: center; }
.ba-img-before {
  position: absolute; inset: 0;
  background-size: cover; background-position: center;
  clip-path: inset(0 50% 0 0);
}
.ba-divider {
  position: absolute; top: 0; bottom: 0; left: 50%; width: 2px;
  background: var(--in); transform: translateX(-50%); pointer-events: none; z-index: 2;
}
.ba-handle {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  width: 44px; height: 44px; border-radius: 50%;
  background: var(--in); display: flex; align-items: center; justify-content: center;
  box-shadow: 0 2px 14px rgba(0,0,0,0.25); pointer-events: none; z-index: 3;
  font-size: 0.9rem; color: var(--padure); font-weight: 600;
}
.ba-tags {
  position: absolute; bottom: 12px; left: 12px; right: 12px;
  display: flex; justify-content: space-between; z-index: 2; pointer-events: none;
}
.ba-tag {
  font-size: 0.6rem; letter-spacing: 0.15em; text-transform: uppercase;
  padding: 0.3rem 0.7rem; background: rgba(44,44,44,0.62); color: var(--in);
  backdrop-filter: blur(4px);
}
.ba-desc { margin-top: 0.8rem; font-size: 0.8rem; text-align: center; opacity: 0.6; font-style: italic; }

/* ── ABOUT ── */
.about { padding: 7rem 4rem; background: var(--in); }
.about-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 6rem; align-items: start; }
.about-img-col { position: relative; }
.about-photo-main { width: 100%; height: 520px; overflow: hidden; background: var(--nisip); }
.about-photo-accent {
  position: absolute; bottom: -40px; right: -32px;
  width: 200px; height: 200px; overflow: hidden;
  border: 6px solid var(--in); background: var(--nisip);
}
.about-year-badge {
  position: absolute; top: 28px; left: -24px;
  background: var(--padure); padding: 1.2rem 1.5rem; text-align: center; z-index: 1;
}
.about-year-badge .y { font-family:'Cormorant Garamond',serif; font-size:2.2rem; color:var(--ocru); line-height:1; }
.about-year-badge .yl { font-size:0.6rem; letter-spacing:0.15em; text-transform:uppercase; color:rgba(245,240,230,0.55); }
.about-text { padding-top: 0.5rem; }
.about-text .display { margin-bottom: 2rem; }
.about-text p { font-size:1rem; line-height:1.9; opacity:0.8; margin-bottom:1.3rem; }
.about-text > p:first-of-type::first-letter {
  font-family:'Cormorant Garamond',serif; font-size:3.5rem; font-weight:400;
  float:left; line-height:0.85; margin-right:0.08em; margin-top:0.1em; color:var(--padure);
}
.pull-quote p::first-letter {
  font-family:'Cormorant Garamond',serif !important; font-size:1.2rem !important; font-weight:400 !important;
  float:none !important; line-height:inherit !important; margin:0 !important; color:var(--padure) !important;
}
.pull-quote {
  margin: 2rem 0; padding: 1.5rem 2rem;
  border-left: 2px solid var(--ocru); background: rgba(196,162,101,0.07);
}
.pull-quote p {
  font-family:'Cormorant Garamond',serif; font-size:1.2rem; font-style:italic;
  color:var(--padure); opacity:1 !important; line-height:1.55; margin:0 !important;
}
.pull-quote p::first-letter { all:unset; }

/* ── SAMSARA BAND ── */
.samsara-band {
  background: var(--padure); padding: 5rem 4rem; text-align: center; position: relative; overflow: hidden;
}
.samsara-band-bg {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-family:'Cormorant Garamond',serif; font-size:11rem; color:rgba(245,240,230,0.04);
  white-space: nowrap; pointer-events: none; font-style: italic; line-height:1;
}
.samsara-band .section-label { justify-content:center; color:var(--ocru); }
.samsara-band .section-label--lines::before, .samsara-band .section-label--lines::after { background:var(--ocru); }
.samsara-band-text {
  font-family:'Cormorant Garamond',serif; font-size:clamp(1.8rem,3.5vw,2.6rem);
  font-style:italic; color:var(--in); max-width:620px; margin:0 auto 1rem; position:relative; line-height:1.5;
}
.samsara-band-sub { font-size:0.88rem; color:rgba(245,240,230,0.5); max-width:420px; margin:0 auto; position:relative; }

/* ── ALEXANDRA ── */
.alexandra { padding: 7rem 4rem; background: var(--nisip); }
.alex-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.alex-text .display { margin-bottom: 2.5rem; }
.alex-text p { font-size:1rem; line-height:1.9; opacity:0.8; margin-bottom:1.2rem; }
.alex-sig { font-family:'Cormorant Garamond',serif; font-style:italic; font-size:1.05rem; color:var(--sienna); margin-top:1.5rem; opacity:1 !important; }
.alex-sig::first-letter { all:unset; }
.alex-visual { display: flex; flex-direction: column; gap: 0.8rem; }
.alex-drawing {
  border: 1px solid rgba(61,90,58,0.18); padding: 0.5rem;
  background: rgba(245,240,230,0.5);
}
.alex-drawing img { width: 100%; height: 260px; object-fit: cover; display: block; }
.alex-note { font-family:'Cormorant Garamond',serif; font-size:1.05rem; font-style:italic; color:var(--sienna); text-align:center; margin-top:0.8rem; }

/* ── SERVICES ── */
.services { padding: 7rem 4rem; background: var(--padure); }
.services .section-label { color: var(--ocru); }
.services .section-label::before, .services .section-label::after { background: var(--ocru); }
.services-head {
  display: grid; grid-template-columns: 1fr 1fr;
  align-items: end; gap: 4rem; margin-bottom: 4rem;
}
.services .display { color: var(--in); }
.services .display em { color: var(--ocru); }
.services-intro { font-size: 0.92rem; color: rgba(245,240,230,0.5); line-height: 1.85; max-width: 380px; }
.srv-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: rgba(255,255,255,0.08);
}
.srv-item {
  background: var(--padure);
  padding: 2.8rem 2rem 2.2rem;
  display: flex; flex-direction: column; gap: 1.8rem;
  position: relative; overflow: hidden;
  transition: background 0.4s;
  cursor: default;
}
.srv-item::after {
  content: '';
  position: absolute; bottom: 0; left: 0; right: 0; height: 2px;
  background: var(--ocru);
  transform: scaleX(0); transform-origin: left;
  transition: transform 0.4s cubic-bezier(0.25,0.46,0.45,0.94);
}
.srv-item:hover { background: rgba(255,255,255,0.04); }
.srv-item:hover::after { transform: scaleX(1); }
.srv-item:hover .srv-icon-wrap i, .srv-item:hover .srv-icon-wrap svg { color: var(--ocru); stroke: var(--ocru); }
.srv-icon-wrap {
  width: 56px; height: 56px;
  display: flex; align-items: center; justify-content: center;
}
.srv-icon-wrap i, .srv-icon-wrap svg { color: rgba(255,255,255,0.55); stroke: rgba(255,255,255,0.55); transition: color 0.4s, stroke 0.4s; }
.srv-body { display: flex; flex-direction: column; gap: 0.6rem; flex: 1; }
.srv-n {
  font-family: var(--font-cormorant), serif;
  font-size: 4.5rem; font-weight: 300; line-height: 1;
  color: rgba(255,255,255,0.03);
  position: absolute; bottom: 1rem; right: 1.2rem;
  pointer-events: none; user-select: none;
  transition: color 0.4s;
}
.srv-item:hover .srv-n { color: rgba(196,162,101,0.06); }
.srv-name { font-size: 1.05rem; color: rgba(245,240,230,0.88); line-height: 1.6; font-weight: 400; }
.srv-cta {
  background: rgba(0,0,0,0.15);
  padding: 2.8rem 2rem 2.2rem;
  display: flex; flex-direction: column; justify-content: space-between;
  position: relative;
}
.srv-cta-quote {
  font-family: var(--font-cormorant), serif; font-style: italic;
  font-size: 1.2rem; color: rgba(245,240,230,0.75); line-height: 1.6;
}
.srv-cta a {
  display: inline-flex; align-items: center; gap: 0.6rem;
  font-size: 0.7rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ocru); text-decoration: none; margin-top: 1.5rem;
  transition: gap 0.3s;
}
.srv-cta a:hover { gap: 1rem; }

/* ── TESTIMONIALS ── */
.testimonials { padding: 7rem 4rem; background: var(--nisip); }
.testi-header { margin-bottom: 3.5rem; }
.testi-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1.5rem;
}
.testi-card {
  background: var(--in);
  padding: 2.5rem 2.2rem;
  position: relative;
  display: flex; flex-direction: column; justify-content: space-between;
  border-bottom: 2px solid transparent;
  transition: border-color 0.35s, transform 0.35s, box-shadow 0.35s;
}
.testi-card:hover {
  border-bottom-color: var(--ocru);
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(61,90,58,0.1);
}
.testi-card-top { margin-bottom: 1.8rem; }
.testi-stars { color:var(--ocru); font-size:0.8rem; margin-bottom:1.2rem; letter-spacing:0.12em; }
.testi-quote {
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-style:italic;
  line-height:1.7; color:var(--padure);
}
.testi-mark {
  position:absolute; top:1rem; right:1.8rem;
  font-family:'Cormorant Garamond',serif; font-size:5rem; line-height:1;
  color:rgba(61,90,58,0.06); font-style:italic; pointer-events:none;
}
.testi-author {
  display:flex; align-items:center; gap:0.9rem;
  padding-top:1.5rem;
  border-top: 1px solid rgba(212,197,160,0.6);
}
.testi-av {
  width:40px; height:40px; border-radius:50%;
  background:var(--padure); display:flex; align-items:center; justify-content:center;
  font-family:'Cormorant Garamond',serif; font-size:1.1rem; font-style:italic;
  color:var(--ocru); flex-shrink:0;
}
.testi-name { font-size:0.82rem; font-weight:500; color:var(--carbune); }
.testi-loc { font-size:0.68rem; opacity:0.5; margin-top:0.1rem; }

/* ── ADD REVIEW CARD ── */
.testi-add {
  cursor: pointer;
  border: 1px dashed rgba(61,90,58,0.25) !important;
  background: transparent !important;
  display: flex; align-items: center; justify-content: center;
  min-height: 220px;
  transition: border-color 0.3s, background 0.3s !important;
}
.testi-add:hover { border-color: var(--ocru) !important; background: rgba(196,162,101,0.05) !important; transform: none !important; box-shadow: none !important; }
.testi-add:hover .testi-add-icon i { color: var(--ocru); }
.testi-add-inner { text-align: center; display: flex; flex-direction: column; align-items: center; gap: 0.8rem; }
.testi-add-icon i { color: var(--nisip); transition: color 0.3s; }
.testi-add-title { font-family: var(--font-cormorant), serif; font-size: 1.15rem; font-style: italic; color: var(--padure); }
.testi-add-sub { font-size: 0.78rem; opacity: 0.55; max-width: 180px; line-height: 1.5; }

/* ── SECTION LABEL CENTERED ── */
.section-label--centered {
  justify-content: center;
  color: var(--ocru);
}
.section-label--lines.section-label--centered::before,
.section-label--lines.section-label--centered::after { background: var(--ocru); }

/* ── TESTIMONIALS CTA BANNER ── */
.testi-cta-banner {
  margin-top: 3rem;
  background: var(--padure);
  padding: 4rem 4rem;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.testi-cta-banner-bg {
  position: absolute; top: 50%; left: 50%; transform: translate(-50%,-50%);
  font-family:'Cormorant Garamond',serif; font-size:11rem; color:rgba(245,240,230,0.04);
  white-space: nowrap; pointer-events: none; font-style: italic; line-height:1;
  user-select: none;
}
.testi-cta-quote {
  font-family: var(--font-cormorant), serif;
  font-size: clamp(1.2rem, 2vw, 1.5rem);
  font-style: italic;
  color: var(--in);
  line-height: 1.6;
  max-width: 520px;
  margin: 0 auto 2rem;
  position: relative;
}
.testi-cta-btn {
  display: inline-block;
  padding: 1rem 2.8rem;
  background: var(--ocru);
  color: var(--carbune);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  text-decoration: none;
  font-weight: 500;
  position: relative;
  transition: background 0.3s, transform 0.3s;
}
.testi-cta-btn:hover { background: var(--nisip); transform: translateY(-2px); }
@media(max-width:900px){
  .testi-cta-banner { padding: 3.5rem 1.5rem; }
}

/* ── REVIEW MODAL ── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(44,44,44,0.65); backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none; transition: opacity 0.35s;
}
.modal-overlay.open { opacity: 1; pointer-events: all; }
.modal {
  background: var(--in); width: 100%; max-width: 520px; margin: 1.5rem;
  padding: 3rem; position: relative;
  transform: translateY(20px);
  transition: transform 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
}
.modal-overlay.open .modal { transform: translateY(0); }
.modal-close {
  position: absolute; top: 1.2rem; right: 1.2rem;
  background: none; border: none; cursor: pointer;
  color: var(--sienna); opacity: 0.6; transition: opacity 0.2s;
  display: flex; align-items: center; justify-content: center; padding: 0.3rem;
}
.modal-close:hover { opacity: 1; }
.modal-label { font-size: 0.68rem; letter-spacing: 0.25em; text-transform: uppercase; color: var(--sienna); margin-bottom: 0.5rem; }
.modal h3 { font-family: var(--font-cormorant), serif; font-size: 1.9rem; font-weight: 300; color: var(--padure); margin-bottom: 1.8rem; line-height: 1.2; }
.modal h3 em { font-style: italic; color: var(--sienna); }
.star-picker { display: flex; gap: 0.3rem; margin-bottom: 1.2rem; }
.star-picker span { font-size: 1.7rem; cursor: pointer; color: rgba(212,197,160,0.5); transition: color 0.15s; line-height: 1; }
.star-picker span.lit { color: var(--ocru); }
.modal .form-group { display: flex; flex-direction: column; gap: 0.4rem; margin-bottom: 1rem; }
.modal .form-group label { font-size: 0.62rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--sienna); }
.modal .form-group input,
.modal .form-group textarea { font-family: var(--font-jost), sans-serif; font-size: 0.9rem; font-weight: 300; color: var(--carbune); padding: 0.85rem 1rem; background: transparent; border: 1px solid var(--nisip); outline: none; transition: border-color 0.3s; resize: none; }
.modal .form-group input:focus,
.modal .form-group textarea:focus { border-color: var(--padure); }
.modal-submit {
  width: 100%; padding: 1rem; background: var(--padure); border: none; cursor: pointer;
  font-family: var(--font-jost), sans-serif; font-size: 0.75rem; letter-spacing: 0.2em;
  text-transform: uppercase; color: var(--in); transition: background 0.3s; margin-top: 0.5rem;
}
.modal-submit:hover { background: var(--carbune); }
.modal-submit:disabled { opacity: 0.4; cursor: not-allowed; }
.modal-submit:disabled:hover { background: var(--padure); }
.modal-success { text-align: center; padding: 1rem 0; display: none; flex-direction: column; align-items: center; gap: 1rem; }

/* Toast notification */
.toast-notification {
  position: fixed; bottom: 2rem; right: 2rem; z-index: 10000;
  background: var(--padure); color: var(--in);
  padding: 1rem 1.8rem; font-size: 0.85rem; letter-spacing: 0.04em;
  box-shadow: 0 4px 20px rgba(0,0,0,0.25);
  animation: toastIn 0.35s ease, toastOut 0.35s ease 3.5s forwards;
}
@keyframes toastIn { from { opacity:0; transform:translateY(20px); } to { opacity:1; transform:translateY(0); } }
@keyframes toastOut { from { opacity:1; transform:translateY(0); } to { opacity:0; transform:translateY(20px); } }
.modal-success p { font-family: var(--font-cormorant), serif; font-size: 1.4rem; font-style: italic; color: var(--padure); line-height: 1.5; }

/* ── BLOG ── */
.blog { padding: 7rem 4rem; background: var(--nisip); }
.blog-header { display: flex; justify-content: space-between; align-items: flex-end; margin-bottom: 3.5rem; }
.blog-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 1.5rem; }
.blog-card { background: var(--in); overflow: hidden; cursor: pointer; display: block; }
.blog-img { height: 220px; overflow: hidden; background: var(--padure); }
.blog-img img { transition: transform 0.6s ease; }
.blog-card:hover .blog-img img { transform: scale(1.05); }
.blog-body { padding: 1.8rem; }
.blog-cat { font-size:0.62rem; letter-spacing:0.18em; text-transform:uppercase; color:var(--sienna); margin-bottom:0.6rem; }
.blog-title { font-family:'Cormorant Garamond',serif; font-size:1.3rem; font-weight:400; line-height:1.35; color:var(--padure); margin-bottom:0.8rem; }
.blog-excerpt { font-size:0.82rem; opacity:0.65; line-height:1.7; margin-bottom:1.2rem; }
.blog-read { font-size:0.68rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--sienna); text-decoration:none; display:flex; align-items:center; gap:0.5rem; transition:gap 0.3s; }
.blog-read:hover { gap:1rem; }
.blog-read::after { content:'\2192'; }
.blog-meta { font-size:0.65rem; opacity:0.4; margin-top:0.4rem; }

/* ── CONTACT ── */
.contact { background: var(--in); }
.contact-grid { display: grid; grid-template-columns: 1fr 1fr; }
.contact-info {
  background: var(--carbune); padding: 6rem 4rem;
  display: flex; flex-direction: column; justify-content: space-between;
}
.contact-info .section-label { color:var(--ocru); }
.contact-info .section-label::before, .contact-info .section-label::after { background:var(--ocru); }
.contact-info .display { color:var(--in); margin-bottom:3rem; }
.contact-info .display em { color:var(--ocru); }
.contact-details { display:flex; flex-direction:column; gap:1.5rem; }
.contact-item { display:flex; align-items:flex-start; gap:1rem; }
.contact-icon { font-size:1.1rem; flex-shrink:0; margin-top:0.15rem; color:var(--ocru); }
.contact-icon svg { stroke:var(--ocru); }
.contact-val { font-size:0.88rem; color:rgba(245,240,230,0.7); line-height:1.5; }
.contact-val strong { display:block; font-size:0.62rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--ocru); margin-bottom:0.2rem; font-weight:400; }
.contact-social { display:flex; gap:0.8rem; margin-top:2.5rem; }
.social-link {
  width:38px; height:38px; border:1px solid rgba(255,255,255,0.15);
  display:flex; align-items:center; justify-content:center;
  color:rgba(245,240,230,0.55); font-size:0.75rem; text-decoration:none;
  transition:all 0.3s; font-weight:500;
}
.social-link:hover { border-color:var(--ocru); color:var(--ocru); }
.contact-form-col { padding: 6rem 4rem; }
.contact-form-col .section-label { margin-bottom:2rem; }
.form-row { display:grid; grid-template-columns:1fr 1fr; gap:1rem; margin-bottom:1rem; }
.form-group { display:flex; flex-direction:column; gap:0.4rem; margin-bottom:1rem; }
.form-group label { font-size:0.62rem; letter-spacing:0.15em; text-transform:uppercase; color:var(--sienna); }
.form-group input,
.form-group select,
.form-group textarea {
  font-family:'Jost',sans-serif; font-size:0.9rem; font-weight:300; color:var(--carbune);
  padding:0.85rem 1rem; background:transparent; border:1px solid var(--nisip);
  outline:none; transition:border-color 0.3s; resize:none;
}
.form-group input:focus, .form-group select:focus, .form-group textarea:focus { border-color:var(--padure); }
.form-group input:-webkit-autofill,
.form-group input:-webkit-autofill:hover,
.form-group input:-webkit-autofill:focus { -webkit-box-shadow:0 0 0 1000px var(--in) inset; -webkit-text-fill-color:var(--carbune); transition:background-color 5000s ease-in-out 0s; }
.form-group select {
  cursor:pointer; appearance:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' fill='none'%3E%3Cpath d='M1 1l4 4 4-4' stroke='%238B6F47' stroke-width='1.2'/%3E%3C/svg%3E");
  background-repeat:no-repeat; background-position:right 1rem center;
}
.form-submit {
  width:100%; padding:1.1rem; background:var(--padure); border:none; cursor:pointer;
  font-family:'Jost',sans-serif; font-size:0.75rem; letter-spacing:0.2em; text-transform:uppercase;
  color:var(--in); font-weight:400; transition:background 0.3s, transform 0.2s; margin-top:0.5rem;
}
.form-submit:disabled { background:rgba(44,62,45,0.35); cursor:not-allowed; transform:none; }
.form-submit:disabled:hover { background:rgba(44,62,45,0.35); transform:none; }
.form-submit:hover:not(:disabled) { background:var(--carbune); transform:translateY(-1px); }
.form-note { font-size:0.7rem; opacity:0.45; text-align:center; margin-top:0.8rem; font-style:italic; }

/* ── FOOTER ── */
footer { background: var(--padure); padding: 3.5rem 4rem 2rem; }
.footer-top {
  display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 4rem;
  margin-bottom: 3rem; padding-bottom: 3rem; border-bottom: 1px solid rgba(255,255,255,0.1);
}
.footer-brand p { font-family:'Cormorant Garamond',serif; font-size:2rem; font-style:italic; color:var(--in); margin-bottom:0.8rem; }
.footer-logo-wrap { display: flex; align-items: center; gap: 0.8rem; margin-bottom: 1rem; }
.footer-logo-img { height: 48px !important; width: 48px !important; object-fit: contain; opacity: 0.4; flex-shrink: 0; }
.footer-logo-text { font-family: var(--font-cormorant), serif; font-size: 1.6rem; font-weight: 300; font-style: italic; color: var(--in); opacity: 0.4; }
.footer-brand small { font-size:1.05rem; color:rgba(245,240,230,0.4); line-height:1.8; display:block; }
.footer-col h4 { font-size:0.75rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--ocru); margin-bottom:1.2rem; }
.footer-col ul { list-style:none; display:flex; flex-direction:column; gap:0.6rem; }
.footer-col ul a { font-size:0.92rem; color:rgba(245,240,230,0.5); text-decoration:none; transition:color 0.3s; }
.footer-col ul a:hover { color:var(--in); }
.footer-bottom { display:flex; justify-content:space-between; align-items:center; }
.footer-bottom span { font-size:0.95rem; color:rgba(245,240,230,0.28); }

/* ── ANIMATIONS ── */
@keyframes fadeUp { from { opacity:0; transform:translateY(28px); } to { opacity:1; transform:translateY(0); } }
.fade-up { opacity:0; transform:translateY(28px); transition:opacity 0.75s ease, transform 0.75s ease; }
.fade-up.visible { opacity:1; transform:translateY(0); }
.fade-up.d1 { transition-delay:0.1s; }
.fade-up.d2 { transition-delay:0.2s; }
.fade-up.d3 { transition-delay:0.3s; }

/* ── BLOG PAGE ── */
.blog-page { padding: 6rem 4rem 5rem; background: var(--in); min-height: 100vh; }
.blog-page-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1.5rem; }
.blog-pagination { display: flex; justify-content: center; gap: 0.5rem; margin-top: 3rem; }
.blog-pagination a, .blog-pagination span {
  padding: 0.6rem 1rem; font-size: 0.75rem; letter-spacing: 0.1em;
  text-decoration: none; border: 1px solid var(--nisip); color: var(--sienna);
  transition: all 0.3s;
}
.blog-pagination .active { background: var(--padure); color: var(--in); border-color: var(--padure); }
.blog-pagination a:hover { background: var(--ocru); color: var(--carbune); border-color: var(--ocru); }

/* ── SINGLE POST ── */
.post-page { padding: 8rem 4rem 5rem; background: var(--in); min-height: 100vh; }
.post-container { max-width: 720px; margin: 0 auto; }
.post-back { font-size: 0.72rem; letter-spacing: 0.15em; text-transform: uppercase; color: var(--sienna); text-decoration: none; display: inline-flex; align-items: center; gap: 0.5rem; margin-bottom: 2rem; }
.post-back::before { content: '\2190'; }
.post-hero-img { height: 400px; overflow: hidden; margin-bottom: 2.5rem; background: var(--nisip); }
.post-cat { font-size: 0.62rem; letter-spacing: 0.18em; text-transform: uppercase; color: var(--sienna); margin-bottom: 0.8rem; }
.post-title { font-family: var(--font-cormorant), serif; font-size: clamp(2rem, 4vw, 3rem); font-weight: 300; color: var(--padure); line-height: 1.2; margin-bottom: 1rem; }
.post-meta { font-size: 0.72rem; opacity: 0.5; margin-bottom: 2.5rem; }
.post-content { font-size: 1rem; line-height: 1.9; }
.post-content p { margin-bottom: 1.3rem; opacity: 0.85; }
.post-content h2 { font-family: var(--font-cormorant), serif; font-size: 1.6rem; font-weight: 400; color: var(--padure); margin: 2rem 0 1rem; }
.post-content h3 { font-size: 1.1rem; font-weight: 500; margin: 1.5rem 0 0.8rem; }
.post-content img { margin: 1.5rem 0; }
.post-content blockquote { border-left: 2px solid var(--ocru); padding: 1rem 1.5rem; margin: 1.5rem 0; background: rgba(196,162,101,0.07); font-style: italic; }

/* ── RESPONSIVE ── */
@media(max-width:1100px){
  .portfolio-grid{ grid-template-rows:260px 220px; }
  .srv-grid{ grid-template-columns:repeat(2,1fr); }
  .testi-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-top{ grid-template-columns:1fr 1fr; gap:2.5rem; }
}
@media(max-width:900px){
  nav{ padding:1.2rem 1.5rem; }
  nav.scrolled{ padding:0.9rem 1.5rem; }
  .nav-links{ display:none; position:fixed; top:0; left:0; right:0; bottom:0; background:var(--padure); flex-direction:column; align-items:center; justify-content:center; gap:2.5rem; z-index:600; }
  .nav-links.open{ display:flex; }
  .nav-links.open a{ color:var(--in) !important; font-size:1.1rem; font-weight:400; letter-spacing:0.18em; }
  nav.menu-open{ background:var(--padure) !important; box-shadow:none !important; backdrop-filter:none !important; }
  nav.menu-open .nav-logo-img{ filter:none !important; }
  .nav-cta{ display:none; }
  .nav-cta.mobile-show{ display:block; }
  .hamburger{ display:flex; flex-direction:column; gap:5px; cursor:pointer; z-index:700; padding:0.5rem; }
  .hamburger span{ width:24px; height:2px; background:var(--in); transition:all 0.3s; }
  nav.scrolled .hamburger span{ background:var(--padure); }
  .hamburger.open span:nth-child(1){ transform:rotate(45deg) translate(5px,5px); }
  .hamburger.open span:nth-child(2){ opacity:0; }
  .hamburger.open span:nth-child(3){ transform:rotate(-45deg) translate(5px,-5px); }
  .hamburger.open span{ background:var(--in) !important; }
  .hero-content{ grid-template-columns:1fr; padding:0 1.5rem 4rem; gap:2rem; }
  .hero-right{ text-align:left; }
  .stats{ grid-template-columns:repeat(2,1fr); }
  .portfolio,.ba-section,.about,.alexandra,.services,.testimonials,.blog{ padding:4.5rem 1.5rem; }
  .samsara-band{ padding:3.5rem 1.5rem; }
  .samsara-band-bg { font-size: 4rem; }
  .testi-cta-banner-bg { font-size: 4rem; }
  .portfolio-header,.blog-header{ flex-direction:column; align-items:flex-start; gap:1rem; }
  .portfolio-grid{ grid-template-columns:1fr 1fr; grid-template-rows:auto; }
  .p-item:nth-child(n){ grid-column:auto; grid-row:auto; height:200px; }
  .ba-grid,.about-grid,.alex-grid,.contact-grid,.blog-grid,.testi-grid{ grid-template-columns:1fr; }
  .about-photo-accent{ width:170px; height:170px; bottom:-28px; right:-8px; border-width:4px; }
  .alex-drawing:nth-child(2){ display:none; }
  .contact-info,.contact-form-col{ padding:3.5rem 1.5rem; }
  .form-row{ grid-template-columns:1fr; }
  .blog-page{ padding:6rem 1.5rem 3rem; }
  .blog-page-grid{ grid-template-columns:1fr; }
  .post-page{ padding:6rem 1.5rem 3rem; }
}
@media(max-width:580px){
  .srv-grid{ grid-template-columns:repeat(2,1fr); }
  .srv-item{ pointer-events:none; }
  .srv-item:hover{ background:var(--padure); }
  .srv-item:hover::after{ transform:scaleX(0); }
  .footer-top{ grid-template-columns:1fr; }
  .footer-bottom{ flex-direction:column; gap:0.3rem; text-align:center; }
  .stats{ grid-template-columns:1fr 1fr; }
}

/* ══════════════════════════════════════
   PACKAGES PAGE
   ══════════════════════════════════════ */

/* ── PAGE HEADER ── */
.page-header {
  padding: 9rem 4rem 6rem;
  background: var(--padure);
  position: relative; overflow: hidden;
}
.page-header::before {
  content: '';
  position: absolute; top: -100px; right: -100px;
  width: 500px; height: 500px; border-radius: 50%;
  background: rgba(196,162,101,0.07);
  pointer-events: none;
}
.page-header-inner {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 5rem; align-items: end; position: relative;
}
.page-header .section-label { color: var(--ocru); }
.page-header .section-label::before, .page-header .section-label::after { background: var(--ocru); }
.page-header .display { color: var(--in); }
.page-header .display em { color: var(--ocru); }
.page-header-note { color: rgba(245,240,230,0.55); font-size: 0.95rem; margin-top: 0.8rem; }
.page-header-right p {
  font-size: 1.05rem; line-height: 1.9; font-weight: 300;
  color: rgba(245,240,230,0.75); max-width: 420px;
}
.page-header-right p + p { margin-top: 1rem; }

/* ── PACKAGES SECTION ── */
.packages { padding: 7rem 4rem; background: var(--in); }
.packages-intro {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: 5rem; align-items: end;
  padding-bottom: 5rem;
  border-bottom: 1px solid var(--nisip);
  margin-bottom: 5rem;
}
.packages-intro-right {
  font-size: 1.05rem; line-height: 1.9; font-weight: 300;
  color: rgba(44,44,44,0.75);
}

.pkg {
  display: grid;
  grid-template-columns: 1fr 1px 1fr;
  gap: 0; margin-bottom: 0;
  border: 1px solid var(--nisip);
}
.pkg + .pkg { border-top: none; }
.pkg-divider { background: var(--nisip); }

.pkg-left {
  padding: 4rem;
  display: flex; flex-direction: column; gap: 2rem;
  position: relative;
}
.pkg-right {
  padding: 4rem;
  display: flex; flex-direction: column; gap: 1.5rem;
  border-left: 1px solid var(--nisip);
}

.pkg-eyebrow {
  font-size: 0.8rem; letter-spacing: 0.22em; text-transform: uppercase;
  color: var(--sienna); font-weight: 400;
}
.pkg-name {
  font-family: var(--font-cormorant), serif;
  font-size: clamp(2.2rem, 3.5vw, 3rem); font-weight: 300; line-height: 1;
  color: var(--padure);
}
.pkg-name em { font-style: italic; }
.pkg-tagline {
  font-size: 1.1rem; line-height: 1.85; font-weight: 300;
  color: rgba(44,44,44,0.8); max-width: 420px;
}

.pkg-prices {
  display: grid; grid-template-columns: repeat(3,1fr);
  gap: 0; border: 1px solid var(--nisip); margin-top: auto;
}
.price-col {
  padding: 1.5rem 1.2rem;
  border-right: 1px solid var(--nisip);
  transition: background 0.3s; cursor: default;
}
.price-col:last-child { border-right: none; }
.price-col:hover { background: rgba(196,162,101,0.06); }
.price-col .label-sm {
  font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--sienna); margin-bottom: 0.3rem; font-weight: 400;
}
.price-col .sqm { font-size: 0.82rem; color: rgba(44,44,44,0.45); font-style: italic; margin-bottom: 0.7rem; }
.price-col .amount {
  font-family: var(--font-cormorant), serif;
  font-size: 1.8rem; font-weight: 300; line-height: 1; color: var(--padure);
}
.price-col .currency { font-family: var(--font-jost), sans-serif; font-size: 0.82rem; color: rgba(44,44,44,0.55); margin-top: 0.2rem; }

.pkg-action { display: flex; align-items: center; gap: 2rem; margin-top: 0.5rem; }
.pkg-btn {
  display: inline-block; padding: 1rem 2.5rem;
  font-family: var(--font-jost), sans-serif; font-size: 0.78rem; letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none; transition: all 0.3s; font-weight: 400;
}
.pkg-btn.outline { border: 1px solid var(--padure); color: var(--padure); }
.pkg-btn.outline:hover { background: var(--padure); color: var(--in); }
.pkg-btn.solid { background: var(--padure); color: var(--in); border: 1px solid var(--padure); }
.pkg-btn.solid:hover { background: var(--carbune); border-color: var(--carbune); }
.pkg-note { font-size: 0.9rem; color: rgba(44,44,44,0.6); font-style: italic; }

.features-heading {
  font-size: 0.78rem; letter-spacing: 0.2em; text-transform: uppercase;
  color: var(--sienna); margin-bottom: 0.5rem; font-weight: 400;
  padding-bottom: 1rem; border-bottom: 1px solid var(--nisip);
}
.feature {
  display: flex; align-items: flex-start; gap: 1rem;
  padding: 1rem 0; border-bottom: 1px solid rgba(212,197,160,0.3);
  font-size: 1.05rem; line-height: 1.7; color: rgba(44,44,44,0.85); font-weight: 300;
}
.feature:last-child { border-bottom: none; }
.feature-check { flex-shrink: 0; margin-top: 0.1rem; color: var(--padure); }
.feature-sub { font-size: 0.9rem; color: rgba(44,44,44,0.6); margin-top: 0.2rem; line-height: 1.5; }

.pkg.premium { position: relative; }
.premium-tag {
  position: absolute; top: 0; right: 0;
  background: var(--padure); color: var(--in);
  font-size: 0.6rem; letter-spacing: 0.18em; text-transform: uppercase;
  padding: 0.4rem 1.2rem;
}

.pkg-plus {
  text-align: center; padding: 1.5rem 4rem;
  background: var(--nisip);
  border: 1px solid var(--nisip); border-top: none;
  display: flex; align-items: center; gap: 1.5rem;
}
.pkg-plus::before, .pkg-plus::after { content: ''; flex: 1; height: 1px; background: rgba(61,90,58,0.15); }
.pkg-plus-text {
  font-family: var(--font-cormorant), serif; font-size: 1.05rem;
  font-style: italic; color: var(--sienna); white-space: nowrap;
}

/* ── PAYMENT ── */
.payment { padding: 7rem 4rem; background: var(--nisip); }
.payment-grid { display: grid; grid-template-columns: 1fr 1.6fr; gap: 7rem; align-items: start; margin-top: 4rem; }
.payment-sticky { position: sticky; top: 5rem; }
.payment-sticky p { font-size: 1.1rem; line-height: 1.9; color: rgba(44,44,44,0.8); font-weight: 300; margin-top: 1.5rem; }

.pay-list { display: flex; flex-direction: column; }
.pay-item {
  display: grid; grid-template-columns: 3rem 1fr;
  gap: 2rem; padding: 2.2rem 0;
  border-top: 1px solid rgba(61,90,58,0.12); align-items: start;
}
.pay-item:last-child { border-bottom: 1px solid rgba(61,90,58,0.12); }
.pay-roman {
  font-family: var(--font-cormorant), serif; font-size: 1.4rem;
  font-style: italic; font-weight: 300;
  color: rgba(61,90,58,0.25); text-align: right; line-height: 1.2; padding-top: 0.1rem;
}
.pay-content h4 {
  font-family: var(--font-cormorant), serif; font-size: 1.4rem;
  font-weight: 400; color: var(--padure); margin-bottom: 0.6rem;
}
.pay-content p { font-size: 1rem; line-height: 1.8; color: rgba(44,44,44,0.8); font-weight: 300; }
.pay-pills { display: flex; gap: 0.5rem; flex-wrap: wrap; margin-top: 0.8rem; }
.pay-pill {
  font-size: 0.65rem; letter-spacing: 0.15em; text-transform: uppercase;
  padding: 0.35rem 0.9rem; border: 1px solid rgba(61,90,58,0.2); color: var(--padure); font-weight: 400;
}

/* ── STAGES ── */
.stages { padding: 7rem 4rem; background: var(--in); }
.stages-header { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: end; margin-bottom: 4rem; }
.stages-header-right { font-size: 0.95rem; line-height: 1.85; color: rgba(44,44,44,0.65); }

.stage-list { display: flex; flex-direction: column; gap: 0; }
.stage-item {
  display: grid; grid-template-columns: 80px 1fr 1fr;
  gap: 3rem; align-items: start; padding: 3rem 0;
  border-top: 1px solid var(--nisip); transition: background 0.3s;
}
.stage-item:last-child { border-bottom: 1px solid var(--nisip); }
.stage-num {
  font-family: var(--font-cormorant), serif;
  font-size: 4rem; font-weight: 300; line-height: 1;
  color: rgba(61,90,58,0.12); text-align: right;
}
.stage-info h4 {
  font-family: var(--font-cormorant), serif; font-size: 1.35rem;
  font-weight: 400; color: var(--padure); margin-bottom: 0.5rem; line-height: 1.3;
}
.stage-info p { font-size: 1rem; line-height: 1.75; color: rgba(44,44,44,0.8); font-weight: 300; }
.stage-pay-col { padding-top: 0.2rem; }
.stage-pay-row {
  display: flex; justify-content: space-between; align-items: baseline;
  padding: 0.6rem 0; border-bottom: 1px solid rgba(212,197,160,0.3); font-size: 0.88rem;
}
.stage-pay-row:last-child { border-bottom: none; }
.stage-pay-row span { color: rgba(44,44,44,0.55); }
.stage-pay-row strong { color: var(--padure); font-weight: 500; }

/* ── ADDONS ── */
.addons { padding: 7rem 4rem; background: var(--padure); }
.addons .section-label { color: var(--ocru); }
.addons .section-label::before, .addons .section-label::after { background: var(--ocru); }
.addons .display { color: var(--in); margin-bottom: 4rem; }
.addons .display em { color: var(--ocru); }
.addon-list { display: flex; flex-direction: column; }
.addon-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: 3rem; align-items: center; padding: 2rem 0;
  border-top: 1px solid rgba(255,255,255,0.07); transition: background 0.3s;
}
.addon-row:last-child { border-bottom: 1px solid rgba(255,255,255,0.07); }
.addon-row:hover { background: rgba(255,255,255,0.03); margin: 0 -1rem; padding-left: 1rem; padding-right: 1rem; }
.addon-left { display: flex; align-items: center; gap: 2rem; }
.addon-icon-w { color: rgba(245,240,230,0.3); flex-shrink: 0; transition: color 0.3s; }
.addon-row:hover .addon-icon-w { color: var(--ocru); }
.addon-name { font-size: 1.05rem; color: rgba(245,240,230,0.9); font-weight: 400; }
.addon-desc { font-size: 0.88rem; color: rgba(245,240,230,0.5); margin-top: 0.2rem; }
.addon-price {
  font-family: var(--font-cormorant), serif;
  font-size: 2rem; font-weight: 300; color: var(--ocru); white-space: nowrap; text-align: right;
}
.addon-price small {
  display: block; font-family: var(--font-jost), sans-serif;
  font-size: 0.65rem; color: rgba(245,240,230,0.3);
  letter-spacing: 0.1em; text-transform: uppercase; margin-top: 0.1rem;
}

.materials-note {
  margin-top: 3rem; padding: 2rem 2.5rem;
  border: 1px solid rgba(196,162,101,0.2);
  display: flex; gap: 1.5rem; align-items: flex-start;
}
.materials-note svg { flex-shrink: 0; color: var(--ocru); opacity: 0.6; margin-top: 0.1rem; }
.materials-note p { font-size: 0.9rem; color: rgba(245,240,230,0.5); line-height: 1.75; }
.materials-note p strong { color: rgba(245,240,230,0.7); font-weight: 400; }

/* ── PACKAGES CTA ── */
.pkg-cta { padding: 8rem 4rem; background: var(--carbune); text-align: center; position: relative; overflow: hidden; }
.pkg-cta::before {
  content: ''; position: absolute; bottom: -80px; right: -80px;
  width: 400px; height: 400px; border-radius: 50%;
  background: rgba(61,90,58,0.12); pointer-events: none; z-index: 0;
}
.pkg-cta > * { position: relative; z-index: 1; }
.pkg-cta .section-label { justify-content: center; color: var(--ocru); }
.pkg-cta .section-label::before, .pkg-cta .section-label::after { background: var(--ocru); }
.pkg-cta .display { color: var(--in); max-width: 600px; margin: 0 auto 1rem; }
.pkg-cta .display em { color: var(--ocru); }
.pkg-cta p { color: rgba(245,240,230,0.4); font-size: 0.9rem; margin-bottom: 3rem; }
.pkg-cta-btns { display: flex; justify-content: center; gap: 1rem; flex-wrap: wrap; }
.pkg-cta-btn-primary {
  display: inline-block; padding: 1.1rem 3rem; background: var(--ocru);
  color: var(--carbune); font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none; transition: background 0.3s;
}
.pkg-cta-btn-primary:hover { background: var(--nisip); }
.pkg-cta-btn-ghost {
  display: inline-block; padding: 1.1rem 3rem; border: 1px solid rgba(245,240,230,0.2);
  color: rgba(245,240,230,0.6); font-size: 0.75rem; letter-spacing: 0.18em; text-transform: uppercase;
  text-decoration: none; transition: all 0.3s;
}
.pkg-cta-btn-ghost:hover { border-color: var(--in); color: var(--in); }

/* ── PACKAGES RESPONSIVE ── */
@media(max-width:1100px) {
  .pkg { grid-template-columns: 1fr; }
  .pkg-right { border-left: none; border-top: 1px solid var(--nisip); }
  .pkg-divider { display: none; }
  .stage-item { grid-template-columns: 60px 1fr; }
  .stage-pay-col { grid-column: 2; }
}
@media(max-width:900px) {
  .page-header { padding: 7rem 1.5rem 3rem; }
  .page-header-inner { grid-template-columns: 1fr; gap: 1.5rem; }
  .page-header-right p { max-width: 100%; }
  .packages, .payment, .stages, .addons, .pkg-cta { padding: 3.5rem 1.5rem; }
  .packages-intro { grid-template-columns: 1fr; gap: 1.5rem; padding-bottom: 3rem; margin-bottom: 3rem; }
  .payment-grid { grid-template-columns: 1fr; gap: 2.5rem; }
  .payment-sticky { position: static; }
  .stages-header { grid-template-columns: 1fr; gap: 1.5rem; }
  .pkg { grid-template-columns: 1fr; }
  .pkg-divider { display: none; }
  .pkg-right { border-left: none; border-top: 1px solid var(--nisip); }
  .pkg-left, .pkg-right { padding: 2rem 1.2rem; }
  .pkg-name { font-size: clamp(1.8rem, 8vw, 2.4rem); }
  .pkg-tagline { max-width: 100%; font-size: 0.92rem; }
  .pkg-prices { grid-template-columns: 1fr; }
  .price-col {
    border-right: none; border-bottom: 1px solid var(--nisip);
    display: grid; grid-template-columns: 1fr auto; grid-template-rows: auto auto;
    gap: 0 1rem; align-items: center;
  }
  .price-col:last-child { border-bottom: none; }
  .price-col .label-sm { grid-column: 1; grid-row: 1; margin-bottom: 0; }
  .price-col .sqm { grid-column: 1; grid-row: 2; margin-bottom: 0; }
  .price-col .amount { grid-column: 2; grid-row: 1; align-self: end; text-align: right; }
  .price-col .currency { grid-column: 2; grid-row: 2; text-align: right; margin-top: 0; }
  .pkg-action { flex-direction: column; gap: 1rem; align-items: flex-start; }
  .pkg-btn { width: 100%; text-align: center; }
  .pkg-plus { padding: 1rem 1.5rem; }
  .pkg-plus-text { white-space: normal; font-size: 1rem; }
  .premium-tag { font-size: 0.55rem; padding: 0.3rem 0.8rem; }
  .stage-item { grid-template-columns: 1fr; gap: 1rem; padding: 2rem 0; }
  .stage-num { text-align: left; font-size: 2.5rem; }
  .stage-pay-col { grid-column: auto; }
  .addons .display { text-align: left; }
  .addon-row { grid-template-columns: 1fr; gap: 1rem; }
  .addon-left { gap: 1rem; }
  .addon-price { text-align: right; font-size: 1.5rem; }
  .addon-price small { display: inline; margin-left: 0.3rem; }
  .materials-note { flex-direction: column; padding: 1.5rem; }
  .pkg-cta { padding: 5rem 1.5rem; }
  .pkg-cta-btns { flex-direction: column; align-items: stretch; }
  .pkg-cta-btn-primary, .pkg-cta-btn-ghost { text-align: center; }
  .pay-item { grid-template-columns: 2rem 1fr; gap: 1rem; }
  .pay-pills { gap: 0.4rem; }
  .pay-pill { font-size: 0.55rem; }
}
