/* ========================================
   New York Wallpaper Installers — Main Stylesheet
   Color Palette:
   - Primary bg: dark plum #3D1F3E
   - Secondary bg: black aubergine #1E0F1F
   - Light sections: creamy sand #F5EDE0
   - Text on dark: pale almond #F0E6D3
   - Text on light: plum-charcoal #3A2A3B
   - Accent: vintage rose gold #C8917C
   ======================================== */

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;font-size:16px}
body{font-family:'Georgia','Times New Roman',serif;color:#3A2A3B;background:#F5EDE0;line-height:1.7}
img{max-width:100%;height:auto;display:block}
a{color:inherit;text-decoration:none}
ul,ol{list-style:none}

/* ---- UTILITY ---- */
.container{max-width:1200px;margin:0 auto;padding:0 20px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.text-center{text-align:center}

/* ---- HEADER ---- */
.top-bar{background:#3D1F3E;color:#F0E6D3;padding:8px 0;border-bottom:1px solid rgba(200,145,124,.2)}
.top-bar-inner{display:flex;align-items:center;justify-content:flex-end;gap:18px;max-width:1200px;margin:0 auto;padding:0 20px;font-size:.9rem}
.top-bar-inner a{color:#C8917C;transition:opacity .3s}
.top-bar-inner a:hover{opacity:.8}
.site-header{position:sticky;top:0;z-index:950;background:#1E0F1F;color:#F0E6D3;padding:16px 0}
.header-inner{display:flex;align-items:center;justify-content:space-between;max-width:1200px;margin:0 auto;padding:0 20px}
.site-logo{font-size:1.25rem;font-weight:700;color:#C8917C;white-space:nowrap}
.site-logo a{color:#C8917C}
.desktop-nav{display:flex;align-items:center;gap:24px}
.desktop-nav > a,.desktop-nav > .nav-item > a{color:#F0E6D3;font-size:.95rem;transition:color .3s}
.desktop-nav > a:hover,.desktop-nav > .nav-item > a:hover{color:#C8917C}
.desktop-nav .nav-item{position:relative}
.desktop-nav .has-dropdown::after{
  content:"";
  position:absolute;
  left:0;
  top:100%;
  width:240px;
  min-width:100%;
  height:10px
}
.desktop-nav .dropdown-menu{
  display:none;
  position:absolute;
  top:calc(100% + 10px);
  left:0;
  min-width:240px;
  background:#1E0F1F;
  border:1px solid rgba(200,145,124,.25);
  border-radius:8px;
  box-shadow:0 10px 28px rgba(0,0,0,.28);
  padding:8px 0;
  z-index:1100
}
.desktop-nav .dropdown-menu a{
  display:block;
  padding:8px 14px;
  color:#F0E6D3;
  font-size:.9rem;
  white-space:nowrap;
  transition:background .25s,color .25s
}
.desktop-nav .dropdown-menu a:hover{background:rgba(200,145,124,.12);color:#C8917C}
.desktop-nav .has-dropdown:hover .dropdown-menu,.desktop-nav .has-dropdown:focus-within .dropdown-menu{display:block}
.desktop-nav .has-dropdown > a::after{content:" ▾";font-size:.75rem;color:#C8917C}
.header-contact{display:flex;align-items:center;gap:18px;font-size:.9rem}
.header-contact a{color:#C8917C;transition:opacity .3s}
.header-contact a:hover{opacity:.8}

/* Burger Menu */
.burger-toggle{display:none}
.burger-label{display:none;cursor:pointer;flex-direction:column;gap:5px;padding:8px}
.burger-label span{display:block;width:26px;height:3px;background:#F0E6D3;border-radius:2px;transition:transform .3s,opacity .3s}
.mobile-nav{display:none;position:fixed;top:0;left:0;width:100%;height:100%;padding:84px 20px 28px;background:rgba(30,15,31,.97);z-index:1000;flex-direction:column;align-items:center;justify-content:flex-start;gap:12px;overflow-y:auto}
.mobile-nav > a,.mobile-nav .mobile-dropdown{width:min(560px,100%)}
.mobile-nav a{display:block;color:#F0E6D3;font-size:1.2rem;transition:color .3s}
.mobile-nav a:hover{color:#C8917C}
.mobile-nav .close-nav{position:absolute;top:20px;right:24px;font-size:2rem;color:#F0E6D3;cursor:pointer}
.mobile-dropdown summary{list-style:none;cursor:pointer;color:#F0E6D3;font-size:1.2rem}
.mobile-dropdown summary::-webkit-details-marker{display:none}
.mobile-dropdown > summary::after{content:"▾";float:right;color:#C8917C;transition:transform .25s}
.mobile-dropdown[open] > summary::after{transform:rotate(180deg)}
.mobile-submenu{margin-top:8px;padding-left:14px;display:flex;flex-direction:column;gap:8px}
.mobile-submenu a{font-size:1rem;opacity:.9}
.burger-toggle:checked ~ .mobile-nav{display:flex}

@media(max-width:900px){
  .top-bar{display:none}
  .desktop-nav,.header-contact{display:none}
  .header-inner{
    display:grid;
    grid-template-columns:minmax(0,1fr) auto;
    gap:12px;
    align-items:center
  }
  .site-logo{
    min-width:0;
    white-space:normal;
    overflow-wrap:anywhere;
    line-height:1.2;
    font-size:1.05rem
  }
  .site-logo a{display:block}
  .burger-label{display:flex}
}

@media(max-width:420px){
  .site-logo{font-size:.95rem}
}

/* ---- HERO ---- */
.hero{position:relative;min-height:520px;display:flex;align-items:center;justify-content:center;background-size:cover;background-position:center;background-repeat:no-repeat;color:#F0E6D3;text-align:center;padding:60px 20px}
.hero::before{content:'';position:absolute;inset:0;background:rgba(30,15,31,.65)}
.hero-content{
  position:relative;
  z-index:2;
  width:min(1200px,100%);
  display:flex;
  gap:32px;
  align-items:center;
  justify-content:space-between;
  text-align:left
}
.hero-copy{flex:1 1 auto;max-width:640px}
.hero-content .feedback-form-container{flex:0 1 520px;margin:0}
.hero-content.hero-content-single{
  display:block;
  max-width:900px;
  text-align:center
}
.hero-content.hero-content-single p{max-width:760px;margin:0 auto 24px}
.hero-content.hero-content-single .btn{margin-top:4px}
.hero h1{font-size:2.6rem;margin-bottom:8px;line-height:1.2;color:#F0E6D3}
.hero p{font-size:1.15rem;margin-bottom:24px;color:#F0E6D3;opacity:.92}
.hero .btn{display:inline-block;padding:14px 36px;background:#C8917C;color:#1E0F1F;font-size:1rem;font-weight:700;border:none;cursor:pointer;transition:background .3s,box-shadow .3s;text-transform:uppercase;letter-spacing:1px}
.hero .btn:hover{background:#d4a08c;box-shadow:0 4px 18px rgba(200,145,124,.4)}
.hero--home{min-height:620px;padding:36px 20px 32px}
.hero--home::before{background:linear-gradient(180deg,rgba(10,10,10,.56) 0%,rgba(10,10,10,.68) 52%,rgba(10,10,10,.74) 100%)}
.hero-content.hero-content-home{
  width:min(1240px,100%);
  min-height:540px;
  display:grid;
  grid-template-rows:auto 1fr auto;
  align-items:start;
  gap:24px;
  text-align:center
}
.hero-topline{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
  font-size:.9rem;
  letter-spacing:.16em;
  text-transform:uppercase;
  color:rgba(240,230,211,.92)
}
.hero-topline-phone{
  color:rgba(240,230,211,.9);
  font-weight:600;
  white-space:nowrap
}
.hero-topline-phone:hover{color:#fff}
.hero-location{
  display:inline-flex;
  align-items:center;
  gap:8px
}
.hero-location::before{
  content:'';
  width:9px;
  height:9px;
  border-radius:50%;
  background:#C8917C;
  box-shadow:0 0 0 4px rgba(200,145,124,.2)
}
.hero-center{
  align-self:center;
  width:min(760px,100%);
  margin:0 auto
}
.hero--home h1{
  font-size:clamp(2.2rem,6.2vw,4rem);
  line-height:1.04;
  margin-bottom:14px;
  letter-spacing:.01em;
  text-transform:uppercase
}
.hero--home p{
  font-size:clamp(1rem,1.8vw,1.2rem);
  margin:0 auto 24px;
  max-width:640px;
  color:rgba(240,230,211,.9)
}
.hero-main-cta{
  background:#fff !important;
  color:#191919 !important;
  border-radius:0;
  padding:14px 34px !important;
  letter-spacing:.12em !important;
  font-size:.82rem !important
}
.hero-main-cta:hover{
  background:#f2f2f2 !important;
  box-shadow:0 10px 30px rgba(0,0,0,.28) !important
}
.hero-bottomline{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  padding:0 72px;
  font-size:.86rem;
  letter-spacing:.08em;
  text-transform:uppercase;
  color:rgba(240,230,211,.85)
}
.hero-bottomline span{
  display:block;
  padding-top:14px;
  border-top:1px solid rgba(240,230,211,.2)
}

/* ---- SECTION BLOCKS ---- */
.section-dark{background:#3D1F3E;color:#F0E6D3;padding:64px 0}
.section-light{background:#F5EDE0;color:#3A2A3B;padding:64px 0}
.section-aubergine{background:#1E0F1F;color:#F0E6D3;padding:64px 0}
.section-dark h2,.section-aubergine h2,.section-dark .section-title,.section-aubergine .section-title{color:#C8917C;font-size:2rem;margin-bottom:20px;text-align:center}
.section-light h2,.section-light .section-title{color:#3D1F3E;font-size:2rem;margin-bottom:20px;text-align:center}
.section-dark p,.section-aubergine p{color:#F0E6D3;line-height:1.8}
.section-light p{color:#3A2A3B;line-height:1.8}

/* ---- GRID LAYOUTS ---- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid-4{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
@media(max-width:900px){
  .grid-2,.grid-3,.grid-4{grid-template-columns:1fr}
  .hero-content{flex-direction:column;text-align:center}
  .hero-copy{max-width:800px}
  .hero-content .feedback-form-container{width:100%;max-width:600px;margin:0 auto}
  .hero-content.hero-content-home{display:grid}
  .hero-topline{font-size:.74rem;letter-spacing:.12em}
  .hero-bottomline{grid-template-columns:1fr;padding:0;gap:8px}
}

/* ---- CARDS ---- */
.card{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 12px rgba(0,0,0,.08);transition:transform .3s,box-shadow .3s}
.card:hover{transform:translateY(-4px);box-shadow:0 6px 24px rgba(0,0,0,.12)}
.card img{width:100%;height:220px;object-fit:cover}
.card-body{padding:20px}
.card-body h3{font-size:1.2rem;margin-bottom:8px;color:#3D1F3E}
.card-body p{font-size:.95rem;color:#5a4a5b}
.card-body .btn-link{display:inline-block;margin-top:12px;color:#C8917C;font-weight:700;transition:color .3s}
.card-body .btn-link:hover{color:#3D1F3E}

/* ---- SERVICE CARDS (on dark bg) ---- */
.service-card{background:rgba(255,255,255,.06);border:1px solid rgba(200,145,124,.2);border-radius:8px;padding:28px;text-align:center;transition:border-color .3s,background .3s}
.service-card:hover{border-color:#C8917C;background:rgba(200,145,124,.08)}
.service-card img{width:100%;height:200px;object-fit:cover;border-radius:6px;margin-bottom:16px}
.service-card h3{color:#C8917C;font-size:1.15rem;margin-bottom:8px}
.service-card p{font-size:.9rem;color:#F0E6D3;opacity:.85}

/* ---- HOME SERVICES EXPLORER ---- */
.services-explorer{
  display:grid;
  grid-template-columns:minmax(280px,420px) minmax(0,1fr);
  gap:24px;
  align-items:stretch
}
.services-list{
  display:flex;
  flex-direction:column;
  gap:10px
}
.services-list-item{
  width:100%;
  border:1px solid rgba(200,145,124,.24);
  background:rgba(255,255,255,.04);
  color:#F0E6D3;
  text-align:left;
  border-radius:8px;
  padding:14px 16px;
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  gap:14px;
  align-items:center;
  cursor:pointer;
  transition:border-color .25s,background .25s,transform .25s
}
.services-list-item:hover,
.services-list-item:focus-visible,
.services-list-item.is-active{
  border-color:#C8917C;
  background:rgba(200,145,124,.12);
  transform:translateX(4px)
}
.services-list-item:focus-visible{outline:2px solid rgba(200,145,124,.55);outline-offset:2px}
.services-list-index{
  font-size:.82rem;
  letter-spacing:.15em;
  color:rgba(240,230,211,.7)
}
.services-list-copy strong{
  display:block;
  color:#F0E6D3;
  font-size:1.05rem
}
.services-list-copy small{
  display:block;
  margin-top:2px;
  font-size:.82rem;
  color:rgba(240,230,211,.72)
}
.services-preview{
  position:relative;
  overflow:hidden;
  border-radius:10px;
  height:460px;
  border:1px solid rgba(200,145,124,.24)
}
.services-preview img{
  width:100%;
  height:100%;
  object-fit:cover;
  display:block
}
.services-preview-overlay{
  position:absolute;
  inset:auto 0 0 0;
  padding:22px;
  background:linear-gradient(180deg,rgba(11,8,12,0) 0%,rgba(11,8,12,.82) 60%,rgba(11,8,12,.94) 100%)
}
.services-preview-overlay h3{
  margin:0 0 6px;
  color:#F0E6D3;
  font-size:1.35rem
}
.services-preview-overlay p{
  margin:0 0 14px;
  color:rgba(240,230,211,.9);
  font-size:.95rem;
  line-height:1.6
}
.services-preview-cta{
  display:inline-block;
  padding:10px 16px;
  background:#fff;
  color:#1a1a1a;
  text-transform:uppercase;
  letter-spacing:.08em;
  font-size:.72rem;
  font-weight:700
}
@media(max-width:900px){
  .services-explorer{grid-template-columns:1fr}
  .services-preview{height:320px}
  .services-list-item:hover,
  .services-list-item:focus-visible,
  .services-list-item.is-active{transform:none}
}

/* ---- BUTTONS ---- */
.btn-primary{display:inline-block;padding:14px 36px;background:#C8917C;color:#1E0F1F;font-size:1rem;font-weight:700;border:none;cursor:pointer;transition:background .3s,box-shadow .3s;text-transform:uppercase;letter-spacing:1px}
.btn-primary:hover{background:#d4a08c;box-shadow:0 4px 18px rgba(200,145,124,.4)}
.btn-secondary{display:inline-block;padding:12px 30px;border:2px solid #C8917C;color:#C8917C;font-size:.95rem;font-weight:700;transition:background .3s,color .3s}
.btn-secondary:hover{background:#C8917C;color:#1E0F1F}

/* ---- CONTACT FORM ---- */
.feedback-form-container{max-width:600px;margin:0 auto;padding:32px;background:rgba(255,255,255,.06);border-radius:10px;border:1px solid rgba(200,145,124,.25)}
.hero .feedback-form-container{background:rgba(15,8,16,.72);border-color:rgba(200,145,124,.42)}
.feedback-form-container h3,.feedback-form-container .form-title{color:#C8917C;font-size:1.4rem;margin-bottom:20px;text-align:center}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
@media(max-width:600px){.form-row{grid-template-columns:1fr}}
.form-group{margin-bottom:0}
.form-group input,.form-group textarea{width:100%;padding:12px 16px;background:rgba(255,255,255,.08);border:1px solid rgba(200,145,124,.3);border-radius:6px;color:#F0E6D3;font-size:.95rem;font-family:inherit;transition:border-color .3s}
.form-group input::placeholder,.form-group textarea::placeholder{color:rgba(240,230,211,.5)}
.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#C8917C}
.form-group textarea{min-height:100px;resize:vertical}
.form-submit{text-align:center;margin-top:16px}
.submit-btn{display:inline-block;padding:14px 48px;background:#C8917C;color:#1E0F1F;font-size:1rem;font-weight:700;border:none;cursor:pointer;border-radius:6px;transition:background .3s,box-shadow .3s;text-transform:uppercase;letter-spacing:1px}
.submit-btn:hover{background:#d4a08c;box-shadow:0 4px 18px rgba(200,145,124,.4)}
#form-success p{color:#C8917C;font-size:1.1rem;text-align:center;padding:20px}

/* Form on light bg */
.section-light .feedback-form-container{background:rgba(61,31,62,.04);border-color:rgba(61,31,62,.15)}
.section-light .feedback-form-container h3,.section-light .feedback-form-container .form-title{color:#3D1F3E}
.section-light .form-group input,.section-light .form-group textarea{background:#fff;border-color:rgba(61,31,62,.2);color:#3A2A3B}
.section-light .form-group input::placeholder,.section-light .form-group textarea::placeholder{color:rgba(58,42,59,.45)}
.section-light .form-group input:focus,.section-light .form-group textarea:focus{border-color:#C8917C}

/* ---- TESTIMONIALS ---- */
.testimonials-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:28px}
@media(max-width:900px){.testimonials-grid{grid-template-columns:1fr}}
.testimonial-card{background:rgba(255,255,255,.06);border:1px solid rgba(200,145,124,.15);border-radius:8px;padding:24px;text-align:center}
.testimonial-card .stars{color:#C8917C;font-size:1.1rem;margin-bottom:8px}
.testimonial-card blockquote{font-style:italic;font-size:.95rem;line-height:1.6;margin-bottom:12px;color:#F0E6D3;opacity:.9}
.testimonial-card .reviewer{font-weight:700;color:#C8917C;font-size:.9rem}
.section-light .testimonial-card{background:rgba(61,31,62,.03);border-color:rgba(61,31,62,.1)}
.section-light .testimonial-card blockquote{color:#3A2A3B;opacity:1}
.section-light .testimonial-card .reviewer{color:#3D1F3E}

/* ---- BREADCRUMBS ---- */
.breadcrumbs{padding:12px 0;font-size:.85rem;color:#F0E6D3;opacity:.7}
.breadcrumbs a{color:#C8917C;transition:opacity .3s}
.breadcrumbs a:hover{opacity:.8}
.breadcrumbs span{margin:0 6px}
.section-light .breadcrumbs{color:#3A2A3B;opacity:.6}
.section-light .breadcrumbs a{color:#3D1F3E}

/* Keep breadcrumb trail near the top edge of hero sections */
.hero .breadcrumbs{
  position:absolute;
  top:2px;
  left:50%;
  transform:translateX(-50%);
  width:min(1200px,calc(100% - 40px));
  padding:0;
  text-align:left;
  z-index:3
}
.hero .hero-content > .breadcrumbs + h1{margin-top:34px}
@media(max-width:900px){
  .hero .breadcrumbs{top:6px}
  .hero .hero-content > .breadcrumbs + h1{margin-top:30px}
}

/* ---- FAQ ---- */
.faq-item{border-bottom:1px solid rgba(200,145,124,.2);padding:20px 0}
.faq-item h3{font-size:1.1rem;margin-bottom:8px;color:#C8917C}
.faq-item p{font-size:.95rem;line-height:1.7}
.section-light .faq-item h3{color:#3D1F3E}
.section-light .faq-item{border-color:rgba(61,31,62,.12)}

/* ---- FAQ ACCORDION ---- */
.faq-accordion{
  max-width:920px;
  margin:0 auto
}
.faq-accordion-item{
  border:1px solid rgba(61,31,62,.15);
  border-radius:8px;
  background:rgba(255,255,255,.66);
  overflow:hidden
}
.faq-accordion-item + .faq-accordion-item{margin-top:12px}
.faq-question{
  width:100%;
  border:none;
  background:transparent;
  color:#3D1F3E;
  text-align:left;
  padding:18px 52px 18px 18px;
  font:700 1rem/1.4 'Georgia','Times New Roman',serif;
  cursor:pointer;
  position:relative
}
.faq-question::after{
  content:'+';
  position:absolute;
  right:18px;
  top:50%;
  transform:translateY(-50%);
  font-size:1.35rem;
  line-height:1;
  color:#C8917C;
  transition:transform .2s ease
}
.faq-accordion-item.is-open .faq-question::after{
  content:'\2212'
}
.faq-question:focus-visible{
  outline:2px solid rgba(200,145,124,.55);
  outline-offset:-2px
}
.faq-answer{
  max-height:0;
  overflow:hidden;
  transition:max-height .3s ease
}
.faq-answer p{
  margin:0;
  padding:0 18px 18px;
  font-size:.96rem;
  color:#3A2A3B
}
.faq-accordion-item.is-open .faq-answer{
  max-height:260px
}

/* ---- PROCESS STEPS ---- */
.process-steps{display:grid;grid-template-columns:repeat(4,1fr);gap:24px;margin-top:28px}
@media(max-width:900px){.process-steps{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.process-steps{grid-template-columns:1fr}}
.step{text-align:center;padding:24px 16px}
.step-number{display:inline-flex;align-items:center;justify-content:center;width:48px;height:48px;border-radius:50%;background:#C8917C;color:#1E0F1F;font-size:1.2rem;font-weight:700;margin-bottom:12px}
.step h3{font-size:1rem;margin-bottom:6px;color:#C8917C}
.step p{font-size:.9rem;opacity:.85}

/* ---- AREAS GRID ---- */
.areas-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:28px}
@media(max-width:900px){.areas-grid{grid-template-columns:1fr 1fr}}
@media(max-width:500px){.areas-grid{grid-template-columns:1fr}}
.area-card{display:block;background:rgba(255,255,255,.06);border:1px solid rgba(200,145,124,.2);border-radius:8px;padding:20px;text-align:center;transition:border-color .3s,background .3s}
.area-card:hover{border-color:#C8917C;background:rgba(200,145,124,.08)}
.area-card h3,.area-card .area-card-title{color:#C8917C;font-size:1.1rem;margin-bottom:4px}
.area-card .area-card-title{display:block}
.area-card p{font-size:.85rem;opacity:.8}

/* ---- IMAGE PANELS ---- */
.img-panel{border-radius:8px;overflow:hidden;box-shadow:0 4px 20px rgba(0,0,0,.1)}
.img-panel img{width:100%;height:100%;object-fit:cover}

/* ---- MAP ---- */
.map-container{width:100%;max-width:100%;margin:24px auto 0;border-radius:8px;overflow:hidden}
.map-container iframe{width:100%;height:400px;border:0}

/* ---- FOOTER ---- */
.site-footer{background:#1E0F1F;color:#F0E6D3;padding:48px 0 24px}
.footer-grid{display:grid;grid-template-columns:1fr 1fr 1fr;gap:32px;margin-bottom:32px}
@media(max-width:768px){.footer-grid{grid-template-columns:1fr}}
.footer-col h3,.footer-col .footer-title{color:#C8917C;font-size:1.1rem;margin-bottom:12px}
.footer-col p,.footer-col a{font-size:.9rem;color:#F0E6D3;opacity:.8;line-height:1.8}
.footer-col a:hover{color:#C8917C;opacity:1}
.footer-col ul li{margin-bottom:6px}
.footer-bottom{text-align:center;padding-top:24px;border-top:1px solid rgba(200,145,124,.15);font-size:.85rem;opacity:.6}

/* ---- STICKY QUOTE BUTTON ---- */
.sticky-quote-btn{position:fixed;bottom:24px;right:24px;z-index:900;padding:14px 28px;background:#C8917C;color:#1E0F1F;font-weight:700;font-size:.95rem;border:none;cursor:pointer;border-radius:6px;box-shadow:0 4px 16px rgba(200,145,124,.35);transition:background .3s,box-shadow .3s;text-transform:uppercase;letter-spacing:1px}
.sticky-quote-btn:hover{background:#d4a08c;box-shadow:0 6px 24px rgba(200,145,124,.5)}
@media(max-width:768px){
  .sticky-quote-btn{right:50%;transform:translateX(50%);bottom:16px;font-size:.85rem;padding:12px 24px}
}

/* ---- MODAL ---- */
.modal-overlay{display:none;position:fixed;inset:0;background:rgba(30,15,31,.85);z-index:1001;align-items:center;justify-content:center;padding:20px}
.modal-overlay.active{display:flex}
.modal-content{position:relative;max-width:640px;width:100%;max-height:90vh;overflow-y:auto;background:#3D1F3E;border-radius:12px;padding:32px}
.modal-close{position:absolute;top:12px;right:16px;font-size:1.8rem;color:#F0E6D3;cursor:pointer;background:none;border:none;line-height:1;transition:color .3s}
.modal-close:hover{color:#C8917C}

/* ---- CONTENT TYPOGRAPHY ---- */
.content-block{max-width:900px;margin:0 auto}
.content-block p{margin-bottom:16px;font-size:1rem;line-height:1.8}
.content-block h2{margin-top:32px;margin-bottom:16px}
.content-block h3{font-size:1.15rem;margin-top:24px;margin-bottom:10px;color:#C8917C}
.section-light .content-block h3{color:#3D1F3E}
.content-block ul{padding-left:20px;margin-bottom:16px}
.content-block ul li{margin-bottom:8px;position:relative;padding-left:16px;font-size:.95rem}
.content-block ul li::before{content:'';position:absolute;left:0;top:10px;width:6px;height:6px;border-radius:50%;background:#C8917C}

/* ---- ANIMATIONS ---- */
@keyframes fadeIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
