/* ============================================================
   SHANDAAR TEXTILE — Shared Stylesheet
   Palette inspired by the brand mark: deep emerald, antique gold,
   ivory, and a warm maroon for festive accents.
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,400;0,500;0,600;0,700;1,500;1,600&family=Jost:wght@300;400;500;600&display=swap');

:root{
  --green-900:#082A1F;
  --green-800:#0E3B2C;
  --green-700:#15493A;
  --green-600:#1C5B49;
  --gold:#D4AF37;
  --gold-deep:#B8901E;
  --gold-soft:#F0DDA0;
  --cream:#FBF6EC;
  --cream-deep:#F2E8D4;
  --ink:#2B2118;
  --ink-soft:#5B5043;
  --maroon:#7A2435;
  --maroon-deep:#5E1B28;

  --display:'Cormorant Garamond', serif;
  --body:'Jost', sans-serif;

  --max:1180px;
  --radius:6px;
  --shadow:0 18px 40px -20px rgba(8,42,31,0.45);
}

*{ margin:0; padding:0; box-sizing:border-box; }

html{ scroll-behavior:smooth; }

body{
  font-family:var(--body);
  color:var(--ink);
  background:var(--cream);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
}

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

a{ color:inherit; text-decoration:none; }

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

/* ---------- Typography helpers ---------- */

.eyebrow{
  font-family:var(--body);
  font-size:0.78rem;
  letter-spacing:0.32em;
  text-transform:uppercase;
  font-weight:500;
  color:var(--gold-deep);
}

.eyebrow.on-dark{ color:var(--gold); }

h1,h2,h3,h4{
  font-family:var(--display);
  font-weight:600;
  color:var(--green-900);
  line-height:1.15;
}

h1{ font-size:clamp(2.6rem,6vw,4.6rem); font-weight:700; }
h2{ font-size:clamp(2rem,4vw,2.9rem); }
h3{ font-size:1.4rem; }

.section-title{
  margin-top:10px;
  margin-bottom:18px;
}

.section-title .accent{
  font-style:italic;
  color:var(--maroon);
}

.lede{
  font-size:1.08rem;
  color:var(--ink-soft);
  max-width:620px;
}

/* ---------- Buttons ---------- */

.btn{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:14px 32px;
  border-radius:2px;
  font-family:var(--body);
  font-size:0.85rem;
  letter-spacing:0.18em;
  text-transform:uppercase;
  font-weight:500;
  border:1px solid var(--gold);
  transition:all .25s ease;
  cursor:pointer;
}

.btn-primary{
  background:var(--gold);
  color:var(--green-900);
}
.btn-primary:hover{
  background:transparent;
  color:var(--gold);
}

.btn-outline{
  background:transparent;
  color:var(--gold);
  border-color:var(--gold);
}
.btn-outline:hover{
  background:var(--gold);
  color:var(--green-900);
}

.btn-row{ display:flex; gap:18px; flex-wrap:wrap; margin-top:36px; }

/* ============================================================
   HEADER
   ============================================================ */

.site-header{
  position:sticky;
  top:0;
  z-index:50;
  background:var(--green-900);
  border-bottom:1px solid rgba(212,175,55,0.25);
}

.site-header .wrap{
  display:flex;
  align-items:center;
  justify-content:space-between;
  height:88px;
}

.brand{
  display:flex;
  align-items:center;
  gap:14px;
}

.brand img{
  width:52px;
  height:52px;
  border-radius:50%;
  border:1.5px solid var(--gold);
  object-fit:cover;
}

.brand-text{
  display:flex;
  flex-direction:column;
  line-height:1.1;
}

.brand-text .name{
  font-family:var(--display);
  font-size:1.5rem;
  font-weight:700;
  color:var(--gold-soft);
  letter-spacing:0.02em;
}

.brand-text .tag{
  font-size:0.62rem;
  letter-spacing:0.36em;
  color:var(--gold-deep);
  text-transform:uppercase;
  margin-top:2px;
}

.nav-links{
  display:flex;
  gap:36px;
  font-size:0.82rem;
  letter-spacing:0.16em;
  text-transform:uppercase;
}

.nav-links a{
  color:var(--cream-deep);
  position:relative;
  padding-bottom:6px;
  transition:color .2s ease;
}

.nav-links a::after{
  content:'';
  position:absolute;
  left:0; right:100%;
  bottom:0;
  height:1px;
  background:var(--gold);
  transition:right .25s ease;
}

.nav-links a:hover,
.nav-links a.active{
  color:var(--gold);
}
.nav-links a:hover::after,
.nav-links a.active::after{
  right:0;
}

.nav-toggle{ display:none; }

/* ============================================================
   HERO
   ============================================================ */

.hero{
  position:relative;
  background:
    radial-gradient(ellipse at 75% 20%, rgba(212,175,55,0.16), transparent 55%),
    radial-gradient(ellipse at 15% 85%, rgba(212,175,55,0.10), transparent 45%),
    linear-gradient(160deg,var(--green-900) 0%,var(--green-800) 55%,var(--green-700) 100%);
  color:var(--cream);
  overflow:hidden;
  padding:110px 0 150px;
}

.hero::before{
  content:'';
  position:absolute;
  inset:0;
  background-image:
    repeating-radial-gradient(circle at center, transparent 0 64px, rgba(212,175,55,0.045) 65px 66px);
  opacity:0.6;
  pointer-events:none;
}

.hero-frame{
  position:relative;
  border:1px solid rgba(212,175,55,0.35);
  padding:64px clamp(28px,8vw,90px);
  text-align:center;
  max-width:880px;
  margin:0 auto;
}

.corner{
  position:absolute;
  width:64px;
  height:64px;
  opacity:0.9;
}
.corner img{ width:100%; height:100%; }
.corner.tl{ top:-1px; left:-1px; }
.corner.tr{ top:-1px; right:-1px; transform:scaleX(-1); }
.corner.bl{ bottom:-1px; left:-1px; transform:scaleY(-1); }
.corner.br{ bottom:-1px; right:-1px; transform:scale(-1,-1); }

.hero h1{
  color:var(--cream);
  margin:18px 0 8px;
}
.hero h1 .leaf{
  display:block;
  font-style:italic;
  font-weight:500;
  font-size:0.42em;
  letter-spacing:0.5em;
  text-transform:uppercase;
  color:var(--gold);
  margin-bottom:14px;
}

.hero .lede{
  margin:24px auto 0;
  color:var(--cream-deep);
  text-align:center;
}

.hero .btn-row{ justify-content:center; }

/* drape divider between hero and content */
.drape{
  display:block;
  width:100%;
  height:90px;
  margin-top:-2px;
}
.drape path{ fill:var(--cream); }
.drape.flip path{ fill:var(--green-900); }
.hero-bottom-drape{ position:relative; margin-top:-90px; }

/* ============================================================
   SECTIONS
   ============================================================ */

section{ padding:100px 0; }

.section-head{
  text-align:center;
  max-width:680px;
  margin:0 auto 64px;
}
.section-head .lede{ margin:18px auto 0; }

.alt{ background:var(--cream-deep); }

.dark{
  background:linear-gradient(160deg,var(--green-900),var(--green-700));
  color:var(--cream);
}
.dark h1, .dark h2, .dark h3{ color:var(--cream); }
.dark .lede{ color:var(--cream-deep); }

/* ---------- Feature / value cards ---------- */

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:36px;
}
.grid-2{
  display:grid;
  grid-template-columns:repeat(2,1fr);
  gap:36px;
}

.card{
  background:var(--cream);
  border:1px solid var(--cream-deep);
  border-top:3px solid var(--gold);
  padding:40px 32px;
  border-radius:var(--radius);
  box-shadow:var(--shadow);
}

.card .num{
  font-family:var(--display);
  font-size:0.95rem;
  letter-spacing:0.3em;
  color:var(--gold-deep);
  font-weight:600;
}

.card h3{ margin-top:14px; margin-bottom:10px; }

.card p{ color:var(--ink-soft); font-size:0.96rem; }

.card-icon{
  width:50px; height:50px;
  border:1px solid var(--gold);
  border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  margin-bottom:18px;
  font-family:var(--display);
  font-size:1.3rem;
  color:var(--gold-deep);
}

/* ---------- Collection swatches ---------- */

.swatch-grid{
  display:grid;
  grid-template-columns:repeat(5,1fr);
  gap:24px;
}

.swatch{
  position:relative;
  aspect-ratio:3/4;
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding:22px;
  box-shadow:var(--shadow);
  border:1px solid var(--cream-deep);
}

.swatch::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(8,42,31,0.78) 0%, rgba(8,42,31,0.1) 60%);
}

.swatch span{
  position:relative;
  z-index:1;
  font-family:var(--display);
  font-size:1.2rem;
  font-weight:600;
  color:var(--cream);
  letter-spacing:0.02em;
}

.swatch.s1{ background:linear-gradient(135deg,#7A2435,#B8901E); }
.swatch.s2{ background:linear-gradient(135deg,#15493A,#D4AF37); }
.swatch.s3{ background:linear-gradient(135deg,#5E1B28,#1C5B49); }
.swatch.s4{ background:linear-gradient(135deg,#B8901E,#082A1F); }
.swatch.s5{ background:linear-gradient(135deg,#1C5B49,#7A2435); }

/* ---------- CTA banner ---------- */

.cta-banner{
  background:linear-gradient(120deg,var(--maroon-deep),var(--maroon) 60%,var(--gold-deep));
  color:var(--cream);
  text-align:center;
  padding:90px 0;
  position:relative;
}
.cta-banner h2{ color:var(--cream); }
.cta-banner .lede{ color:var(--gold-soft); margin:18px auto 0; }
.cta-banner .btn-row{ justify-content:center; }
.cta-banner .btn-primary{ background:var(--cream); border-color:var(--cream); color:var(--maroon-deep); }
.cta-banner .btn-primary:hover{ background:transparent; color:var(--cream); }
.cta-banner .btn-outline{ color:var(--cream); border-color:var(--cream); }
.cta-banner .btn-outline:hover{ background:var(--cream); color:var(--maroon-deep); }

/* ---------- Steps (franchise process) ---------- */

.steps{
  display:flex;
  flex-direction:column;
  gap:0;
  max-width:760px;
  margin:0 auto;
}
.step{
  display:grid;
  grid-template-columns:90px 1fr;
  gap:28px;
  padding:32px 0;
  border-bottom:1px solid var(--cream-deep);
}
.step:last-child{ border-bottom:none; }
.step .step-num{
  font-family:var(--display);
  font-size:2.6rem;
  font-weight:600;
  color:var(--gold);
  line-height:1;
}
.step h3{ margin-bottom:6px; }
.step p{ color:var(--ink-soft); }

/* ---------- Contact ---------- */

.contact-grid{
  display:grid;
  grid-template-columns:1fr 1.2fr;
  gap:60px;
}

.contact-info .item{
  margin-bottom:28px;
}
.contact-info .item .label{
  font-size:0.74rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:6px;
}
.contact-info .item .value{
  font-family:var(--display);
  font-size:1.3rem;
  font-weight:600;
  color:var(--green-900);
}

form{
  background:var(--cream);
  border:1px solid var(--cream-deep);
  border-top:3px solid var(--gold);
  border-radius:var(--radius);
  padding:40px;
  box-shadow:var(--shadow);
  display:grid;
  gap:20px;
}

.field label{
  display:block;
  font-size:0.74rem;
  letter-spacing:0.22em;
  text-transform:uppercase;
  color:var(--ink-soft);
  margin-bottom:8px;
}

.field input,
.field select,
.field textarea{
  width:100%;
  padding:13px 14px;
  border:1px solid var(--cream-deep);
  background:#fff;
  border-radius:3px;
  font-family:var(--body);
  font-size:0.95rem;
  color:var(--ink);
}
.field input:focus,
.field select:focus,
.field textarea:focus{
  outline:2px solid var(--gold);
  outline-offset:1px;
}

.row-2{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:20px;
}

/* ============================================================
   FOOTER
   ============================================================ */

.site-footer{
  background:var(--green-900);
  color:var(--cream-deep);
  border-top:3px solid var(--gold);
  padding:64px 0 28px;
}

.footer-grid{
  display:grid;
  grid-template-columns:1.4fr 1fr 1fr;
  gap:48px;
  padding-bottom:40px;
}

.footer-grid h4{
  color:var(--gold);
  font-size:0.78rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  font-weight:500;
  margin-bottom:18px;
  font-family:var(--body);
}

.footer-grid .brand{ margin-bottom:18px; }
.footer-grid p{ color:var(--cream-deep); font-size:0.92rem; }

.footer-grid ul{ list-style:none; display:flex; flex-direction:column; gap:10px; font-size:0.92rem; }
.footer-grid ul a:hover{ color:var(--gold); }

.footer-bottom{
  border-top:1px solid rgba(212,175,55,0.2);
  padding-top:24px;
  display:flex;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:12px;
  font-size:0.8rem;
  color:var(--gold-soft);
  letter-spacing:0.05em;
}

.footer-bottom a:hover{ color:var(--gold); }

/* ============================================================
   POLICY PAGE
   ============================================================ */

.policy{
  max-width:760px;
  margin:0 auto;
}
.policy h2{ margin-top:46px; margin-bottom:14px; font-size:1.6rem; }
.policy h2:first-of-type{ margin-top:0; }
.policy p, .policy li{ color:var(--ink-soft); margin-bottom:12px; }
.policy ul{ padding-left:22px; margin-bottom:14px; }
.policy .updated{
  display:inline-block;
  margin-bottom:30px;
  font-size:0.78rem;
  letter-spacing:0.28em;
  text-transform:uppercase;
  color:var(--gold-deep);
}

/* ============================================================
   PAGE INTRO BANNER (for inner pages)
   ============================================================ */

.page-banner{
  background:linear-gradient(160deg,var(--green-900),var(--green-700));
  color:var(--cream);
  text-align:center;
  padding:80px 0 70px;
  position:relative;
}
.page-banner .eyebrow{ margin-bottom:14px; }
.page-banner h1{ color:var(--cream); font-size:clamp(2.4rem,5vw,3.6rem); }

/* ============================================================
   RESPONSIVE
   ============================================================ */

@media (max-width:980px){
  .grid-3, .grid-2{ grid-template-columns:1fr; }
  .swatch-grid{ grid-template-columns:repeat(2,1fr); }
  .footer-grid{ grid-template-columns:1fr; gap:32px; }
  .contact-grid{ grid-template-columns:1fr; gap:40px; }
  .row-2{ grid-template-columns:1fr; }
}

@media (max-width:760px){
  .site-header .wrap{ height:76px; }
  .nav-links{
    position:absolute;
    top:76px; left:0; right:0;
    background:var(--green-900);
    flex-direction:column;
    align-items:center;
    gap:0;
    padding:0;
    max-height:0;
    overflow:hidden;
    transition:max-height .3s ease;
    border-bottom:1px solid rgba(212,175,55,0.25);
  }
  .nav-links a{ padding:16px 0; width:100%; text-align:center; }
  .nav-toggle{
    display:flex;
    flex-direction:column;
    gap:5px;
    background:none;
    border:none;
    cursor:pointer;
    padding:8px;
  }
  .nav-toggle span{ width:24px; height:1.5px; background:var(--gold); display:block; }
  .site-header.open .nav-links{ max-height:280px; }
  .hero{ padding:80px 0 110px; }
  .hero-frame{ padding:44px 22px; }
  .swatch-grid{ grid-template-columns:repeat(2,1fr); }
}

@media (max-width:520px){
  .wrap{ padding:0 20px; }
  .swatch-grid{ grid-template-columns:1fr 1fr; }
  .corner{ width:40px; height:40px; }
}

/* ============================================================
   MARQUEE TICKER
   ============================================================ */

.marquee{
  background:var(--green-900);
  border-bottom:1px solid rgba(212,175,55,0.25);
  overflow:hidden;
  padding:13px 0;
}
.marquee-track{
  display:flex;
  width:max-content;
  gap:0;
  animation:marquee 32s linear infinite;
}
.marquee-track .seg{
  display:flex;
  align-items:center;
  gap:60px;
  padding-right:60px;
}
.marquee-track span{
  font-family:var(--display);
  font-style:italic;
  font-size:1.02rem;
  color:var(--gold-soft);
  letter-spacing:0.04em;
  white-space:nowrap;
}
.marquee-track .dot{ color:var(--gold); font-style:normal; }

@keyframes marquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-50%); }
}

/* ============================================================
   STATS BAND
   ============================================================ */

.stats{
  background:linear-gradient(160deg,var(--green-800),var(--green-900));
  color:var(--cream);
  padding:74px 0;
  position:relative;
}
.stats-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:32px;
  text-align:center;
}
.stat .num{
  font-family:var(--display);
  font-size:clamp(2.2rem,5vw,3.4rem);
  font-weight:700;
  color:var(--gold);
  line-height:1;
}
.stat .label{
  margin-top:10px;
  font-size:0.74rem;
  letter-spacing:0.24em;
  text-transform:uppercase;
  color:var(--cream-deep);
}
.stat + .stat{ border-left:1px solid rgba(212,175,55,0.18); }

/* ============================================================
   SCROLL REVEAL
   ============================================================ */

.reveal{
  opacity:0;
  transform:translateY(26px);
  transition:opacity .7s ease, transform .7s ease;
}
.reveal.visible{
  opacity:1;
  transform:translateY(0);
}

/* ============================================================
   PRESENCE / CITIES GRID
   ============================================================ */

.presence-grid{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
}
.presence-chip{
  border:1px solid var(--cream-deep);
  border-radius:30px;
  padding:14px 10px;
  text-align:center;
  font-family:var(--display);
  font-weight:600;
  font-size:0.95rem;
  color:var(--green-900);
  background:var(--cream);
  transition:all .25s ease;
}
.presence-chip:hover{
  background:var(--green-900);
  color:var(--gold);
  border-color:var(--gold);
  transform:translateY(-3px);
}
.presence-chip .dot-tag{
  display:block;
  font-family:var(--body);
  font-size:0.62rem;
  letter-spacing:0.2em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-top:4px;
}
.presence-chip:hover .dot-tag{ color:var(--gold-soft); }

/* ============================================================
   MINI PROCESS (3-step)
   ============================================================ */

.mini-process{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:36px;
  position:relative;
}
.mini-process::before{
  content:'';
  position:absolute;
  top:30px; left:8%; right:8%;
  height:1px;
  background:repeating-linear-gradient(90deg, var(--gold) 0 10px, transparent 10px 20px);
  z-index:0;
}
.mini-step{
  position:relative;
  z-index:1;
  text-align:center;
}
.mini-step .circle{
  width:62px; height:62px;
  margin:0 auto 20px;
  border-radius:50%;
  background:var(--cream);
  border:2px solid var(--gold);
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display);
  font-size:1.6rem;
  font-weight:700;
  color:var(--green-900);
}
.mini-step h3{ margin-bottom:8px; }
.mini-step p{ color:var(--ink-soft); font-size:0.94rem; }

/* ============================================================
   TESTIMONIALS
   ============================================================ */

.testimonial-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
}
.testimonial{
  background:var(--cream);
  border:1px solid var(--cream-deep);
  border-top:3px solid var(--gold);
  border-radius:var(--radius);
  padding:38px 32px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
}
.testimonial .stars{
  color:var(--gold);
  font-size:1.05rem;
  letter-spacing:0.18em;
  margin-bottom:16px;
}
.testimonial .quote{
  font-family:var(--display);
  font-style:italic;
  font-size:1.1rem;
  color:var(--ink);
  flex-grow:1;
  margin-bottom:24px;
}
.testimonial .who{
  display:flex;
  align-items:center;
  gap:14px;
}
.testimonial .avatar{
  width:46px; height:46px;
  border-radius:50%;
  flex-shrink:0;
  background:linear-gradient(135deg,var(--gold),var(--maroon));
  display:flex; align-items:center; justify-content:center;
  font-family:var(--display); font-weight:700; color:var(--cream);
}
.testimonial .who .name{ font-weight:600; font-family:var(--display); font-size:1.02rem; color:var(--green-900); }
.testimonial .who .loc{ font-size:0.78rem; letter-spacing:0.06em; color:var(--ink-soft); }

.dark .testimonial{ background:rgba(251,246,236,0.04); border-color:rgba(212,175,55,0.2); box-shadow:none; }
.dark .testimonial .quote{ color:var(--cream); }
.dark .testimonial .who .name{ color:var(--cream); }
.dark .testimonial .who .loc{ color:var(--cream-deep); }

/* ============================================================
   GALLERY / LOOKBOOK
   ============================================================ */

.gallery-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  grid-auto-rows:150px;
  gap:18px;
}
.gallery-item{
  position:relative;
  border-radius:var(--radius);
  overflow:hidden;
  display:flex;
  align-items:flex-end;
  padding:20px;
  box-shadow:var(--shadow);
  border:1px solid var(--cream-deep);
}
.gallery-item::after{
  content:'';
  position:absolute; inset:0;
  background:linear-gradient(0deg, rgba(8,42,31,0.8) 0%, rgba(8,42,31,0.05) 65%);
}
.gallery-item span{
  position:relative; z-index:1;
  font-family:var(--display);
  font-weight:600;
  font-size:1.05rem;
  color:var(--cream);
}
.gallery-item.tall{ grid-row:span 2; }
.gallery-item.wide{ grid-column:span 2; }

.gallery-item.g1{ background:linear-gradient(135deg,#7A2435,#D4AF37); }
.gallery-item.g2{ background:linear-gradient(135deg,#15493A,#D4AF37); }
.gallery-item.g3{ background:linear-gradient(135deg,#5E1B28,#1C5B49); }
.gallery-item.g4{ background:linear-gradient(135deg,#B8901E,#082A1F); }
.gallery-item.g5{ background:linear-gradient(135deg,#1C5B49,#7A2435); }
.gallery-item.g6{ background:linear-gradient(135deg,#082A1F,#D4AF37); }

/* ============================================================
   FAQ ACCORDION
   ============================================================ */

.faq{
  max-width:760px;
  margin:0 auto;
}
.faq-item{
  border-bottom:1px solid var(--cream-deep);
}
.faq-item:first-child{ border-top:1px solid var(--cream-deep); }

.faq-q{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
  text-align:left;
  background:none;
  border:none;
  cursor:pointer;
  padding:26px 4px;
  font-family:var(--display);
  font-size:1.12rem;
  font-weight:600;
  color:var(--green-900);
}
.faq-q .icon{
  flex-shrink:0;
  font-family:var(--body);
  font-size:1.5rem;
  line-height:1;
  color:var(--gold-deep);
  transition:transform .3s ease;
}
.faq-item.open .faq-q .icon{ transform:rotate(45deg); }

.faq-a{
  max-height:0;
  overflow:hidden;
  transition:max-height .35s ease;
}
.faq-a p{
  padding:0 4px 26px;
  color:var(--ink-soft);
  max-width:none;
}

/* ============================================================
   VERTICAL TIMELINE (franchise process)
   ============================================================ */

.timeline{
  position:relative;
  max-width:760px;
  margin:0 auto;
  padding-left:56px;
}
.timeline::before{
  content:'';
  position:absolute;
  left:17px; top:8px; bottom:8px;
  width:2px;
  background:linear-gradient(var(--gold), var(--cream-deep));
}
.timeline-item{
  position:relative;
  padding-bottom:44px;
}
.timeline-item:last-child{ padding-bottom:0; }
.timeline-item::before{
  content:'';
  position:absolute;
  left:-56px; top:4px;
  width:16px; height:16px;
  border-radius:50%;
  background:var(--cream);
  border:3px solid var(--gold);
}
.timeline-item .day{
  font-family:var(--body);
  font-size:0.74rem;
  letter-spacing:0.3em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:6px;
}
.timeline-item h3{ margin-bottom:6px; }
.timeline-item p{ color:var(--ink-soft); }

.dark .timeline::before{ background:linear-gradient(var(--gold), rgba(212,175,55,0.15)); }
.dark .timeline-item::before{ background:var(--green-900); }
.dark .timeline-item .day{ color:var(--gold); }
.dark .timeline-item p{ color:var(--cream-deep); }

/* ============================================================
   PLANS / INVESTMENT TIERS
   ============================================================ */

.plans-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:32px;
  align-items:stretch;
}
.plan{
  background:var(--cream);
  border:1px solid var(--cream-deep);
  border-top:3px solid var(--gold);
  border-radius:var(--radius);
  padding:42px 32px;
  box-shadow:var(--shadow);
  display:flex;
  flex-direction:column;
}
.plan .badge{
  align-self:flex-start;
  background:var(--maroon);
  color:var(--cream);
  font-size:0.66rem;
  letter-spacing:0.24em;
  text-transform:uppercase;
  padding:5px 14px;
  border-radius:20px;
  margin-bottom:16px;
}
.plan .scale{
  font-family:var(--display);
  font-size:0.95rem;
  letter-spacing:0.18em;
  color:var(--gold-deep);
  text-transform:uppercase;
  margin-bottom:6px;
}
.plan h3{ margin-bottom:14px; }
.plan ul{
  list-style:none;
  display:flex;
  flex-direction:column;
  gap:12px;
  margin:18px 0 28px;
  flex-grow:1;
}
.plan ul li{
  color:var(--ink-soft);
  padding-left:26px;
  position:relative;
  font-size:0.95rem;
}
.plan ul li::before{
  content:'✓';
  position:absolute; left:0; top:0;
  color:var(--gold-deep);
  font-weight:700;
}

.plan.featured{
  background:linear-gradient(160deg,var(--green-900),var(--green-700));
  border-top-color:var(--maroon);
  color:var(--cream);
  transform:translateY(-12px);
}
.plan.featured h3, .plan.featured .scale{ color:var(--cream); }
.plan.featured .scale{ color:var(--gold); }
.plan.featured ul li{ color:var(--cream-deep); }
.plan.featured ul li::before{ color:var(--gold); }
.plan.featured .btn-outline{ color:var(--gold); border-color:var(--gold); }
.plan.featured .btn-outline:hover{ background:var(--gold); color:var(--green-900); }

/* ============================================================
   WHATSAPP FLOATING BUTTON
   ============================================================ */

.whatsapp-float{
  position:fixed;
  bottom:26px; right:26px;
  z-index:60;
  width:58px; height:58px;
  border-radius:50%;
  background:#25D366;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 14px 30px -8px rgba(8,42,31,0.5);
  transition:transform .2s ease;
}
.whatsapp-float:hover{ transform:scale(1.08); }
.whatsapp-float svg{ width:28px; height:28px; }

/* ============================================================
   ADDITIONAL RESPONSIVE
   ============================================================ */

@media (max-width:980px){
  .stats-grid{ grid-template-columns:repeat(2,1fr); gap:40px 24px; }
  .stat + .stat{ border-left:none; }
  .presence-grid{ grid-template-columns:repeat(3,1fr); }
  .mini-process{ grid-template-columns:1fr; gap:48px; }
  .mini-process::before{ display:none; }
  .testimonial-grid{ grid-template-columns:1fr; }
  .gallery-grid{ grid-template-columns:repeat(2,1fr); grid-auto-rows:160px; }
  .gallery-item.wide{ grid-column:span 2; }
  .gallery-item.tall{ grid-row:span 1; }
  .plans-grid{ grid-template-columns:1fr; }
  .plan.featured{ transform:none; order:-1; }
}

@media (max-width:520px){
  .presence-grid{ grid-template-columns:repeat(2,1fr); }
  .gallery-grid{ grid-template-columns:1fr 1fr; }
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior:auto; }
  *{ transition:none !important; animation:none !important; }
  .reveal{ opacity:1; transform:none; }
}
