/* Updated: 2024 - Fixed topbar color */
:root{
  --brown-900:#E8D5C4;
  --brown-800:#F0E6D8;
  --brown-700:#F5E6D3;
  --brown-600:#F8EBD7;
  --brown-500:#F5E6D3;
  --beige-100:#F5E6D3;
  --beige-050:#F8EBD7;
  --ink-900:#1a1a1a;
  --ink-700:#1a1a1a;
  --ink-500:#333333;
  --ink-300:#555555;
  --white:#ffffff;
  --card:#F8EBD7;
  --shadow:0 10px 30px rgba(232,213,196,.12);
  --radius:14px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:var(--ink-900);background:var(--beige-050);scroll-behavior:smooth}

/* Josefin Slab for headings and titles */
h1, h2, h3, h4, h5, h6,
.hero__copy h1,
.lead,
.sub,
.nav__brand-text strong,
.service-card h3,
.about-feature h4,
.why-feature h4,
.mission-card h4,
.faq-question h4,
.contact-card h3,
.footer__brand h3,
.footer__section h4 {
  font-family: 'Josefin Slab', serif;
}
.container{width:min(1120px,92%);margin-inline:auto}
.center{text-align:center}
.small{font-size:.875rem}
.tiny{font-size:.75rem}
.mute{color:#333333}
.gap-md{display:flex;gap:12px;justify-content:center}

/* Topbar */
.topbar{background:#F5E6D3;color:#1a1a1a;font-size:.9rem}
.topbar .container{display:flex;align-items:center;justify-content:space-between;padding:6px 0}
.topbar .timing{font-weight:600;color:#1a1a1a}
.topbar .link{color:#1a1a1a;text-decoration:none}
.topbar .dot{opacity:.6;margin:0 8px}

/* Header/Nav */
.header{position:sticky;top:0;z-index:50;background:#E6D7C3;backdrop-filter:saturate(180%) blur(8px);transition:background .25s ease, box-shadow .25s ease}
.header.scrolled{background:rgba(230,215,195,.95);box-shadow:0 6px 24px rgba(0,0,0,.15)}

.nav{display:flex;align-items:center;justify-content:space-between;padding:18px 0}
.nav__brand{display:flex;gap:12px;align-items:center;color:inherit;text-decoration:none;transition:transform .25s ease}
.nav__brand:hover{transform:translateY(-1px)}
.logo{width:56px;height:56px;border-radius:12px;object-fit:cover;box-shadow:0 6px 16px rgba(0,0,0,.12)}
.nav__brand-text small{display:block;color:#1a1a1a;font-weight:600}
.header.scrolled .nav__brand-text small{color:#1a1a1a}
.nav__brand-text strong{font-size:1.4rem;font-weight:900;font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif;color:#1a1a1a;text-shadow:0 1px 2px rgba(255,255,255,0.8)}
.header.scrolled .nav__brand-text strong{color:#1a1a1a;text-shadow:0 1px 2px rgba(255,255,255,0.8)}
.nav__menu{display:flex;gap:18px;align-items:center}
.nav__menu a{color:#1a1a1a;text-decoration:none;font-weight:600;padding:8px 16px;border-radius:6px;transition:all .3s ease}
.nav__menu a:hover{background:rgba(139,69,19,0.1);color:#333333;transform:translateY(-2px)}
.header.scrolled .nav__menu a{color:#1a1a1a}
.header.scrolled .nav__menu a:hover{background:rgba(139,69,19,0.15);color:#333333}
.btn{display:inline-block;padding:12px 18px;border-radius:999px;font-weight:700;text-decoration:none;transition:transform .15s ease,box-shadow .2s ease}
.btn:active{transform:translateY(1px)}
.btn--primary{background:linear-gradient(135deg,var(--brown-600),var(--brown-700));color:#1a1a1a;box-shadow:0 8px 18px rgba(210,105,30,.35)}
.btn--outline{border:2px solid var(--brown-700);color:#1a1a1a;background:transparent}
.btn--services{background:var(--white);color:#1a1a1a;border:1px solid var(--brown-300);font-weight:600;padding:14px 28px;font-size:1rem}
.btn--ghost{background:transparent;color:#1a1a1a;border:1px dashed var(--brown-700)}

.nav__toggle{display:none;border:none;background:transparent;width:40px;height:40px;position:relative}
.nav__toggle span{position:absolute;left:8px;right:8px;height:2px;background:currentColor;border-radius:2px;transition:transform .25s ease,opacity .25s ease}
.nav__toggle span:nth-child(1){top:12px}
.nav__toggle span:nth-child(2){top:19px}
.nav__toggle span:nth-child(3){top:26px}
.nav__toggle.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}
.nav__toggle.active span:nth-child(2){opacity:0}
.nav__toggle.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* Hero */
.hero{position:relative;background:var(--brown-700);padding:80px 0;color:var(--ink-900)}
.hero__grid{display:grid;grid-template-columns:1.2fr .8fr;gap:36px;align-items:center}
.hero__copy h1{font-size:clamp(32px,5vw,56px);line-height:1.1;margin:0 0 20px;color:#1a1a1a;font-weight:700}
.lead{font-size:clamp(16px,2.3vw,20px);margin:0 0 32px;color:#1a1a1a;font-weight:400;line-height:1.6}
.sub{margin:.5rem 0 1rem}
.badges{list-style:none;padding:0;margin:18px 0 0;display:flex;flex-wrap:wrap;gap:10px}
.badges li{background:var(--beige-100);border:1px solid #DEB887;color:#1a1a1a;padding:8px 12px;border-radius:999px;font-weight:600}
.hero__image img{width:100%;max-height:520px;object-fit:cover;border-radius:20px;border:3px solid var(--brown-700);box-shadow:0 20px 40px rgba(0,0,0,0.2);animation:floatY 6s ease-in-out infinite;transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);opacity:0;transform:scale(0.95)}
.hero__image img.loaded{opacity:1;transform:scale(1)}
.hero__image{will-change:transform;position:relative;overflow:hidden}
.hero__image:hover img{transform:scale(1.02);box-shadow:0 25px 50px rgba(139,69,19,.25)}

/* Shiny line sweep animation for Hero image */
.hero__image::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-25deg);
  z-index: 1;
  transition: left 0.6s ease-in-out;
}

.hero__image:hover::before {
  left: 100%;
}
.hero__copy .btn{transition:transform .15s ease, box-shadow .2s ease, background .2s ease}
.hero__copy .btn:hover{transform:translateY(-2px)}
.hero__copy .btn.btn--outline:hover{background:var(--beige-100)}

@keyframes floatY{0%{transform:translateY(0)}50%{transform:translateY(-6px)}100%{transform:translateY(0)}}

/* Sections */
.section{padding:72px 0}

/* Different background colors for sections */
.section--about{background:linear-gradient(135deg,#E8F5E8 0%,#F0F8F0 100%)}
.section--services{background:linear-gradient(135deg,#FDF5E6 0%,#FFF8DC 100%)}
.section--why-us{background:linear-gradient(135deg,#F0F8FF 0%,#E6F3FF 100%)}
.section--mission{background:linear-gradient(135deg,#FFF5F5 0%,#FFF0F0 100%)}
.section--faq{background:linear-gradient(135deg,#F8F8F8 0%,#F5F5F5 100%)}
.section--appointment{background:linear-gradient(135deg,#E6F7E6 0%,#F0FFF0 100%)}
.section--contact{background:linear-gradient(135deg,#F5F5DC 0%,#FAF0E6 100%)}
.section--alt{background:#FDF5E6}
.grid.two{display:grid;grid-template-columns:1fr 1fr;gap:32px;align-items:center}
.grid.three{display:grid;grid-template-columns:repeat(3,1fr);gap:18px}

.tick-list{padding-left:18px}
.tick-list li{margin-bottom:8px}

.info-card,.contact-card{background:var(--white);border:1px solid #DEB887;border-radius:16px;padding:18px;box-shadow:0 10px 22px rgba(0,0,0,.06)}
.info-card h3,.contact-card h3{margin-top:0;color:#1a1a1a}

/* Services */
.services{margin-top:28px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.service{background:var(--white);border-radius:16px;border:1px solid #DEB887;box-shadow:0 10px 20px rgba(139,69,19,.06);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease;perspective:1000px}
.service:hover{transform:translateY(-4px);box-shadow:0 18px 32px rgba(139,69,19,.12)}

/* Service Flip Cards */
.service-card{position:relative;width:100%;height:320px;transform-style:preserve-3d;transition:transform .6s ease}
.service:hover .service-card{transform:rotateY(180deg)}

.service-front,.service-back{position:absolute;width:100%;height:100%;backface-visibility:hidden;border-radius:16px;overflow:hidden;display:flex;flex-direction:column}

.service-front{background:var(--white)}
.service-back{background:var(--white);color:#1a1a1a;transform:rotateY(180deg);padding:20px;justify-content:center;text-align:center;border:1px solid #DEB887}

.service-image{width:100%;height:200px;object-fit:cover;border-radius:16px 16px 0 0}
.service-front h3{margin:0;padding:16px;color:#1a1a1a;text-align:center;font-size:1.1rem}
.service-back h3{margin:0 0 12px;color:#1a1a1a;font-size:1.1rem}
.service-back p{margin:0;line-height:1.5;font-size:0.9rem;color:#1a1a1a}

/* Services Buttons */
.services-buttons{margin-top:48px}

/* Features */
.features{margin-top:28px;display:grid;grid-template-columns:repeat(3,1fr);gap:18px}
.feature{background:var(--white);border-radius:16px;padding:18px;border:1px solid #DEB887;box-shadow:0 10px 20px rgba(139,69,19,.06);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.feature:hover{transform:translateY(-4px);box-shadow:0 18px 32px rgba(139,69,19,.12)}
.feature h4{margin-top:0;color:#1a1a1a}

/* Highlights */
.highlight{background:var(--white);border-radius:16px;padding:18px;border:1px solid #DEB887;box-shadow:0 10px 20px rgba(139,69,19,.06);transition:transform .2s ease, box-shadow .2s ease, border-color .2s ease}
.highlight:hover{transform:translateY(-4px);box-shadow:0 18px 32px rgba(139,69,19,.12)}
.highlight__icon{font-size:2rem;display:block;margin-bottom:8px}
.highlight h4{margin-top:0;color:#1a1a1a}

/* FAQ Section */
.faq-container{margin-top:28px;max-width:800px;margin-inline:auto}
.faq-item{background:var(--white);border-radius:16px;margin-bottom:12px;border:1px solid #DEB887;overflow:hidden;box-shadow:0 10px 20px rgba(139,69,19,.06)}
.faq-question{display:flex;justify-content:space-between;align-items:center;padding:18px;cursor:pointer;transition:background .2s ease}
.faq-question:hover{background:var(--beige-050)}
.faq-question h4{margin:0;color:#1a1a1a;font-size:1rem}
.faq-toggle{font-size:1.5rem;color:#1a1a1a;font-weight:bold;transition:transform .2s ease}
.faq-item.active .faq-toggle{transform:rotate(45deg)}
.faq-answer{padding:0 18px;max-height:0;overflow:hidden;transition:all .3s ease}
.faq-item.active .faq-answer{padding:18px;max-height:200px}

/* Social Links */
.social-links{display:flex;gap:12px;margin:18px 0}
.social-link{color:#1a1a1a;text-decoration:none;font-weight:600;padding:8px 12px;border:1px solid var(--brown-500);border-radius:8px;transition:all .2s ease}
.social-link:hover{background:var(--brown-700);color:var(--white)}

/* Contact List */
.contact-list{list-style:none;padding:0;margin:18px 0}
.contact-list li{margin-bottom:8px;display:flex;gap:8px}
.contact-list a{color:#1a1a1a;text-decoration:none}
.contact-list a:hover{text-decoration:underline}

/* Booking Card */
.booking{background:var(--white);border-radius:16px;padding:24px;border:1px solid #DEB887;box-shadow:0 10px 22px rgba(139,69,19,.06);display:flex;justify-content:space-between;align-items:center;gap:24px}
.booking h3{margin-top:0;color:#1a1a1a}
.booking__actions{display:flex;gap:12px;flex-shrink:0}

/* Footer */
.footer{background:#8B4513;color:var(--white);padding:48px 0 24px}
.footer__main{display:grid;grid-template-columns:2fr 1fr 1.5fr 1fr;gap:32px;margin-bottom:32px;transition:all .3s ease}
.footer__main:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,0.2)}
.footer__section{transition:all .3s ease;padding:16px;border-radius:8px;position:relative;overflow:hidden}
.footer__section:hover{background:rgba(255,255,255,0.05);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__section h4{color:var(--white);margin:0 0 16px;font-size:1.1rem;transition:all .3s ease;padding:4px 0;position:relative}
.footer__section h4:hover{color:var(--white);transform:translateX(4px);text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.footer__section h4::after{content:'';position:absolute;bottom:0;left:0;width:0;height:2px;background:var(--white);transition:width .3s ease}
.footer__section h4:hover::after{width:100%}
.footer__brand{display:flex;gap:12px;align-items:center;margin-bottom:16px;transition:all .3s ease;padding:8px;border-radius:8px;cursor:pointer}
.footer__brand:hover{background:rgba(255,255,255,0.05);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__logo{width:48px;height:48px;border-radius:8px;object-fit:cover;transition:all .3s ease;box-shadow:0 2px 8px rgba(0,0,0,0.2)}
.footer__brand:hover .footer__logo{transform:scale(1.1) rotate(5deg);box-shadow:0 4px 16px rgba(0,0,0,0.3)}
.footer__brand h3{margin:0;color:var(--white);font-size:1.2rem;transition:all .3s ease;position:relative}
.footer__brand:hover h3{transform:translateX(4px);text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.footer__brand p{margin:4px 0 0;color:var(--white);font-size:0.9rem;transition:all .3s ease;position:relative}
.footer__brand:hover p{transform:translateX(4px);text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.footer__description{color:var(--white);line-height:1.6;margin:0;transition:all .3s ease;padding:8px;border-radius:6px}
.footer__description:hover{background:rgba(255,255,255,0.05);transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.footer__links{list-style:none;padding:0;margin:0;transition:all .3s ease;padding:8px;border-radius:8px}
.footer__links:hover{background:rgba(255,255,255,0.05);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__links li{margin-bottom:8px;transition:all .3s ease;padding:4px;border-radius:4px}
.footer__links li:hover{background:rgba(255,255,255,0.05);transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.footer__links a{color:var(--white);text-decoration:none;transition:all .3s ease;padding:4px 8px;border-radius:6px;display:inline-block;position:relative;overflow:hidden}
.footer__links a:hover{color:var(--white);background:rgba(255,255,255,0.1);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__links a:active{transform:translateY(0);transition:transform 0.1s ease}
.footer__contact{list-style:none;padding:0;margin:0;transition:all .3s ease;padding:8px;border-radius:8px}
.footer__contact:hover{background:rgba(255,255,255,0.05);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__contact li{margin-bottom:12px;display:flex;flex-direction:column;gap:4px;transition:all .3s ease;padding:4px;border-radius:4px}
.footer__contact li:hover{background:rgba(255,255,255,0.05);transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.footer__contact strong{color:var(--white);font-size:0.9rem;transition:all .3s ease;position:relative}
.footer__contact strong:hover{transform:translateX(4px);text-shadow:0 2px 4px rgba(0,0,0,0.3)}
.footer__contact a,.footer__contact span{color:var(--white);text-decoration:none;font-size:0.9rem;transition:all .3s ease;padding:2px 4px;border-radius:4px;display:inline-block;position:relative}
.footer__contact span:hover{background:rgba(255,255,255,0.1);transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.footer__contact a:hover{color:var(--white);background:rgba(255,255,255,0.1);transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.footer__contact a:active{transform:translateX(2px);transition:transform 0.1s ease}
.footer__social{display:flex;gap:12px;transition:all .3s ease;padding:8px;border-radius:8px}
.footer__social:hover{background:rgba(255,255,255,0.05);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.social-icon{width:40px;height:40px;border-radius:50%;background:rgba(255,255,255,0.1);display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative;overflow:hidden;cursor:pointer}
.social-icon:hover{background:rgba(255,255,255,0.2);transform:translateY(-3px) scale(1.1);box-shadow:0 6px 20px rgba(0,0,0,0.3)}
.social-icon:active{transform:translateY(-1px) scale(1.05);transition:transform 0.1s ease}
.social-icon::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.3);border-radius:50%;transform:translate(-50%,-50%);transition:all 0.3s ease}
.social-icon:hover::before{width:100%;height:100%}
.social-icon svg{width:20px;height:20px;fill:var(--white);transition:all .3s ease;position:relative;z-index:2}
.social-icon:hover svg{transform:scale(1.1) rotate(5deg);filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3))}
.footer__bottom{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid rgba(255,255,255,0.1);transition:all .3s ease;position:relative}
.footer__bottom::before{content:'';position:absolute;top:0;left:0;width:0;height:2px;background:linear-gradient(90deg, var(--white), rgba(255,255,255,0.5), var(--white));transition:width .3s ease}
.footer__bottom:hover::before{width:100%}
.footer__copyright p{margin:0;color:var(--white);font-size:0.9rem;transition:all .3s ease;padding:4px 8px;border-radius:4px;display:inline-block}
.footer__copyright p:hover{background:rgba(255,255,255,0.05);transform:translateX(4px);box-shadow:0 2px 8px rgba(0,0,0,0.15)}
.footer__actions{display:flex;gap:16px;transition:all .3s ease;padding:8px;border-radius:8px}
.footer__actions:hover{background:rgba(255,255,255,0.05);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__action{color:var(--white);text-decoration:none;font-size:0.9rem;transition:all .3s ease;padding:6px 12px;border-radius:6px;display:inline-block;position:relative;overflow:hidden}
.footer__action:hover{color:var(--white);background:rgba(255,255,255,0.1);transform:translateY(-2px);box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.footer__action:active{transform:translateY(0);transition:transform 0.1s ease}

/* Floating CTA */
.floating-cta{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:12px;z-index:100}
.fab{width:56px;height:56px;border-radius:50%;display:flex;align-items:center;justify-content:center;text-decoration:none;box-shadow:0 8px 24px rgba(0,0,0,.15);transition:all .3s ease;position:relative;overflow:hidden;cursor:pointer}
.fab:hover{transform:translateY(-4px) scale(1.05);box-shadow:0 12px 32px rgba(0,0,0,.25)}
.fab:active{transform:translateY(-2px) scale(1.02);transition:transform 0.1s ease}
.fab::before{content:'';position:absolute;top:50%;left:50%;width:0;height:0;background:rgba(255,255,255,0.2);border-radius:50%;transform:translate(-50%,-50%);transition:all 0.3s ease}
.fab:hover::before{width:100%;height:100%}
.fab--call{background:#FF69B4;color:var(--white);position:relative;overflow:hidden}
.fab--call::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);transition:left 0.5s ease}
.fab--call:hover::after{left:100%}
.fab--wa{background:#25D366;color:var(--white);position:relative;overflow:hidden}
.fab--wa::after{content:'';position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg, transparent, rgba(255,255,255,0.2), transparent);transition:left 0.5s ease}
.fab--wa:hover::after{left:100%}
.fab svg{width:24px;height:24px;fill:currentColor;transition:all .3s ease;position:relative;z-index:3}
.fab:hover svg{transform:scale(1.1) rotate(5deg);filter:drop-shadow(0 2px 4px rgba(0,0,0,0.3))}

/* Reveal Animations */
.reveal{opacity:0;transform:translateY(30px);transition:opacity .6s ease,transform .6s ease}
.reveal.visible{opacity:1;transform:translateY(0)}

/* Why Choose Us Section */
.why-choose-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:center;margin-top:32px}
.why-choose-content h2{color:#1a1a1a;font-size:2.5rem;margin:0 0 32px;font-weight:700}
.why-choose-features{display:flex;flex-direction:column;gap:24px}
.why-feature{display:flex;gap:16px;align-items:flex-start}
.feature-bullet{width:8px;height:8px;background:var(--brown-700);border-radius:50%;flex-shrink:0;margin-top:12px}
.feature-text h4{color:#1a1a1a;margin:0 0 8px;font-size:1.1rem;font-weight:600}
.feature-text p{color:var(--ink-700);margin:0;line-height:1.6;font-size:0.95rem}

.why-choose-image{position:relative;overflow:hidden}
.why-choose-image img{width:100%;height:500px;object-fit:cover;border-radius:20px;box-shadow:0 20px 40px rgba(139,69,19,.15);transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);opacity:0;transform:scale(0.95)}
.why-choose-image img.loaded{opacity:1;transform:scale(1)}

/* Shiny line sweep animation for Why Choose Us image */
.why-choose-image:hover img {
  transform: scale(1.02);
  box-shadow: 0 25px 50px rgba(139,69,19,.25);
}

.why-choose-image::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-25deg);
  z-index: 1;
  transition: left 0.6s ease-in-out;
}

.why-choose-image:hover::before {
  left: 100%;
}

/* About Us Section */
.about-grid{display:grid;grid-template-columns:1fr 1fr;gap:48px;align-items:start;margin-top:32px}
.about-content h2{color:#1a1a1a;font-size:2.5rem;margin:0 0 24px;font-weight:700}
.about-lead{color:#333333;font-size:1.1rem;line-height:1.7;margin:0 0 20px;font-weight:500}
.about-content p{color:var(--ink-700);margin:0 0 24px;line-height:1.6;font-size:0.95rem}

.about-features{display:flex;flex-direction:column;gap:20px;margin:32px 0}
.about-feature{display:flex;gap:16px;align-items:flex-start}
.about-feature .feature-bullet{width:8px;height:8px;background:var(--brown-700);border-radius:50%;flex-shrink:0;margin-top:12px}

/* About features when inside the image container */
.about-image .about-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
  padding-top: 16px;
}

@media (max-width: 768px) {
  .about-image .about-features {
    grid-template-columns: 1fr;
    gap: 16px;
  }
}
.about-feature .feature-text h4{color:#1a1a1a;margin:0 0 6px;font-size:1rem;font-weight:600}
.about-feature .feature-text p{color:var(--ink-700);margin:0;line-height:1.5;font-size:0.9rem}

.clinic-info{margin-top:32px;padding:24px;background:var(--beige-050);border-radius:16px;border:1px solid var(--brown-300)}
.clinic-info h4{color:#1a1a1a;margin:0 0 16px;font-size:1.1rem;font-weight:600}
.info-grid{display:flex;flex-direction:column;gap:12px}
.info-item{color:var(--ink-700);font-size:0.9rem;line-height:1.5}
.info-item strong{color:#1a1a1a;font-weight:600}
.info-item a{color:#1a1a1a;text-decoration:none;transition:color .2s ease}
.info-item a:hover{color:#333333}

.about-image{position:relative;height:600px;overflow:hidden}
.about-image img{width:100%;height:100%;object-fit:cover;border-radius:20px;transition:all 0.4s cubic-bezier(0.4, 0, 0.2, 1);opacity:0;transform:scale(0.95)}
.about-image img.loaded{opacity:1;transform:scale(1)}

/* Shiny line sweep animation for About Us image */
.about-image {
  position: relative;
  overflow: hidden;
}

.about-image:hover img {
  transform: scale(1.02);
}



/* Mission, Vision, Values Section */
.mission-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:40px}
/* Mission Header */
.mission-header {
  text-align: center;
  margin-bottom: 48px;
}

.mission-indicator {
  color: #333333;
  font-size: 0.9rem;
  font-weight: 500;
  margin-bottom: 16px;
}

.mission-header h2 {
  color: #1a1a1a;
  font-size: 2.5rem;
  line-height: 1.2;
  margin: 0 0 20px;
  font-weight: 700;
}

.mission-description {
  color: var(--ink-700);
  font-size: 1.1rem;
  line-height: 1.6;
  margin: 0 0 24px;
  max-width: 600px;
  margin-inline: auto;
}

.mission-dot {
  color: #333333;
  font-size: 1.2rem;
  margin-top: 16px;
}

/* Mission Cards */
.mission-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 24px;
  margin-top: 32px;
}

.mission-card {
  background: var(--white);
  padding: 32px 24px;
  border-radius: 16px;
  box-shadow: 0 8px 24px rgba(139,69,19,.08);
  border: 1px solid var(--brown-200);
  transition: all 0.5s ease;
  text-align: center;
  position: relative;
  overflow: hidden;
}

.mission-card::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 0;
  background: var(--brown-700);
  transition: height 0.5s ease;
  z-index: 0;
}

.mission-card:hover {
  transform: translateY(-8px);
  box-shadow: 0 16px 40px rgba(139,69,19,.15);
}

.mission-card:hover::before {
  height: 100%;
}

.mission-card > * {
  position: relative;
  z-index: 1;
}
.mission-card:hover{transform:translateY(-4px);box-shadow:0 20px 40px rgba(139,69,19,.12)}

.card-icon {
  width: 60px;
  height: 60px;
  margin: 0 auto 20px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.icon-box {
  width: 48px;
  height: 48px;
  border-radius: 8px;
  background: var(--beige-100);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #1a1a1a;
  transition: all 0.5s ease;
}

.mission-card:hover .icon-box {
  transform: scale(1.1);
  background: rgba(255, 255, 255, 0.2);
  color: var(--white);
}
.card-icon svg{width:48px;height:48px}
.mission-card h4 {
  color: #1a1a1a;
  margin: 0 0 16px;
  font-size: 1.3rem;
  font-weight: 600;
  transition: color 0.5s ease;
}

.mission-card p {
  color: var(--ink-700);
  margin: 0;
  line-height: 1.6;
  font-size: 0.95rem;
  transition: color 0.5s ease;
}

.mission-card:hover h4 {
  color: var(--white);
}

.mission-card:hover p {
  color: rgba(255, 255, 255, 0.9);
}

/* Benefits Section */
.section--benefits {
  background: linear-gradient(135deg, var(--brown-800), var(--brown-700));
  color: var(--ink-900);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}

.benefits-header {
  text-align: center;
  margin-bottom: 60px;
}

.benefits-indicator {
  font-size: 0.9rem;
  font-weight: 600;
  color: #333333;
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.benefits-header h2 {
  font-size: clamp(28px, 4vw, 42px);
  font-weight: 700;
  margin: 0 0 20px;
  color: #1a1a1a;
  line-height: 1.2;
}

.benefits-description {
  font-size: clamp(16px, 2vw, 18px);
  color: #333333;
  max-width: 600px;
  margin: 0 auto;
  line-height: 1.6;
}

.benefits-layout {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 40px;
  align-items: center;
  max-width: 1000px;
  margin: 0 auto;
}

.benefits-column {
  display: flex;
  flex-direction: column;
  gap: 30px;
}

.benefits-left {
  justify-content: flex-start;
}

.benefits-right {
  justify-content: flex-end;
}

.benefits-center {
  display: flex;
  justify-content: center;
  align-items: center;
}

.central-image-container {
  width: 280px;
  height: 350px;
  border-radius: 20px;
  overflow: hidden;
  background: #2F4F2F;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 20px 40px rgba(139, 69, 19, 0.15);
  position: relative;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.central-image-container img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: 20px;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  opacity: 0;
  transform: scale(0.95);
}

.central-image-container img.loaded {
  opacity: 1;
  transform: scale(1);
}

.central-image-container:hover img {
  transform: scale(1.02);
  box-shadow: 0 25px 50px rgba(139, 69, 19, 0.25);
}

/* Shiny line sweep animation for Benefits image */
.central-image-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-25deg);
  z-index: 1;
  transition: left 0.6s ease-in-out;
}

.central-image-container:hover::before {
  left: 100%;
}

.benefit-card {
  background: rgba(255, 255, 255, 0.3);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(45, 45, 45, 0.2);
  border-radius: 16px;
  padding: 24px;
  transition: all 0.3s ease;
  max-width: 280px;
}

.benefit-card:hover {
  background: rgba(255, 255, 255, 0.4);
  transform: translateY(-5px);
  box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2);
}

.benefit-icon {
  margin-bottom: 16px;
}

.icon-bg {
  width: 50px;
  height: 50px;
  background: rgba(45, 45, 45, 0.2);
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s ease;
}

.benefit-card:hover .icon-bg {
  background: rgba(45, 45, 45, 0.3);
  transform: scale(1.1);
}

.icon-bg svg {
  width: 24px;
  height: 24px;
  color: #1a1a1a;
}

.benefit-content h4 {
  font-size: 1.1rem;
  font-weight: 700;
  margin: 0 0 8px;
  color: #1a1a1a;
  font-family: 'Josefin Slab', serif;
}

.benefit-content p {
  font-size: 0.9rem;
  color: #333333;
  margin: 0;
  line-height: 1.5;
}

.floating-contact-icons {
  position: absolute;
  right: 20px;
  top: 50%;
  transform: translateY(-50%);
  display: flex;
  flex-direction: column;
  gap: 16px;
  z-index: 10;
}

.contact-icon {
  width: 50px;
  height: 50px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
  transition: all 0.3s ease;
  box-shadow: 0 8px 20px rgba(0, 0, 0, 0.2);
}

.contact-icon.whatsapp {
  background: #25D366;
  color: white;
}

.contact-icon.phone {
  background: var(--brown-700);
  color: white;
}

.contact-icon:hover {
  transform: scale(1.1);
  box-shadow: 0 12px 25px rgba(0, 0, 0, 0.3);
}

.contact-icon svg {
  width: 24px;
  height: 24px;
}

/* Process Section */
.section--process {
  background: var(--beige-050);
  padding: 80px 0;
  position: relative;
  overflow: hidden;
}

.process-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: center;
  max-width: 1200px;
  margin: 0 auto;
}

.process-visual {
  position: relative;
}

.visual-container {
  position: relative;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: 0 20px 40px rgba(139, 69, 19, 0.15);
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}

.visual-container img {
  width: 100%;
  height: 500px;
  object-fit: cover;
  display: block;
  border-radius: 20px;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  opacity: 0;
  transform: scale(0.95);
}

.visual-container img.loaded {
  opacity: 1;
  transform: scale(1);
}

.visual-container:hover img {
  transform: scale(1.02);
  box-shadow: 0 25px 50px rgba(139, 69, 19, 0.25);
}

/* Shiny line sweep animation for Process image */
.visual-container::before {
  content: '';
  position: absolute;
  top: 0;
  left: -100%;
  width: 100%;
  height: 100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.4), transparent);
  transform: skewX(-25deg);
  z-index: 1;
  transition: left 0.6s ease-in-out;
}

.visual-container:hover::before {
  left: 100%;
}

.video-overlay {
  position: absolute;
  bottom: 20px;
  left: 20px;
  background: rgba(0, 0, 0, 0.8);
  color: white;
  padding: 16px 20px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  gap: 12px;
  backdrop-filter: blur(10px);
}

.play-button {
  width: 40px;
  height: 40px;
  background: var(--brown-600);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  transition: all 0.3s ease;
}

.play-button:hover {
  background: var(--brown-700);
  transform: scale(1.1);
}

.play-button svg {
  width: 16px;
  height: 16px;
  color: white;
  margin-left: 2px;
}

.overlay-text {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.overlay-title {
  font-size: 0.8rem;
  font-weight: 600;
  color: var(--white);
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.overlay-subtitle {
  font-size: 0.9rem;
  font-weight: 500;
}

.process-content {
  padding: 20px 0;
}

.process-header {
  margin-bottom: 30px;
}

.process-indicator {
  font-size: 0.9rem;
  font-weight: 600;
  color: #1a1a1a;
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.process-header h2 {
  font-size: clamp(28px, 4vw, 36px);
  font-weight: 700;
  color: #1a1a1a;
  line-height: 1.2;
  margin: 0;
  font-family: 'Josefin Slab', serif;
}

.process-description {
  margin-bottom: 40px;
}

.process-description p {
  font-size: 1.1rem;
  color: var(--ink-700);
  line-height: 1.7;
  margin: 0;
}

.process-benefits {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
  margin-bottom: 40px;
}

.benefit-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
}

.benefit-item .benefit-icon {
  width: 24px;
  height: 24px;
  flex-shrink: 0;
}

.benefit-item .benefit-icon svg {
  width: 100%;
  height: 100%;
  color: #1a1a1a;
}

.benefit-item span {
  font-size: 1rem;
  font-weight: 500;
  color: var(--ink-700);
  line-height: 1.4;
}

.process-cta {
  padding-top: 20px;
  border-top: 1px solid rgba(139, 69, 19, 0.2);
}

.process-cta p {
  font-size: 1.2rem;
  font-weight: 600;
  color: #1a1a1a;
  margin: 0;
  font-family: 'Josefin Slab', serif;
}

/* Mobile Responsive */
@media (max-width:768px){
  .nav__menu{position:fixed;top:100%;left:0;right:0;background:var(--white);flex-direction:column;padding:24px;transform:translateY(-100%);opacity:0;visibility:hidden;transition:all .3s ease;box-shadow:0 8px 24px rgba(0,0,0,.1)}
  .nav__menu.show{transform:translateY(0);opacity:1;visibility:visible}
  .nav__toggle{display:block}
  .hero__grid{grid-template-columns:1fr;text-align:center}
  .grid.two,.grid.three{grid-template-columns:1fr}
  .services,.features{grid-template-columns:1fr}
  .why-choose-grid,.about-grid{grid-template-columns:1fr;gap:32px;text-align:center}
  .why-choose-content h2,.about-content h2{font-size:2rem;margin-bottom:24px}
  .why-feature,.about-feature{text-align:left}
  .why-choose-image img,.about-image img{height:400px}
  .mission-cards{grid-template-columns:1fr;gap:20px}
  .mission-card{padding:24px}
  .mission-header h2{font-size:2rem}
  .mission-description{font-size:1rem}
  .card-icon{width:50px;height:50px;margin-bottom:16px}
  .card-icon svg{width:40px;height:40px}
  .service-card{height:360px}
  .service-image{height:220px}
  .service-back{padding:16px}
  .service-back h3{font-size:1rem}
  .service-back p{font-size:0.85rem}
  .booking{flex-direction:column;text-align:center}
  .booking__actions{flex-direction:column;width:100%}
  .footer__main{grid-template-columns:1fr;gap:24px;text-align:center}
  .footer__brand{justify-content:center}
  .footer__social{justify-content:center}
  .footer__bottom{flex-direction:column;gap:16px;text-align:center}
  .footer__actions{justify-content:center}
  
  /* Benefits Section Mobile */
  .benefits-layout{grid-template-columns:1fr;gap:30px;text-align:center}
  .benefits-column{flex-direction:row;flex-wrap:wrap;justify-content:center;gap:20px}
  .benefit-card{max-width:250px;min-width:250px}
  .central-image-container{width:200px;height:250px;margin:20px auto;border-radius:16px}
  .central-image-container img{border-radius:16px}
  .floating-contact-icons{position:static;flex-direction:row;justify-content:center;margin-top:30px;transform:none}
  .benefits-header h2{font-size:2rem}
  .benefits-description{font-size:1rem}
  
  /* Process Section Mobile */
  .process-grid{grid-template-columns:1fr;gap:40px;text-align:center}
  .process-visual{order:2}
  .process-content{order:1}
  .visual-container img{height:300px;border-radius:16px}
  .visual-container{border-radius:16px}
  .video-overlay{bottom:15px;left:15px;padding:12px 16px}
  .play-button{width:35px;height:35px}
  .play-button svg{width:14px;height:14px}
  .overlay-title{font-size:0.7rem}
  .overlay-subtitle{font-size:0.8rem}
  .process-header h2{font-size:2rem}
  .process-description p{font-size:1rem}
  .process-benefits{grid-template-columns:1fr;gap:15px}
  .benefit-item{justify-content:center}
  .process-cta p{font-size:1.1rem}
}

/* Custom Cursor with Trailing Point */
body {
  cursor: auto; /* Show the default cursor */
}

/* Custom cursor dot that follows the mouse */
.cursor-dot {
  width: 8px;
  height: 8px;
  background: var(--brown-700);
  border-radius: 50%;
  position: fixed;
  pointer-events: none;
  z-index: 9999;
  transition: transform 0.1s ease, opacity 0.25s ease;
  box-shadow: 0 2px 4px rgba(139, 69, 19, 0.3);
  opacity: 0; /* hidden by default, shown on mouse move */
  display: block;
}

/* Main cursor circle - hidden */
.cursor-circle {
  display: none;
}

/* Hover effects for interactive elements */
.btn:hover ~ .cursor-circle,
a:hover ~ .cursor-circle,
.service-card:hover ~ .cursor-circle,
.nav__menu a:hover ~ .cursor-circle {
  transform: scale(1.5);
  border-color: var(--brown-600);
  background: rgba(255, 255, 255, 0.2);
}

.btn:hover ~ .cursor-dot,
a:hover ~ .cursor-dot,
.service-card:hover ~ .cursor-dot,
.nav__menu a:hover ~ .cursor-dot {
  transform: scale(1.2);
  background: var(--brown-600);
}

/* Hide custom cursor on mobile devices */
@media (max-width: 768px) {
  .cursor-dot,
  .cursor-circle {
    display: none;
  }
}

/* ===== Two-Color Theme Overrides (c28566 & #F7F0F2) ===== */
:root{
  --brown-900:#F7F0F2;
  --brown-800:#F7F0F2;
  --brown-700:#c28566;
  --brown-600:#c28566;
  --brown-500:#F7F0F2;
  --beige-100:#F7F0F2;
  --beige-050:#F7F0F2;
  --ink-900:#c28566;
  --ink-700:#c28566;
  --ink-500:#c28566;
  --ink-300:#c28566;
  --white:#F7F0F2;
  --card:#F7F0F2;
  --shadow:0 10px 30px rgba(194,133,102,.12);
}

body{color:var(--ink-900);background:var(--beige-050)}
.topbar{background:var(--white);color:var(--ink-900)}
.header{background:var(--white)}
.header.scrolled{background:rgba(194,133,102,.08);box-shadow:0 6px 24px rgba(194,133,102,.2)}
.nav__menu a{color:var(--ink-900)}
.nav__menu a:hover{background:rgba(194,133,102,.1);color:var(--ink-900)}
.btn--primary{background:linear-gradient(135deg,var(--brown-600),var(--brown-700));color:var(--white);box-shadow:0 8px 18px rgba(194,133,102,.35)}
.btn--outline{border:2px solid var(--brown-700);color:var(--ink-900);background:transparent}
.btn--services{background:var(--white);color:var(--ink-900);border:1px solid var(--brown-700)}
.btn--ghost{background:transparent;color:var(--ink-900);border:1px dashed var(--brown-700)}
.hero{background:var(--brown-700);color:var(--white);position:relative;overflow:hidden}
.hero::before,.hero::after{display:none}
.hero .lead,.hero h1{color:var(--white)}
.badges li{background:var(--white);border:1px solid var(--brown-700);color:var(--ink-900)}
.info-card,.contact-card,.service,.feature,.highlight,.faq-item,.booking{border-color:var(--brown-700);box-shadow:0 10px 22px rgba(194,133,102,.12)}
.service-back{border-color:var(--brown-700);color:var(--ink-900)}
.service-front h3,.service-back h3,.service-back p{color:var(--ink-900)}
.feature-bullet,.about-feature .feature-bullet{background:var(--brown-700)}
.section--about,.section--services,.section--why-us,.section--mission,.section--faq,.section--appointment,.section--contact,.section--alt{background:var(--white)}
.footer{background:var(--brown-700);color:var(--white)}
.footer__bottom{border-top:1px solid rgba(247,240,242,0.25)}
.fab--call,.fab--wa{background:var(--brown-700);color:var(--white)}
.social-link{border-color:var(--brown-700);color:var(--ink-900)}
.social-link:hover{background:var(--brown-700);color:var(--white)}
.contact-icon.phone{background:var(--brown-700)}
.cursor-dot{background:var(--brown-700);box-shadow:0 2px 4px rgba(194,133,102,0.3)}

/* Ensure nav bar Book Appointment text is light on primary button */
.nav__menu .btn.btn--primary{color:var(--white)}
.nav__menu .btn.btn--primary:hover{color:var(--white)}

@keyframes heroSweep{0%{left:-100%}50%{left:100%}100%{left:100%}}


/* About section color swap: heading = primary, content = dark */
.about-content h2{color:var(--ink-900)}
.about-content p,.about-lead{color:#1a1a1a}

