
:root{
  --bg:#f8f3ee; --bg-soft:#fffaf6; --surface:#ffffff; --surface-2:#f5efe8;
  --text:#1e1e24; --muted:#6c6b75; --primary:#9a6b4f; --primary-2:#d3a77f;
  --accent:#3f7d74; --accent-2:#f0d6be; --border:rgba(41,25,18,.09);
  --shadow:0 24px 70px rgba(28,22,18,.12); --hero-shadow:0 24px 80px rgba(0,0,0,.28);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0; color:var(--text); background:
  radial-gradient(circle at top left, rgba(255,255,255,.9), transparent 34%),
  linear-gradient(180deg, var(--bg) 0%, var(--bg-soft) 100%);
  font-family: "Segoe UI", Arial, sans-serif; line-height:1.72; letter-spacing:.01em;
}
.brand-combo{
    display:flex;
    align-items:center;
    gap:14px;
    text-decoration:none;
}

.logo-box{
    width:64px;
    height:64px;
    flex:0 0 64px;
    display:flex;
    align-items:center;
    justify-content:center;
    overflow:hidden;
}

.logo-box img{
    max-width:100%;
    max-height:100%;
    width:auto;
    height:auto;
    display:block;
}

.brand-text h1{
    margin:0;
    font-size:26px;
    line-height:1.1;
    font-weight:700;
}

.brand-text p{
    margin:4px 0 0;
    font-size:11px;
    letter-spacing:2px;
}

.map-preview{
display:block;
position:relative;
margin-top:15px;
border-radius:10px;
overflow:hidden;
}

.map-preview img{
width: 55%;
height: 196px;
object-fit: cover;
}

.map-btn{
position:absolute;
bottom:15px;
left:15px;
background:#ffffff;
padding:8px 14px;
border-radius:6px;
font-weight:600;
box-shadow:0 4px 10px rgba(0,0,0,0.15);
}

img{max-width:100%;display:block}
a{text-decoration:none;transition:all .28s ease}
.section{padding:95px 0; position:relative}
.section.alt{background:linear-gradient(180deg, rgba(255,255,255,.5), rgba(255,255,255,.92))}
.container{position:relative}
.topbar{
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(13,12,15,.32)!important; backdrop-filter: blur(16px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar.scrolled{background:rgba(13,12,15,.8)!important; box-shadow:0 12px 30px rgba(0,0,0,.2)}
.logo-image img{height:54px; width:auto}
.navbar-dark .navbar-nav .nav-link{
  color:#fff!important; font-size:13px; letter-spacing:.16em; font-weight:700; padding:16px 14px!important;
}
.navbar-dark .navbar-nav .nav-link:hover,.navbar-dark .navbar-nav .nav-link.active{color:var(--primary-2)!important}
.hero-carousel,.hero-slide{height:100vh; min-height:760px}
.carousel-fade .carousel-item{opacity:0;transition-property:opacity;transform:none}
.carousel-fade .carousel-item.active,.carousel-fade .carousel-item-next.carousel-item-left,.carousel-fade .carousel-item-prev.carousel-item-right{opacity:1}
.carousel-fade .active.carousel-item-left,.carousel-fade .active.carousel-item-right{opacity:0}
.hero-slide{
  background-size:cover; background-position:center; position:relative; overflow:hidden;
}
.hero-slide:before{
  content:""; position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(7,9,14,.84) 0%, rgba(7,9,14,.66) 42%, rgba(7,9,14,.22) 100%),
    linear-gradient(180deg, rgba(0,0,0,.1), rgba(0,0,0,.35));
}
.hero-slide:after{
  content:""; position:absolute; inset:auto -10% -80px -10%; height:180px;
  background:radial-gradient(circle at center, rgba(255,255,255,.18), transparent 65%);
  filter:blur(14px);
}
.hero-content{
  position:relative; z-index:2; max-width:760px; padding-top:180px; color:#fff;
}
.eyebrow{
  display:inline-flex; align-items:center; gap:10px; padding:12px 18px; border-radius:999px;
  background:rgba(255,255,255,.12); border:1px solid rgba(255,255,255,.12);
  font-size:12px; letter-spacing:.18em; text-transform:uppercase; font-weight:800;
  backdrop-filter:blur(8px);
}
.hero-content h1{
  margin:26px 0 18px; font-size:clamp(38px,5.5vw,68px); line-height:1.05; font-weight:800;
  letter-spacing:-.03em;
}
.hero-content .lead{
  font-size:19px; color:rgba(255,255,255,.92); max-width:690px;
}
.hero-points{display:flex;flex-wrap:wrap;gap:12px;margin:26px 0 0;padding:0;list-style:none}
.hero-points li{
  padding:12px 16px; border-radius:999px; background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.14); font-size:14px;
}
.hero-actions{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.btn-spa{
  display:inline-flex; align-items:center; justify-content:center; gap:10px;
  min-width:190px; padding:16px 24px; border-radius:18px; font-weight:800; letter-spacing:.04em;
  box-shadow:var(--hero-shadow); text-transform:uppercase; font-size:13px;
}
.btn-solid{background:linear-gradient(135deg,var(--primary),var(--primary-2)); color:#fff}
.btn-solid:hover{transform:translateY(-2px); color:#fff; filter:saturate(1.05)}
.btn-ghost{background:rgba(255,255,255,.1); color:#fff; border:1px solid rgba(255,255,255,.18)}
.btn-ghost:hover{background:rgba(255,255,255,.16); color:#fff}
.hero-floating-card{
  position:absolute; right:0; bottom:100px; z-index:2; width:310px; border-radius:28px;
  padding:26px; background:rgba(255,255,255,.12); color:#fff; backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.16); box-shadow:var(--hero-shadow);
}
.hero-floating-card h4{margin:0 0 10px;font-size:19px}
.hero-floating-card p{margin:0;color:rgba(255,255,255,.84);font-size:14px}
.hero-floating-card .mini-list{padding:0;list-style:none;margin:16px 0 0}
.hero-floating-card .mini-list li{margin:9px 0;font-size:14px}
.carousel-control-next,.carousel-control-prev{width:8%}
.carousel-control-next .fa,.carousel-control-prev .fa{
  width:56px;height:56px;border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,.12); backdrop-filter:blur(8px); border:1px solid rgba(255,255,255,.14)
}
.carousel-indicators li{
  width:12px; height:12px; border-radius:50%; border:none; margin:0 7px;
  background:rgba(255,255,255,.45)
}
.carousel-indicators .active{background:#fff; transform:scale(1.18)}
.quick-strip{margin-top:-72px; position:relative; z-index:5}
.quick-card{
  height:100%; border-radius:28px; padding:28px; background:rgba(255,255,255,.78); backdrop-filter:blur(12px);
  box-shadow:var(--shadow); border:1px solid rgba(255,255,255,.6)
}
.quick-card i{font-size:28px; color:var(--primary); margin-bottom:12px}
.quick-card h3{font-size:22px; margin:0 0 10px; font-weight:800}
.section-tag{
  display:inline-block; margin-bottom:18px; color:var(--primary); font-weight:800; letter-spacing:.2em; font-size:12px;
  text-transform:uppercase;
}
.section h2{font-size:clamp(30px,4vw,48px); line-height:1.1; margin:0 0 18px; font-weight:800; letter-spacing:-.03em}
.section p.lead{font-size:18px; color:var(--muted); max-width:820px}
.service-card,.feature-card,.gallery-card,.faq-item,.contact-card,.about-panel,.story-panel{
  background:var(--surface); border:1px solid var(--border); box-shadow:var(--shadow); border-radius:28px;
}
.service-grid .col-lg-3,.feature-grid .col-lg-4,.gallery-grid .col-lg-4{display:flex}
.service-card{
  padding:28px; margin-top:28px; position:relative; overflow:hidden; width:100%;
  transition:transform .28s ease, box-shadow .28s ease
}
.service-card:hover,.feature-card:hover,.gallery-card:hover{transform:translateY(-8px)}
.service-card:before{
  content:""; position:absolute; top:-40px; right:-40px; width:120px; height:120px; border-radius:50%;
  background:linear-gradient(135deg, rgba(211,167,127,.18), transparent 68%);
}
.service-icon{
  width:64px; height:64px; border-radius:20px; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,var(--accent-2), rgba(255,255,255,.85)); color:var(--primary);
  font-size:26px; box-shadow:0 10px 24px rgba(0,0,0,.06)
}
.service-card h3{margin:18px 0 12px; font-size:23px; font-weight:800}
.service-card p{color:var(--muted); margin:0 0 10px}
.service-card .small-note{font-size:14px; color:var(--primary); font-weight:700}
.about-visual{
  position:relative; padding:26px;
}
.about-visual .main-photo{
  border-radius:34px; overflow:hidden; box-shadow:var(--shadow); min-height:560px;
}
.about-visual .main-photo img{
  width:100%; height:560px; object-fit:cover;
}
.about-visual .floating-badge{
  position:absolute; left:-5px; bottom:60px; background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff; padding:20px 22px; border-radius:24px; min-width:210px; box-shadow:var(--shadow)
}
.about-visual .floating-badge strong{display:block;font-size:32px;line-height:1}
.about-panel{padding:36px}
.check-list{padding:0; margin:28px 0 0; list-style:none}
.check-list li{padding:0 0 16px 34px; position:relative; color:var(--muted)}
.check-list li:before{
  content:"\f00c"; font-family:FontAwesome; position:absolute; left:0; top:1px; color:var(--accent); font-size:18px
}
.feature-card{padding:30px; margin-top:28px; width:100%}
.feature-card .num{
  width:58px;height:58px;border-radius:18px;background:linear-gradient(135deg,var(--primary),var(--primary-2));
  color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:22px;margin-bottom:18px
}
.story-panel{padding:42px}
.story-copy{padding-right:20px}
.story-band{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px; margin-top:28px
}
.story-stat{padding:24px;border-radius:24px;background:linear-gradient(180deg,var(--surface-2), rgba(255,255,255,.95)); border:1px solid var(--border)}
.story-stat strong{display:block;font-size:30px;color:var(--primary);line-height:1.1}
.gallery-card{overflow:hidden; margin-top:28px; width:100%}
.gallery-card img{width:100%; height:280px; object-fit:cover; transition:transform .35s ease}
.gallery-card:hover img{transform:scale(1.06)}
.gallery-card .copy{padding:22px}
.gallery-card h4{margin:0 0 8px; font-size:22px; font-weight:800}
.gallery-card p{margin:0; color:var(--muted)}
.seo-box{
  margin-top:36px; border-radius:28px; padding:34px; background:
  linear-gradient(135deg, rgba(211,167,127,.15), rgba(255,255,255,.85)),
  linear-gradient(180deg, rgba(255,255,255,.9), rgba(255,255,255,.82));
  border:1px solid rgba(211,167,127,.18); box-shadow:var(--shadow)
}
.faq-item{padding:26px; margin-top:18px}
.faq-item h4{margin:0 0 10px; font-size:21px; font-weight:800}
.faq-item p{margin:0; color:var(--muted)}
.contact-wrap{padding:0}
.contact-card{padding:34px; height:100%}
.contact-list{list-style:none; padding:0; margin:26px 0 0}
.contact-list li{display:flex; gap:16px; margin:0 0 20px}
.contact-list i{
  width:48px; height:48px; border-radius:16px; background:linear-gradient(135deg,var(--accent-2),#fff);
  display:flex; align-items:center; justify-content:center; color:var(--primary); font-size:20px; flex:0 0 48px
}
.social-row{display:flex; flex-wrap:wrap; gap:12px; margin-top:20px}
.social-row a{
  display:inline-flex; align-items:center; justify-content:center; width:46px; height:46px; border-radius:16px;
  background:var(--surface-2); color:var(--primary); border:1px solid var(--border)
}
.social-row a:hover{transform:translateY(-3px); background:var(--primary); color:#fff}
.map-card{
  min-height:100%; overflow:hidden; border-radius:28px; box-shadow:var(--shadow); border:1px solid var(--border);
  background:
   linear-gradient(180deg, rgba(9,15,20,.25), rgba(9,15,20,.55)),
   url('../../images/feelgood-banner-b.jpg') center/cover no-repeat;
  position:relative; padding:34px; color:#fff
}
.map-card .map-overlay{
  position:absolute; inset:auto 34px 34px 34px; background:rgba(255,255,255,.12); backdrop-filter:blur(12px);
  border:1px solid rgba(255,255,255,.14); border-radius:24px; padding:24px
}
.map-card h3{font-size:30px; font-weight:800; margin:0 0 14px}
.map-card p{color:rgba(255,255,255,.88)}
.footer{
  padding:30px 0 44px; color:#ddd; background:#101114; position:relative
}
.footer a{color:#fff}
.footer small{color:rgba(255,255,255,.68)}
.whatsapp-float{
  position:fixed; right:24px; bottom:24px; z-index:999;
  width:62px;height:62px;border-radius:50%; background:#25d366; color:#fff;
  display:flex; align-items:center; justify-content:center; box-shadow:0 20px 40px rgba(37,211,102,.34); font-size:30px
}
.whatsapp-float:hover{transform:translateY(-4px); color:#fff}
.theme-switcher{
  position:fixed; left:24px; bottom:24px; z-index:999; display:flex; flex-direction:column; gap:8px
}
.theme-switcher a{
  background:rgba(16,17,20,.84); color:#fff; border:1px solid rgba(255,255,255,.09); padding:9px 12px; border-radius:14px;
  font-size:12px; letter-spacing:.08em; text-transform:uppercase
}
.theme-switcher a:hover{background:var(--primary)}
.pad-fix{padding-top:16px}
@media (max-width:1199px){
  .hero-floating-card{display:none}
}
@media (max-width:991px){
  .hero-carousel,.hero-slide{height:auto; min-height:760px}
  .hero-content{padding-top:150px}
  .quick-strip{margin-top:24px}
  .section{padding:76px 0}
  .about-visual .main-photo img{height:420px}
  .map-card{min-height:420px;margin-top:28px}
}
@media (max-width:767px){
  .logo-image img{height:46px}
  .hero-content h1{font-size:38px}
  .hero-content .lead{font-size:17px}
  .btn-spa{min-width:unset; width:100%}
  .section h2{font-size:32px}
  .story-band{grid-template-columns:1fr}
  .theme-switcher{left:12px; bottom:96px}
  .theme-switcher a{font-size:11px; padding:8px 10px}
}


.brand-combo{display:flex!important;align-items:center;gap:14px;white-space:normal}
.brand-copy{display:flex;flex-direction:column;line-height:1.1}
.brand-copy strong{font-size:26px;font-weight:900;color:#fff;letter-spacing:.01em}
.brand-copy small{font-size:11px;color:rgba(255,255,255,.82);letter-spacing:.12em;text-transform:uppercase;margin-top:4px}
.org-title{font-size:34px;line-height:1.08;font-weight:900;margin:0 0 10px}
.image-info-panel{height:100%}
.compact-gallery .gallery-card img{height:230px}
@media (max-width:991px){.brand-copy strong{font-size:22px}.brand-copy small{font-size:10px;letter-spacing:.08em}}
@media (max-width:767px){.brand-copy strong{font-size:18px}.brand-copy small{display:none}.brand-combo{gap:10px}.org-title{font-size:28px}}
