/* =============================================================
   BLUSH & BIRCH — Website Design Studio
   Shared stylesheet
   Brand palette:
     Navy (anchor)   #24364F
     White Sand (bg) #FCFAF8
     Pale Peach      #F7DDD2
     Light Stone     #E7E1DA
     Driftwood       #C8B7A5
     Fog Gray        #C7C9CC
     Soft Gold       #C7B28A
   ============================================================= */
:root{
  --navy:#24364F;
  --navy-deep:#1c2c42;
  --white-sand:#FCFAF8;
  --peach:#F7DDD2;
  --peach-soft:#FBEDE6;
  --stone:#E7E1DA;
  --driftwood:#C8B7A5;
  --fog:#C7C9CC;
  --gold:#C7B28A;
  --gold-deep:#B08B54;
  --ink:#2a2f38;
  --muted:#6f7580;

  --serif:"Cormorant Garamond", Georgia, "Times New Roman", serif;
  --sans:"Jost", "Helvetica Neue", Arial, sans-serif;

  --maxw:1200px;
  --radius:14px;
  --shadow:0 18px 50px -22px rgba(36,54,79,.35);
  --shadow-soft:0 10px 30px -18px rgba(36,54,79,.30);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--white-sand);
  color:var(--ink);
  font-family:var(--sans);
  font-size:17px;
  line-height:1.7;
  font-weight:300;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
img{max-width:100%;display:block;}
a{color:inherit;text-decoration:none;}

h1,h2,h3,h4{font-family:var(--serif);font-weight:500;color:var(--navy);line-height:1.1;margin:0 0 .4em;}
h1{font-size:clamp(2.6rem,6vw,4.6rem);letter-spacing:.5px;}
h2{font-size:clamp(2rem,4.4vw,3.2rem);}
h3{font-size:clamp(1.4rem,2.4vw,1.9rem);}
p{margin:0 0 1.1em;}

.eyebrow{
  font-family:var(--sans);
  font-size:.8rem;
  font-weight:500;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--gold-deep);
  margin-bottom:1rem;
  display:inline-block;
}
.script-note{
  font-family:var(--serif);
  font-style:italic;
  font-weight:500;
  font-size:1.8rem;
  color:var(--driftwood);
  line-height:1.25;
}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.5rem);}
section{padding:clamp(4rem,9vw,7.5rem) 0;}
.center{text-align:center;}
.lead{font-size:1.15rem;color:var(--muted);max-width:620px;}
.center .lead{margin-left:auto;margin-right:auto;}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:.5em;
  font-family:var(--sans);font-size:.82rem;font-weight:400;
  letter-spacing:.16em;text-transform:uppercase;
  padding:1.05em 2.1em;border-radius:100px;
  border:1px solid var(--navy);white-space:nowrap;
  transition:all .35s var(--ease);cursor:pointer;
}
.btn-primary{background:var(--navy);color:var(--white-sand);}
.btn-primary:hover{background:var(--navy-deep);transform:translateY(-2px);box-shadow:var(--shadow-soft);}
.btn-ghost{background:transparent;color:var(--navy);}
.btn-ghost:hover{background:var(--navy);color:var(--white-sand);transform:translateY(-2px);}
.btn-peach{background:var(--peach);color:var(--navy);border-color:var(--peach);}
.btn-peach:hover{background:var(--gold);border-color:var(--gold);transform:translateY(-2px);}

/* ---------- Header / Nav ---------- */
.site-header{
  position:sticky;top:0;z-index:100;
  background:rgba(252,250,248,.82);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(200,183,165,.35);
  transition:box-shadow .3s ease;
}
.site-header.scrolled{box-shadow:0 6px 24px -18px rgba(36,54,79,.5);}
.nav{display:flex;align-items:center;justify-content:space-between;height:108px;}
.brand{display:flex;flex-direction:column;line-height:1;}
.brand img{height:68px;width:auto;display:block;align-self:flex-start;flex:0 0 auto;}
.brand .brand-name{font-family:var(--serif);font-size:1.5rem;font-weight:500;letter-spacing:1px;color:var(--navy);}
.brand .brand-sub{font-family:var(--sans);font-size:.55rem;letter-spacing:.34em;text-transform:uppercase;color:var(--driftwood);margin-top:3px;}
.nav-links{display:flex;align-items:center;gap:2rem;list-style:none;margin:0;padding:0;}
.nav-links a{
  font-size:.8rem;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);
  position:relative;padding:4px 0;transition:color .3s;
}
.nav-links a::after{content:"";position:absolute;left:0;bottom:-2px;width:0;height:1px;background:var(--gold);transition:width .3s var(--ease);}
.nav-links a:hover::after,.nav-links a.active::after{width:100%;}
.nav-links a.active{color:var(--gold);}
.nav-cta{margin-left:.8rem;}
.nav-links a.nav-cta,.nav-links a.nav-cta:hover{color:var(--white-sand);font-size:.86rem;letter-spacing:.14em;padding:1.05em 2.6em;}
.nav-links a.nav-cta::after{display:none;}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;}
.nav-toggle span{display:block;width:24px;height:2px;background:var(--navy);margin:5px 0;transition:.3s;}

/* ---------- Marquee ---------- */
.marquee{
  overflow:hidden;white-space:nowrap;
  padding:1.15rem 0;
  border-top:1px solid rgba(200,183,165,.4);
  border-bottom:1px solid rgba(200,183,165,.4);
}
.marquee.navy{background:var(--navy);border-color:var(--navy-deep);}
.marquee-track{display:inline-flex;align-items:center;animation:scroll-x 32s linear infinite;}
.marquee:hover .marquee-track{animation-play-state:paused;}
.marquee-track span{
  font-family:var(--serif);font-size:1.5rem;font-style:italic;color:var(--navy);
  padding:0 1.4rem;display:inline-flex;align-items:center;gap:1.4rem;
}
.marquee.navy .marquee-track span{color:var(--peach);}
.marquee-track .star{font-style:normal;color:var(--gold);font-size:1rem;}
@keyframes scroll-x{from{transform:translateX(0);}to{transform:translateX(-50%);}}

/* reverse variant */
.marquee-track.rev{animation-direction:reverse;}

/* ---------- Hero ---------- */
.hero{position:relative;padding:clamp(3rem,7vw,5.5rem) 0 clamp(3rem,6vw,4.5rem);}
.hero-grid{display:grid;grid-template-columns:1.15fr .85fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
.hero h1{margin-bottom:.3em;}
.hero .hello{font-family:var(--serif);font-style:italic;font-size:1.8rem;color:var(--driftwood);margin-bottom:.4rem;}
.hero-cta{display:flex;gap:1rem;flex-wrap:wrap;margin-top:1.8rem;}
.hero-photo{position:relative;}
.hero-photo .photo-frame{
  border-radius:200px 200px 14px 14px;overflow:hidden;
  aspect-ratio:3/3.6;background:var(--stone);box-shadow:var(--shadow);
}
.hero-photo .photo-frame img{width:100%;height:100%;object-fit:cover;}
.hero-photo .badge{
  position:absolute;bottom:-18px;left:-18px;
  background:var(--white-sand);border:1px solid var(--stone);
  border-radius:100px;padding:.7rem 1.2rem;box-shadow:var(--shadow-soft);
  font-size:.75rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);
}
.hero-photo .badge b{color:var(--gold);}

/* image placeholder */
.ph{
  display:flex;align-items:center;justify-content:center;text-align:center;
  background:repeating-linear-gradient(45deg,var(--stone),var(--stone) 12px,var(--peach-soft) 12px,var(--peach-soft) 24px);
  color:var(--navy);font-family:var(--sans);font-size:.72rem;letter-spacing:.12em;text-transform:uppercase;
  padding:1rem;width:100%;height:100%;
}
.ph small{display:block;color:var(--muted);letter-spacing:.05em;text-transform:none;margin-top:.4rem;font-size:.7rem;}

/* ---------- Services grid ---------- */
.grid{display:grid;gap:1.4rem;}
.grid-3{grid-template-columns:repeat(3,1fr);}
.grid-2{grid-template-columns:repeat(2,1fr);}
.card{
  background:#fff;border:1px solid var(--stone);border-radius:var(--radius);
  padding:2rem 1.8rem;transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow-soft);}
.card .num{font-family:var(--serif);font-style:italic;font-size:1.2rem;color:var(--gold);}
.card h3{margin:.4rem 0 .5rem;}
.card p{color:var(--muted);font-size:.98rem;margin:0;}

/* ---------- Section intro ---------- */
.sec-head{max-width:640px;margin-bottom:3rem;}
.center.sec-head{margin-left:auto;margin-right:auto;}

/* ---------- Pricing ---------- */
.tier{
  background:#fff;border:1px solid var(--stone);border-radius:18px;
  padding:2.4rem 2rem;display:flex;flex-direction:column;position:relative;
  transition:transform .4s var(--ease),box-shadow .4s var(--ease);
}
.tier:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.tier.featured{background:var(--navy);color:var(--peach-soft);border-color:var(--navy);}
.tier.featured h3,.tier.featured .price{color:#fff;}
.tier.featured .tier-kicker{color:var(--peach);}
.tier.featured ul li{color:rgba(255,255,255,.85);border-color:rgba(255,255,255,.14);}
.tier.featured ul li::before{color:var(--peach);}
.tier-flag{
  position:absolute;top:-13px;left:50%;transform:translateX(-50%);
  background:var(--gold);color:#fff;font-size:.66rem;letter-spacing:.16em;text-transform:uppercase;
  padding:.4rem 1rem;border-radius:100px;white-space:nowrap;
}
.tier-kicker{font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--gold);margin-bottom:.6rem;}
.price{font-family:var(--serif);font-size:2.6rem;color:var(--navy);margin:.4rem 0 .2rem;}
.price small{font-size:.8rem;font-family:var(--sans);letter-spacing:.1em;text-transform:uppercase;color:var(--muted);display:block;}
.tier ul{list-style:none;padding:0;margin:1.4rem 0 1.8rem;flex:1;}
.tier ul li{font-size:.95rem;padding:.55rem 0 .55rem 1.6rem;position:relative;border-bottom:1px solid var(--stone);color:var(--muted);}
.tier ul li::before{content:"✦";position:absolute;left:0;color:var(--gold);font-size:.8rem;top:.7rem;}
.tier .care{font-size:.85rem;color:var(--muted);margin-bottom:1.2rem;}
.tier .btn{width:100%;justify-content:center;}

/* ---------- Process ---------- */
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step;}
.step{padding:1.6rem 0;}
.step .n{
  font-family:var(--serif);font-size:2.4rem;color:var(--peach);
  border-bottom:1px solid var(--stone);padding-bottom:.4rem;margin-bottom:.9rem;display:block;
}
.step h3{font-size:1.25rem;}
.step p{color:var(--muted);font-size:.95rem;margin:0;}

/* ---------- Testimonials carousel ---------- */
.testimonials{background:var(--peach-soft);}
.tcar{position:relative;max-width:840px;margin:0 auto;overflow:hidden;}
.tcar-track{display:flex;transition:transform .6s var(--ease);}
.tslide{min-width:100%;padding:1rem 2rem;text-align:center;}
.tslide .quote{font-family:var(--serif);font-size:clamp(1.4rem,3vw,2rem);font-style:italic;color:var(--navy);line-height:1.35;margin-bottom:1.4rem;}
.tslide .who{font-size:.8rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.tslide .who b{color:var(--navy);display:block;font-family:var(--serif);font-size:1.15rem;letter-spacing:0;text-transform:none;font-weight:500;margin-bottom:.2rem;}
.tcar-dots{display:flex;gap:.5rem;justify-content:center;margin-top:2rem;}
.tcar-dots button{width:9px;height:9px;border-radius:50%;border:none;background:var(--driftwood);opacity:.4;cursor:pointer;transition:.3s;}
.tcar-dots button.active{opacity:1;background:var(--gold);width:26px;border-radius:100px;}
.tcar-arrows{display:flex;gap:.8rem;justify-content:center;margin-top:1.2rem;}
.tcar-arrows button{width:44px;height:44px;border-radius:50%;border:1px solid var(--driftwood);background:transparent;color:var(--navy);cursor:pointer;font-size:1rem;transition:.3s;}
.tcar-arrows button:hover{background:var(--navy);color:#fff;border-color:var(--navy);}

/* ---------- Portfolio ---------- */
.folio{display:grid;grid-template-columns:repeat(3,1fr);gap:1.6rem;}
.folio-card{border-radius:var(--radius);overflow:hidden;background:#fff;border:1px solid var(--stone);transition:transform .4s var(--ease),box-shadow .4s var(--ease);}
.folio-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);}
.folio-thumb{aspect-ratio:4/3;background:var(--stone);overflow:hidden;}
.folio-thumb img{width:100%;height:100%;object-fit:cover;transition:transform .6s var(--ease);}
.folio-card:hover .folio-thumb img{transform:scale(1.05);}
.folio-body{padding:1.4rem 1.5rem 1.7rem;}
.folio-body .cat{font-size:.7rem;letter-spacing:.16em;text-transform:uppercase;color:var(--gold);}
.folio-body h3{margin:.4rem 0 .5rem;font-size:1.4rem;}
.folio-body p{color:var(--muted);font-size:.92rem;margin:0 0 1rem;}
.folio-body .visit{font-size:.78rem;letter-spacing:.12em;text-transform:uppercase;color:var(--navy);border-bottom:1px solid var(--gold);padding-bottom:2px;}

/* ---------- Split / About ---------- */
.split{display:grid;grid-template-columns:.9fr 1.1fr;gap:clamp(2rem,5vw,4rem);align-items:center;}
.split.rev{grid-template-columns:1.1fr .9fr;}
.about-photo .photo-frame{border-radius:14px 14px 200px 200px;overflow:hidden;aspect-ratio:3/3.7;background:var(--stone);box-shadow:var(--shadow);}
.about-photo .photo-frame img{width:100%;height:100%;object-fit:cover;}
.stat-row{display:flex;gap:2.5rem;margin-top:1.5rem;flex-wrap:wrap;}
.stat b{font-family:var(--serif);font-size:2.2rem;color:var(--navy);display:block;line-height:1;}
.stat span{font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--muted);}

/* ---------- Contact ---------- */
.contact-grid{display:grid;grid-template-columns:1.1fr .9fr;gap:clamp(2rem,5vw,4rem);}
.form-field{margin-bottom:1.2rem;}
.form-field label{display:block;font-size:.74rem;letter-spacing:.14em;text-transform:uppercase;color:var(--navy);margin-bottom:.5rem;}
.form-field input,.form-field select,.form-field textarea{
  width:100%;padding:.9rem 1rem;border:1px solid var(--driftwood);border-radius:10px;
  background:#fff;font-family:var(--sans);font-size:1rem;color:var(--ink);transition:border .3s;
}
.form-field input:focus,.form-field select:focus,.form-field textarea:focus{outline:none;border-color:var(--gold);}
.form-field textarea{min-height:130px;resize:vertical;}
.form-note{font-size:.82rem;color:var(--muted);margin-top:.6rem;}
.book-card{background:var(--navy);color:var(--peach-soft);border-radius:18px;padding:2.4rem;display:flex;flex-direction:column;justify-content:center;}
.book-card h3{color:#fff;}
.book-card ul{list-style:none;padding:0;margin:1.4rem 0 0;}
.book-card ul li{padding:.5rem 0 .5rem 1.6rem;position:relative;font-size:.95rem;color:rgba(255,255,255,.85);}
.book-card ul li::before{content:"✦";position:absolute;left:0;color:var(--peach);}

/* ---------- CTA band ---------- */
.cta-band{background:var(--navy);color:var(--peach-soft);text-align:center;}
.cta-band h2{color:#fff;}
.cta-band .lead{color:rgba(255,255,255,.8);margin-left:auto;margin-right:auto;}

/* ---------- FAQ ---------- */
.faq{max-width:780px;margin:0 auto;}
.faq details{border-bottom:1px solid var(--stone);padding:1.2rem 0;}
.faq summary{font-family:var(--serif);font-size:1.3rem;color:var(--navy);cursor:pointer;list-style:none;display:flex;justify-content:space-between;align-items:center;}
.faq summary::-webkit-details-marker{display:none;}
.faq summary::after{content:"+";color:var(--gold);font-size:1.5rem;transition:transform .3s;}
.faq details[open] summary::after{transform:rotate(45deg);}
.faq details p{color:var(--muted);margin:.9rem 0 0;font-size:.98rem;}

/* ---------- Footer ---------- */
.site-footer{background:var(--navy);color:rgba(255,255,255,.7);padding:4rem 0 2rem;}
.footer-grid{display:flex;justify-content:space-between;gap:2rem;flex-wrap:wrap;align-items:flex-start;}
.site-footer .brand-name{color:#fff;}
.site-footer .brand-sub{color:var(--driftwood);}
.site-footer .brand img{height:62px;width:auto;display:block;margin-bottom:.6rem;align-self:flex-start;flex:0 0 auto;}
.footer-nav{display:flex;gap:1.6rem;flex-wrap:wrap;}
.footer-nav a{font-size:.8rem;letter-spacing:.12em;text-transform:uppercase;transition:color .3s;}
.footer-nav a:hover{color:var(--peach);}
.footer-bottom{margin-top:3rem;padding-top:1.5rem;border-top:1px solid rgba(255,255,255,.12);font-size:.78rem;letter-spacing:.06em;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.6rem;}

/* ---------- Scroll reveal ---------- */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .8s var(--ease),transform .8s var(--ease);}
.reveal.in{opacity:1;transform:none;}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  .hero-grid,.split,.split.rev,.contact-grid{grid-template-columns:1fr;}
  .hero-photo{order:-1;max-width:420px;margin:0 auto;}
  .grid-3,.folio{grid-template-columns:repeat(2,1fr);}
  .steps{grid-template-columns:repeat(2,1fr);}
  .nav-links{
    position:fixed;inset:108px 0 auto 0;background:var(--white-sand);
    flex-direction:column;gap:0;padding:1rem 0;border-bottom:1px solid var(--stone);
    transform:translateY(-120%);transition:transform .4s var(--ease);box-shadow:var(--shadow-soft);
  }
  .nav-links.open{transform:translateY(0);}
  .nav-links li{width:100%;text-align:center;}
  .nav-links a{display:block;padding:1rem;}
  .nav-links .nav-cta{margin:1rem auto;}
  .nav-toggle{display:block;}
}
@media(max-width:560px){
  .grid-3,.grid-2,.folio,.steps{grid-template-columns:1fr;}
  .pricing-grid{grid-template-columns:1fr !important;}
}
.pricing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.5rem;align-items:stretch;}
@media(max-width:900px){.pricing-grid{grid-template-columns:1fr;max-width:460px;margin:0 auto;}}
