
:root{
  --green:#89ad2d;
  --green-dark:#6f941d;
  --blue:#0b6c96;
  --text:#2d2f48;
  --muted:#6f7d94;
  --soft:#f3f5f9;
  --white:#fff;
  --line:#e9edf3;
  --radius:14px;
  --shadow:0 16px 40px rgba(25,36,64,.06);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Poppins,Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif;
  background:var(--soft);
  color:var(--text);
}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{width:min(1180px,calc(100% - 34px));margin:auto}
.topbar{
  background:#eef2f7;
  color:var(--blue);
  font-size:13px;
}
.topbar-inner{height:36px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.topbar-left,.topbar-right{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.header{
  background:#fff;
  position:sticky;top:0;z-index:50;
  border-bottom:1px solid #edf1f5;
}
.header-inner{height:76px;display:flex;align-items:center;justify-content:space-between;gap:30px}
.logo img{height:36px;width:auto}
.nav{display:flex;align-items:center;gap:28px;font-weight:600;font-size:14px;color:#292b43}
.nav a.active,.nav a:hover{color:var(--green)}
.btn{
  border:0;border-radius:999px;
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:44px;padding:0 22px;
  font-weight:700;cursor:pointer;
}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-dark)}
.btn-light{background:#fff;color:var(--green);box-shadow:var(--shadow)}
.mobile-toggle{display:none;border:0;background:#f3f5f9;border-radius:10px;width:42px;height:42px;font-size:24px}
.breadcrumb-wrap{background:#eef2f7;padding:15px 0;color:var(--blue);font-size:13px}
.breadcrumb{display:flex;gap:10px;align-items:center}
.page-section{padding:78px 0}
.section-head{text-align:center;margin-bottom:45px}
.section-kicker{color:var(--blue);font-weight:700;font-size:13px;margin-bottom:5px}
.section-title{font-size:34px;line-height:1.15;margin:0;color:var(--text)}
.section-text{color:var(--muted);line-height:1.75}
.hero{padding:70px 0 45px}
.contact-strip{
  display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-bottom:55px
}
.contact-card{
  background:#fff;border-radius:12px;box-shadow:var(--shadow);
  padding:22px 24px;display:flex;align-items:center;gap:16px
}
.contact-icon{width:48px;height:48px;border-radius:10px;background:#f2f8fb;display:grid;place-items:center;color:var(--blue);font-size:20px}
.contact-card small{display:block;color:var(--blue);font-weight:700}
.contact-card strong{font-size:15px}
.hero-grid{display:grid;grid-template-columns:1fr 520px;gap:55px;align-items:center}
.hero h1{font-size:42px;line-height:1.04;margin:10px 0 20px;max-width:580px}
.hero .lead{color:var(--blue);font-weight:700;font-size:14px}
.hero p{color:var(--muted);line-height:1.8;font-size:15px}
.hero-media{position:relative;padding:0 0 24px 24px}
.hero-media:after{content:"";position:absolute;right:0;bottom:0;width:92%;height:92%;background:var(--green);border-radius:10px;z-index:0}
.hero-media img{position:relative;z-index:1;border-radius:8px}
.info-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin-top:60px}
.about-grid{display:grid;grid-template-columns:1fr 360px 190px;gap:48px;align-items:center}
.check-list{display:grid;gap:24px;margin-top:25px}
.check-item{display:flex;gap:15px;align-items:flex-start}
.check-icon{width:34px;height:34px;min-width:34px;border-radius:50%;background:#fff;box-shadow:var(--shadow);display:grid;place-items:center;color:var(--green)}
.about-image img{border-radius:16px}
.stats-side{display:grid;gap:24px;text-align:center}
.stat-number{font-size:31px;font-weight:800;color:var(--text)}
.stat-label{color:var(--blue);font-size:13px}
.card-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.card{
  background:#fff;border-radius:14px;box-shadow:var(--shadow);overflow:hidden
}
.card-body{padding:26px}
.card h3{margin:0 0 14px;font-size:20px}
.card p{color:var(--blue);line-height:1.65}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:24px}
.team-card{
  background:#fff;border-radius:14px;box-shadow:var(--shadow);
  padding:24px;display:grid;grid-template-columns:210px 1fr;gap:24px;align-items:center
}
.team-card img{border-radius:12px}
.team-card h3{font-size:23px;margin:0 0 14px}
.team-card p{color:var(--blue);line-height:1.6}
.team-role{color:var(--blue);font-weight:600}
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.gallery-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);overflow:hidden}
.gallery-card h3{padding:28px;margin:0}
.gallery-card .btn{margin:0 28px 28px;width:calc(100% - 56px)}
.blog-layout{display:grid;grid-template-columns:1fr 270px;gap:28px}
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}
.blog-card img{border-radius:12px}
.blog-card h3{font-size:18px;line-height:1.45}
.blog-card p{color:var(--blue);line-height:1.65}
.tag{display:inline-flex;background:var(--green);color:#fff;border-radius:8px;padding:7px 12px;font-size:12px}
.sidebar-box{background:#fff;border-radius:0;min-height:180px;display:grid;place-items:center;font-weight:800;color:#0c4c76;text-align:center}
.search-box{background:#fff;border-radius:10px;overflow:hidden;margin-top:22px}
.search-title{background:var(--green);color:#fff;padding:18px;font-weight:700}
.search-input{padding:18px;display:flex;border:1px solid var(--line)}
.search-input input{border:0;outline:0;flex:1}
.policy-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:34px;line-height:1.8;color:var(--blue)}
.policy-card h1{color:var(--text);font-size:22px;border-bottom:1px solid var(--line);padding-bottom:22px;margin-top:0}
.map-section{padding:35px 0 0}
.map-box{position:relative}
.map-box>img{width:100%;border-radius:0;min-height:350px;object-fit:cover}
.map-info{
  position:absolute;right:54px;top:50%;transform:translateY(-50%);
  background:#fff;border-radius:12px;box-shadow:var(--shadow);
  padding:34px;width:320px
}
.map-info .logo img{height:34px;margin-bottom:22px}
.map-info p{line-height:1.7}
.footer{padding:36px 0 0}
.footer-grid{display:grid;grid-template-columns:1.4fr 1fr 1.2fr 1fr 1fr;gap:45px}
.footer h4{margin:0 0 22px}.footer p,.footer a{color:#3d4561;line-height:1.8;font-size:14px}
.footer a{display:block;margin-bottom:10px}
.footer-bottom{border-top:1px solid var(--line);margin-top:42px;padding:22px 0;display:flex;justify-content:space-between;color:#6d758d;font-size:13px}
.form-card{background:#fff;border-radius:14px;box-shadow:var(--shadow);padding:30px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.field label{display:block;font-weight:700;margin-bottom:8px}
.input,.textarea,.select{width:100%;border:1px solid var(--line);border-radius:10px;min-height:48px;padding:0 15px;background:#fff}
.textarea{min-height:140px;padding:15px;resize:vertical}
.accordion{display:grid;gap:14px}
.acc-item{background:#fff;border-radius:12px;box-shadow:var(--shadow);padding:20px}
.acc-title{font-weight:800;display:flex;justify-content:space-between}
.acc-content{color:var(--blue);line-height:1.7;margin-top:12px}
.cta{background:#fff;border-radius:18px;box-shadow:var(--shadow);padding:42px;text-align:center}
@media(max-width:1000px){
  .nav{display:none;position:absolute;left:0;right:0;top:76px;background:#fff;padding:20px;flex-direction:column;align-items:flex-start;border-top:1px solid var(--line)}
  .nav.open{display:flex}
  .mobile-toggle{display:block}
  .hero-grid,.about-grid,.blog-layout{grid-template-columns:1fr}
  .contact-strip,.info-strip,.card-grid,.gallery-grid,.blog-grid,.footer-grid,.team-grid{grid-template-columns:1fr 1fr}
  .map-info{position:static;transform:none;width:auto;margin-top:18px}
}
@media(max-width:640px){
  .topbar-inner{height:auto;padding:10px 0;align-items:flex-start;flex-direction:column}
  .hero h1{font-size:32px}
  .contact-strip,.info-strip,.card-grid,.gallery-grid,.blog-grid,.footer-grid,.team-grid,.form-grid{grid-template-columns:1fr}
  .team-card{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;gap:12px}
  .page-section{padding:52px 0}
}


/* =========================================================
   V2 REVISION - TOPBAR, HERO SLIDER, FLOATING ACTIONS
   ========================================================= */

.topbar{
  background:#f4f7fb;
  border-bottom:1px solid #e7edf5;
}
.topbar-inner{
  height:38px;
  gap:16px;
  font-size:12px;
}
.topbar-left,
.topbar-right{
  gap:14px;
}
.topbar-item{
  display:inline-flex;
  align-items:center;
  gap:7px;
  color:#0b6c96;
  white-space:nowrap;
  font-weight:600;
}
.topbar-social{
  width:22px;
  height:22px;
  border-radius:50%;
  display:inline-grid;
  place-items:center;
  color:#0b6c96;
  background:transparent;
  font-size:12px;
  font-weight:700;
}
.topbar-lang{
  display:inline-flex;
  align-items:center;
  gap:7px;
  padding-left:10px;
  border-left:1px solid #dce4ee;
  color:#2d2f48;
  font-weight:600;
}
.header{
  box-shadow:0 10px 28px rgba(25,36,64,.02);
}
.header.scrolled{
  box-shadow:0 16px 36px rgba(25,36,64,.08);
}
.nav{
  gap:24px;
}
.nav a{
  position:relative;
}
.nav a:after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:-27px;
  height:3px;
  background:var(--green);
  opacity:0;
  transform:scaleX(.4);
  transition:.2s ease;
}
.nav a.active:after,
.nav a:hover:after{
  opacity:1;
  transform:scaleX(1);
}

.home-slider{
  position:relative;
  background:#dfe8df;
  overflow:hidden;
}
.slider-track{
  position:relative;
}
.slide{
  min-height:440px;
  display:none;
  background-size:cover;
  background-position:center;
  position:relative;
}
.slide.active{
  display:block;
}
.slide:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(90deg,rgba(238,245,240,.95) 0%,rgba(238,245,240,.82) 38%,rgba(238,245,240,.08) 70%);
}
.slide-inner{
  position:relative;
  z-index:2;
  min-height:440px;
  display:flex;
  align-items:center;
}
.slide-card{
  width:min(520px,92%);
  background:#fff;
  border-radius:12px;
  box-shadow:0 22px 55px rgba(25,36,64,.13);
  padding:42px 44px;
}
.slide-kicker{
  color:var(--green);
  font-size:13px;
  font-weight:800;
  margin-bottom:8px;
}
.slide-card h1{
  margin:0 0 16px;
  color:var(--text);
  font-size:34px;
  line-height:1.12;
}
.slide-card p{
  color:var(--blue);
  line-height:1.75;
  font-size:14px;
  margin-bottom:22px;
}
.slider-actions{
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.slider-dots{
  position:absolute;
  right:34px;
  top:50%;
  transform:translateY(-50%);
  display:grid;
  gap:10px;
  z-index:5;
}
.slider-dot{
  width:11px;
  height:11px;
  border-radius:50%;
  border:2px solid #fff;
  background:var(--green);
  opacity:.55;
  cursor:pointer;
}
.slider-dot.active{
  opacity:1;
  transform:scale(1.25);
}
.slider-arrow{
  position:absolute;
  z-index:5;
  top:50%;
  transform:translateY(-50%);
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:#fff;
  color:var(--green);
  box-shadow:var(--shadow);
  cursor:pointer;
  font-size:22px;
}
.slider-arrow.prev{left:26px}
.slider-arrow.next{right:26px}

.hero{
  padding-top:62px;
}

.floating-actions{
  position:fixed;
  right:26px;
  top:50%;
  transform:translateY(-50%);
  z-index:80;
  display:grid;
  gap:16px;
}
.float-btn{
  width:58px;
  height:58px;
  border-radius:20px;
  background:#20252b;
  color:#fff;
  border:0;
  display:grid;
  place-items:center;
  box-shadow:0 18px 40px rgba(20,25,30,.22);
  font-size:22px;
  cursor:pointer;
  transition:.2s ease;
}
.float-btn:hover{
  transform:translateY(-3px);
  background:var(--green);
}
.float-btn.whatsapp{
  font-family:Arial,sans-serif;
}

.randevu-banner{
  background:#fff;
  border-radius:12px;
  box-shadow:var(--shadow);
  padding:18px 22px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:46px;
}
.randevu-banner-left{
  display:flex;
  align-items:center;
  gap:16px;
  color:var(--blue);
  font-weight:800;
}
.randevu-banner-icon{
  width:52px;
  height:52px;
  border-radius:12px;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:22px;
}

.form-card{
  border-radius:16px;
}
.form-card-title{
  display:flex;
  align-items:center;
  justify-content:space-between;
  border-bottom:1px solid var(--line);
  margin:-4px 0 22px;
  padding-bottom:20px;
}
.form-card-title h1,
.form-card-title h2{
  margin:0;
  font-size:21px;
}
.form-dots{
  display:flex;
  gap:7px;
}
.form-dots span{
  width:9px;
  height:9px;
  border-radius:50%;
  background:#cfe3a7;
}
.icon-input{
  position:relative;
}
.icon-input .input,
.icon-input .select,
.icon-input .textarea{
  background:#f5f7fb;
  border-color:#f5f7fb;
  padding-left:54px;
}
.icon-input .field-icon{
  position:absolute;
  left:18px;
  top:50%;
  transform:translateY(-50%);
  color:var(--blue);
}
.icon-input.textarea-wrap .field-icon{
  top:22px;
  transform:none;
}
.icon-input.textarea-wrap .textarea{
  padding-top:18px;
}
.randevu-form-submit{
  width:100%;
  border-radius:9px;
  min-height:56px;
  margin-top:4px;
}

@media(max-width:1000px){
  .topbar-inner{
    height:auto;
    padding:9px 0;
  }
  .topbar-left{
    gap:10px;
  }
  .topbar-right{
    gap:8px;
  }
  .topbar-item.address{
    display:none;
  }
  .slide,
  .slide-inner{
    min-height:390px;
  }
  .slider-arrow{
    display:none;
  }
  .slider-dots{
    right:16px;
  }
  .floating-actions{
    right:14px;
    gap:10px;
  }
  .float-btn{
    width:50px;
    height:50px;
    border-radius:16px;
  }
}
@media(max-width:640px){
  .topbar-left,
  .topbar-right{
    width:100%;
    justify-content:center;
  }
  .topbar-item.email,
  .topbar-item.address{
    display:none;
  }
  .slide-card{
    padding:28px 24px;
  }
  .slide-card h1{
    font-size:27px;
  }
  .slide,
  .slide-inner{
    min-height:360px;
  }
  .floating-actions{
    top:auto;
    right:14px;
    bottom:16px;
    transform:none;
    grid-auto-flow:column;
    grid-template-columns:repeat(4,1fr);
  }
  .float-btn{
    width:48px;
    height:48px;
    border-radius:15px;
    font-size:18px;
  }
  .randevu-banner{
    align-items:flex-start;
    flex-direction:column;
  }
  .randevu-banner .btn{
    width:100%;
  }
}


/* =========================================================
   V3 REVISION - POLISHED SOCIAL BAR, SLIDER IMAGE, TEAM DETAIL,
   TESTIMONIALS, BRANDS, FLOATING BUTTON POSITION
   ========================================================= */

.topbar{
  background:#f5f8fc !important;
}
.topbar-inner{
  height:40px !important;
}
.topbar-left{
  gap:18px !important;
}
.topbar-right{
  gap:8px !important;
}
.topbar-item{
  height:24px;
  line-height:24px;
}
.topbar-item .tb-icon{
  width:20px;
  height:20px;
  border-radius:50%;
  background:#e9f3f8;
  display:inline-grid;
  place-items:center;
  font-size:11px;
}
.topbar-social{
  width:26px !important;
  height:26px !important;
  border-radius:8px !important;
  background:#edf4f9 !important;
  color:#0b6c96 !important;
  font-size:12px !important;
  transition:.2s ease;
}
.topbar-social:hover{
  background:var(--green) !important;
  color:#fff !important;
}
.topbar-lang{
  height:26px;
  padding:0 10px !important;
  border:1px solid #e1e8f0 !important;
  border-radius:8px;
  background:#fff;
  color:#0b6c96 !important;
}
.header-inner{
  height:78px;
}
.logo img{
  height:38px;
}
.nav{
  gap:22px !important;
}
.btn-green{
  box-shadow:0 10px 24px rgba(137,173,45,.18);
}

/* Slider, real visual layout */
.home-slider{
  background:#edf3f0 !important;
}
.slide{
  min-height:520px !important;
  background-size:cover !important;
  background-position:center right !important;
}
.slide:before{
  background:linear-gradient(90deg,rgba(238,245,240,.96) 0%,rgba(238,245,240,.90) 35%,rgba(238,245,240,.28) 62%,rgba(238,245,240,.02) 100%) !important;
}
.slide-inner{
  min-height:520px !important;
}
.slide-card{
  margin-left:0;
  width:min(540px,94%);
  padding:44px 46px !important;
}
.slide-card h1{
  font-size:38px !important;
}
.slide-visual-card{
  position:absolute;
  right:10%;
  bottom:48px;
  width:280px;
  background:#fff;
  border-radius:18px;
  box-shadow:0 20px 46px rgba(25,36,64,.14);
  padding:18px;
  z-index:3;
  display:grid;
  grid-template-columns:52px 1fr;
  gap:14px;
  align-items:center;
}
.slide-visual-icon{
  width:52px;
  height:52px;
  border-radius:14px;
  background:#eff8df;
  color:var(--green);
  display:grid;
  place-items:center;
  font-size:24px;
}
.slide-visual-card strong{
  display:block;
  font-size:15px;
  color:var(--text);
}
.slide-visual-card span{
  color:var(--blue);
  font-size:12px;
}

/* Floating buttons moved down */
.floating-actions{
  top:auto !important;
  bottom:96px !important;
  transform:none !important;
  right:28px !important;
  gap:14px !important;
}
.float-btn{
  width:56px !important;
  height:56px !important;
  border-radius:18px !important;
  background:#20252b !important;
}
.float-btn:hover{
  background:var(--green) !important;
}

/* Brand strip */
.brand-strip{
  padding:35px 0;
}
.brand-row{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:18px;
  align-items:center;
}
.brand-item{
  min-height:58px;
  border-radius:12px;
  color:#9aa4b7;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:800;
  opacity:.88;
  filter:grayscale(1);
}
.brand-item:before{
  content:"✺";
  color:#c3cbd7;
}

/* Better testimonial like reference */
.testimonial-section{
  padding:75px 0;
}
.testimonial-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:0;
  align-items:stretch;
}
.testimonial-media{
  min-height:420px;
  background:#d4d4d4;
  border-radius:0;
  display:grid;
  place-items:center;
  color:#8a8a8a;
  font-size:42px;
}
.testimonial-card{
  background:#fff;
  padding:58px 64px;
  position:relative;
  border-left:2px solid #c7d798;
}
.testimonial-card .quote-mark{
  color:var(--green);
  font-size:48px;
  line-height:1;
}
.testimonial-card h2{
  font-size:30px;
  margin:6px 0 22px;
}
.testimonial-card p{
  color:var(--blue);
  line-height:1.75;
}
.testimonial-user{
  display:flex;
  align-items:center;
  gap:14px;
  margin-top:24px;
}
.testimonial-avatar{
  width:44px;
  height:44px;
  border-radius:50%;
  background:#d8d8d8;
}
.testimonial-stars{
  color:#e5b100;
  letter-spacing:3px;
}

/* Team detail page */
.detail-layout{
  display:grid;
  grid-template-columns:330px 1fr;
  gap:26px;
  align-items:start;
}
.detail-sidebar{
  display:grid;
  gap:22px;
}
.profile-photo-card{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.profile-photo-card img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
  background:#edf1f7;
}
.profile-photo-card .btn{
  width:calc(100% - 32px);
  margin:16px;
}
.side-feature-list{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:20px;
  display:grid;
  gap:16px;
}
.side-feature{
  background:#f4f6fa;
  border-radius:10px;
  padding:14px 16px;
  display:flex;
  align-items:center;
  gap:10px;
  color:#0b6c96;
  font-weight:700;
  font-size:13px;
}
.side-menu-card{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:22px;
}
.side-menu-card h3{
  margin:0 0 18px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
}
.side-menu-card a{
  display:flex;
  align-items:center;
  gap:10px;
  background:#f4f6fa;
  color:#0b6c96;
  border-radius:10px;
  padding:14px 16px;
  margin-bottom:12px;
  font-weight:700;
}
.detail-content-card{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:34px 38px;
}
.detail-content-card h1{
  margin:0 0 22px;
  font-size:26px;
}
.detail-content-card p{
  color:#0b6c96;
  line-height:1.8;
}
.detail-metrics{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:14px;
  margin:28px 0;
}
.detail-metric{
  background:#f4f6fa;
  border-radius:12px;
  padding:18px;
  text-align:center;
}
.detail-metric strong{
  display:block;
  font-size:24px;
  color:var(--green);
}
.detail-blocks{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
  margin-top:26px;
}
.detail-block{
  background:#f8fafc;
  border-radius:12px;
  padding:22px;
}
.detail-block h3{
  margin-top:0;
}
.detail-list{
  display:grid;
  gap:10px;
  color:#0b6c96;
}
.detail-list span:before{
  content:"✓";
  color:var(--green);
  margin-right:8px;
  font-weight:900;
}
.detail-cta{
  margin-top:28px;
  background:linear-gradient(135deg,#eef8df,#ffffff);
  border-radius:14px;
  padding:26px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
}

/* Lower map spacing on detail pages */
.map-section{
  padding-top:55px !important;
}

@media(max-width:1100px){
  .slide-visual-card{
    right:4%;
  }
  .detail-layout{
    grid-template-columns:1fr;
  }
  .detail-sidebar{
    grid-template-columns:1fr 1fr;
  }
  .profile-photo-card{
    grid-row:span 2;
  }
}
@media(max-width:900px){
  .testimonial-grid{
    grid-template-columns:1fr;
  }
  .brand-row{
    grid-template-columns:repeat(3,1fr);
  }
  .slide-visual-card{
    display:none;
  }
}
@media(max-width:640px){
  .topbar-social{
    width:24px !important;
    height:24px !important;
  }
  .topbar-lang{
    height:24px;
    font-size:11px;
  }
  .slide-card h1{
    font-size:29px !important;
  }
  .detail-sidebar,
  .detail-blocks,
  .detail-metrics{
    grid-template-columns:1fr;
  }
  .detail-content-card{
    padding:26px 22px;
  }
  .detail-cta{
    align-items:flex-start;
    flex-direction:column;
  }
  .brand-row{
    grid-template-columns:repeat(2,1fr);
  }
}


/* =========================================================
   51 PAGE COMPLETE PACK - PAGE TEMPLATES
   ========================================================= */

.page-hero-mini{
  padding:68px 0 34px;
  text-align:center;
}
.page-hero-mini .section-title{
  font-size:38px;
}
.detail-page-grid{
  display:grid;
  grid-template-columns:330px minmax(0,1fr);
  gap:26px;
  align-items:start;
}
.left-panel{
  display:grid;
  gap:22px;
}
.left-photo-card,
.left-menu-card,
.left-cta-card{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.left-photo-card img{
  width:100%;
  aspect-ratio:1/1;
  object-fit:cover;
}
.left-photo-card .btn{
  width:calc(100% - 32px);
  margin:16px;
}
.left-cta-card{
  padding:22px;
  color:#0b6c96;
}
.left-cta-card h3{
  margin:0 0 10px;
  color:var(--text);
}
.left-menu-card{
  padding:22px;
}
.left-menu-card h3{
  margin:0 0 18px;
  padding-bottom:18px;
  border-bottom:1px solid var(--line);
}
.left-menu-card a{
  display:flex;
  align-items:center;
  gap:10px;
  background:#f4f6fa;
  color:#0b6c96;
  border-radius:10px;
  padding:14px 16px;
  margin-bottom:12px;
  font-weight:700;
}
.content-card{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:36px 40px;
}
.content-card h1{
  margin:0 0 20px;
  font-size:27px;
}
.content-card h2{
  margin-top:32px;
  font-size:22px;
}
.content-card p{
  color:#0b6c96;
  line-height:1.85;
}
.content-card ul{
  color:#0b6c96;
  line-height:1.9;
}
.feature-mini-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin:26px 0;
}
.feature-mini{
  background:#f6f8fb;
  border-radius:12px;
  padding:18px;
  color:#0b6c96;
  font-weight:700;
}
.feature-mini strong{
  display:block;
  color:var(--text);
  margin-bottom:5px;
}
.process-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:18px;
  margin-top:28px;
}
.process-card{
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:14px;
  padding:24px;
  text-align:center;
}
.process-no{
  width:46px;
  height:46px;
  border-radius:50%;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  margin:0 auto 14px;
  font-weight:900;
}
.pricing-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.price-card{
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:16px;
  padding:30px;
  position:relative;
}
.price-card.popular{
  border:2px solid var(--green);
}
.price-label{
  position:absolute;
  top:18px;
  right:18px;
  background:var(--green);
  color:#fff;
  border-radius:999px;
  padding:7px 12px;
  font-size:12px;
  font-weight:800;
}
.price{
  font-size:38px;
  font-weight:900;
  color:var(--text);
  margin:16px 0;
}
.price-card ul{
  list-style:none;
  padding:0;
  margin:20px 0;
  color:#0b6c96;
  line-height:2;
}
.price-card li:before{
  content:"✓";
  color:var(--green);
  margin-right:8px;
  font-weight:900;
}
.compare-table{
  overflow:auto;
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:14px;
}
.compare-table table{
  width:100%;
  border-collapse:collapse;
}
.compare-table th,
.compare-table td{
  padding:17px;
  border-bottom:1px solid var(--line);
  text-align:left;
}
.compare-table th{
  color:var(--text);
}
.story-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.story-card{
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:14px;
  overflow:hidden;
}
.story-card .story-body{
  padding:24px;
}
.before-after{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}
.ba-box{
  background:#d8d8d8;
  min-height:230px;
  display:grid;
  place-items:center;
  color:#777;
  font-size:28px;
  border-radius:12px;
}
.review-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
}
.review-card{
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:14px;
  padding:28px;
}
.review-card .stars{
  color:#e4af00;
  letter-spacing:2px;
}
.tool-card{
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:16px;
  padding:32px;
}
.tool-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:start;
}
.result-box{
  background:#f4f8ed;
  border:1px solid #dcebc0;
  color:#587a18;
  border-radius:14px;
  padding:24px;
}
.result-value{
  font-size:38px;
  font-weight:900;
  color:var(--green);
}
.search-results-list{
  display:grid;
  gap:18px;
}
.search-result{
  background:#fff;
  box-shadow:var(--shadow);
  border-radius:14px;
  padding:24px;
}
.category-chip-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  justify-content:center;
  margin:0 0 32px;
}
.category-chip{
  background:#fff;
  border-radius:999px;
  padding:11px 18px;
  color:#0b6c96;
  font-weight:700;
  box-shadow:var(--shadow);
}
.gallery-detail-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}
.gallery-detail-grid img,
.gallery-detail-grid .gallery-placeholder{
  width:100%;
  aspect-ratio:4/3;
  object-fit:cover;
  border-radius:14px;
  background:#d8d8d8;
}
.video-player{
  background:#111;
  border-radius:16px;
  min-height:520px;
  display:grid;
  place-items:center;
  color:#fff;
  font-size:62px;
  box-shadow:var(--shadow);
}
.success-box,
.maintenance-box{
  background:#fff;
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:60px 40px;
  text-align:center;
}
.success-icon{
  width:82px;
  height:82px;
  border-radius:50%;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:38px;
  margin:0 auto 22px;
}
.legal-nav{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-bottom:24px;
}
.legal-nav a{
  background:#fff;
  border-radius:999px;
  padding:10px 15px;
  color:#0b6c96;
  font-weight:700;
  box-shadow:var(--shadow);
}
@media(max-width:1100px){
  .detail-page-grid,
  .tool-grid{
    grid-template-columns:1fr;
  }
  .process-grid,
  .pricing-grid,
  .story-grid,
  .review-grid{
    grid-template-columns:repeat(2,1fr);
  }
}
@media(max-width:720px){
  .feature-mini-grid,
  .process-grid,
  .pricing-grid,
  .story-grid,
  .review-grid,
  .gallery-detail-grid{
    grid-template-columns:1fr;
  }
  .content-card{
    padding:28px 22px;
  }
}


/* =========================================================
   V4 FIX - LANGUAGE DROPDOWN, FLOATING BUTTON ORDER,
   FOOTER CONTACT, TESTIMONIAL CAROUSEL
   ========================================================= */

.topbar-right{
  align-items:center !important;
}

.lang-switcher{
  position:relative;
  display:inline-flex;
  align-items:center;
  height:28px;
}

.lang-toggle{
  height:28px;
  border:1px solid #e1e8f0;
  background:#fff;
  border-radius:8px;
  padding:0 11px;
  color:#0b6c96;
  display:inline-flex;
  align-items:center;
  gap:7px;
  line-height:1;
  font-size:12px;
  font-weight:700;
  cursor:pointer;
  white-space:nowrap;
}

.lang-toggle span{
  display:inline-flex;
  align-items:center;
  line-height:1;
}

.lang-menu{
  position:absolute;
  right:0;
  top:calc(100% + 8px);
  width:145px;
  background:#fff;
  border:1px solid #e7edf5;
  border-radius:10px;
  box-shadow:0 18px 42px rgba(25,36,64,.12);
  padding:8px;
  display:none;
  z-index:100;
}

.lang-switcher:hover .lang-menu,
.lang-switcher.open .lang-menu{
  display:block;
}

.lang-menu a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:9px 10px;
  border-radius:8px;
  color:#0b6c96;
  font-size:12px;
  font-weight:700;
}

.lang-menu a:hover,
.lang-menu a.active{
  background:#f1f6fa;
  color:var(--green);
}

.floating-actions{
  bottom:86px !important;
  right:24px !important;
  gap:12px !important;
}

.float-btn{
  width:54px !important;
  height:54px !important;
  border-radius:18px !important;
  font-size:20px !important;
}

.footer-contact{
  margin-top:18px;
  display:grid;
  gap:8px;
  color:#0b6c96;
  font-size:14px;
  line-height:1.5;
}

.footer-contact a{
  display:inline-flex !important;
  align-items:center;
  gap:8px;
  margin:0 !important;
  color:#0b6c96 !important;
  font-weight:600;
}

.testimonial-section{
  overflow:hidden;
}

.testimonial-carousel-shell{
  position:relative;
}

.testimonial-carousel{
  overflow:hidden;
}

.testimonial-track{
  display:flex;
  transition:transform .35s ease;
  will-change:transform;
}

.testimonial-slide{
  min-width:100%;
}

.testimonial-controls{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:12px;
  margin-top:22px;
}

.testimonial-control{
  width:42px;
  height:42px;
  border:0;
  border-radius:50%;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  cursor:pointer;
  font-size:22px;
  box-shadow:0 12px 28px rgba(137,173,45,.22);
}

.testimonial-control:hover{
  background:var(--green-dark);
}

.testimonial-dots{
  display:flex;
  gap:7px;
  align-items:center;
}

.testimonial-dot{
  width:9px;
  height:9px;
  border-radius:50%;
  border:0;
  background:#d4e4b6;
  cursor:pointer;
}

.testimonial-dot.active{
  background:var(--green);
  transform:scale(1.25);
}

@media(max-width:640px){
  .lang-toggle{
    height:26px;
    padding:0 8px;
    font-size:11px;
  }
  .lang-menu{
    right:-4px;
  }
  .floating-actions{
    bottom:14px !important;
    right:14px !important;
  }
}


/* =========================================================
   V5 FIX - DROPDOWN MENU + CONTACT PAGE LIKE REFERENCE
   ========================================================= */

.nav-item{
  position:relative;
  display:flex;
  align-items:center;
}

.nav-item > a{
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.nav-caret{
  font-size:10px;
  opacity:.75;
  transform:translateY(1px);
}

.dropdown-menu{
  position:absolute;
  left:0;
  top:calc(100% + 22px);
  min-width:245px;
  background:#fff;
  border:1px solid #e8eef5;
  border-radius:14px;
  box-shadow:0 22px 54px rgba(25,36,64,.13);
  padding:10px;
  opacity:0;
  visibility:hidden;
  transform:translateY(8px);
  transition:.18s ease;
  z-index:120;
}

.dropdown-menu:before{
  content:"";
  position:absolute;
  top:-18px;
  left:0;
  right:0;
  height:18px;
}

.nav-item:hover .dropdown-menu,
.nav-item.open .dropdown-menu{
  opacity:1;
  visibility:visible;
  transform:translateY(0);
}

.dropdown-menu a{
  display:flex !important;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:11px 12px;
  border-radius:10px;
  color:#2d2f48 !important;
  font-size:13px;
  font-weight:700;
  white-space:nowrap;
}

.dropdown-menu a:after{
  display:none !important;
}

.dropdown-menu a:hover{
  background:#f4f8ed;
  color:var(--green) !important;
}

.dropdown-menu a span{
  color:#9aa8b7;
  font-size:13px;
}

.contact-page-main{
  padding:56px 0 34px;
}

.contact-info-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:24px;
  margin-bottom:48px;
}

.contact-info-card{
  background:#fff;
  border-radius:15px;
  box-shadow:var(--shadow);
  padding:34px 36px;
  min-height:220px;
  position:relative;
  overflow:hidden;
}

.contact-info-card .arrow{
  position:absolute;
  right:32px;
  top:52px;
  color:#a7b1bc;
  font-size:34px;
  font-weight:300;
}

.contact-info-icon{
  width:62px;
  height:62px;
  border-radius:50%;
  background:#f2f4f9;
  color:#0b6c96;
  display:grid;
  place-items:center;
  font-size:25px;
  margin-bottom:28px;
}

.contact-info-card.active .contact-info-icon{
  background:var(--green);
  color:#fff;
}

.contact-info-card.active .arrow{
  color:var(--green);
  transform:rotate(90deg);
}

.contact-info-label{
  color:#0b6c96;
  font-weight:600;
  margin-bottom:8px;
}

.contact-info-value{
  color:var(--text);
  font-size:26px;
  line-height:1.22;
  font-weight:800;
}

.contact-work-grid{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(430px,.8fr);
  gap:28px;
  align-items:stretch;
}

.contact-map-large{
  min-height:520px;
  border-radius:0;
  overflow:hidden;
  box-shadow:var(--shadow);
  background:#d8d8d8;
}

.contact-map-large img{
  width:100%;
  height:100%;
  object-fit:cover;
  min-height:520px;
}

.contact-form-panel{
  display:grid;
  gap:22px;
}

.contact-form-panel .input,
.contact-form-panel .textarea,
.contact-form-panel .select{
  background:#fff;
  border-color:#fff;
  box-shadow:none;
  min-height:70px;
  border-radius:14px;
}

.contact-form-panel .textarea{
  min-height:172px;
  padding-top:24px;
}

.contact-form-panel .icon-input .input,
.contact-form-panel .icon-input .textarea,
.contact-form-panel .icon-input .select{
  padding-left:62px;
}

.contact-form-panel .field-icon{
  left:22px;
  color:#0b6c96;
  font-size:22px;
}

.contact-submit{
  width:100%;
  height:68px;
  border-radius:12px;
  font-size:16px;
}

.social-contact-grid{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:20px;
  margin-top:36px;
}

.social-contact-card{
  background:#fff;
  border-radius:12px;
  min-height:66px;
  display:flex;
  align-items:center;
  gap:12px;
  padding:0 22px;
  color:#0b6c96;
  font-weight:800;
  box-shadow:var(--shadow);
}

.social-contact-card span{
  font-size:20px;
}

@media(max-width:1050px){
  .dropdown-menu{
    position:static;
    opacity:1;
    visibility:visible;
    transform:none;
    box-shadow:none;
    border:0;
    padding:4px 0 0 18px;
    min-width:100%;
    background:transparent;
    display:none;
  }
  .nav-item.open .dropdown-menu{
    display:block;
  }
  .nav-item{
    width:100%;
    flex-direction:column;
    align-items:flex-start;
  }
  .dropdown-menu a{
    background:#f6f8fb;
    width:100%;
    margin:4px 0;
  }
  .contact-info-grid,
  .contact-work-grid,
  .social-contact-grid{
    grid-template-columns:1fr;
  }
  .contact-map-large,
  .contact-map-large img{
    min-height:390px;
  }
}

@media(max-width:640px){
  .contact-info-card{
    min-height:auto;
    padding:26px;
  }
  .contact-info-value{
    font-size:21px;
  }
}


/* =========================================================
   V6 VISUAL POLISH - PREMIUM PAGE DESIGN SYSTEM
   ========================================================= */

body{
  background:
    radial-gradient(circle at 20% 5%, rgba(137,173,45,.06), transparent 28%),
    radial-gradient(circle at 80% 15%, rgba(11,108,150,.05), transparent 25%),
    var(--soft);
}

.breadcrumb-wrap{
  background:linear-gradient(180deg,#f0f4f9 0%,#eef2f7 100%);
  border-top:1px solid #eef2f6;
  border-bottom:1px solid #e8edf5;
}

.page-hero-mini{
  padding:72px 0 46px !important;
  position:relative;
}

.page-hero-mini:before{
  content:"";
  position:absolute;
  left:50%;
  top:38px;
  width:82px;
  height:5px;
  transform:translateX(-50%);
  background:var(--green);
  border-radius:999px;
  opacity:.25;
}

.page-hero-mini .section-title{
  font-size:40px !important;
  letter-spacing:-.04em;
}

.page-hero-mini .section-kicker{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:28px;
  padding:0 14px;
  border-radius:999px;
  background:#fff;
  box-shadow:var(--shadow);
  margin-bottom:14px;
}

.card,
.gallery-card,
.story-card,
.review-card,
.price-card,
.process-card,
.search-result,
.tool-card,
.content-card,
.form-card,
.policy-card{
  border:1px solid rgba(231,237,245,.9);
}

.card,
.gallery-card,
.blog-card,
.story-card,
.review-card,
.price-card{
  transition:transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}

.card:hover,
.gallery-card:hover,
.blog-card:hover,
.story-card:hover,
.review-card:hover,
.price-card:hover{
  transform:translateY(-6px);
  box-shadow:0 22px 52px rgba(25,36,64,.12);
  border-color:rgba(137,173,45,.25);
}

.card img,
.gallery-card img,
.blog-card img,
.story-card img{
  transition:transform .35s ease, filter .35s ease;
}

.card:hover img,
.gallery-card:hover img,
.blog-card:hover img,
.story-card:hover img{
  transform:scale(1.035);
  filter:saturate(1.06);
}

.gallery-card,
.blog-card,
.story-card{
  position:relative;
}

.gallery-card img{
  height:220px;
  width:100%;
  object-fit:cover;
}

.gallery-card h3{
  font-size:20px;
  padding:28px 28px 18px !important;
}

.gallery-card h3:after{
  content:"";
  display:block;
  width:48px;
  height:2px;
  background:#e6edf3;
  margin-top:24px;
}

.gallery-card .btn{
  min-height:48px;
  border-radius:10px;
}

.gallery-card:before{
  content:"";
  position:absolute;
  top:18px;
  right:18px;
  width:44px;
  height:44px;
  border-radius:50%;
  background:rgba(255,255,255,.92);
  box-shadow:0 10px 24px rgba(25,36,64,.12);
  z-index:2;
}

.gallery-card:after{
  content:"↗";
  position:absolute;
  top:29px;
  right:32px;
  color:var(--green);
  z-index:3;
  font-weight:900;
}

.video-gallery-card:after{
  content:"▶";
  right:31px;
}

.video-gallery-card:before{
  background:var(--green);
}

.video-gallery-card:after{
  color:#fff;
}

.video-gallery-card img{
  height:220px;
  width:100%;
  object-fit:cover;
}

.blog-card{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  padding:0 0 22px;
  overflow:hidden;
}

.blog-card img{
  width:100%;
  height:210px;
  object-fit:cover;
}

.blog-card h3,
.blog-card p{
  padding-left:22px;
  padding-right:22px;
}

.blog-card h3{
  min-height:62px;
}

.blog-card p{
  margin-bottom:0;
}

.blog-card .tag{
  margin:18px 22px 0;
}

.section-head{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}

.section-title{
  letter-spacing:-.035em;
}

.section-text{
  font-size:15px;
}

.map-section{
  padding-top:70px !important;
}

.map-box{
  border-radius:18px;
  overflow:hidden;
  box-shadow:0 22px 54px rgba(25,36,64,.09);
}

.map-box>img{
  min-height:390px;
}

.map-info{
  box-shadow:0 18px 46px rgba(25,36,64,.14) !important;
}

.footer{
  padding-top:44px !important;
}

.footer-grid{
  align-items:start;
}

.footer h4{
  position:relative;
  padding-bottom:12px;
}

.footer h4:after{
  content:"";
  position:absolute;
  left:0;
  bottom:0;
  width:34px;
  height:2px;
  border-radius:999px;
  background:var(--green);
}

.social-contact-card,
.category-chip{
  transition:.2s ease;
}

.social-contact-card:hover,
.category-chip:hover{
  transform:translateY(-3px);
  background:#f4f8ed;
  color:var(--green);
}

/* Premium listing blocks for gallery/video pages */
.premium-listing{
  padding:34px 0 20px;
}

.premium-listing .section-head{
  margin-bottom:36px;
}

.premium-card-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:26px;
}

.premium-media-card{
  background:#fff;
  border-radius:18px;
  overflow:hidden;
  box-shadow:var(--shadow);
  border:1px solid rgba(231,237,245,.95);
  position:relative;
  transition:.22s ease;
}

.premium-media-card:hover{
  transform:translateY(-7px);
  box-shadow:0 24px 58px rgba(25,36,64,.13);
}

.premium-media{
  height:230px;
  position:relative;
  overflow:hidden;
}

.premium-media img{
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.35s ease;
}

.premium-media-card:hover .premium-media img{
  transform:scale(1.05);
}

.premium-media:before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,rgba(0,0,0,0) 45%,rgba(20,28,38,.28) 100%);
  z-index:1;
}

.premium-badge{
  position:absolute;
  left:18px;
  top:18px;
  z-index:2;
  min-height:30px;
  border-radius:999px;
  background:#fff;
  color:var(--green);
  padding:7px 13px;
  font-size:12px;
  font-weight:900;
  box-shadow:0 12px 25px rgba(25,36,64,.11);
}

.premium-action{
  position:absolute;
  right:18px;
  top:18px;
  z-index:2;
  width:42px;
  height:42px;
  border-radius:50%;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  font-weight:900;
  box-shadow:0 14px 28px rgba(137,173,45,.25);
}

.premium-body{
  padding:24px;
}

.premium-body h3{
  margin:0 0 10px;
  font-size:20px;
}

.premium-body p{
  color:#0b6c96;
  line-height:1.65;
  margin:0 0 20px;
}

.premium-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding-top:18px;
  border-top:1px solid var(--line);
  color:#8a96a8;
  font-size:13px;
  font-weight:700;
}

.premium-meta a{
  color:var(--green);
  font-weight:900;
}

/* Service/detail pages stronger */
.detail-page-grid{
  gap:32px !important;
}

.left-photo-card,
.left-menu-card,
.left-cta-card,
.detail-content-card,
.content-card{
  border:1px solid rgba(231,237,245,.95);
}

.left-photo-card img{
  background:#eef2f7;
}

.detail-content-card h1,
.content-card h1{
  letter-spacing:-.035em;
}

.feature-mini{
  border:1px solid #e8eef5;
}

.detail-cta{
  border:1px solid #dcebc0;
}

/* Pricing page */
.price-card{
  overflow:hidden;
}

.price-card:before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:5px;
  background:var(--green);
  opacity:.55;
}

.price-card.popular:before{
  opacity:1;
}

/* Calculator tools */
.tool-card{
  position:relative;
  overflow:hidden;
}

.tool-card:before{
  content:"";
  position:absolute;
  right:-80px;
  top:-80px;
  width:180px;
  height:180px;
  background:rgba(137,173,45,.09);
  border-radius:50%;
}

.result-box{
  box-shadow:var(--shadow);
}

@media(max-width:1050px){
  .premium-card-grid{
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}

@media(max-width:700px){
  .premium-card-grid{
    grid-template-columns:1fr;
  }
  .premium-media{
    height:210px;
  }
}


/* =========================================================
   V7 FINAL FIX - FLOATING BUTTONS DEFINITIVE POSITION/ORDER
   ========================================================= */

.floating-actions{
  position:fixed !important;
  right:24px !important;
  bottom:86px !important;
  top:auto !important;
  left:auto !important;
  transform:none !important;
  z-index:9999 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:12px !important;
  width:auto !important;
}

.float-btn{
  width:56px !important;
  height:56px !important;
  min-width:56px !important;
  min-height:56px !important;
  border-radius:18px !important;
  background:#20252b !important;
  color:#fff !important;
  border:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-shadow:0 18px 40px rgba(20,25,30,.22) !important;
  font-size:0 !important;
  line-height:1 !important;
  cursor:pointer !important;
  transition:.2s ease !important;
  text-decoration:none !important;
  position:relative !important;
}

.float-btn:hover{
  background:var(--green) !important;
  transform:translateY(-3px) !important;
}

.float-btn::before{
  font-size:22px !important;
  font-weight:800 !important;
  line-height:1 !important;
}

.float-btn.float-top::before{content:"⌃";}
.float-btn.float-whatsapp::before{content:"";}
.float-btn.float-phone::before{content:"☎";}
.float-btn.float-chat::before{content:"💬";font-size:20px !important;}

.float-btn .float-label{
  position:absolute;
  right:66px;
  top:50%;
  transform:translateY(-50%);
  background:#20252b;
  color:#fff;
  padding:8px 12px;
  border-radius:10px;
  font-size:12px;
  font-weight:800;
  white-space:nowrap;
  opacity:0;
  visibility:hidden;
  transition:.18s ease;
  box-shadow:0 12px 26px rgba(20,25,30,.18);
}

.float-btn:hover .float-label{
  opacity:1;
  visibility:visible;
  right:72px;
}

@media(max-width:640px){
  .floating-actions{
    right:14px !important;
    bottom:14px !important;
    flex-direction:row !important;
    gap:8px !important;
  }

  .float-btn{
    width:48px !important;
    height:48px !important;
    min-width:48px !important;
    min-height:48px !important;
    border-radius:15px !important;
  }

  .float-btn::before{
    font-size:19px !important;
  }

  .float-btn .float-label{
    display:none !important;
  }
}


/* =========================================================
   V8 FINAL - ICON ONLY FLOAT BUTTONS + REFERENCE STYLE SLIDER
   ========================================================= */

/* Floating buttons: icon only, no text labels */
.floating-actions{
  position:fixed !important;
  right:24px !important;
  bottom:86px !important;
  top:auto !important;
  left:auto !important;
  transform:none !important;
  z-index:9999 !important;
  display:flex !important;
  flex-direction:column !important;
  gap:12px !important;
}

.float-btn{
  width:56px !important;
  height:56px !important;
  min-width:56px !important;
  min-height:56px !important;
  border-radius:18px !important;
  background:#20252b !important;
  color:#fff !important;
  border:0 !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  box-shadow:0 18px 40px rgba(20,25,30,.22) !important;
  font-size:0 !important;
  line-height:1 !important;
  cursor:pointer !important;
  transition:.2s ease !important;
  text-decoration:none !important;
  position:relative !important;
}

.float-btn:hover{
  background:var(--green) !important;
  transform:translateY(-3px) !important;
}

.float-btn::before{
  font-size:22px !important;
  font-weight:800 !important;
  line-height:1 !important;
}

.float-btn.float-top::before{content:"⌃";}
.float-btn.float-whatsapp::before{content:"";}
.float-btn.float-phone::before{content:"☎";}
.float-btn.float-chat::before{content:"💬";font-size:20px !important;}

.float-btn .float-label{
  display:none !important;
}

/* Slider closer to the reference */
.home-slider{
  position:relative !important;
  background:#eef3f0 !important;
  overflow:hidden !important;
  border-bottom:1px solid #e5ebf0;
}

.slide{
  min-height:520px !important;
  display:none;
  background-repeat:no-repeat !important;
  background-size:cover !important;
  background-position:center right !important;
  position:relative !important;
}

.slide.active{
  display:block !important;
}

.slide:before{
  content:"" !important;
  position:absolute !important;
  inset:0 !important;
  background:linear-gradient(90deg,rgba(238,245,240,.55) 0%,rgba(238,245,240,.22) 46%,rgba(238,245,240,.04) 100%) !important;
  z-index:1 !important;
}

.slide-inner{
  min-height:520px !important;
  position:relative !important;
  z-index:2 !important;
  display:flex !important;
  align-items:center !important;
}

.slide-card{
  width:515px !important;
  max-width:calc(100% - 40px) !important;
  margin-left:0 !important;
  background:#fff !important;
  border-radius:0 !important;
  box-shadow:0 22px 55px rgba(25,36,64,.13) !important;
  padding:42px 46px !important;
  position:relative !important;
}

.slide-kicker{
  color:var(--green) !important;
  font-size:13px !important;
  font-weight:800 !important;
  margin-bottom:9px !important;
}

.slide-card h1{
  margin:0 0 16px !important;
  color:var(--text) !important;
  font-size:32px !important;
  line-height:1.12 !important;
  letter-spacing:-.04em !important;
}

.slide-card p{
  color:#0b6c96 !important;
  line-height:1.75 !important;
  font-size:14px !important;
  margin:0 0 24px !important;
}

.slider-actions{
  display:flex !important;
  gap:12px !important;
  align-items:center !important;
  flex-wrap:wrap !important;
}

.slider-actions .btn{
  min-height:42px !important;
  padding:0 22px !important;
  border-radius:999px !important;
  font-size:13px !important;
}

.slide-visual-card{
  display:none !important;
}

/* Reference-like side arrows, both left and right */
.slider-arrow{
  position:absolute !important;
  z-index:10 !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  width:48px !important;
  height:48px !important;
  border:0 !important;
  border-radius:50% !important;
  background:var(--green) !important;
  color:#fff !important;
  box-shadow:0 16px 34px rgba(137,173,45,.28) !important;
  cursor:pointer !important;
  font-size:30px !important;
  display:grid !important;
  place-items:center !important;
  line-height:1 !important;
  opacity:.96 !important;
}

.slider-arrow:hover{
  background:var(--green-dark) !important;
}

.slider-arrow.prev{
  left:28px !important;
}

.slider-arrow.next{
  right:28px !important;
}

/* Bottom 3 dot selector */
.slider-dots{
  position:absolute !important;
  z-index:11 !important;
  left:50% !important;
  right:auto !important;
  top:auto !important;
  bottom:24px !important;
  transform:translateX(-50%) !important;
  display:flex !important;
  gap:9px !important;
  align-items:center !important;
  justify-content:center !important;
}

.slider-dot{
  width:9px !important;
  height:9px !important;
  border-radius:50% !important;
  border:0 !important;
  background:#cfd8df !important;
  opacity:1 !important;
  cursor:pointer !important;
  padding:0 !important;
  transition:.2s ease !important;
}

.slider-dot.active{
  width:28px !important;
  border-radius:999px !important;
  background:var(--green) !important;
  transform:none !important;
}

@media(max-width:1000px){
  .slide,
  .slide-inner{
    min-height:430px !important;
  }

  .slide-card{
    width:460px !important;
    padding:32px 34px !important;
  }

  .slide-card h1{
    font-size:28px !important;
  }

  .slider-arrow{
    width:42px !important;
    height:42px !important;
    font-size:26px !important;
  }

  .slider-arrow.prev{left:14px !important;}
  .slider-arrow.next{right:14px !important;}
}

@media(max-width:640px){
  .floating-actions{
    right:14px !important;
    bottom:14px !important;
    flex-direction:row !important;
    gap:8px !important;
  }

  .float-btn{
    width:48px !important;
    height:48px !important;
    min-width:48px !important;
    min-height:48px !important;
    border-radius:15px !important;
  }

  .float-btn::before{
    font-size:19px !important;
  }

  .slide,
  .slide-inner{
    min-height:390px !important;
  }

  .slide:before{
    background:rgba(238,245,240,.72) !important;
  }

  .slide-card{
    width:calc(100% - 52px) !important;
    margin:0 auto !important;
    padding:26px 24px !important;
  }

  .slide-card h1{
    font-size:25px !important;
  }

  .slider-arrow{
    display:none !important;
  }

  .slider-dots{
    bottom:14px !important;
  }
}


/* =========================================================
   V9 - BLOG SIDEBAR, FOOTER CONTACT COLOR, SMALL ROUND FLOATS,
   FIXED IMAGE TESTIMONIAL SLIDER
   ========================================================= */

/* FontAwesome-like fallback icons */
.fa{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-style:normal;
  font-weight:900;
  line-height:1;
}
.fa-arrow-up:before{content:"↑";}
.fa-whatsapp:before{content:"";}
.fa-phone:before{content:"☎";}
.fa-comments:before{content:"💬";}
.fa-search:before{content:"⌕";}
.fa-folder-open:before{content:"▣";}
.fa-tags:before{content:"";}
.fa-calendar-check:before{content:"✓";}
.fa-envelope:before{content:"✉";}

/* Footer contact same color as footer text */
.footer-contact{
  margin-top:16px !important;
  display:grid !important;
  gap:7px !important;
}
.footer-contact a{
  color:#3d4561 !important;
  font-size:14px !important;
  font-weight:500 !important;
  line-height:1.8 !important;
  display:flex !important;
  align-items:center !important;
  gap:9px !important;
  margin:0 !important;
}
.footer-contact a .fa{
  color:#3d4561 !important;
  width:16px;
}

/* Floating buttons final: smaller, rounder, lower */
.floating-actions{
  right:20px !important;
  bottom:42px !important;
  top:auto !important;
  transform:none !important;
  display:flex !important;
  flex-direction:column !important;
  gap:10px !important;
  z-index:9999 !important;
}
.float-btn{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  min-height:46px !important;
  border-radius:50% !important;
  background:#20252b !important;
  color:#fff !important;
  font-size:18px !important;
  box-shadow:0 14px 30px rgba(20,25,30,.20) !important;
}
.float-btn:before{
  display:none !important;
}
.float-btn .fa{
  color:#fff !important;
  font-size:18px !important;
}
.float-btn:hover{
  background:var(--green) !important;
  transform:translateY(-2px) !important;
}
@media(max-width:640px){
  .floating-actions{
    right:12px !important;
    bottom:12px !important;
    flex-direction:row !important;
    gap:8px !important;
  }
  .float-btn{
    width:42px !important;
    height:42px !important;
    min-width:42px !important;
    min-height:42px !important;
  }
}

/* Blog sidebar premium */
.blog-sidebar{
  display:grid;
  gap:22px;
}
.blog-side-widget{
  background:#fff;
  border-radius:14px;
  box-shadow:var(--shadow);
  border:1px solid rgba(231,237,245,.95);
  overflow:hidden;
}
.blog-side-title{
  min-height:54px;
  background:var(--green);
  color:#fff;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 20px;
  font-weight:800;
}
.blog-side-body{
  padding:20px;
}
.blog-search-form{
  display:flex;
  align-items:center;
  gap:10px;
  background:#f5f7fb;
  border-radius:10px;
  padding:0 14px;
  min-height:48px;
}
.blog-search-form input{
  border:0;
  outline:0;
  background:transparent;
  flex:1;
  color:var(--text);
}
.blog-category-list{
  display:grid;
  gap:10px;
}
.blog-category-list a{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  background:#f6f8fb;
  border-radius:10px;
  padding:12px 14px;
  color:#0b6c96;
  font-weight:700;
  transition:.18s ease;
}
.blog-category-list a:hover{
  background:#f0f7e5;
  color:var(--green);
  transform:translateX(3px);
}
.tag-cloud{
  display:flex;
  flex-wrap:wrap;
  gap:9px;
}
.tag-cloud a{
  background:#f6f8fb;
  color:#0b6c96;
  border-radius:999px;
  padding:8px 12px;
  font-size:12px;
  font-weight:800;
}
.tag-cloud a:hover{
  background:var(--green);
  color:#fff;
}
.blog-cta-box{
  background:linear-gradient(135deg,#89ad2d,#6f941d);
  color:#fff;
  border-radius:14px;
  padding:22px;
  box-shadow:0 18px 38px rgba(137,173,45,.24);
}
.blog-cta-box h3{
  color:#fff;
  margin:0 0 10px;
  font-size:20px;
}
.blog-cta-box p{
  color:rgba(255,255,255,.86);
  line-height:1.65;
}
.blog-cta-buttons{
  display:grid;
  gap:10px;
  margin-top:18px;
}
.blog-cta-buttons a{
  min-height:44px;
  border-radius:10px;
  background:#fff;
  color:var(--green);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  font-weight:900;
}
.blog-cta-buttons a.alt{
  background:rgba(255,255,255,.16);
  color:#fff;
  border:1px solid rgba(255,255,255,.28);
}

/* Blog layout more consistent */
.blog-layout{
  align-items:start;
}
.blog-layout aside{
  position:sticky;
  top:110px;
}

/* Testimonial: image fixed, text slides only */
.testimonial-fixed-grid{
  display:grid;
  grid-template-columns:1.15fr .85fr;
  gap:0;
  align-items:stretch;
}
.testimonial-text-carousel{
  overflow:hidden;
  background:#fff;
  border-left:2px solid #c7d798;
}
.testimonial-text-track{
  display:flex;
  transition:transform .35s ease;
  will-change:transform;
}
.testimonial-text-slide{
  min-width:100%;
  padding:58px 64px;
  position:relative;
}
.testimonial-text-slide .quote-mark{
  color:var(--green);
  font-size:48px;
  line-height:1;
}
.testimonial-text-slide h2{
  font-size:30px;
  margin:6px 0 22px;
}
.testimonial-text-slide p{
  color:var(--blue);
  line-height:1.75;
}
.testimonial-controls.inside{
  justify-content:flex-start;
  margin-top:20px;
}
@media(max-width:900px){
  .testimonial-fixed-grid{
    grid-template-columns:1fr;
  }
  .testimonial-text-slide{
    padding:38px 28px;
  }
  .blog-layout aside{
    position:static;
  }
}


/* =========================================================
   V10 - COOKIE CONSENT + SUBSCRIPTION PACKAGES PAGE
   ========================================================= */

/* Cookie consent */
.cookie-consent{
  position:fixed;
  left:24px;
  bottom:24px;
  width:min(430px, calc(100vw - 48px));
  background:#fff;
  border:1px solid rgba(231,237,245,.95);
  border-radius:20px;
  box-shadow:0 24px 70px rgba(25,36,64,.18);
  padding:22px;
  z-index:10000;
  display:none;
  overflow:hidden;
}
.cookie-consent.show{
  display:block;
  animation:cookieIn .35s ease both;
}
@keyframes cookieIn{
  from{opacity:0; transform:translateY(18px);}
  to{opacity:1; transform:translateY(0);}
}
.cookie-consent:before{
  content:"";
  position:absolute;
  right:-42px;
  top:-42px;
  width:130px;
  height:130px;
  border-radius:50%;
  background:rgba(137,173,45,.10);
}
.cookie-head{
  display:flex;
  gap:14px;
  align-items:flex-start;
  position:relative;
  z-index:2;
}
.cookie-icon{
  width:50px;
  height:50px;
  min-width:50px;
  border-radius:16px;
  background:#f3f8e8;
  color:var(--green);
  display:grid;
  place-items:center;
  font-size:25px;
}
.cookie-title{
  margin:0 0 6px;
  font-size:18px;
  color:var(--text);
}
.cookie-text{
  margin:0;
  color:#0b6c96;
  line-height:1.65;
  font-size:13px;
}
.cookie-actions{
  position:relative;
  z-index:2;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}
.cookie-actions .btn{
  min-height:42px;
  border-radius:999px;
  padding:0 18px;
  font-size:13px;
}
.cookie-link{
  display:inline-flex;
  align-items:center;
  min-height:42px;
  color:#0b6c96;
  font-weight:800;
  font-size:13px;
}
@media(max-width:640px){
  .cookie-consent{
    left:14px;
    bottom:74px;
    width:calc(100vw - 28px);
    padding:18px;
  }
  .cookie-actions .btn,
  .cookie-link{
    width:100%;
    justify-content:center;
  }
}

/* Subscription page */
.subscription-hero{
  padding:72px 0 40px;
  text-align:center;
  position:relative;
}
.subscription-hero .section-title{
  font-size:42px;
}
.subscription-switch{
  margin:26px auto 0;
  display:inline-flex;
  background:#fff;
  border:1px solid #e8eef5;
  border-radius:999px;
  padding:7px;
  box-shadow:var(--shadow);
  gap:6px;
}
.subscription-switch a{
  min-height:42px;
  padding:0 20px;
  border-radius:999px;
  color:#0b6c96;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:800;
}
.subscription-switch a.active,
.subscription-switch a:hover{
  background:var(--green);
  color:#fff;
}
.subscription-section{
  padding:42px 0 78px;
}
.subscription-section.alt{
  background:linear-gradient(180deg, rgba(255,255,255,.32), rgba(255,255,255,0));
}
.subscription-heading{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:28px;
}
.subscription-heading h2{
  margin:0;
  font-size:30px;
  letter-spacing:-.035em;
}
.subscription-heading p{
  margin:7px 0 0;
  color:#0b6c96;
  max-width:640px;
  line-height:1.7;
}
.subscription-grid{
  display:grid;
  grid-template-columns:repeat(3, minmax(0,1fr));
  gap:28px;
}
.sub-card{
  background:#fff;
  border:1px solid rgba(231,237,245,.95);
  border-radius:22px;
  overflow:hidden;
  box-shadow:var(--shadow);
  position:relative;
  transition:.22s ease;
}
.sub-card:hover{
  transform:translateY(-7px);
  box-shadow:0 26px 62px rgba(25,36,64,.14);
}
.sub-card.recommended{
  border-color:rgba(137,173,45,.55);
}
.sub-ribbon{
  position:absolute;
  left:-38px;
  top:20px;
  transform:rotate(-45deg);
  width:142px;
  min-height:30px;
  background:var(--green);
  color:#fff;
  display:grid;
  place-items:center;
  font-size:11px;
  font-weight:900;
  z-index:4;
}
.sub-top{
  min-height:210px;
  background:linear-gradient(135deg,#ffffff,#f6f8fb);
  display:grid;
  place-items:center;
  text-align:center;
  padding:28px 24px;
}
.trainer .sub-top{
  background:linear-gradient(135deg,#20252b,#121416);
}
.trainer .sub-title,
.trainer .sub-icon{
  color:#fff;
}
.sub-icon{
  width:70px;
  height:70px;
  border-radius:22px;
  background:#f3f8e8;
  color:var(--green);
  display:grid;
  place-items:center;
  margin:0 auto 20px;
  font-size:34px;
}
.trainer .sub-icon{
  background:rgba(255,255,255,.08);
}
.sub-title{
  margin:0;
  font-size:22px;
  line-height:1.28;
  letter-spacing:-.02em;
  color:#0f1624;
  font-weight:900;
  text-transform:uppercase;
}
.sub-price{
  min-height:126px;
  background:var(--green);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:7px;
  color:#fff;
  padding:22px;
}
.sub-card.yellow .sub-price,
.trainer .sub-price{
  background:var(--blue);
  color:#fff;
}
.sub-currency{
  font-size:26px;
  font-weight:900;
  transform:translateY(-10px);
}
.sub-amount{
  font-size:48px;
  line-height:1;
  font-weight:900;
  letter-spacing:-.04em;
}
.sub-period{
  font-size:16px;
  font-weight:800;
  align-self:flex-end;
  margin-bottom:10px;
}
.sub-features{
  list-style:none;
  padding:0;
  margin:0;
}
.sub-features li{
  display:flex;
  align-items:center;
  gap:11px;
  min-height:62px;
  padding:0 28px;
  border-bottom:1px solid #e8eef5;
  color:#20253a;
  font-weight:700;
}
.trainer .sub-features{
  background:#303030;
}
.trainer .sub-features li{
  color:#fff;
  border-color:rgba(255,255,255,.08);
}
.sub-features li:before{
  content:"✓";
  width:22px;
  height:22px;
  border-radius:50%;
  background:#f3f8e8;
  color:var(--green);
  display:grid;
  place-items:center;
  font-size:12px;
  font-weight:900;
}
.trainer .sub-features li:before{
  background:var(--green);
  color:#fff;
}
.sub-action{
  padding:28px;
  background:#f8fafc;
}
.trainer .sub-action{
  background:#4a4a4a;
}
.sub-action .btn{
  width:100%;
  min-height:54px;
  border-radius:0;
  background:var(--green);
  color:#fff;
  font-weight:900;
}
.trainer .sub-action .btn{
  background:var(--green);
  color:#fff;
}
.sub-action .btn:hover{
  filter:brightness(.96);
}
.subscription-note{
  margin-top:28px;
  background:#fff;
  border:1px solid #e8eef5;
  border-radius:16px;
  box-shadow:var(--shadow);
  padding:22px;
  color:#0b6c96;
  line-height:1.7;
}
@media(max-width:1050px){
  .subscription-grid{
    grid-template-columns:repeat(2, minmax(0,1fr));
  }
}
@media(max-width:720px){
  .subscription-heading{
    align-items:flex-start;
    flex-direction:column;
  }
  .subscription-grid{
    grid-template-columns:1fr;
  }
  .subscription-hero .section-title{
    font-size:32px;
  }
  .sub-amount{
    font-size:40px;
  }
}


/* =========================================================
   V11 - REAL IMAGE POLISH
   ========================================================= */

.slide.real-photo:before{
  background:linear-gradient(90deg,rgba(238,245,240,.92) 0%,rgba(238,245,240,.68) 38%,rgba(238,245,240,.14) 72%,rgba(238,245,240,.02) 100%) !important;
}

.slide.real-photo .slide-card{
  border-radius:12px !important;
}

.real-image-badge{
  position:absolute;
  right:34px;
  bottom:34px;
  z-index:3;
  background:#fff;
  color:#0b6c96;
  border-radius:14px;
  box-shadow:0 18px 46px rgba(25,36,64,.16);
  padding:16px 18px;
  display:flex;
  align-items:center;
  gap:12px;
  font-weight:800;
}

.real-image-badge span{
  width:42px;
  height:42px;
  border-radius:50%;
  background:#f3f8e8;
  color:var(--green);
  display:grid;
  place-items:center;
}

.premium-media img,
.card img,
.blog-card img,
.gallery-card img,
.profile-photo-card img,
.left-photo-card img{
  background:#eef2f7;
}

.ba-real{
  overflow:hidden;
}
.ba-real img{
  width:100%;
  height:100%;
  object-fit:cover;
  min-height:230px;
  border-radius:12px;
}
.ba-label{
  position:absolute;
  left:14px;
  top:14px;
  background:#fff;
  color:var(--green);
  border-radius:999px;
  padding:7px 12px;
  font-size:12px;
  font-weight:900;
  box-shadow:0 10px 22px rgba(25,36,64,.10);
}
.ba-box{
  position:relative;
  overflow:hidden;
}
@media(max-width:640px){
  .real-image-badge{
    display:none;
  }
}


/* =========================================================
   V12 FINAL FIXES - CENTER COOKIE, PACKAGE PAGES, FLOAT ICONS,
   TESTIMONIAL DOTS
   ========================================================= */

/* Cookie consent centered modal */
.cookie-consent{
  left:50% !important;
  top:50% !important;
  bottom:auto !important;
  right:auto !important;
  transform:translate(-50%, -50%) scale(.96) !important;
  width:min(520px, calc(100vw - 34px)) !important;
  border-radius:24px !important;
  padding:28px !important;
  text-align:left !important;
  box-shadow:0 35px 100px rgba(20,25,30,.28) !important;
}
.cookie-consent.show{
  display:block !important;
  animation:cookieCenterIn .28s ease both !important;
}
.cookie-consent.show:after{
  content:"";
  position:fixed;
  inset:-100vh;
  background:rgba(14,19,28,.34);
  z-index:-1;
}
@keyframes cookieCenterIn{
  from{opacity:0; transform:translate(-50%, -46%) scale(.94);}
  to{opacity:1; transform:translate(-50%, -50%) scale(1);}
}
.cookie-head{
  align-items:center !important;
}
.cookie-icon{
  width:58px !important;
  height:58px !important;
  min-width:58px !important;
  border-radius:18px !important;
}
.cookie-title{
  font-size:21px !important;
}
.cookie-text{
  font-size:14px !important;
}
.cookie-actions{
  justify-content:flex-start !important;
}
@media(max-width:640px){
  .cookie-consent{
    left:50% !important;
    top:50% !important;
    bottom:auto !important;
    width:calc(100vw - 28px) !important;
    padding:22px !important;
  }
}

/* Correct icon set for floating buttons */
.float-btn{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  min-height:46px !important;
  border-radius:50% !important;
  font-size:0 !important;
}
.float-btn:before,
.float-btn::before{
  display:none !important;
  content:none !important;
}
.float-btn .fa{
  font-size:18px !important;
  color:#fff !important;
  font-family:Arial, sans-serif !important;
}
.fa-arrow-up:before{content:"↑" !important;}
.fa-whatsapp:before{
  content:"☎" !important;
  transform:rotate(-18deg);
  display:inline-flex;
}
.fa-phone:before{content:"☎" !important;}
.fa-comments:before{content:"✉" !important;}

/* Give WhatsApp a clear identity by color on hover */
.float-whatsapp:hover{
  background:#20252b !important;
}
.float-phone:hover{
  background:#0b6c96 !important;
}
.float-chat:hover{
  background:#89ad2d !important;
}

/* Testimonial fixed image slider polishing */
.testimonial-text-carousel{
  position:relative;
  overflow:hidden !important;
}
.testimonial-controls.inside{
  display:flex !important;
  align-items:center !important;
  gap:12px !important;
  margin-top:24px !important;
}
.testimonial-control{
  width:34px !important;
  height:34px !important;
  font-size:20px !important;
  border-radius:50% !important;
  flex:0 0 auto !important;
}
.testimonial-dots{
  display:flex !important;
  align-items:center !important;
  gap:7px !important;
}
.testimonial-dot{
  display:block !important;
  width:7px !important;
  height:7px !important;
  min-width:7px !important;
  min-height:7px !important;
  border-radius:50% !important;
  border:0 !important;
  background:#d6e5b8 !important;
  padding:0 !important;
}
.testimonial-dot.active{
  width:22px !important;
  border-radius:999px !important;
  background:var(--green) !important;
  transform:none !important;
}
.testimonial-fixed-grid .testimonial-media img{
  width:100%;
  height:100%;
  min-height:420px;
  object-fit:cover;
}

/* Subscription landing page */
.subscription-choice-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:28px;
  margin-top:34px;
}
.subscription-choice-card{
  background:#fff;
  border:1px solid rgba(231,237,245,.95);
  border-radius:22px;
  box-shadow:var(--shadow);
  padding:34px;
  position:relative;
  overflow:hidden;
  transition:.22s ease;
}
.subscription-choice-card:hover{
  transform:translateY(-6px);
  box-shadow:0 26px 62px rgba(25,36,64,.14);
}
.subscription-choice-card:before{
  content:"";
  position:absolute;
  right:-70px;
  top:-70px;
  width:180px;
  height:180px;
  border-radius:50%;
  background:rgba(137,173,45,.10);
}
.subscription-choice-icon{
  width:72px;
  height:72px;
  border-radius:22px;
  background:#f3f8e8;
  color:var(--green);
  display:grid;
  place-items:center;
  font-size:34px;
  margin-bottom:20px;
}
.subscription-choice-card h2{
  margin:0 0 12px;
  font-size:28px;
}
.subscription-choice-card p{
  color:#0b6c96;
  line-height:1.75;
  margin-bottom:22px;
}
@media(max-width:760px){
  .subscription-choice-grid{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   V13 FINAL - REAL IMAGES, FAQ ACCORDION, SOCIALS, MAP LINK,
   CORRECT FLOAT ICONS
   ========================================================= */

.header .topbar-social,
.footer-social a{
  width:24px;
  height:24px;
  border-radius:50%;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:12px;
  color:#0b6c96 !important;
  background:transparent;
  font-weight:800;
}
.header .topbar-social:hover,
.footer-social a:hover{
  color:var(--green) !important;
  background:#f3f8e8;
}

.footer-social{
  display:flex !important;
  align-items:center;
  justify-content:flex-end;
  gap:9px;
}

.float-btn{
  width:46px !important;
  height:46px !important;
  min-width:46px !important;
  min-height:46px !important;
  border-radius:50% !important;
  background:#20252b !important;
  color:#fff !important;
  display:flex !important;
  align-items:center !important;
  justify-content:center !important;
  font-size:0 !important;
}
.float-btn:before,
.float-btn::before{
  display:none !important;
  content:none !important;
}
.float-btn svg{
  width:21px;
  height:21px;
  display:block;
  fill:none;
  stroke:#fff;
  stroke-width:2.35;
  stroke-linecap:round;
  stroke-linejoin:round;
}
.float-whatsapp svg{
  fill:#fff;
  stroke:none;
}
.float-top:hover{background:#89ad2d !important;}
.float-whatsapp:hover{background:#20252b !important;}
.float-phone:hover{background:#0b6c96 !important;}
.float-chat:hover{background:#6f941d !important;}

.map-link-wrap{
  display:block;
  position:relative;
  color:inherit;
}
.map-link-wrap:hover .map-open-badge{
  opacity:1;
  transform:translateY(0);
}
.map-open-badge{
  position:absolute;
  right:18px;
  top:18px;
  z-index:4;
  background:#fff;
  color:#0b6c96;
  border-radius:999px;
  padding:10px 14px;
  font-size:12px;
  font-weight:900;
  box-shadow:0 14px 30px rgba(25,36,64,.14);
  opacity:.92;
  transform:translateY(-2px);
  transition:.18s ease;
}

.faq-list{
  display:grid;
  gap:14px;
}
.faq-item{
  background:#fff;
  border:1px solid rgba(231,237,245,.95);
  border-radius:14px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.faq-question{
  width:100%;
  min-height:68px;
  border:0;
  background:#fff;
  color:var(--text);
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  padding:0 24px;
  font-size:17px;
  font-weight:800;
  text-align:left;
  cursor:pointer;
}
.faq-question span{
  width:32px;
  height:32px;
  border-radius:50%;
  background:#f3f8e8;
  color:var(--green);
  display:grid;
  place-items:center;
  flex:0 0 auto;
  transition:.18s ease;
}
.faq-item.active .faq-question span{
  background:var(--green);
  color:#fff;
  transform:rotate(45deg);
}
.faq-answer{
  display:none;
  padding:0 24px 24px;
  color:#0b6c96;
  line-height:1.8;
}
.faq-item.active .faq-answer{
  display:block;
}

.real-photo-card img,
.premium-media img,
.blog-card img,
.story-card img,
.gallery-detail-grid img{
  object-fit:cover;
}

.before-after-real-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:24px;
}
.before-after-real-card{
  background:#fff;
  border-radius:18px;
  box-shadow:var(--shadow);
  overflow:hidden;
  border:1px solid rgba(231,237,245,.95);
  transition:.22s ease;
}
.before-after-real-card:hover{
  transform:translateY(-6px);
  box-shadow:0 24px 58px rgba(25,36,64,.13);
}
.before-after-real-card img{
  width:100%;
  height:420px;
  object-fit:cover;
  display:block;
}
.before-after-real-card-body{
  padding:22px;
}
.before-after-real-card h3{
  margin:0 0 8px;
  color:var(--text);
}
.before-after-real-card p{
  margin:0;
  color:#0b6c96;
  line-height:1.6;
}
@media(max-width:1100px){
  .before-after-real-grid{grid-template-columns:repeat(2,1fr);}
}
@media(max-width:640px){
  .before-after-real-grid{grid-template-columns:1fr;}
  .before-after-real-card img{height:auto;}
}


/* =========================================================
   V14 - GOOGLE MAPS LINK DEFINITIVE FIX
   ========================================================= */

.map-box,
.contact-map-large{
  position:relative !important;
  overflow:hidden !important;
}

.map-box a.map-link-wrap,
.contact-map-large a.map-link-wrap{
  display:block !important;
  width:100% !important;
  height:100% !important;
  position:relative !important;
  color:inherit !important;
  text-decoration:none !important;
}

.map-box a.map-link-wrap img,
.contact-map-large a.map-link-wrap img{
  display:block !important;
  width:100% !important;
  height:100% !important;
  object-fit:cover !important;
}

.map-open-badge{
  position:absolute !important;
  right:18px !important;
  top:18px !important;
  z-index:20 !important;
  background:#fff !important;
  color:#0b6c96 !important;
  border-radius:999px !important;
  padding:10px 14px !important;
  font-size:12px !important;
  font-weight:900 !important;
  box-shadow:0 14px 30px rgba(25,36,64,.16) !important;
  pointer-events:none !important;
}

.map-link-wrap:hover .map-open-badge{
  background:var(--green) !important;
  color:#fff !important;
}


/* =========================================================
   V15 - EMBED MAP, REAL SOCIAL ICONS, SLIDER BADGE REMOVED,
   TESTIMONIAL CONTROLS CENTERED
   ========================================================= */

.real-image-badge{
  display:none !important;
}

.map-box,
.contact-map-large{
  background:#dce7ee !important;
  min-height:390px;
}

.map-embed{
  width:100% !important;
  height:390px !important;
  border:0 !important;
  display:block !important;
  filter:saturate(.95);
}

.contact-map-large .map-embed{
  height:520px !important;
}

.map-open-badge,
.map-link-wrap{
  display:none !important;
}

.social-icon{
  width:24px;
  height:24px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius:50%;
  color:#0b6c96 !important;
  transition:.18s ease;
}

.social-icon svg{
  width:15px;
  height:15px;
  display:block;
  fill:currentColor;
}

.social-icon:hover{
  color:var(--green) !important;
  background:#f3f8e8;
}

.footer-social{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:10px !important;
}

.footer-social .social-icon{
  color:#3d4561 !important;
}

.footer-social .social-icon:hover{
  color:var(--green) !important;
}

.testimonial-text-carousel{
  display:flex;
  flex-direction:column;
  justify-content:center;
}

.testimonial-text-slide{
  padding-bottom:28px !important;
}

.testimonial-controls.inside{
  justify-content:center !important;
  align-items:center !important;
  margin:4px auto 34px !important;
  width:100%;
}

.testimonial-dots{
  justify-content:center !important;
}

.testimonial-control{
  background:#fff !important;
  color:var(--green) !important;
  border:1px solid #e1ebd0 !important;
  box-shadow:0 10px 24px rgba(25,36,64,.08) !important;
}

.testimonial-control:hover{
  background:var(--green) !important;
  color:#fff !important;
}

@media(max-width:900px){
  .contact-map-large .map-embed,
  .map-embed{
    height:360px !important;
  }
}


/* =========================================================
   V16 FINAL CLEAN FIXES
   ========================================================= */
.real-image-badge{display:none!important;}
.hero-media img,.about-image img,.card img{object-fit:cover!important;background:#eef2f7;}
.hero-media img{border-radius:14px;box-shadow:0 22px 54px rgba(25,36,64,.12);}
.google-map-embed{width:100%;height:390px;border:0;display:block;border-radius:18px;filter:saturate(.95);}
.map-box{position:relative!important;overflow:hidden!important;border-radius:18px;box-shadow:0 22px 54px rgba(25,36,64,.09);min-height:390px;}
.contact-map-large{position:relative!important;overflow:hidden!important;border-radius:16px;box-shadow:0 22px 54px rgba(25,36,64,.09);min-height:520px;}
.contact-map-large .google-map-embed{height:520px;border-radius:16px;}
.map-info{position:absolute;right:44px;top:52px;z-index:3;background:#fff;border-radius:16px;padding:28px;box-shadow:0 18px 46px rgba(25,36,64,.14);min-width:280px;}
.footer-bottom{display:flex!important;align-items:center!important;justify-content:space-between!important;gap:20px!important;}
.footer-social{display:flex!important;align-items:center!important;justify-content:flex-end!important;gap:10px!important;}
.social-icon{width:28px;height:28px;border-radius:50%;display:inline-flex!important;align-items:center;justify-content:center;color:#3d4561!important;text-decoration:none!important;transition:.18s ease;}
.topbar .social-icon{color:#0b6c96!important;}
.social-icon svg{width:15px;height:15px;fill:currentColor;display:block;}
.social-icon:hover{background:#f3f8e8;color:var(--green)!important;}
.floating-actions{right:18px!important;bottom:38px!important;gap:10px!important;}
.float-btn{width:44px!important;height:44px!important;min-width:44px!important;min-height:44px!important;border-radius:50%!important;background:#20252b!important;color:#fff!important;display:flex!important;align-items:center!important;justify-content:center!important;box-shadow:0 14px 30px rgba(20,25,30,.20)!important;}
.float-btn:before,.float-btn::before{display:none!important;content:none!important;}
.float-btn svg{width:20px!important;height:20px!important;display:block!important;fill:none;stroke:#fff;stroke-width:2.3;stroke-linecap:round;stroke-linejoin:round;}
.float-whatsapp svg{fill:#fff!important;stroke:none!important;}
.float-whatsapp:hover{background:#20252b!important;}.float-phone:hover{background:#0b6c96!important;}.float-chat:hover,.float-top:hover{background:var(--green)!important;}
.testimonial-text-carousel{display:flex!important;flex-direction:column!important;justify-content:center!important;position:relative!important;overflow:hidden!important;}
.testimonial-text-slide{padding-bottom:22px!important;}
.testimonial-controls.inside{justify-content:center!important;align-items:center!important;margin:0 auto 36px!important;width:100%!important;position:relative!important;z-index:8!important;}
.testimonial-dots{display:flex!important;align-items:center!important;justify-content:center!important;gap:8px!important;}
.testimonial-dot{display:block!important;width:8px!important;height:8px!important;min-width:8px!important;min-height:8px!important;border-radius:50%!important;border:0!important;background:#d6e5b8!important;padding:0!important;}
.testimonial-dot.active{width:24px!important;border-radius:999px!important;background:var(--green)!important;}
.testimonial-control{width:34px!important;height:34px!important;border-radius:50%!important;background:#fff!important;color:var(--green)!important;border:1px solid #e1ebd0!important;box-shadow:0 10px 24px rgba(25,36,64,.08)!important;}
.review-page-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:26px;text-align:left;}
.review-page-card{background:#fff;border:1px solid rgba(231,237,245,.95);border-radius:18px;box-shadow:var(--shadow);padding:28px;transition:.22s ease;}
.review-page-card:hover{transform:translateY(-6px);box-shadow:0 24px 58px rgba(25,36,64,.13);}
.review-page-card img{width:72px;height:72px;border-radius:50%;object-fit:cover;margin-bottom:16px;}
.review-page-card .stars{color:#f3bd18;font-weight:900;letter-spacing:2px;margin:10px 0;}
.review-page-card p{color:#0b6c96;line-height:1.75;}
.blog-cta-buttons a svg{width:18px;height:18px;fill:currentColor;display:block;}
.blog-cta-buttons a{gap:9px!important;}
@media(max-width:900px){.review-page-grid{grid-template-columns:1fr}.map-info{position:relative;right:auto;top:auto;margin:16px}.contact-map-large .google-map-embed,.google-map-embed{height:360px}.footer-bottom{flex-direction:column;text-align:center}.footer-social{justify-content:center!important}}


/* =========================================================
   V17 FIX - MAP EMBED, SERVICE IMAGE RATIOS, COOKIES RESTORE
   ========================================================= */

.map-box,
.contact-map-large{
  position:relative !important;
  overflow:hidden !important;
  background:#dce7ee !important;
  border-radius:18px !important;
}

.map-embed{
  width:100% !important;
  height:390px !important;
  min-height:390px !important;
  border:0 !important;
  display:block !important;
}

.contact-map-large .map-embed{
  height:520px !important;
  min-height:520px !important;
}

.logo img,
.header .logo img{
  height:38px !important;
  width:auto !important;
  object-fit:contain !important;
}

/* Home service cards: prevent oversized/cropped look */
.service-card img,
.service-grid .card img,
.form-card img{
  width:100% !important;
  height:190px !important;
  object-fit:cover !important;
  object-position:center !important;
}

.form-keep-card img,
.keep-form-card img{
  height:180px !important;
  object-fit:cover !important;
}

/* Vertical image for diet consulting block */
.diet-consult-image,
.health-diet-image{
  width:100% !important;
  max-width:386px !important;
  height:520px !important;
  object-fit:cover !important;
  border-radius:16px !important;
  box-shadow:0 18px 45px rgba(25,36,64,.12);
}

/* Team cards: enforce images */
.team-card img,
.expert-card img,
.team-slider img,
.team-section img{
  background:#eef2f7;
  object-fit:cover !important;
}

/* Cookie must be visible if not accepted */
.cookie-consent{
  z-index:10000 !important;
}

.cookie-consent.show{
  display:block !important;
}

.cookie-consent.force-preview{
  display:block !important;
}

/* Better WhatsApp icon if SVG exists */
.float-whatsapp svg{
  width:22px !important;
  height:22px !important;
}


/* =========================================================
   V18 - FOOTER ADDRESS CONTACT LINE
   ========================================================= */

.footer-contact{
  margin-top:18px !important;
  display:grid !important;
  gap:8px !important;
}

.footer-contact a,
.footer-contact span{
  color:#3d4561 !important;
  font-size:14px !important;
  font-weight:500 !important;
  line-height:1.75 !important;
  display:flex !important;
  align-items:flex-start !important;
  gap:9px !important;
  margin:0 !important;
}

.footer-contact .fa{
  width:18px !important;
  min-width:18px !important;
  color:#3d4561 !important;
  margin-top:3px !important;
}

.fa-map-marker-alt:before,
.fa-location-dot:before{
  content:"⌖";
}


/* =========================================================
   V19 - HOME SERVICE IMAGE RATIO, HEALTH DIET VERTICAL IMAGE,
   TEAM LEYLA IMAGE, MAP LAYOUT FIX
   ========================================================= */

/* Anasayfa hizmet kartları: tüm kart görselleri yatay ve aynı oran */
.home-services .card img,
.home-services .service-card img,
.service-card img,
.form-protect-card img{
  width:100% !important;
  height:178px !important;
  min-height:178px !important;
  max-height:178px !important;
  object-fit:cover !important;
  object-position:center !important;
  border-radius:12px 12px 0 0 !important;
}

/* Gebelik/Çocuk/Sporcu kart görselleri büyümesin */
.card:has(h3) img{
  object-fit:cover;
}

/* Sağlıklı Diyet bölümündeki görsel dikey olacak */
.health-diet-image,
.diet-consult-image,
.health-diet-visual img,
.diet-consult-visual img{
  width:100% !important;
  max-width:386px !important;
  height:520px !important;
  min-height:520px !important;
  max-height:520px !important;
  object-fit:cover !important;
  object-position:center !important;
  border-radius:18px !important;
  display:block !important;
  margin:0 auto !important;
}

/* Harita alanını düzgün iframe + bilgi kartı haline getir */
.map-section{
  padding:64px 0 0 !important;
}

.map-box{
  position:relative !important;
  min-height:390px !important;
  height:390px !important;
  border-radius:18px !important;
  overflow:hidden !important;
  background:#dbe7ee !important;
  box-shadow:0 22px 54px rgba(25,36,64,.09) !important;
}

.map-box .map-embed{
  width:100% !important;
  height:100% !important;
  min-height:390px !important;
  border:0 !important;
  display:block !important;
}

.map-info{
  position:absolute !important;
  right:36px !important;
  top:50% !important;
  transform:translateY(-50%) !important;
  width:300px !important;
  max-width:calc(100% - 72px) !important;
  background:#fff !important;
  border-radius:16px !important;
  padding:28px !important;
  box-shadow:0 18px 46px rgba(25,36,64,.16) !important;
  z-index:5 !important;
}

.map-info img{
  height:38px !important;
  width:auto !important;
  object-fit:contain !important;
  margin-bottom:16px !important;
}

.map-info p{
  margin:0 0 12px !important;
  color:#2f3854 !important;
  line-height:1.65 !important;
}

.map-info hr{
  border:0 !important;
  border-top:1px solid #eef2f6 !important;
  margin:16px 0 !important;
}

.map-info strong{
  color:#2d2f48 !important;
}

.map-actions{
  margin-top:16px !important;
}

.map-actions a{
  min-height:38px !important;
  border-radius:999px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  padding:0 15px !important;
  background:var(--green) !important;
  color:#fff !important;
  font-weight:800 !important;
  font-size:13px !important;
}

/* Eski bozuk harita badge/link kalıntıları görünmesin */
.map-open-badge,
.map-link-wrap{
  display:none !important;
}

/* Contact sayfası büyük harita */
.contact-map-large{
  min-height:520px !important;
  height:520px !important;
  border-radius:18px !important;
  overflow:hidden !important;
  background:#dbe7ee !important;
}

.contact-map-large .map-embed{
  width:100% !important;
  height:100% !important;
  min-height:520px !important;
  border:0 !important;
  display:block !important;
}

@media(max-width:760px){
  .map-box{
    height:auto !important;
    min-height:0 !important;
  }
  .map-box .map-embed{
    height:330px !important;
    min-height:330px !important;
  }
  .map-info{
    position:relative !important;
    right:auto !important;
    top:auto !important;
    transform:none !important;
    width:auto !important;
    max-width:none !important;
    margin:14px !important;
  }
  .contact-map-large,
  .contact-map-large .map-embed{
    height:360px !important;
    min-height:360px !important;
  }
}


/* =========================================================
   V20 - FOOTER ADDRESS ICON + PREGNANCY CARD IMAGE HARD FIX
   ========================================================= */

/* Footer adres ikonu: gerçek pin/location ikonu */
.footer-contact .fa-map-marker-alt::before,
.footer-contact .fa-location-dot::before{
  content:"";
  display:block;
  width:16px;
  height:16px;
  background:currentColor;
  -webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 384 512'%3E%3Cpath d='M215.7 499.2C267 435 384 279.4 384 192C384 86 298 0 192 0S0 86 0 192c0 87.4 117 243 168.3 307.2c12.3 15.3 35.1 15.3 47.4 0zM192 256a64 64 0 1 1 0-128a64 64 0 1 1 0 128z'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 384 512'%3E%3Cpath d='M215.7 499.2C267 435 384 279.4 384 192C384 86 298 0 192 0S0 86 0 192c0 87.4 117 243 168.3 307.2c12.3 15.3 35.1 15.3 47.4 0zM192 256a64 64 0 1 1 0-128a64 64 0 1 1 0 128z'/%3E%3C/svg%3E") center/contain no-repeat;
}

.footer-contact .fa-map-marker-alt,
.footer-contact .fa-location-dot{
  width:18px !important;
  min-width:18px !important;
  height:18px !important;
  margin-top:3px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
}

/* Anasayfa Gebelikte Beslenme kart görseli: kesin yatay kart oranı */
.home-pregnancy-card img,
.pregnancy-card-img,
[data-card="gebelikte-beslenme"] img{
  width:100% !important;
  height:178px !important;
  min-height:178px !important;
  max-height:178px !important;
  aspect-ratio:auto !important;
  object-fit:cover !important;
  object-position:center !important;
  border-radius:12px 12px 0 0 !important;
  display:block !important;
}

/* Eğer tema kartları farklı class kullanırsa başlık çevresindeki görseli de ez */
.home-services article:has(h3) img,
.home-services .premium-media:has(img) img{
  height:178px !important;
  max-height:178px !important;
  object-fit:cover !important;
}

.premium-media{
  height:178px !important;
  max-height:178px !important;
}


/* =========================================================
   V21 - REMOVE FOOTER BOTTOM SOCIALS + APPOINTMENT FORM SPACING
   ========================================================= */

/* Footer en alt sosyal medya alanı tamamen kaldırıldı */
.footer-social,
.footer-bottom .footer-social,
footer .footer-social{
  display:none !important;
}

/* Randevu formu alan boşlukları */
.randevu-form .field,
.appointment-form .field,
form.randevu-form .field,
form.appointment-form .field{
  margin-bottom:18px !important;
}

.randevu-form .form-grid,
.appointment-form .form-grid,
form.randevu-form .form-grid,
form.appointment-form .form-grid{
  gap:18px 22px !important;
}

/* Mesaj textarea ile sonraki alan arasında net boşluk */
.randevu-form .textarea,
.appointment-form .textarea,
form.randevu-form .textarea,
form.appointment-form .textarea{
  margin-bottom:18px !important;
}

/* Randevu al sayfasındaki genel form kartı aralıkları */
body .form-card .field{
  margin-bottom:16px;
}

body .form-card .form-grid{
  gap:18px 22px;
}


.form-spacer{
  height:2px;
  grid-column:1 / -1;
}


/* =========================================================
   V22 FINAL - PREGNANCY CARD HARD FIX + FOOTER BOTTOM SOCIALS RIGHT
   ========================================================= */

/* Footer copyright satırı: solda copyright, sağda sosyal medya */
.footer-bottom,
.footer .footer-bottom,
footer .footer-bottom{
  display:flex !important;
  align-items:center !important;
  justify-content:space-between !important;
  gap:18px !important;
  flex-wrap:wrap !important;
}

.footer-bottom-social{
  display:flex !important;
  align-items:center !important;
  justify-content:flex-end !important;
  gap:10px !important;
  margin-left:auto !important;
}

.footer-bottom-social a{
  width:30px !important;
  height:30px !important;
  border-radius:50% !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  color:#3d4561 !important;
  background:#f5f7fb !important;
  transition:.18s ease !important;
}

.footer-bottom-social a:hover{
  color:#fff !important;
  background:var(--green) !important;
}

.footer-bottom-social svg{
  width:15px !important;
  height:15px !important;
  fill:currentColor !important;
  display:block !important;
}

/* Eski genel footer social hide kuralını sadece eski footer-social için tut, yeni bottom social görünsün */
.footer-social{
  display:none !important;
}

/* Anasayfa Gebelikte Beslenme kartı: kart özelinde nihai düzeltme */
.home-pregnancy-card,
article.home-pregnancy-card,
div.home-pregnancy-card{
  overflow:hidden !important;
}

.home-pregnancy-card .premium-media,
.home-pregnancy-card .card-media,
.home-pregnancy-card .service-media,
.home-pregnancy-card picture,
.home-pregnancy-card figure{
  height:178px !important;
  min-height:178px !important;
  max-height:178px !important;
  overflow:hidden !important;
  border-radius:12px 12px 0 0 !important;
}

.home-pregnancy-card img,
img.home-pregnancy-img{
  width:100% !important;
  height:178px !important;
  min-height:178px !important;
  max-height:178px !important;
  aspect-ratio:16 / 9 !important;
  object-fit:cover !important;
  object-position:center center !important;
  display:block !important;
  border-radius:12px 12px 0 0 !important;
}

/* Eğer premium-media global 230/178 çakışıyorsa bu kartta kesin 178 */
.home-pregnancy-card .premium-media img{
  height:178px !important;
  max-height:178px !important;
}

/* Home service section kartlarındaki media alanları aynı hizada */
.home-service-card .premium-media,
.home-service-card .card-media,
.home-service-card .service-media{
  height:178px !important;
  min-height:178px !important;
  max-height:178px !important;
  overflow:hidden !important;
}


/* =========================================================
   V23 - CUSTOM LOGO + FAVICON
   ========================================================= */

.header .logo img,
.logo img,
.footer-brand img,
.map-info img{
  width:auto !important;
  object-fit:contain !important;
}

.header .logo img,
.logo img{
  height:54px !important;
  max-width:260px !important;
}

.footer-brand img{
  height:54px !important;
  max-width:260px !important;
}

.map-info img{
  height:46px !important;
  max-width:230px !important;
}

@media(max-width:640px){
  .header .logo img,
  .logo img{
    height:42px !important;
    max-width:210px !important;
  }
}


/* =========================================================
   V24 - COOKIE CONSENT BOTTOM CENTER
   ========================================================= */

.cookie-consent{
  left:50% !important;
  right:auto !important;
  top:auto !important;
  bottom:24px !important;
  transform:translateX(-50%) !important;
  width:min(520px, calc(100vw - 34px)) !important;
  max-width:520px !important;
  border-radius:22px !important;
  padding:24px !important;
  text-align:left !important;
}

.cookie-consent.show{
  animation:cookieBottomCenterIn .28s ease both !important;
}

.cookie-consent.show:after{
  content:none !important;
  display:none !important;
}

@keyframes cookieBottomCenterIn{
  from{opacity:0; transform:translate(-50%, 18px);}
  to{opacity:1; transform:translate(-50%, 0);}
}

@media(max-width:640px){
  .cookie-consent{
    bottom:14px !important;
    width:calc(100vw - 28px) !important;
    padding:18px !important;
  }
}


/* =========================================================
   V25 - FLOATING WHATSAPP ICON FIX
   ========================================================= */

.floating-actions .float-whatsapp{
  background:#20252b !important;
  color:#fff !important;
}

.floating-actions .float-whatsapp::before,
.floating-actions .float-whatsapp:before{
  display:none !important;
  content:none !important;
}

.floating-actions .float-whatsapp svg{
  width:23px !important;
  height:23px !important;
  display:block !important;
  overflow:visible !important;
  color:#fff !important;
  fill:currentColor !important;
  stroke:none !important;
}

.floating-actions .float-whatsapp svg path{
  fill:currentColor !important;
  fill-rule:evenodd !important;
  clip-rule:evenodd !important;
  stroke:none !important;
}

.floating-actions .float-whatsapp:hover{
  background:#20252b !important;
}


/* =========================================================
   V34 - MOBILE RESPONSIVE QA REFINEMENT
   ========================================================= */

@media(max-width:640px){
  .topbar{
    overflow:hidden !important;
  }

  .topbar-inner{
    height:38px !important;
    min-height:38px !important;
    padding:0 !important;
    display:flex !important;
    flex-direction:row !important;
    align-items:center !important;
    justify-content:center !important;
    gap:0 !important;
    overflow:hidden !important;
  }

  .topbar-left{
    width:100% !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    flex-wrap:nowrap !important;
    gap:14px !important;
    min-width:0 !important;
  }

  .topbar-right,
  .topbar-social,
  .topbar-lang{
    display:none !important;
  }

  .topbar-item{
    min-width:0 !important;
    max-width:50% !important;
    height:28px !important;
    min-height:28px !important;
    font-size:12px !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }

  .topbar-item.email{
    display:inline-flex !important;
  }

  .topbar-item.address{
    display:none !important;
  }

  .header-inner{
    display:grid !important;
    grid-template-columns:minmax(0, 1fr) auto 40px !important;
    align-items:center !important;
    justify-content:normal !important;
    height:68px !important;
    gap:8px !important;
  }

  .header .logo{
    min-width:0 !important;
    max-width:100% !important;
  }

  .header .logo img,
  .logo img{
    height:38px !important;
    max-width:min(158px, 100%) !important;
  }

  .header-inner > .btn.btn-green{
    justify-self:end !important;
    width:auto !important;
    max-width:112px !important;
    min-height:38px !important;
    height:38px !important;
    padding:0 12px !important;
    border-radius:999px !important;
    font-size:13px !important;
    line-height:1 !important;
    white-space:nowrap !important;
    flex:0 0 auto !important;
  }

  .mobile-toggle{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    justify-self:end !important;
    width:40px !important;
    min-width:40px !important;
    height:40px !important;
    flex:0 0 40px !important;
    padding:0 !important;
    line-height:1 !important;
    position:relative !important;
    z-index:2 !important;
  }

  .nav{
    top:68px !important;
  }

  .section-title,
  .page-hero-mini .section-title,
  .subscription-hero .section-title{
    max-width:100% !important;
    white-space:normal !important;
    overflow-wrap:normal !important;
    word-break:normal !important;
    letter-spacing:0 !important;
    font-size:28px !important;
    line-height:1.18 !important;
  }

  .subscription-hero{
    padding:54px 0 32px !important;
  }

  .subscription-switch{
    width:100% !important;
    max-width:100% !important;
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:6px !important;
    border-radius:28px !important;
    padding:6px !important;
  }

  .subscription-switch a{
    min-width:0 !important;
    min-height:48px !important;
    padding:0 8px !important;
    border-radius:24px !important;
    font-size:15px !important;
    line-height:1.24 !important;
    text-align:center !important;
    white-space:normal !important;
    overflow-wrap:normal !important;
  }

  .cookie-consent{
    width:calc(100vw - 16px) !important;
    padding:18px !important;
  }

  .cookie-head{
    align-items:flex-start !important;
    gap:12px !important;
  }

  .cookie-head > div{
    min-width:0 !important;
  }

  .cookie-text{
    overflow-wrap:normal !important;
  }

  .cookie-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  .cookie-actions .btn,
  .cookie-link{
    width:100% !important;
  }
}

@media(max-width:360px){
  .header .logo img,
  .logo img{
    max-width:min(142px, 100%) !important;
  }

  .header-inner > .btn.btn-green{
    width:40px !important;
    min-width:40px !important;
    max-width:40px !important;
    padding:0 !important;
    font-size:0 !important;
    gap:0 !important;
  }

  .header-inner > .btn.btn-green::before{
    content:"☑";
    font-size:14px !important;
  }
}


/* =========================================================
   V36 - TABLET TEAM GRID OVERFLOW FIX
   ========================================================= */

@media(max-width:900px){
  .team-grid{
    grid-template-columns:1fr !important;
  }

  .team-card{
    width:100% !important;
    min-width:0 !important;
  }
}


/* =========================================================
   V38 - HOME PROMOTION POPUP
   ========================================================= */

body.promo-popup-open{
  overflow:hidden;
}

body.promo-popup-open .cookie-consent{
  visibility:hidden;
}

.promo-popup[hidden]{
  display:none !important;
}

.promo-popup{
  position:fixed;
  inset:0;
  z-index:13000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:24px;
}

.promo-popup-backdrop{
  position:absolute;
  inset:0;
  background:rgba(14,18,28,.72);
}

.promo-popup-panel{
  position:relative;
  width:min(1000px, calc(100vw - 48px));
  min-height:475px;
  background:#fff;
  box-shadow:0 34px 110px rgba(0,0,0,.34);
  overflow:hidden;
  animation:promoPopupIn .24s ease both;
}

@keyframes promoPopupIn{
  from{opacity:0; transform:translateY(18px) scale(.98);}
  to{opacity:1; transform:translateY(0) scale(1);}
}

.promo-popup-close{
  position:absolute;
  top:14px;
  right:14px;
  z-index:4;
  width:32px;
  height:32px;
  border:0;
  border-radius:4px;
  background:#f6f9fe;
  color:#8a99ae;
  font-size:26px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
  box-shadow:0 8px 20px rgba(11,108,150,.08);
}

.promo-popup-close:hover{
  color:var(--green);
}

.promo-popup-content{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(330px, .95fr);
  min-height:475px;
  min-width:0;
}

.promo-popup-copy{
  padding:58px 38px 44px 50px;
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  min-width:0;
}

.promo-popup-kicker{
  margin:0 0 16px;
  color:var(--blue);
  font-size:15px;
  line-height:1.2;
  font-weight:900;
  letter-spacing:.02em;
}

.promo-popup-copy h2{
  margin:0;
  max-width:490px;
  color:#253f6d;
  font-size:40px;
  line-height:1.02;
  font-weight:900;
}

.promo-popup-copy p:not(.promo-popup-kicker){
  max-width:470px;
  margin:28px 0 0;
  color:#0b6c96;
  font-size:16px;
  line-height:1.58;
  font-weight:700;
}

.promo-popup-cta{
  margin-top:34px;
  min-width:375px;
  min-height:60px;
  padding:0 28px;
  border-radius:6px;
  background:var(--green);
  color:#fff;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-weight:900;
  box-shadow:0 16px 34px rgba(137,173,45,.24);
}

.promo-popup-cta:hover{
  background:var(--green-dark);
}

.promo-popup-visual{
  position:relative;
  min-height:475px;
  overflow:hidden;
  background:linear-gradient(180deg, #ffffff 0%, #ffffff 34%, #d9edf9 34%, #d9edf9 100%);
  min-width:0;
}

.promo-popup-visual::before{
  content:"";
  position:absolute;
  right:-120px;
  bottom:-150px;
  width:480px;
  height:430px;
  border-radius:55% 0 0 0;
  background:#cde9f8;
}

.promo-popup-visual::after{
  content:"";
  position:absolute;
  right:56px;
  top:86px;
  width:108px;
  height:74px;
  border-radius:12px;
  background:rgba(255,255,255,.84);
  box-shadow:0 18px 44px rgba(11,108,150,.12);
  transform:rotate(-9deg);
}

.promo-popup-visual img{
  position:absolute;
  right:70px;
  bottom:0;
  z-index:2;
  width:270px;
  height:390px;
  object-fit:cover;
  object-position:center top;
  border-radius:140px 140px 0 0;
  filter:drop-shadow(0 24px 36px rgba(11,108,150,.2));
}

.promo-mail{
  position:absolute;
  z-index:3;
  width:62px;
  height:42px;
  border-radius:4px;
  background:#fff;
  box-shadow:0 14px 30px rgba(11,108,150,.14);
  transform:rotate(14deg);
}

.promo-mail::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(145deg, transparent 48%, rgba(11,108,150,.12) 49% 51%, transparent 52%),
             linear-gradient(35deg, transparent 48%, rgba(11,108,150,.12) 49% 51%, transparent 52%);
}

.promo-mail::after{
  content:"";
  position:absolute;
  right:12px;
  top:13px;
  width:11px;
  height:11px;
  border-radius:50%;
  background:var(--green);
}

.promo-mail-one{
  left:62px;
  top:58px;
  transform:rotate(18deg);
}

.promo-mail-two{
  right:90px;
  top:120px;
  transform:rotate(-16deg) scale(.86);
}

.promo-mail-three{
  right:170px;
  top:190px;
  transform:rotate(12deg) scale(.7);
}

@media(max-width:760px){
  .promo-popup{
    align-items:flex-start;
    padding:18px;
    overflow-y:auto;
    overflow-x:hidden;
    width:100vw;
    max-width:100vw;
  }

  .promo-popup-panel{
    width:100%;
    max-width:100%;
    flex:0 0 auto;
    min-height:0;
    min-width:0;
    margin:24px auto;
  }

  .promo-popup-close{
    top:10px;
    right:10px;
    width:34px;
    height:34px;
    border:1px solid #dbe6f4;
    background:#fff;
    color:#253f6d;
    font-size:24px;
  }

  .promo-popup-content{
    grid-template-columns:1fr;
    min-height:0;
    width:100%;
    max-width:100%;
  }

  .promo-popup-copy{
    padding:42px 24px 28px;
    width:100%;
    max-width:100%;
  }

  .promo-popup-copy h2{
    max-width:100%;
    font-size:29px;
    line-height:1.08;
    overflow-wrap:break-word;
  }

  .promo-popup-copy p:not(.promo-popup-kicker){
    max-width:100%;
    margin-top:20px;
    font-size:15px;
    overflow-wrap:break-word;
  }

  .promo-popup-cta{
    width:100%;
    min-width:0;
    min-height:54px;
    margin-top:24px;
  }

  .promo-popup-visual{
    min-height:260px;
  }

  .promo-popup-visual img{
    width:190px;
    height:245px;
    right:34px;
  }

  .promo-popup-visual::before{
    right:-150px;
    bottom:-170px;
    width:380px;
    height:330px;
  }

  .promo-popup-visual::after,
  .promo-mail-three{
    display:none;
  }

  .promo-mail-one{
    left:26px;
    top:42px;
  }

  .promo-mail-two{
    right:38px;
    top:42px;
  }
}


/* =========================================================
   V37 - BLOG CARD META + DETAIL HERO
   ========================================================= */

.blog-card-meta{
  padding:16px 22px 0;
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  color:#0b6c96;
  font-size:12px;
  font-weight:800;
}

.blog-card-meta span{
  display:inline-flex;
  align-items:center;
  gap:6px;
}

.blog-card-meta span::before{
  content:"";
  width:6px;
  height:6px;
  border-radius:50%;
  background:var(--green);
}

.home-blog-grid .blog-card h3{
  min-height:0 !important;
  margin:12px 0 8px !important;
}

.home-blog-grid .blog-card p{
  margin-top:0 !important;
}

.blog-detail-card{
  overflow:hidden;
}

.blog-detail-hero-image{
  width:100%;
  height:360px;
  object-fit:cover;
  border-radius:14px;
  margin-bottom:18px;
  background:#eef2f7;
}

.blog-detail-meta{
  display:flex;
  align-items:center;
  gap:10px;
  flex-wrap:wrap;
  margin:0 0 22px;
  color:#0b6c96;
  font-size:13px;
  font-weight:800;
}

.blog-detail-meta span{
  display:inline-flex;
  align-items:center;
  min-height:32px;
  padding:0 12px;
  border-radius:999px;
  background:#f3f8e8;
  color:#0b6c96;
}

@media(max-width:640px){
  .blog-card-meta{
    padding-top:14px;
  }

  .blog-detail-hero-image{
    height:230px;
  }

  .blog-detail-meta{
    align-items:stretch;
    flex-direction:column;
    gap:8px;
  }

  .blog-detail-meta span{
    justify-content:center;
  }
}


/* =========================================================
   V33 - RESPONSIVE QA PASS
   ========================================================= */

html,
body{
  max-width:100%;
  overflow-x:hidden;
}

.brand-shell,
.testimonial-text-carousel,
.compare-table{
  max-width:100%;
}

.compare-table{
  overflow-x:auto !important;
  overflow-y:hidden !important;
  -webkit-overflow-scrolling:touch;
}

.compare-table table{
  min-width:520px;
}

@media(max-width:640px){
  .header-inner{
    height:68px !important;
    gap:8px !important;
  }

  .header .logo,
  .header .logo img{
    flex:0 1 auto;
    min-width:0;
  }

  .header .logo img,
  .logo img{
    height:38px !important;
    max-width:158px !important;
  }

  .header-inner > .btn.btn-green{
    min-height:38px !important;
    height:38px !important;
    padding:0 12px !important;
    border-radius:999px !important;
    font-size:13px !important;
    line-height:1 !important;
    white-space:nowrap !important;
    flex:0 0 auto !important;
    box-shadow:0 8px 18px rgba(137,173,45,.18) !important;
  }

  .mobile-toggle{
    width:40px !important;
    min-width:40px !important;
    height:40px !important;
    border-radius:12px !important;
    flex:0 0 40px !important;
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    line-height:1 !important;
  }

  .sub-ribbon{
    left:16px !important;
    top:16px !important;
    transform:none !important;
    width:auto !important;
    min-height:28px !important;
    padding:0 12px !important;
    border-radius:999px !important;
  }
}

@media(max-width:360px){
  .header .logo img,
  .logo img{
    max-width:142px !important;
  }

  .header-inner > .btn.btn-green{
    width:40px !important;
    min-width:40px !important;
    padding:0 !important;
    font-size:0 !important;
    gap:0 !important;
  }

  .header-inner > .btn.btn-green::before{
    content:"☑";
    font-size:14px !important;
  }
}


/* =========================================================
   V26 - HOME CONTACT STRIP ORDER
   ========================================================= */

.hero .contact-strip-after-info{
  margin-top:18px !important;
  margin-bottom:0 !important;
}


/* =========================================================
   V27 - HOME BLOG + FOOTER CONTACT ICONS
   ========================================================= */

.home-blog-section{
  padding-top:0 !important;
}

.home-blog-grid{
  align-items:stretch;
}

.home-blog-grid .blog-card{
  height:100%;
}

.home-blog-actions{
  margin-top:30px;
  text-align:center;
}

.footer-contact-clean{
  margin-top:16px !important;
  display:grid !important;
  gap:8px !important;
  color:#3d4561 !important;
}

.footer-contact-clean .footer-contact-item{
  color:#3d4561 !important;
  font-size:14px !important;
  font-weight:400 !important;
  line-height:1.8 !important;
  display:flex !important;
  align-items:flex-start !important;
  gap:9px !important;
  margin:0 !important;
}

.footer-contact-clean .footer-contact-icon{
  width:18px !important;
  min-width:18px !important;
  height:18px !important;
  margin-top:3px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  color:#3d4561 !important;
}

.footer-contact-clean .footer-contact-icon svg{
  width:16px !important;
  height:16px !important;
  display:block !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}

@media(max-width:640px){
  .home-blog-actions{
    margin-top:22px;
  }
}


/* =========================================================
   V28 - TOPBAR ICON ALIGNMENT + SCROLLABLE BRAND STRIP
   ========================================================= */

.topbar-inner,
.topbar-left,
.topbar-right{
  align-items:center !important;
}

.topbar-item{
  min-height:28px !important;
  height:28px !important;
  line-height:1 !important;
  display:inline-flex !important;
  align-items:center !important;
  gap:7px !important;
  white-space:nowrap !important;
}

.topbar-item .tb-icon{
  width:22px !important;
  min-width:22px !important;
  height:22px !important;
  margin:0 !important;
  border-radius:50% !important;
  background:#e9f3f8 !important;
  color:#0b6c96 !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}

.topbar-item .tb-icon svg{
  width:13px !important;
  height:13px !important;
  display:block !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}

.lang-switcher{
  height:28px !important;
  display:inline-flex !important;
  align-items:center !important;
}

.lang-toggle{
  min-height:28px !important;
  height:28px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  gap:7px !important;
  line-height:1 !important;
}

.lang-toggle span,
.lang-toggle .lang-icon,
.lang-toggle .lang-caret{
  height:16px !important;
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
}

.lang-toggle .lang-icon,
.lang-toggle .lang-caret{
  width:16px !important;
  min-width:16px !important;
  color:#0b6c96 !important;
}

.lang-toggle svg{
  width:15px !important;
  height:15px !important;
  display:block !important;
  fill:none !important;
  stroke:currentColor !important;
  stroke-width:2 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}

.lang-toggle .lang-caret svg{
  width:13px !important;
  height:13px !important;
}

.nav-caret{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  line-height:1 !important;
  vertical-align:middle !important;
}

.brand-shell{
  overflow:hidden;
}

.brand-scroll{
  display:flex !important;
  grid-template-columns:none !important;
  gap:18px !important;
  overflow-x:auto !important;
  overflow-y:hidden !important;
  scroll-snap-type:x proximity;
  -webkit-overflow-scrolling:touch;
  padding:4px 0 14px !important;
}

.brand-scroll .brand-item{
  flex:0 0 210px;
  scroll-snap-align:start;
}

.brand-scroll::-webkit-scrollbar{
  height:7px;
}

.brand-scroll::-webkit-scrollbar-track{
  background:#eef2f7;
  border-radius:999px;
}

.brand-scroll::-webkit-scrollbar-thumb{
  background:#c8d4e2;
  border-radius:999px;
}

@media(max-width:640px){
  .topbar-item{
    min-height:26px !important;
    height:26px !important;
  }

  .brand-scroll .brand-item{
    flex-basis:165px;
  }
}


/* =========================================================
   V29 - PACKAGE PAYMENT + BANK ACCOUNT PAGE
   ========================================================= */

.payment-section{
  padding-top:18px !important;
  background:linear-gradient(180deg, rgba(245,248,252,.72), rgba(245,248,252,0));
}

.payment-choice-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
  align-items:stretch;
}

.payment-option-card,
.bank-account-card,
.account-note-box{
  background:#fff;
  border:1px solid rgba(231,237,245,.95);
  border-radius:18px;
  box-shadow:var(--shadow);
}

.payment-option-card{
  padding:30px;
  position:relative;
  overflow:hidden;
}

.payment-option-card:before{
  content:"";
  position:absolute;
  right:-72px;
  top:-72px;
  width:190px;
  height:190px;
  border-radius:50%;
  background:rgba(137,173,45,.09);
}

.payment-option-icon{
  width:52px;
  height:52px;
  border-radius:16px;
  background:#eef7e1;
  color:var(--green);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  margin-bottom:18px;
  position:relative;
  z-index:1;
}

.payment-option-icon svg{
  width:24px;
  height:24px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.payment-option-tag{
  display:inline-flex;
  align-items:center;
  min-height:28px;
  padding:0 10px;
  border-radius:999px;
  background:#f5f8fc;
  color:#0b6c96;
  font-size:12px;
  font-weight:800;
  margin-left:8px;
  vertical-align:top;
}

.payment-option-card h3,
.bank-account-card h3,
.account-note-box h3{
  margin:0 0 10px;
  color:var(--text);
}

.payment-option-card p,
.account-note-box p{
  color:#0b6c96;
  line-height:1.7;
}

.payment-option-card ul{
  list-style:none;
  padding:0;
  margin:20px 0 24px;
  color:#3d4561;
  line-height:1.9;
}

.payment-option-card li:before{
  content:"✓";
  color:var(--green);
  font-weight:900;
  margin-right:8px;
}

.card-payment-preview{
  display:grid;
  gap:14px;
  margin-top:20px;
  position:relative;
  z-index:1;
}

.card-payment-preview label{
  display:grid;
  gap:8px;
  color:#2d2f48;
  font-size:13px;
  font-weight:800;
}

.card-payment-preview input{
  width:100%;
  height:46px;
  border:1px solid #e3ebf2;
  border-radius:12px;
  padding:0 14px;
  color:#2d2f48;
  font:inherit;
  background:#f9fbfd;
}

.card-payment-row{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
}

.account-page-head{
  margin-bottom:34px;
}

.bank-accounts-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:24px;
}

.bank-account-card{
  padding:28px;
}

.bank-account-top{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  margin-bottom:24px;
}

.bank-account-top img{
  width:auto;
  height:30px;
  object-fit:contain;
}

.bank-account-top span{
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  background:#eef7e1;
  color:var(--green);
  display:inline-flex;
  align-items:center;
  font-size:12px;
  font-weight:900;
}

.bank-field{
  display:grid;
  gap:5px;
  padding:15px 0;
  border-top:1px solid #eef2f6;
}

.bank-field small{
  color:#7a8799;
  font-weight:700;
}

.bank-field strong{
  color:#2d2f48;
  font-size:16px;
  overflow-wrap:anywhere;
}

.copy-field{
  grid-template-columns:1fr auto;
  align-items:center;
  gap:5px 14px;
}

.copy-field small,
.copy-field strong{
  grid-column:1;
}

.copy-field button{
  grid-column:2;
  grid-row:1 / span 2;
  min-height:34px;
  border:0;
  border-radius:999px;
  padding:0 13px;
  background:#f4f8ed;
  color:var(--green);
  font-weight:900;
  cursor:pointer;
}

.copy-field button.copied{
  background:var(--green);
  color:#fff;
}

.iban-field strong{
  letter-spacing:.02em;
}

.account-note-box{
  margin-top:26px;
  padding:24px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:20px;
}

.account-note-box p{
  margin:0;
}

@media(max-width:900px){
  .payment-choice-grid,
  .bank-accounts-grid{
    grid-template-columns:1fr;
  }

  .account-note-box{
    align-items:flex-start;
    flex-direction:column;
  }
}

@media(max-width:560px){
  .page-hero-mini .section-title,
  .payment-section .section-title,
  .account-page-head .section-title{
    max-width:100%;
    font-size:28px !important;
    line-height:1.16 !important;
    letter-spacing:0 !important;
    overflow-wrap:anywhere;
  }

  .account-page-head .section-title,
  .payment-section .section-title{
    font-size:26px !important;
  }

  .payment-section .section-head,
  .account-page-head{
    max-width:100%;
    padding-left:4px;
    padding-right:4px;
  }

  .payment-section .section-text,
  .account-page-head .section-text{
    max-width:305px;
    margin-left:auto;
    margin-right:auto;
    font-size:13px !important;
    line-height:1.6 !important;
  }

  .payment-choice-grid,
  .bank-accounts-grid{
    min-width:0;
    justify-items:center;
  }

  .payment-option-card,
  .bank-account-card{
    padding:22px;
    width:100%;
    min-width:0;
    max-width:calc(100vw - 34px);
    margin-left:auto;
    margin-right:auto;
  }

  .account-note-box{
    max-width:calc(100vw - 34px);
    margin-left:auto;
    margin-right:auto;
  }

  .bank-account-top{
    align-items:flex-start;
    flex-direction:column;
    gap:10px;
  }

  .payment-option-card p,
  .payment-option-card li,
  .bank-field strong,
  .account-note-box p{
    max-width:300px;
    font-size:14px !important;
    line-height:1.7 !important;
    overflow-wrap:anywhere;
    word-break:break-word;
  }

  .card-payment-row{
    grid-template-columns:1fr;
  }

  .copy-field{
    grid-template-columns:1fr;
  }

  .copy-field button{
    grid-column:1;
    grid-row:auto;
    justify-self:start;
  }
}


/* =========================================================
   V30 - PAYMENT METHOD SWITCH + CONTACT/FOOTER TYPE TUNE
   ========================================================= */

.payment-method-shell{
  max-width:1180px;
  margin:0 auto;
}

.payment-method-tabs{
  display:flex;
  justify-content:center;
  gap:10px;
  margin:0 auto 24px;
  flex-wrap:wrap;
}

.payment-method-tab{
  min-height:44px;
  border:1px solid #e3ebf2;
  border-radius:999px;
  padding:0 20px;
  background:#fff;
  color:#0b6c96;
  font-weight:900;
  font-family:inherit;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(25,36,64,.05);
}

.payment-method-tab.active{
  background:var(--green);
  border-color:var(--green);
  color:#fff;
}

.payment-method-panel{
  background:#fff;
  border:1px solid rgba(231,237,245,.95);
  border-radius:18px;
  box-shadow:var(--shadow);
  padding:30px;
}

.payment-method-panel[hidden]{
  display:none !important;
}

.payment-panel-head{
  display:flex;
  align-items:flex-start;
  gap:16px;
  margin-bottom:24px;
}

.payment-panel-head .payment-option-icon{
  flex:0 0 auto;
  margin-bottom:0;
}

.payment-panel-head .payment-option-tag{
  margin:0 0 10px;
}

.payment-panel-head h3{
  margin:0 0 8px;
  color:var(--text);
}

.payment-panel-head p{
  margin:0;
  color:#0b6c96;
  line-height:1.7;
}

.payment-bank-grid{
  margin-top:8px;
}

.payment-panel-actions{
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  margin-top:24px;
}

.payment-method-panel .card-payment-preview{
  max-width:620px;
}

.contact-info-value{
  font-size:19px !important;
  line-height:1.45 !important;
  font-weight:700 !important;
  letter-spacing:0 !important;
}

.contact-info-label{
  font-size:13px !important;
}

.social-contact-grid{
  grid-template-columns:repeat(6, minmax(0, 1fr)) !important;
}

.social-contact-card{
  min-width:0;
  justify-content:center;
  padding:0 14px !important;
  text-align:center;
}

.social-contact-card span{
  min-width:22px;
  text-align:center;
  font-weight:900;
}

.footer-grid > div:first-child > p,
.footer-contact a,
.footer-contact span,
.footer-contact-clean .footer-contact-item{
  font-family:Poppins,Inter,system-ui,-apple-system,Segoe UI,Arial,sans-serif !important;
  color:#3d4561 !important;
  font-size:14px !important;
  font-weight:400 !important;
  line-height:1.8 !important;
}

.footer-contact .fa{
  font-size:13px !important;
}

@media(max-width:1050px){
  .social-contact-grid{
    grid-template-columns:repeat(3, minmax(0, 1fr)) !important;
  }
}

@media(max-width:640px){
  .payment-method-panel{
    padding:22px;
  }

  .payment-panel-head{
    flex-direction:column;
  }

  .payment-panel-actions{
    align-items:stretch;
    flex-direction:column;
  }

  .payment-panel-actions .btn{
    width:100%;
  }

  .social-contact-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr)) !important;
  }
}


/* =========================================================
   V31 - CONTACT CARD TEXT SMALLER
   ========================================================= */

.contact-info-value{
  font-size:16px !important;
  line-height:1.55 !important;
  font-weight:600 !important;
  letter-spacing:0 !important;
}

.contact-info-label{
  font-size:12px !important;
  font-weight:700 !important;
}

@media(max-width:640px){
  .contact-info-value{
    font-size:15px !important;
  }
}


/* =========================================================
   V32 - FLOATING WHATSAPP ICON RESET
   ========================================================= */

.floating-actions .float-whatsapp{
  background:#20252b !important;
}

.floating-actions .float-whatsapp::before,
.floating-actions .float-whatsapp:before{
  display:none !important;
  content:none !important;
}

.floating-actions .float-whatsapp svg{
  display:none !important;
}

.floating-actions .float-whatsapp::after{
  content:"" !important;
  display:block !important;
  width:26px !important;
  height:26px !important;
  flex:0 0 26px !important;
  background-repeat:no-repeat !important;
  background-position:center !important;
  background-size:contain !important;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='white' stroke-width='2.15' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M12 21a9 9 0 1 0-7.8-4.5L3 22l5.7-1.2A8.9 8.9 0 0 0 12 21Z'/%3E%3Cpath d='M8.8 7.7c.2-.35.4-.5.7-.5h.55c.25 0 .45.15.55.38l.8 1.82c.1.25.05.5-.13.7l-.6.68c.58 1.15 1.55 2.12 2.7 2.7l.68-.6c.2-.18.45-.23.7-.13l1.82.8c.23.1.38.3.38.55v.55c0 .3-.15.55-.5.75-.7.35-1.72.4-2.88.02-2.85-.95-5.08-3.18-6.03-6.03-.38-1.16-.33-2.18.02-2.88Z'/%3E%3C/svg%3E") !important;
}

.floating-actions .float-whatsapp:hover{
  background:#20252b !important;
}


/* =========================================================
   V35 - MOBILE RESPONSIVE QA FINAL OVERRIDES
   ========================================================= */

@media(max-width:640px){
  .topbar{
    overflow:hidden !important;
  }

  .topbar-inner{
    height:38px !important;
    min-height:38px !important;
    padding:0 !important;
    display:flex !important;
    flex-direction:row !important;
    align-items:center !important;
    justify-content:center !important;
    gap:0 !important;
    overflow:hidden !important;
  }

  .topbar-left{
    width:100% !important;
    display:flex !important;
    align-items:center !important;
    justify-content:center !important;
    flex-wrap:nowrap !important;
    gap:14px !important;
    min-width:0 !important;
  }

  .topbar-right,
  .topbar-social,
  .topbar-lang{
    display:none !important;
  }

  .topbar-item{
    min-width:0 !important;
    max-width:50% !important;
    height:28px !important;
    min-height:28px !important;
    font-size:12px !important;
    overflow:hidden !important;
    text-overflow:ellipsis !important;
  }

  .topbar-item.email{
    display:inline-flex !important;
  }

  .topbar-item.address{
    display:none !important;
  }

  .header-inner{
    display:grid !important;
    grid-template-columns:minmax(0, 1fr) auto 40px !important;
    align-items:center !important;
    justify-content:normal !important;
    height:68px !important;
    gap:8px !important;
  }

  .header .logo{
    min-width:0 !important;
    max-width:100% !important;
  }

  .header .logo img,
  .logo img{
    height:38px !important;
    max-width:min(158px, 100%) !important;
  }

  .header-inner > .btn.btn-green{
    justify-self:end !important;
    width:auto !important;
    max-width:112px !important;
    min-height:38px !important;
    height:38px !important;
    padding:0 12px !important;
    border-radius:999px !important;
    font-size:13px !important;
    line-height:1 !important;
    white-space:nowrap !important;
    flex:0 0 auto !important;
  }

  .mobile-toggle{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
    justify-self:end !important;
    width:40px !important;
    min-width:40px !important;
    height:40px !important;
    flex:0 0 40px !important;
    padding:0 !important;
    line-height:1 !important;
    position:relative !important;
    z-index:2 !important;
  }

  .nav{
    top:68px !important;
  }

  .section-title,
  .page-hero-mini .section-title,
  .subscription-hero .section-title{
    max-width:100% !important;
    white-space:normal !important;
    overflow-wrap:normal !important;
    word-break:normal !important;
    letter-spacing:0 !important;
    font-size:28px !important;
    line-height:1.18 !important;
  }

  .subscription-hero{
    padding:54px 0 32px !important;
  }

  .subscription-switch{
    width:100% !important;
    max-width:100% !important;
    display:grid !important;
    grid-template-columns:1fr 1fr !important;
    gap:6px !important;
    border-radius:28px !important;
    padding:6px !important;
  }

  .subscription-switch a{
    min-width:0 !important;
    min-height:48px !important;
    padding:0 8px !important;
    border-radius:24px !important;
    font-size:15px !important;
    line-height:1.24 !important;
    text-align:center !important;
    white-space:normal !important;
    overflow-wrap:normal !important;
  }

  .cookie-consent{
    width:calc(100vw - 16px) !important;
    padding:18px !important;
  }

  .cookie-head{
    align-items:flex-start !important;
    gap:12px !important;
  }

  .cookie-head > div{
    min-width:0 !important;
  }

  .cookie-text{
    overflow-wrap:normal !important;
  }

  .cookie-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:10px !important;
  }

  .cookie-actions .btn,
  .cookie-link{
    width:100% !important;
  }
}

@media(max-width:360px){
  .header .logo img,
  .logo img{
    max-width:min(142px, 100%) !important;
  }

  .header-inner > .btn.btn-green{
    width:40px !important;
    min-width:40px !important;
    max-width:40px !important;
    padding:0 !important;
    font-size:0 !important;
    gap:0 !important;
  }

  .header-inner > .btn.btn-green::before{
    content:"☑";
    font-size:14px !important;
  }
}


/* =========================================================
   V36 - TABLET TEAM GRID OVERFLOW FIX
   ========================================================= */

@media(max-width:900px){
  .team-grid{
    grid-template-columns:1fr !important;
  }

  .team-card{
    width:100% !important;
    min-width:0 !important;
  }
}


/* =========================================================
   V41 - PROMOTION POPUP FINAL EOF OVERRIDE
   ========================================================= */

@media(max-width:760px){
  .promo-popup{
    inset:0 !important;
    width:100vw !important;
    max-width:100vw !important;
    padding:18px !important;
    overflow-x:hidden !important;
  }

  .promo-popup-panel{
    width:calc(100vw - 36px) !important;
    max-width:calc(100vw - 36px) !important;
    flex:0 0 calc(100vw - 36px) !important;
    min-width:0 !important;
  }

  .promo-popup-content,
  .promo-popup-copy,
  .promo-popup-visual{
    width:100% !important;
    max-width:100% !important;
    min-width:0 !important;
  }

  .promo-popup-copy h2{
    max-width:100% !important;
    white-space:normal !important;
    word-break:normal !important;
    overflow-wrap:break-word !important;
    font-size:27px !important;
  }

  .promo-popup-copy p:not(.promo-popup-kicker){
    max-width:100% !important;
    overflow-wrap:break-word !important;
  }

  .promo-popup-close{
    display:flex !important;
    visibility:visible !important;
    opacity:1 !important;
    z-index:20 !important;
  }
}


/* =========================================================
   V42 - HOME STATS BAND + FOOTER APPOINTMENT CTA
   ========================================================= */

.home-stats-band{
  padding:10px 0 76px;
  margin-top:-18px;
}

.home-stats-panel{
  min-height:132px;
  border-radius:6px;
  background:#89ad2d;
  color:#fff;
  display:grid;
  grid-template-columns:repeat(4, 1fr);
  align-items:center;
  gap:24px;
  padding:30px 48px;
  box-shadow:0 22px 55px rgba(137,173,45,.22);
}

.home-stat-item{
  text-align:center;
  min-width:0;
}

.home-stat-item strong{
  display:block;
  font-size:38px;
  line-height:1;
  font-weight:900;
  letter-spacing:0;
}

.home-stat-item span{
  display:block;
  margin-top:8px;
  color:rgba(255,255,255,.9);
  font-size:14px;
  line-height:1.35;
  font-weight:800;
}

.footer-appointment-cta{
  background:var(--soft);
  padding:34px 0 28px;
}

.footer-appointment-panel{
  border-radius:6px;
  background:linear-gradient(135deg, #0b6c96 0%, #89ad2d 100%);
  color:#fff;
  display:grid;
  grid-template-columns:minmax(0, 1fr) auto;
  align-items:center;
  gap:32px;
  padding:28px 30px;
  box-shadow:0 22px 56px rgba(11,108,150,.16);
}

.footer-appointment-copy{
  min-width:0;
}

.footer-appointment-copy h2{
  margin:0;
  color:#fff;
  font-size:21px;
  line-height:1.25;
  font-weight:900;
  letter-spacing:0;
}

.footer-appointment-copy p{
  margin:9px 0 0;
  max-width:720px;
  color:rgba(255,255,255,.92);
  font-size:15px;
  line-height:1.55;
  font-weight:700;
}

.footer-appointment-actions{
  display:flex;
  align-items:center;
  gap:18px;
}

.footer-appointment-btn{
  width:180px;
  min-height:60px;
  border-radius:6px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:#fff;
  font-size:15px;
  line-height:1.2;
  font-weight:900;
  text-align:center;
}

.footer-appointment-btn.primary{
  background:rgba(255,255,255,.18);
}

.footer-appointment-btn.secondary{
  background:rgba(37,63,109,.22);
}

.footer-appointment-btn:hover{
  transform:translateY(-1px);
  background:rgba(255,255,255,.25);
}

@media(max-width:900px){
  .home-stats-panel{
    grid-template-columns:repeat(2, 1fr);
    padding:30px 24px;
  }

  .footer-appointment-panel{
    grid-template-columns:1fr;
    gap:22px;
    text-align:center;
  }

  .footer-appointment-copy p{
    margin-left:auto;
    margin-right:auto;
  }

  .footer-appointment-actions{
    justify-content:center;
  }
}

@media(max-width:560px){
  .home-stats-band{
    padding:0 0 48px;
    margin-top:-10px;
  }

  .home-stats-panel{
    grid-template-columns:1fr;
    gap:20px;
    padding:28px 20px;
  }

  .home-stat-item strong{
    font-size:32px;
  }

  .footer-appointment-cta{
    padding:24px 0 22px;
  }

  .footer-appointment-panel{
    padding:26px 20px;
  }

  .footer-appointment-copy h2{
    font-size:20px;
  }

  .footer-appointment-actions{
    display:grid;
    grid-template-columns:1fr;
    width:100%;
    gap:12px;
  }

  .footer-appointment-btn{
    width:100%;
    min-height:54px;
  }
}


/* =========================================================
   V43 - AUTOMATIC BRAND MARQUEE
   ========================================================= */

.brand-strip{
  overflow:hidden;
}

.brand-shell{
  position:relative;
  overflow:hidden !important;
}

.brand-shell::before,
.brand-shell::after{
  content:"";
  position:absolute;
  top:0;
  bottom:0;
  width:72px;
  z-index:2;
  pointer-events:none;
}

.brand-shell::before{
  left:0;
  background:linear-gradient(90deg, var(--soft) 0%, rgba(243,245,249,0) 100%);
}

.brand-shell::after{
  right:0;
  background:linear-gradient(270deg, var(--soft) 0%, rgba(243,245,249,0) 100%);
}

.brand-scroll{
  display:flex !important;
  grid-template-columns:none !important;
  gap:0 !important;
  width:max-content;
  overflow:visible !important;
  scroll-snap-type:none !important;
  padding:0 !important;
}

.brand-marquee-group{
  display:flex;
  align-items:center;
  gap:28px;
  flex:0 0 auto;
  min-width:max-content;
  padding-right:28px;
  animation:brandMarquee 26s linear infinite;
}

.brand-scroll:hover .brand-marquee-group{
  animation-play-state:paused;
}

.brand-marquee-group .brand-item{
  flex:0 0 190px !important;
  min-height:60px;
  border-radius:0;
  background:transparent;
  color:#8c96a8;
  opacity:1;
  filter:none;
}

@keyframes brandMarquee{
  from{ transform:translateX(0); }
  to{ transform:translateX(-100%); }
}

@media(max-width:640px){
  .brand-shell::before,
  .brand-shell::after{
    width:34px;
  }

  .brand-marquee-group{
    gap:18px;
    padding-right:18px;
    animation-duration:22s;
  }

  .brand-marquee-group .brand-item{
    flex-basis:145px !important;
    min-height:54px;
  }
}

@media(prefers-reduced-motion:reduce){
  .brand-marquee-group{
    animation:none;
  }
}


/* =========================================================
   V44 - FLOATING WHATSAPP BUTTON FIX
   ========================================================= */

.floating-actions .float-whatsapp,
.floating-actions .float-whatsapp:hover,
.floating-actions .float-whatsapp:focus-visible{
  background:#20252b !important;
  color:#fff !important;
}

.floating-actions .float-whatsapp svg{
  display:block !important;
  width:21px !important;
  height:21px !important;
  fill:none !important;
  stroke:#fff !important;
  stroke-width:1.9 !important;
  stroke-linecap:round !important;
  stroke-linejoin:round !important;
}

.floating-actions .float-whatsapp svg path{
  fill:none !important;
  stroke:currentColor !important;
}

.floating-actions .float-whatsapp::before,
.floating-actions .float-whatsapp::after{
  display:none !important;
  content:none !important;
  background-image:none !important;
}


/* =========================================================
   V45 - SYSTEM ICON CONSISTENCY
   ========================================================= */

.fa{
  display:inline-flex !important;
  align-items:center !important;
  justify-content:center !important;
  width:1.15em;
  min-width:1.15em;
  height:1.15em;
  font-style:normal !important;
  line-height:1 !important;
  color:currentColor;
}

.fa::before{
  content:"" !important;
  display:block !important;
  width:1em !important;
  height:1em !important;
  background:currentColor !important;
  -webkit-mask:var(--fa-mask) center/contain no-repeat !important;
  mask:var(--fa-mask) center/contain no-repeat !important;
}

.fa-phone{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 16.9v3a2 2 0 0 1-2.2 2 19.8 19.8 0 0 1-8.6-3.1 19.4 19.4 0 0 1-6-6A19.8 19.8 0 0 1 2.1 4.2 2 2 0 0 1 4.1 2h3a2 2 0 0 1 2 1.7c.1 1 .4 2 .7 2.9a2 2 0 0 1-.5 2.1L8 10a16 16 0 0 0 6 6l1.3-1.3a2 2 0 0 1 2.1-.5c.9.3 1.9.6 2.9.7A2 2 0 0 1 22 16.9z'/%3E%3C/svg%3E");}
.fa-envelope{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 4h16a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2zm0 3 8 6 8-6v-1H4v1z'/%3E%3C/svg%3E");}
.fa-location-dot,
.fa-map-marker-alt{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 384 512'%3E%3Cpath d='M192 0C86 0 0 86 0 192c0 87.4 117 243 168.3 307.2 12.3 15.3 35.1 15.3 47.4 0C267 435 384 279.4 384 192 384 86 298 0 192 0zm0 272a80 80 0 1 1 0-160 80 80 0 0 1 0 160z'/%3E%3C/svg%3E");}
.fa-search{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M10.8 3a7.8 7.8 0 1 1 0 15.6 7.8 7.8 0 0 1 0-15.6zm0 2a5.8 5.8 0 1 0 0 11.6 5.8 5.8 0 0 0 0-11.6zm4.6 10 5 5-1.4 1.4-5-5 1.4-1.4z'/%3E%3C/svg%3E");}
.fa-folder-open{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 5a2 2 0 0 1 2-2h5l2 3h7a2 2 0 0 1 2 2v2H8.2a3 3 0 0 0-2.8 2L3 19.2V5zm3.8 8A1.5 1.5 0 0 1 8.2 12H22l-2.5 7.5A2 2 0 0 1 17.6 21H4.2L6.8 13z'/%3E%3C/svg%3E");}
.fa-tags{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M3 5a2 2 0 0 1 2-2h7.6a2 2 0 0 1 1.4.6l6.4 6.4a2 2 0 0 1 0 2.8l-7.6 7.6a2 2 0 0 1-2.8 0L3.6 14A2 2 0 0 1 3 12.6V5zm4 3.5A1.5 1.5 0 1 0 7 5.5a1.5 1.5 0 0 0 0 3z'/%3E%3C/svg%3E");}
.fa-calendar-check{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2h2v3h6V2h2v3h2a2 2 0 0 1 2 2v13a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V7a2 2 0 0 1 2-2h2V2zm12 8H5v10h14V10zm-3.2 2.8 1.4 1.4-5.2 5.2-3.2-3.2 1.4-1.4 1.8 1.8 3.8-3.8z'/%3E%3C/svg%3E");}
.fa-whatsapp{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12.1 2a9.8 9.8 0 0 0-8.4 14.8L2.5 22l5.3-1.4A9.8 9.8 0 1 0 12.1 2zm0 2a7.8 7.8 0 1 1-3.9 14.5l-.4-.2-2.4.6.6-2.3-.2-.4A7.8 7.8 0 0 1 12.1 4zm-2.6 3.7c.3 0 .5.1.7.5l.7 1.6c.1.3.1.5-.1.8l-.5.5c.7 1.2 1.6 2.1 2.8 2.8l.5-.5c.3-.2.5-.2.8-.1l1.6.7c.4.2.5.4.5.8 0 .7-.3 1.2-.8 1.4-.8.3-1.7.2-2.7-.2-2.5-.9-4.5-2.9-5.4-5.4-.4-1-.5-1.9-.2-2.7.2-.5.7-.8 1.4-.8h.7z'/%3E%3C/svg%3E");}
.fa-comments{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 4h16a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H9l-5 4v-4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2zm3 5h10v2H7V9zm0 4h7v2H7v-2z'/%3E%3C/svg%3E");}
.fa-arrow-up{--fa-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 4 5 11h5v9h4v-9h5L12 4z'/%3E%3C/svg%3E");}

.fa:not(.fa-phone):not(.fa-envelope):not(.fa-location-dot):not(.fa-map-marker-alt):not(.fa-search):not(.fa-folder-open):not(.fa-tags):not(.fa-calendar-check):not(.fa-whatsapp):not(.fa-comments):not(.fa-arrow-up)::before{
  -webkit-mask:none !important;
  mask:none !important;
  width:.5em !important;
  height:.5em !important;
  border-radius:50%;
}

.icon-phone{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M22 16.9v3a2 2 0 0 1-2.2 2 19.8 19.8 0 0 1-8.6-3.1 19.4 19.4 0 0 1-6-6A19.8 19.8 0 0 1 2.1 4.2 2 2 0 0 1 4.1 2h3a2 2 0 0 1 2 1.7c.1 1 .4 2 .7 2.9a2 2 0 0 1-.5 2.1L8 10a16 16 0 0 0 6 6l1.3-1.3a2 2 0 0 1 2.1-.5c.9.3 1.9.6 2.9.7A2 2 0 0 1 22 16.9z'/%3E%3C/svg%3E");}
.icon-mail{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 4h16a2 2 0 0 1 2 2v12a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2zm0 3 8 6 8-6v-1H4v1z'/%3E%3C/svg%3E");}
.icon-location{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 384 512'%3E%3Cpath d='M192 0C86 0 0 86 0 192c0 87.4 117 243 168.3 307.2 12.3 15.3 35.1 15.3 47.4 0C267 435 384 279.4 384 192 384 86 298 0 192 0zm0 272a80 80 0 1 1 0-160 80 80 0 0 1 0 160z'/%3E%3C/svg%3E");}
.icon-user{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10zm0 2c-5 0-9 2.5-9 5.5V22h18v-2.5c0-3-4-5.5-9-5.5z'/%3E%3C/svg%3E");}
.icon-user-check{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 12a5 5 0 1 0 0-10 5 5 0 0 0 0 10zm0 2c-4.4 0-8 2.2-8 5v3h12.2a6.8 6.8 0 0 1-.2-1.6 7 7 0 0 1 1.6-4.4A11.6 11.6 0 0 0 9 14zm12.7 2.3 1.3 1.4-5.1 5.1-3.1-3.1 1.4-1.4 1.7 1.7 3.8-3.7z'/%3E%3C/svg%3E");}
.icon-office{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 22V3h12v5h4v14h-6v-4h-4v4H4zm4-15v2h2V7H8zm0 4v2h2v-2H8zm0 4v2h2v-2H8zm5-8v2h2V7h-2zm0 4v2h2v-2h-2zm0 4v2h2v-2h-2z'/%3E%3C/svg%3E");}
.icon-tax{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 2h14v20l-2-1.2-2 1.2-2-1.2-2 1.2-2-1.2L7 22l-2-1.2V2zm4 5v2h6V7H9zm0 4v2h8v-2H9zm0 4v2h5v-2H9z'/%3E%3C/svg%3E");}
.icon-calendar{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2h2v3h6V2h2v3h2a2 2 0 0 1 2 2v13a2 2 0 0 1-2 2H5a2 2 0 0 1-2-2V7a2 2 0 0 1 2-2h2V2zm12 8H5v10h14V10z'/%3E%3C/svg%3E");}
.icon-service{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M5 4h14v4H5V4zm0 6h14v4H5v-4zm0 6h14v4H5v-4zM3 5h1v2H3V5zm0 6h1v2H3v-2zm0 6h1v2H3v-2z'/%3E%3C/svg%3E");}
.icon-team{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 11a4 4 0 1 0 0-8 4 4 0 0 0 0 8zm8-1a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7zM9 13c-4.4 0-8 2.2-8 5v3h16v-3c0-2.8-3.6-5-8-5zm8.2-.4c1.9.8 3.8 2.3 3.8 4.4v3h2v-3c0-2.4-2.5-4.2-5.8-4.4z'/%3E%3C/svg%3E");}
.icon-message{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 4h16a2 2 0 0 1 2 2v9a2 2 0 0 1-2 2H9l-5 4v-4a2 2 0 0 1-2-2V6a2 2 0 0 1 2-2zm3 5h10v2H7V9zm0 4h7v2H7v-2z'/%3E%3C/svg%3E");}
.icon-subject{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 3h16v18H4V3zm3 4v2h10V7H7zm0 4v2h10v-2H7zm0 4v2h6v-2H7z'/%3E%3C/svg%3E");}
.icon-shield{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2 4 5v6c0 5.1 3.4 9.8 8 11 4.6-1.2 8-5.9 8-11V5l-8-3zm4.8 6.8 1.4 1.4-6.4 6.4-3.6-3.6 1.4-1.4 2.2 2.2 5-5z'/%3E%3C/svg%3E");}
.icon-video{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 6h11a2 2 0 0 1 2 2v2.5l4-2.5v8l-4-2.5V16a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2z'/%3E%3C/svg%3E");}
.icon-instagram{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M7 2h10a5 5 0 0 1 5 5v10a5 5 0 0 1-5 5H7a5 5 0 0 1-5-5V7a5 5 0 0 1 5-5zm0 2a3 3 0 0 0-3 3v10a3 3 0 0 0 3 3h10a3 3 0 0 0 3-3V7a3 3 0 0 0-3-3H7zm5 4a4 4 0 1 1 0 8 4 4 0 0 1 0-8zm0 2.1a1.9 1.9 0 1 0 0 3.8 1.9 1.9 0 0 0 0-3.8zM17.5 6.2a1.1 1.1 0 1 1 0 2.2 1.1 1.1 0 0 1 0-2.2z'/%3E%3C/svg%3E");}
.icon-x{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 3h4.8l4.1 5.8L18 3h2.4l-6.3 7.2L21 21h-4.8l-4.6-6.5L6 21H3.6l6.8-7.8L4 3zm3.7 2 9.6 14h1L8.7 5h-1z'/%3E%3C/svg%3E");}
.icon-facebook{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M14 8h3V4h-3c-3.3 0-5 2-5 5v3H6v4h3v8h4v-8h3.2l.8-4h-4V9c0-.7.3-1 1-1z'/%3E%3C/svg%3E");}
.icon-youtube{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M23.5 6.2a3 3 0 0 0-2.1-2.1C19.5 3.6 12 3.6 12 3.6s-7.5 0-9.4.5A3 3 0 0 0 .5 6.2 31 31 0 0 0 0 12a31 31 0 0 0 .5 5.8 3 3 0 0 0 2.1 2.1c1.9.5 9.4.5 9.4.5s7.5 0 9.4-.5a3 3 0 0 0 2.1-2.1A31 31 0 0 0 24 12a31 31 0 0 0-.5-5.8zM9.6 15.5v-7l6.2 3.5-6.2 3.5z'/%3E%3C/svg%3E");}
.icon-linkedin{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4.98 3.5C4.98 4.9 3.86 6 2.5 6S0 4.9 0 3.5 1.12 1 2.5 1s2.48 1.1 2.48 2.5zM.4 8h4.2v13H.4V8zm7.1 0h4v1.8h.1c.6-1.1 2-2.2 4.1-2.2 4.4 0 5.2 2.9 5.2 6.7V21h-4.2v-6c0-1.4 0-3.3-2-3.3s-2.3 1.6-2.3 3.2V21H7.5V8z'/%3E%3C/svg%3E");}
.icon-tiktok{--ui-icon:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M16 3c.4 3 2.1 4.8 5 5v4c-1.9 0-3.6-.6-5-1.7v6.2A6.5 6.5 0 1 1 9.5 10c.4 0 .8 0 1.2.1v4.2a2.3 2.3 0 1 0 1.6 2.2V3H16z'/%3E%3C/svg%3E");}

.field-icon,
.contact-icon,
.contact-info-icon,
.social-contact-icon{
  font-size:0 !important;
}

.field-icon::before,
.contact-icon::before,
.contact-info-icon::before,
.social-contact-icon::before,
.map-contact-line::before,
.side-feature::before{
  content:"" !important;
  display:block !important;
  flex:0 0 auto;
  background:currentColor !important;
  -webkit-mask:var(--ui-icon) center/contain no-repeat !important;
  mask:var(--ui-icon) center/contain no-repeat !important;
}

.field-icon::before{width:20px;height:20px;}
.contact-icon::before{width:22px;height:22px;}
.contact-info-icon::before{width:26px;height:26px;}
.social-contact-icon,
.social-contact-icon::before{width:22px !important;height:22px !important;}

.map-contact-lines{
  display:grid !important;
  gap:6px !important;
}

.map-contact-line{
  display:inline-flex;
  align-items:center;
  gap:8px;
}

.map-contact-line::before{width:15px;height:15px;}

.side-feature{
  gap:10px;
}

.side-feature::before{
  width:18px;
  height:18px;
  color:var(--green);
}

.side-feature:nth-child(1){--ui-icon:var(--ui-icon-shield, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M12 2 4 5v6c0 5.1 3.4 9.8 8 11 4.6-1.2 8-5.9 8-11V5l-8-3zm4.8 6.8 1.4 1.4-6.4 6.4-3.6-3.6 1.4-1.4 2.2 2.2 5-5z'/%3E%3C/svg%3E"));}
.side-feature:nth-child(2){--ui-icon:var(--ui-icon-team, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M9 11a4 4 0 1 0 0-8 4 4 0 0 0 0 8zm8-1a3.5 3.5 0 1 0 0-7 3.5 3.5 0 0 0 0 7zM9 13c-4.4 0-8 2.2-8 5v3h16v-3c0-2.8-3.6-5-8-5zm8.2-.4c1.9.8 3.8 2.3 3.8 4.4v3h2v-3c0-2.4-2.5-4.2-5.8-4.4z'/%3E%3C/svg%3E"));}
.side-feature:nth-child(3),
.side-feature:nth-child(4){--ui-icon:var(--ui-icon-video, url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Cpath d='M4 6h11a2 2 0 0 1 2 2v2.5l4-2.5v8l-4-2.5V16a2 2 0 0 1-2 2H4a2 2 0 0 1-2-2V8a2 2 0 0 1 2-2z'/%3E%3C/svg%3E"));}


/* =========================================================
   V46 - GENERAL DESIGN POLISH
   ========================================================= */

body,
body *{
  letter-spacing:0 !important;
}

:where(.card,.team-card,.gallery-card,.blog-card,.form-card,.content-card,.detail-content-card,.left-photo-card,.left-menu-card,.left-cta-card,.contact-card,.contact-info-card,.payment-method-panel,.payment-option-card,.bank-account-card,.account-note-box,.sub-card,.subscription-choice-card,.review-page-card,.story-card,.tool-card,.policy-card,.search-box,.promo-popup-panel,.footer-appointment-panel,.home-stats-panel){
  border-radius:8px !important;
}

:where(.card,.team-card,.gallery-card,.blog-card,.form-card,.content-card,.detail-content-card,.left-photo-card,.left-menu-card,.left-cta-card,.contact-card,.contact-info-card,.payment-method-panel,.payment-option-card,.bank-account-card,.account-note-box,.sub-card,.subscription-choice-card,.review-page-card,.story-card,.tool-card,.policy-card,.search-box){
  box-shadow:0 14px 34px rgba(25,36,64,.07) !important;
}

:where(.card,.blog-card,.gallery-card,.team-card,.left-photo-card,.profile-photo-card) img{
  border-radius:8px !important;
}

.btn,
.footer-appointment-btn,
.payment-method-tab,
.copy-field button,
.category-chip,
.tag{
  border-radius:8px !important;
}

.section-head{
  max-width:760px;
  margin-left:auto;
  margin-right:auto;
}

.section-title,
.hero h1,
.slide-card h1,
.content-card h1,
.detail-content-card h1{
  text-wrap:balance;
}

.section-text,
.content-card p,
.detail-content-card p,
.blog-card p,
.team-card p{
  color:var(--muted) !important;
}

.blog-card,
.team-card,
.payment-method-panel,
.bank-account-card{
  border:1px solid rgba(231,237,245,.95);
}

.blog-card h3,
.team-card h3,
.content-card h1,
.detail-content-card h1{
  color:var(--text);
}

@media(max-width:640px){
  .section-head{
    margin-bottom:28px;
  }

  .hero{
    padding-top:42px;
  }

  .floating-actions{
    right:12px !important;
    bottom:18px !important;
    display:flex !important;
    flex-direction:column !important;
    gap:8px !important;
    width:auto !important;
  }

  .float-btn{
    width:42px !important;
    height:42px !important;
    min-width:42px !important;
    min-height:42px !important;
  }
}


/* =========================================================
   V47 - IMAGE BREADCRUMB HERO
   ========================================================= */

.breadcrumb-wrap{
  position:relative !important;
  isolation:isolate;
  min-height:230px;
  display:flex !important;
  align-items:center !important;
  overflow:hidden;
  margin:0 !important;
  padding:56px 0 !important;
  color:#fff !important;
  background:
    linear-gradient(90deg, rgba(91,128,18,.97) 0%, rgba(137,173,45,.86) 46%, rgba(91,128,18,.62) 100%),
    url("../images/real-dietitian-office.jpg") center/cover no-repeat !important;
  border-top:0 !important;
  border-bottom:1px solid rgba(255,255,255,.32) !important;
}

.breadcrumb-hero-inner{
  position:relative;
  z-index:1;
  display:grid;
  justify-items:center;
  gap:14px;
  text-align:center;
}

.breadcrumb-hero-inner h1{
  max-width:920px;
  margin:0;
  color:#fff !important;
  font-size:42px;
  line-height:1.12;
  font-weight:900;
  overflow-wrap:break-word;
  text-wrap:balance;
  text-shadow:0 10px 26px rgba(0,0,0,.18);
}

.breadcrumb-wrap .breadcrumb{
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  color:rgba(255,255,255,.94) !important;
  font-size:18px;
  font-weight:800;
}

.breadcrumb-wrap .breadcrumb a,
.breadcrumb-wrap .breadcrumb span{
  color:#fff !important;
}

.breadcrumb-wrap .breadcrumb a:hover{
  color:rgba(255,255,255,.82) !important;
}

@media(max-width:760px){
  .breadcrumb-wrap{
    min-height:174px;
    padding:42px 0 !important;
    background:
      linear-gradient(90deg, rgba(91,128,18,.98) 0%, rgba(137,173,45,.88) 54%, rgba(91,128,18,.68) 100%),
      url("../images/real-dietitian-office.jpg") center/cover no-repeat !important;
  }

  .breadcrumb-hero-inner{
    gap:10px;
  }

  .breadcrumb-hero-inner h1{
    font-size:30px;
    line-height:1.18;
  }

  .breadcrumb-wrap .breadcrumb{
    gap:8px;
    font-size:14px;
  }
}

@media(max-width:420px){
  .breadcrumb-hero-inner h1{
    font-size:27px;
  }
}


/* =========================================================
   V48 - FOOTER HELP CTA BLUE STYLE
   ========================================================= */

.footer-appointment-cta{
  background:#eef5f9 !important;
  padding:54px 0 58px !important;
}

.footer-appointment-cta .container{
  width:min(1980px, calc(100% - 72px));
}

.footer-appointment-panel{
  min-height:160px;
  display:grid !important;
  grid-template-columns:minmax(0, 1fr) auto !important;
  align-items:center !important;
  gap:42px !important;
  padding:36px 48px !important;
  color:#fff !important;
  background:#89ad2d !important;
  border-radius:6px !important;
  border:0 !important;
  box-shadow:0 22px 55px rgba(137,173,45,.22) !important;
}

.footer-appointment-copy h2{
  margin:0 !important;
  color:#fff !important;
  font-size:32px !important;
  line-height:1.18 !important;
  font-weight:900 !important;
}

.footer-appointment-copy p{
  max-width:760px !important;
  margin:16px 0 0 !important;
  color:rgba(255,255,255,.96) !important;
  font-size:26px !important;
  line-height:1.35 !important;
  font-weight:500 !important;
}

.footer-appointment-actions{
  display:flex !important;
  align-items:center !important;
  gap:48px !important;
}

.footer-appointment-btn{
  width:288px !important;
  min-height:96px !important;
  padding:0 28px !important;
  color:#fff !important;
  background:#6f941d !important;
  font-size:27px !important;
  line-height:1.15 !important;
  font-weight:800 !important;
  box-shadow:none !important;
}

.footer-appointment-btn:hover{
  color:#fff !important;
  background:#5f8217 !important;
  transform:translateY(-1px);
}

@media(max-width:1500px){
  .footer-appointment-copy h2{
    font-size:28px !important;
  }

  .footer-appointment-copy p{
    font-size:22px !important;
  }

  .footer-appointment-actions{
    gap:28px !important;
  }

  .footer-appointment-btn{
    width:232px !important;
    min-height:78px !important;
    font-size:22px !important;
  }
}

@media(max-width:1180px){
  .footer-appointment-panel{
    gap:28px !important;
    padding:32px 34px !important;
  }

  .footer-appointment-copy h2{
    font-size:28px !important;
  }

  .footer-appointment-copy p{
    font-size:20px !important;
  }

  .footer-appointment-actions{
    gap:20px !important;
  }

  .footer-appointment-btn{
    width:210px !important;
    min-height:76px !important;
    font-size:21px !important;
  }
}

@media(max-width:900px){
  .footer-appointment-cta .container{
    width:min(100% - 34px, 1180px);
  }

  .footer-appointment-panel{
    grid-template-columns:1fr !important;
    text-align:center;
  }

  .footer-appointment-copy p{
    margin-left:auto !important;
    margin-right:auto !important;
  }

  .footer-appointment-actions{
    justify-content:center !important;
  }
}

@media(max-width:560px){
  .footer-appointment-cta{
    padding:32px 0 36px !important;
  }

  .footer-appointment-panel{
    min-height:auto;
    padding:28px 20px !important;
    gap:22px !important;
  }

  .footer-appointment-copy h2{
    font-size:24px !important;
  }

  .footer-appointment-copy p{
    font-size:16px !important;
  }

  .footer-appointment-actions{
    display:grid !important;
    grid-template-columns:1fr;
    width:100%;
    gap:12px !important;
  }

  .footer-appointment-btn{
    width:100% !important;
    min-height:58px !important;
    font-size:17px !important;
  }
}


/* =========================================================
   V49 - BRAND GREEN STAT AND HELP BLOCKS
   ========================================================= */

.home-stats-panel{
  background:#89ad2d !important;
  box-shadow:0 22px 55px rgba(137,173,45,.22) !important;
}


/* =========================================================
   V50 - CHECKOUT INVOICE FLOW
   ========================================================= */

.checkout-page{
  background:#fff;
}

.checkout-layout{
  display:grid;
  grid-template-columns:300px minmax(0, 1fr);
  align-items:start;
  gap:58px;
}

.order-summary-card,
.checkout-card{
  background:#fff;
  border:1px solid #e4e9ef;
  box-shadow:none;
}

.order-summary-card{
  position:sticky;
  top:112px;
  padding:28px 26px 22px;
}

.order-summary-card h2,
.checkout-card h2{
  margin:0 0 28px;
  color:#151827;
  font-size:22px;
  line-height:1.2;
  font-weight:900;
  text-transform:uppercase;
}

.summary-product{
  display:grid;
  gap:8px;
  margin-bottom:20px;
  padding:0 0 18px;
  border-bottom:1px solid #e9edf2;
}

.summary-product small,
.summary-line span{
  color:#151827;
  font-size:12px;
  font-weight:800;
  text-transform:uppercase;
}

.summary-product strong{
  color:#151827;
  font-size:18px;
  line-height:1.35;
  font-weight:900;
  text-transform:uppercase;
}

.summary-line{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:16px 0;
  border-bottom:1px solid #e9edf2;
}

.summary-line strong{
  color:#151827;
  font-size:16px;
  font-weight:900;
}

.summary-line.total{
  margin-top:0;
  padding:18px 14px;
  background:#f6f8fa;
  border-bottom:0;
}

.checkout-form{
  display:grid;
  gap:50px;
  min-width:0;
}

.checkout-card{
  padding:34px 36px 38px;
}

.checkout-form-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:22px 30px;
}

.checkout-form-grid.three-col{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.checkout-field{
  display:grid;
  gap:9px;
  min-width:0;
  color:#202332;
  font-size:14px;
  font-weight:500;
}

.checkout-field.field-wide{
  grid-column:1 / -1;
}

.checkout-field input,
.checkout-field textarea{
  width:100%;
  border:1px solid #cfd7df;
  border-radius:0;
  background:#fbfcfd;
  color:#202332;
  font:inherit;
  outline:none;
}

.checkout-field input{
  height:40px;
  padding:0 12px;
}

.checkout-field textarea{
  min-height:64px;
  padding:10px 12px;
  resize:vertical;
}

.checkout-field input:focus,
.checkout-field textarea:focus{
  border-color:var(--green);
  box-shadow:0 0 0 3px rgba(137,173,45,.13);
}

.invoice-card{
  margin-top:0;
}

.invoice-type-tabs{
  display:flex;
  align-items:center;
  gap:24px;
  margin:-4px 0 34px;
  flex-wrap:wrap;
}

.invoice-type-tabs label{
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:#202332;
  font-size:15px;
  font-weight:600;
  cursor:pointer;
}

.invoice-type-tabs input{
  width:18px;
  height:18px;
  accent-color:var(--green);
}

.invoice-fields[hidden]{
  display:none !important;
}

.checkout-submit-row{
  display:grid;
  justify-items:end;
  gap:28px;
}

.terms-check{
  display:inline-flex;
  align-items:center;
  gap:9px;
  color:#202332;
  font-size:14px;
  line-height:1.5;
}

.terms-check input{
  width:17px;
  height:17px;
  accent-color:var(--green);
}

.terms-check a{
  color:#202332;
  font-weight:900;
  text-decoration:underline;
}

.checkout-submit{
  min-width:154px;
  min-height:58px;
  border-radius:0 !important;
  text-transform:uppercase;
}

.payment-options-page{
  padding-top:0 !important;
}

@media(max-width:1100px){
  .checkout-layout{
    grid-template-columns:1fr;
    gap:28px;
  }

  .order-summary-card{
    position:static;
  }
}

@media(max-width:860px){
  .checkout-form-grid,
  .checkout-form-grid.three-col{
    grid-template-columns:1fr;
  }

  .checkout-card{
    padding:26px 22px;
  }

  .checkout-submit-row{
    justify-items:stretch;
  }

  .terms-check{
    align-items:flex-start;
  }

  .checkout-submit{
    width:100%;
  }
}

@media(max-width:560px){
  .checkout-layout{
    gap:22px;
  }

  .order-summary-card,
  .checkout-card{
    max-width:calc(100vw - 34px);
    margin-left:auto;
    margin-right:auto;
  }

  .order-summary-card h2,
  .checkout-card h2{
    font-size:20px;
  }

  .checkout-form{
    gap:28px;
  }
}


/* =========================================================
   V51 - PAYMENT CHECKOUT SCREEN
   ========================================================= */

.payment-checkout-container{
  width:min(1260px, calc(100% - 34px));
}

.payment-checkout-shell{
  max-width:none !important;
  margin:0 auto !important;
}

.payment-checkout-tabs{
  justify-content:flex-start !important;
  gap:0 !important;
  margin:0 !important;
  border-bottom:1px solid #d8e0e8;
}

.payment-checkout-tab{
  min-width:148px;
  min-height:60px;
  margin:0 0 -1px;
  border:1px solid #d8e0e8 !important;
  border-bottom-color:#d8e0e8 !important;
  border-radius:4px 4px 0 0 !important;
  background:#fff !important;
  color:#151827 !important;
  box-shadow:none !important;
  text-transform:uppercase;
}

.payment-checkout-tab + .payment-checkout-tab{
  margin-left:-1px;
}

.payment-checkout-tab.active{
  border-bottom-color:#fff !important;
  color:#151827 !important;
  background:#fff !important;
}

.payment-checkout-panel{
  border:1px solid #d8e0e8 !important;
  border-top:0 !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:30px 50px 50px !important;
}

.payment-checkout-panel[hidden]{
  display:none !important;
}

.card-checkout-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 450px;
  gap:60px;
  align-items:start;
}

.card-gateway-card,
.payment-order-summary,
.bank-select-box{
  border:1px solid #e0e5ea;
  background:#fff;
  box-shadow:none !important;
}

.card-gateway-card{
  min-height:540px;
  padding:36px 80px;
}

.sandbox-ribbon{
  height:42px;
  margin:0 auto 16px;
  border-radius:7px;
  display:grid;
  place-items:center;
  max-width:500px;
  background:#ffe06f;
  color:#405064;
  font-size:14px;
  font-weight:600;
}

.iyzico-widget{
  max-width:500px;
  margin:0 auto;
  border:1px solid #d9e0e7;
  border-radius:6px;
  overflow:hidden;
  background:#fff;
}

.iyzico-widget-top{
  min-height:66px;
  display:grid;
  grid-template-columns:1fr auto 42px;
  align-items:center;
  gap:14px;
  padding:8px 8px 8px 10px;
}

.iyzico-pay-tab{
  min-height:48px;
  border:1px solid #1763ff;
  border-radius:6px;
  background:#f7fbff;
  color:#3d4561;
  font:inherit;
  font-size:15px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
}

.iyzico-brand{
  display:flex;
  align-items:center;
  gap:5px;
  color:#1763ff;
}

.iyzico-brand strong{
  font-size:18px;
  line-height:1;
}

.iyzico-brand small{
  color:#4c566f;
  font-size:11px;
  line-height:1.1;
}

.iyzico-brand span{
  margin-left:8px;
  border:1px solid #ff8b7d;
  border-radius:4px;
  padding:5px 9px;
  color:#ff6e60;
  font-size:11px;
  font-weight:800;
}

.iyzico-menu{
  width:36px;
  height:50px;
  border:0;
  border-radius:5px;
  background:#eef2f5;
  color:#8c96a3;
  font-size:24px;
}

.iyzico-promo{
  min-height:118px;
  margin:10px;
  padding:12px 14px;
  border-radius:7px;
  display:grid;
  align-content:center;
  gap:10px;
  background:linear-gradient(135deg,#1763ff,#2874ff);
  color:#fff;
  overflow:hidden;
}

.iyzico-promo div{
  max-width:340px;
  font-size:17px;
  line-height:1.32;
  font-weight:800;
}

.iyzico-promo span{
  width:max-content;
  max-width:100%;
  padding:8px 12px;
  border-radius:999px;
  background:#fff;
  color:#1763ff;
  font-weight:900;
}

.payment-divider{
  display:flex;
  align-items:center;
  gap:12px;
  margin:8px 12px 12px;
  color:#a0a9b6;
  font-size:13px;
}

.payment-divider:before,
.payment-divider:after{
  content:"";
  height:1px;
  flex:1;
  background:#e1e6ec;
}

.checkout-card-form{
  margin:0 !important;
  gap:0 !important;
}

.checkout-card-form label{
  gap:0 !important;
  color:#8c96a3 !important;
  font-weight:600 !important;
}

.checkout-card-form label span{
  display:none;
}

.checkout-card-form input{
  height:48px !important;
  border:0 !important;
  border-top:1px solid #d9e0e7 !important;
  border-radius:0 !important;
  background:#fff !important;
}

.checkout-card-form .card-payment-row{
  gap:0 !important;
}

.checkout-create-order{
  width:100%;
  min-height:58px;
  border:0;
  border-radius:0 !important;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  background:#c9e9f1;
  color:#4b6780;
  font:inherit;
  font-size:14px;
  font-weight:900;
  text-transform:uppercase;
  cursor:pointer;
}

.checkout-create-order:hover{
  background:#b7dfe9;
}

.payment-order-summary{
  position:static !important;
  padding:30px 28px 22px !important;
}

.bank-select-box{
  margin:0;
  padding:34px 34px 20px;
}

.bank-select-box legend{
  padding:0 10px;
  margin-left:0;
  color:#151827;
  font-size:22px;
  font-weight:900;
}

.bank-select-row{
  display:grid;
  grid-template-columns:20px 90px minmax(0, 1fr);
  align-items:center;
  gap:28px;
  padding:20px 0;
  border-bottom:1px solid #e5e9ee;
  cursor:pointer;
}

.bank-select-row input{
  width:18px;
  height:18px;
  accent-color:var(--green);
}

.bank-logo-box{
  width:90px;
  height:42px;
  border:1px solid #e5e9ee;
  display:grid;
  place-items:center;
  padding:7px;
  background:#fff;
}

.bank-logo-box img{
  max-height:28px;
  max-width:76px;
  object-fit:contain;
}

.bank-select-copy{
  display:grid;
  gap:6px;
  color:#202332;
  font-size:14px;
  line-height:1.35;
}

.bank-select-copy strong{
  color:#151827;
  font-size:15px;
  font-weight:900;
  overflow-wrap:anywhere;
}

.bank-discount-box{
  margin-top:20px;
  border:1px solid #ffe28a;
  background:#fffde9;
  padding:30px;
  display:grid;
  gap:14px;
  color:#151827;
}

.bank-discount-box strong{
  font-size:14px;
  font-weight:900;
}

.bank-discount-box span{
  font-size:22px;
  line-height:1.25;
  font-weight:900;
}

.bank-checkout-actions{
  display:grid;
  gap:12px;
  margin-top:20px;
}

.bank-account-link{
  justify-self:center;
  color:var(--green);
  font-size:14px;
  font-weight:900;
}

@media(max-width:1100px){
  .payment-checkout-panel{
    padding:26px !important;
  }

  .card-checkout-layout{
    grid-template-columns:1fr;
    gap:26px;
  }

  .card-gateway-card{
    padding:28px;
  }
}

@media(max-width:640px){
  .payment-checkout-tab{
    min-width:50%;
    padding:0 10px;
    font-size:13px;
  }

  .payment-checkout-panel{
    padding:18px !important;
  }

  .card-gateway-card{
    min-height:auto;
    padding:18px;
  }

  .iyzico-widget-top{
    grid-template-columns:1fr;
  }

  .iyzico-menu{
    display:none;
  }

  .bank-select-box{
    padding:24px 18px 12px;
  }

  .bank-select-row{
    grid-template-columns:20px minmax(0, 1fr);
    gap:14px;
  }

  .bank-logo-box{
    grid-column:2;
  }

  .bank-select-copy{
    grid-column:1 / -1;
  }
}


/* =========================================================
   V52 - FULL WIDTH PAYMENT CHECKOUT ALIGNMENT
   ========================================================= */

.payment-options-page{
  padding-top:0 !important;
  padding-left:0 !important;
  padding-right:0 !important;
}

.payment-options-page > .payment-checkout-container{
  width:100% !important;
  max-width:none !important;
  margin:0 !important;
}

.payment-checkout-shell{
  width:100% !important;
}

.payment-checkout-tabs{
  width:100% !important;
  padding-left:max(17px, calc((100% - 1180px) / 2)) !important;
  padding-right:max(17px, calc((100% - 1180px) / 2)) !important;
}

.payment-checkout-panel{
  width:100% !important;
  padding:30px 0 52px !important;
}

.payment-checkout-panel > .card-checkout-layout,
.payment-checkout-panel > .bank-select-box,
.payment-checkout-panel > .bank-discount-box,
.payment-checkout-panel > .bank-checkout-actions{
  width:min(1180px, calc(100% - 34px));
  margin-left:auto;
  margin-right:auto;
}

.payment-checkout-panel > .bank-discount-box{
  margin-top:20px;
}

.payment-checkout-panel > .bank-checkout-actions{
  margin-top:20px;
}

@media(max-width:1100px){
  .payment-checkout-panel{
    padding:26px 0 42px !important;
  }
}

@media(max-width:640px){
  .payment-checkout-tabs{
    padding-left:17px !important;
    padding-right:17px !important;
  }

  .payment-checkout-panel{
    padding:18px 0 34px !important;
  }
}


/* =========================================================
   V53 - PAYMENT HERO AND TRANSFER NOTIFICATION
   ========================================================= */

.checkout-visual-hero{
  position:relative;
  isolation:isolate;
  min-height:240px;
  display:flex;
  align-items:center;
  overflow:hidden;
  padding:56px 0;
  color:#fff;
  background:
    linear-gradient(90deg, rgba(91,128,18,.97) 0%, rgba(137,173,45,.86) 48%, rgba(91,128,18,.62) 100%),
    url("../images/real-dietitian-office.jpg") center/cover no-repeat;
}

.checkout-visual-hero-inner{
  display:grid;
  justify-items:center;
  gap:12px;
  text-align:center;
}

.checkout-visual-hero .section-kicker,
.checkout-visual-hero .section-title,
.checkout-visual-hero .breadcrumb,
.checkout-visual-hero .breadcrumb a,
.checkout-visual-hero .breadcrumb span{
  color:#fff !important;
}

.checkout-visual-hero .section-kicker{
  margin:0;
  font-size:15px;
  font-weight:900;
}

.checkout-visual-hero .section-title{
  margin:0;
  font-size:42px;
  line-height:1.12;
  font-weight:900;
  text-shadow:0 10px 26px rgba(0,0,0,.16);
}

.checkout-visual-hero .breadcrumb{
  justify-content:center;
  flex-wrap:wrap;
  gap:10px;
  font-size:16px;
  font-weight:800;
}

.payment-flow-head{
  display:grid;
  gap:7px;
  margin:0 0 24px;
}

.payment-flow-head span{
  color:var(--green);
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

.payment-flow-head h2{
  margin:0;
  color:#151827;
  font-size:25px;
  line-height:1.22;
  font-weight:900;
}

.payment-flow-head p{
  max-width:560px;
  margin:0;
  color:#425068;
  font-size:15px;
  line-height:1.65;
}

.payment-checkout-panel > .bank-transfer-layout{
  width:min(1180px, calc(100% - 34px));
  margin-left:auto;
  margin-right:auto;
}

.bank-transfer-layout{
  display:grid;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:34px;
  align-items:start;
}

.bank-transfer-main{
  min-width:0;
}

.bank-notification-card{
  border:1px solid #e0e5ea;
  background:#fff;
  padding:28px;
}

.bank-notification-card h2{
  margin:0 0 10px;
  color:#151827;
  font-size:22px;
  line-height:1.2;
  font-weight:900;
}

.bank-notification-card p{
  margin:0 0 20px;
  color:#425068;
  font-size:14px;
  line-height:1.65;
}

.bank-notification-card .bank-discount-box{
  margin:0 0 20px;
  padding:22px;
}

.bank-notification-card .bank-discount-box span{
  font-size:20px;
}

.bank-notification-card .bank-checkout-actions{
  margin-top:0;
}

.bank-select-box{
  padding:30px 34px 14px;
}

.bank-select-row{
  grid-template-columns:20px 86px minmax(0, 1fr);
  gap:22px;
  align-items:start;
}

.bank-select-copy{
  gap:4px;
}

.bank-select-copy span,
.bank-select-copy strong{
  display:block;
}

@media(max-width:1100px){
  .bank-transfer-layout{
    grid-template-columns:1fr;
  }

  .bank-notification-card{
    order:2;
  }
}

@media(max-width:760px){
  .checkout-visual-hero{
    min-height:190px;
    padding:44px 0;
  }

  .checkout-visual-hero .section-title{
    font-size:31px;
  }

  .checkout-visual-hero .breadcrumb{
    font-size:14px;
  }
}

@media(max-width:640px){
  .payment-flow-head h2{
    font-size:22px;
  }

  .bank-notification-card{
    padding:22px;
  }
}


/* =========================================================
   V54 - FULL WIDTH FOOTER HELP CTA
   ========================================================= */

.footer-appointment-cta{
  background:#89ad2d !important;
  padding:0 !important;
}

.footer-appointment-cta .container{
  width:100% !important;
  max-width:none !important;
  padding:0 !important;
}

.footer-appointment-panel{
  width:100% !important;
  min-height:148px !important;
  border-radius:0 !important;
  box-shadow:none !important;
  padding:32px max(34px, calc((100vw - 1180px) / 2)) !important;
}

.footer-appointment-copy h2{
  font-size:25px !important;
  line-height:1.22 !important;
}

.footer-appointment-copy p{
  max-width:700px !important;
  margin-top:10px !important;
  font-size:17px !important;
  line-height:1.45 !important;
}

.footer-appointment-actions{
  gap:22px !important;
}

.footer-appointment-btn{
  width:218px !important;
  min-height:64px !important;
  padding:0 22px !important;
  font-size:17px !important;
  line-height:1.2 !important;
}

@media(max-width:900px){
  .footer-appointment-panel{
    min-height:auto !important;
    padding:30px 28px !important;
  }

  .footer-appointment-copy h2{
    font-size:23px !important;
  }

  .footer-appointment-copy p{
    font-size:16px !important;
  }

  .footer-appointment-btn{
    width:210px !important;
    min-height:56px !important;
    font-size:16px !important;
  }
}

@media(max-width:560px){
  .footer-appointment-cta{
    padding:0 !important;
  }

  .footer-appointment-panel{
    padding:26px 18px !important;
  }

  .footer-appointment-copy h2{
    font-size:21px !important;
  }

  .footer-appointment-copy p{
    font-size:15px !important;
  }

  .footer-appointment-btn{
    min-height:50px !important;
    font-size:15px !important;
  }
}


/* =========================================================
   V55 - PAYMENT OPTIONS THEME REDESIGN
   ========================================================= */

.payment-options-page{
  background:linear-gradient(180deg, #f6f9ef 0%, #fff 52%, #f7faf3 100%) !important;
  padding-bottom:72px !important;
}

.checkout-visual-hero{
  min-height:280px;
  background:
    linear-gradient(90deg, rgba(73,103,13,.96) 0%, rgba(137,173,45,.88) 50%, rgba(11,108,150,.58) 100%),
    url("../images/real-dietitian-office.jpg") center/cover no-repeat !important;
}

.checkout-progress{
  position:relative;
  z-index:2;
  width:min(1180px, calc(100% - 34px));
  margin:-42px auto 30px;
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:14px;
}

.checkout-progress-step{
  min-height:86px;
  display:grid;
  grid-template-columns:42px minmax(0, 1fr);
  grid-template-areas:"icon title" "icon text";
  align-items:center;
  column-gap:14px;
  padding:18px 20px;
  border:1px solid #e1ead2;
  border-radius:8px;
  background:#fff;
  box-shadow:0 18px 45px rgba(57,78,26,.08);
}

.checkout-progress-step span{
  grid-area:icon;
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#eef6dd;
  color:#6f941d;
  font-size:15px;
  font-weight:900;
}

.checkout-progress-step strong{
  grid-area:title;
  color:#1f2a19;
  font-size:15px;
  line-height:1.2;
  font-weight:900;
}

.checkout-progress-step small{
  grid-area:text;
  color:#66725d;
  font-size:12px;
  line-height:1.35;
  font-weight:700;
}

.checkout-progress-step.completed span,
.checkout-progress-step.active span{
  background:#89ad2d;
  color:#fff;
}

.checkout-progress-step.active{
  border-color:#89ad2d;
}

.payment-page-heading{
  width:min(1180px, calc(100% - 34px));
  margin:0 auto 24px;
  display:grid;
  gap:8px;
}

.payment-page-heading span{
  color:#89ad2d;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

.payment-page-heading h2{
  margin:0;
  color:#1c2633;
  font-size:30px;
  line-height:1.2;
  font-weight:900;
}

.payment-page-heading p{
  max-width:720px;
  margin:0;
  color:#647186;
  font-size:15px;
  line-height:1.65;
  font-weight:600;
}

.payment-options-page .payment-checkout-tabs{
  width:min(1180px, calc(100% - 34px)) !important;
  margin:0 auto 18px !important;
  padding:0 !important;
  display:grid !important;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px !important;
  border:0 !important;
}

.payment-options-page .payment-checkout-tab{
  min-width:0 !important;
  min-height:94px;
  margin:0 !important;
  padding:18px 20px !important;
  border:1px solid #e1e8ef !important;
  border-radius:8px !important;
  display:flex !important;
  align-items:center;
  justify-content:flex-start;
  gap:16px;
  background:#fff !important;
  color:#263342 !important;
  text-align:left;
  text-transform:none;
  box-shadow:0 18px 45px rgba(25,36,64,.07) !important;
}

.payment-options-page .payment-checkout-tab.active{
  border-color:#89ad2d !important;
  background:#89ad2d !important;
  color:#fff !important;
  box-shadow:0 20px 46px rgba(137,173,45,.24) !important;
}

.payment-tab-icon{
  width:48px;
  height:48px;
  border-radius:50%;
  display:grid;
  place-items:center;
  flex:0 0 auto;
  background:#eef6dd;
  color:#6f941d;
}

.payment-checkout-tab.active .payment-tab-icon{
  background:rgba(255,255,255,.2);
  color:#fff;
}

.payment-tab-icon svg{
  width:23px;
  height:23px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.payment-checkout-tab strong,
.payment-checkout-tab small{
  display:block;
}

.payment-checkout-tab strong{
  font-size:17px;
  line-height:1.25;
  font-weight:900;
}

.payment-checkout-tab small{
  margin-top:4px;
  color:inherit;
  opacity:.78;
  font-size:13px;
  line-height:1.35;
  font-weight:700;
}

.payment-options-page .payment-checkout-panel{
  border:0 !important;
  background:transparent !important;
  box-shadow:none !important;
  padding:12px 0 0 !important;
}

.payment-options-page .card-checkout-layout{
  width:min(1180px, calc(100% - 34px));
  margin:0 auto;
  grid-template-columns:minmax(0, 1fr) 360px;
  gap:26px;
}

.payment-options-page .card-gateway-card,
.payment-options-page .payment-order-summary,
.payment-options-page .bank-select-box,
.payment-options-page .bank-notification-card{
  border:1px solid #e2ead8;
  border-radius:8px;
  background:#fff;
  box-shadow:0 20px 52px rgba(49,67,31,.08) !important;
}

.payment-options-page .card-gateway-card{
  min-height:auto;
  padding:30px;
}

.payment-options-page .payment-flow-head{
  margin-bottom:18px;
}

.payment-options-page .payment-flow-head h2{
  font-size:26px;
}

.payment-security-badges{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:0 0 18px;
}

.payment-security-badges span{
  min-height:32px;
  border-radius:999px;
  display:inline-flex;
  align-items:center;
  padding:0 12px;
  background:#f0f7df;
  color:#5f8217;
  font-size:12px;
  font-weight:900;
}

.payment-options-page .sandbox-ribbon{
  max-width:none;
  height:38px;
  margin:0 0 14px;
  border:1px solid #e5d171;
  border-radius:6px;
  background:#fff7c6;
  color:#66561b;
}

.payment-options-page .iyzico-widget{
  max-width:none;
  border-radius:8px;
  border-color:#e0e8ef;
}

.payment-options-page .iyzico-widget-top{
  padding:10px;
}

.payment-options-page .iyzico-promo{
  min-height:104px;
  background:linear-gradient(135deg, #0b6c96 0%, #89ad2d 100%);
}

.payment-options-page .iyzico-promo div{
  max-width:520px;
  font-size:15px;
}

.payment-options-page .iyzico-promo span{
  color:#5f8217;
}

.payment-options-page .checkout-card-form{
  display:grid;
  gap:12px !important;
  padding:0 12px 12px;
}

.payment-options-page .checkout-card-form label{
  display:grid;
  gap:7px !important;
  color:#516078 !important;
  font-size:13px;
}

.payment-options-page .checkout-card-form label span{
  display:block;
}

.payment-options-page .checkout-card-form input,
.payment-options-page .bank-notice-fields input{
  height:50px !important;
  border:1px solid #dfe7ee !important;
  border-radius:6px !important;
  padding:0 14px !important;
  background:#fff !important;
  color:#253142 !important;
  font:inherit;
  outline:none;
}

.payment-options-page .checkout-card-form input:focus,
.payment-options-page .bank-notice-fields input:focus{
  border-color:#89ad2d !important;
  box-shadow:0 0 0 3px rgba(137,173,45,.14);
}

.payment-options-page .checkout-create-order{
  min-height:54px;
  border-radius:6px !important;
  background:#89ad2d;
  color:#fff;
  box-shadow:0 14px 28px rgba(137,173,45,.24);
}

.payment-options-page .checkout-create-order:hover{
  background:#6f941d;
}

.payment-summary-badge{
  width:max-content;
  max-width:100%;
  margin:0 0 14px;
  border-radius:999px;
  padding:8px 12px;
  background:#f0f7df;
  color:#5f8217;
  font-size:12px;
  font-weight:900;
}

.payment-options-page .payment-order-summary{
  top:102px;
  padding:24px !important;
}

.payment-options-page .payment-order-summary h2{
  margin-bottom:20px;
  font-size:20px;
}

.payment-options-page .summary-line.total{
  margin-top:12px;
  border-radius:8px;
  background:#f1f7e3;
  color:#1f2a19;
}

.payment-options-page .summary-line.total strong{
  color:#5f8217;
  font-size:19px;
}

.payment-summary-note{
  margin-top:18px;
  border-top:1px solid #edf1e6;
  padding-top:16px;
  display:grid;
  gap:4px;
}

.payment-summary-note strong{
  color:#1f2a19;
  font-size:13px;
  font-weight:900;
}

.payment-summary-note span{
  color:#647186;
  font-size:13px;
  line-height:1.5;
  font-weight:600;
}

.payment-options-page .bank-transfer-layout{
  gap:26px;
  grid-template-columns:minmax(0, 1fr) 360px;
}

.payment-options-page .bank-select-box{
  padding:28px;
}

.payment-options-page .bank-select-box legend{
  padding:0;
  margin:0 0 10px;
  float:left;
  width:100%;
  color:#1c2633;
  font-size:22px;
}

.bank-select-note{
  clear:both;
  margin:0 0 14px;
  color:#647186;
  font-size:14px;
  line-height:1.6;
  font-weight:600;
}

.payment-options-page .bank-select-row{
  grid-template-columns:20px 96px minmax(0, 1fr);
  gap:18px;
  margin-top:12px;
  padding:18px;
  border:1px solid #e5ecf1;
  border-radius:8px;
  background:#fff;
  transition:border-color .2s ease, box-shadow .2s ease, background .2s ease;
}

.payment-options-page .bank-select-row:hover,
.payment-options-page .bank-select-row:has(input:checked){
  border-color:#89ad2d;
  background:#fbfdf6;
  box-shadow:0 14px 28px rgba(137,173,45,.12);
}

.payment-options-page .bank-logo-box{
  width:96px;
  height:48px;
  border-radius:6px;
}

.payment-options-page .bank-select-copy{
  gap:5px;
}

.payment-options-page .bank-select-copy .bank-name{
  color:#5f8217;
  font-weight:900;
}

.payment-options-page .bank-notification-card{
  position:sticky;
  top:102px;
}

.payment-options-page .bank-discount-box{
  border-radius:8px;
  background:#fff8d8;
}

.bank-notice-fields{
  display:grid;
  gap:12px;
  margin:0 0 18px;
}

.bank-notice-fields label{
  display:grid;
  gap:7px;
  color:#516078;
  font-size:13px;
  font-weight:800;
}

.payment-options-page .bank-account-link{
  color:#5f8217;
}

@media(max-width:1100px){
  .payment-options-page .card-checkout-layout,
  .payment-options-page .bank-transfer-layout{
    grid-template-columns:1fr;
  }

  .payment-options-page .payment-order-summary,
  .payment-options-page .bank-notification-card{
    position:static;
  }
}

@media(max-width:760px){
  .checkout-progress{
    margin-top:-28px;
    grid-template-columns:1fr;
  }

  .checkout-progress-step{
    min-height:72px;
  }

  .payment-page-heading h2{
    font-size:25px;
  }

  .payment-options-page .payment-checkout-tabs{
    grid-template-columns:1fr;
  }

  .payment-options-page .payment-checkout-tab{
    min-height:78px;
  }
}

@media(max-width:640px){
  .payment-options-page .card-gateway-card,
  .payment-options-page .bank-select-box,
  .payment-options-page .bank-notification-card,
  .payment-options-page .payment-order-summary{
    padding:20px !important;
  }

  .payment-options-page .bank-select-row{
    grid-template-columns:20px minmax(0, 1fr);
    padding:16px;
  }

  .payment-options-page .bank-logo-box{
    grid-column:2;
  }

  .payment-options-page .bank-select-copy{
    grid-column:1 / -1;
  }
}


/* =========================================================
   V56 - VKI CALCULATOR TOOL
   ========================================================= */

.vki-tool-section{
  background:linear-gradient(180deg, #f7faf2 0%, #fff 50%, #f7faf2 100%);
}

.vki-calculator{
  display:grid;
  grid-template-columns:minmax(0, 1.05fr) minmax(320px, .95fr);
  gap:26px;
  align-items:stretch;
}

.vki-form,
.vki-result-card{
  border:1px solid #e2ead8;
  border-radius:8px;
  box-shadow:0 20px 52px rgba(49,67,31,.08);
}

.vki-form{
  padding:34px;
}

.vki-form:before{
  display:none;
}

.vki-form-head{
  display:grid;
  gap:8px;
  margin-bottom:24px;
}

.vki-form-head span,
.vki-result-head span,
.vki-range-card span{
  color:#89ad2d;
  font-size:13px;
  font-weight:900;
  text-transform:uppercase;
}

.vki-form-head h2{
  margin:0;
  color:#1c2633;
  font-size:30px;
  line-height:1.2;
  font-weight:900;
}

.vki-form-head p,
.vki-helper,
.vki-result-card p{
  margin:0;
  color:#647186;
  font-size:15px;
  line-height:1.65;
  font-weight:600;
}

.vki-field-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:16px;
}

.vki-field{
  display:grid;
  gap:8px;
  color:#253142;
  font-size:14px;
  font-weight:900;
}

.vki-input-wrap{
  position:relative;
}

.vki-input-wrap .input{
  min-height:58px;
  border-color:#dfe7ee;
  border-radius:8px;
  padding-right:58px;
  color:#1c2633;
  font-size:18px;
  font-weight:800;
}

.vki-input-wrap .input:focus{
  border-color:#89ad2d;
  box-shadow:0 0 0 3px rgba(137,173,45,.14);
  outline:none;
}

.vki-input-wrap small{
  position:absolute;
  right:16px;
  top:50%;
  transform:translateY(-50%);
  color:#89ad2d;
  font-size:13px;
  font-weight:900;
}

.vki-actions{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin:22px 0 18px;
}

.vki-actions .btn{
  min-width:150px;
}

.vki-result-card{
  position:relative;
  overflow:hidden;
  padding:34px;
  background:#fff;
  color:#1c2633;
}

.vki-result-card:before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:7px;
  background:linear-gradient(90deg, #0b6c96, #89ad2d);
}

.vki-result-head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:22px;
}

.vki-result-head strong{
  border-radius:999px;
  padding:8px 12px;
  background:#f0f7df;
  color:#5f8217;
  font-size:13px;
  line-height:1.2;
  font-weight:900;
  text-align:right;
}

.vki-score{
  display:flex;
  align-items:flex-end;
  gap:10px;
  margin-bottom:22px;
}

.vki-score .result-value{
  color:#5f8217;
  font-size:58px;
  line-height:.9;
}

.vki-score small{
  margin-bottom:6px;
  color:#647186;
  font-size:14px;
  font-weight:800;
}

.vki-meter{
  position:relative;
  height:12px;
  margin:0 0 22px;
  border-radius:999px;
  background:linear-gradient(90deg, #5aa1cc 0 25%, #89ad2d 25% 54%, #f2b84b 54% 73%, #dc695c 73% 100%);
}

.vki-meter-marker{
  position:absolute;
  top:50%;
  width:22px;
  height:22px;
  border:4px solid #fff;
  border-radius:50%;
  background:#1c2633;
  box-shadow:0 8px 18px rgba(28,38,51,.22);
  transform:translate(-50%, -50%);
  transition:left .25s ease;
}

.vki-range-card{
  margin-top:22px;
  border-radius:8px;
  padding:18px;
  display:grid;
  gap:8px;
  background:#f5f9ec;
}

.vki-range-card strong{
  color:#1f2a19;
  font-size:20px;
  line-height:1.25;
  font-weight:900;
}

.vki-category-grid{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 1fr));
  gap:14px;
  margin-top:18px;
}

.vki-category-grid div{
  min-height:84px;
  border:1px solid #e2ead8;
  border-radius:8px;
  padding:18px;
  display:grid;
  gap:6px;
  background:#fff;
  box-shadow:0 14px 34px rgba(49,67,31,.05);
}

.vki-category-grid strong{
  color:#1c2633;
  font-size:15px;
  font-weight:900;
}

.vki-category-grid span{
  color:#647186;
  font-size:13px;
  font-weight:700;
}

@media(max-width:900px){
  .vki-calculator{
    grid-template-columns:1fr;
  }

  .vki-category-grid{
    grid-template-columns:repeat(2, minmax(0, 1fr));
  }
}

@media(max-width:560px){
  .vki-form,
  .vki-result-card{
    padding:24px 20px;
  }

  .vki-form-head h2{
    font-size:25px;
  }

  .vki-field-grid,
  .vki-category-grid{
    grid-template-columns:1fr;
  }

  .vki-actions .btn{
    width:100%;
  }

  .vki-score .result-value{
    font-size:48px;
  }
}


/* =========================================================
   V57 - IDEAL WEIGHT CALCULATOR
   ========================================================= */

.ideal-gender-toggle{
  min-height:58px;
  border:1px solid #dfe7ee;
  border-radius:8px;
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:8px;
  padding:6px;
  background:#fff;
}

.ideal-gender-toggle label{
  cursor:pointer;
}

.ideal-gender-toggle input{
  position:absolute;
  opacity:0;
  pointer-events:none;
}

.ideal-gender-toggle span{
  height:44px;
  border-radius:6px;
  display:grid;
  place-items:center;
  color:#647186;
  font-size:14px;
  font-weight:900;
}

.ideal-gender-toggle input:checked + span{
  background:#89ad2d;
  color:#fff;
  box-shadow:0 10px 22px rgba(137,173,45,.22);
}

.ideal-result-list{
  display:grid;
  gap:12px;
  margin:0 0 22px;
}

.ideal-result-list div{
  border-radius:8px;
  padding:16px;
  display:grid;
  gap:7px;
  background:#f5f9ec;
}

.ideal-result-list span{
  color:#89ad2d;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}

.ideal-result-list strong{
  color:#1f2a19;
  font-size:18px;
  line-height:1.25;
  font-weight:900;
}

.ideal-score{
  margin-bottom:20px;
}

.ideal-info-grid div{
  min-height:100px;
}

@media(max-width:560px){
  .ideal-gender-toggle{
    grid-template-columns:1fr;
  }
}


/* =========================================================
   V58 - CALCULATOR SELECTS, CALORIE AND WATER TOOLS
   ========================================================= */

.calc-select{
  min-height:58px;
  width:100%;
  border:1px solid #dfe7ee;
  border-radius:8px;
  padding:0 42px 0 16px;
  background:#fff;
  color:#1c2633;
  font:inherit;
  font-size:15px;
  font-weight:800;
  line-height:1.2;
  outline:0;
  appearance:none;
  background-image:linear-gradient(45deg, transparent 50%, #89ad2d 50%), linear-gradient(135deg, #89ad2d 50%, transparent 50%);
  background-position:calc(100% - 20px) 52%, calc(100% - 14px) 52%;
  background-size:6px 6px, 6px 6px;
  background-repeat:no-repeat;
}

.calc-select:focus{
  border-color:#89ad2d;
  box-shadow:0 0 0 4px rgba(137,173,45,.13);
}

.calorie-field-grid{
  grid-template-columns:repeat(2, minmax(0, 1fr));
}

.water-field-grid{
  grid-template-columns:repeat(3, minmax(0, 1fr));
}

.calorie-gender-field{
  margin-top:16px;
}

.calorie-result-list div,
.water-result-list div{
  min-height:82px;
}

.calorie-info-grid div,
.water-info-grid div{
  min-height:108px;
}

.calorie-result-card .vki-result-head span,
.water-result-card .vki-result-head h3{
  margin:0;
  color:#1c2633;
  font-size:22px;
  line-height:1.2;
  font-weight:900;
}

.calorie-score .result-value,
.water-score .result-value{
  letter-spacing:0;
}

.water-score small{
  max-width:78px;
}

@media(max-width:900px){
  .water-field-grid{
    grid-template-columns:1fr;
  }
}

@media(max-width:560px){
  .calorie-field-grid{
    grid-template-columns:1fr;
  }

  .calc-select{
    min-height:54px;
    font-size:14px;
  }
}


/* =========================================================
   V59 - ABOUT PAGE REFERENCE LAYOUT
   ========================================================= */

.about-page-template{
  background:var(--soft);
}

.about-mini-breadcrumb{
  padding:17px 0;
  background:#eef3f8;
  color:var(--blue);
  font-size:13px;
  font-weight:700;
}

.about-mini-breadcrumb .breadcrumb{
  min-height:18px;
}

.about-page-v2{
  overflow:hidden;
}

.about-intro-section{
  padding:64px 0 62px;
}

.about-info-strip{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:24px;
}

.about-info-card{
  min-height:112px;
  border-radius:8px;
  background:#fff;
  display:flex;
  align-items:center;
  gap:22px;
  padding:22px 26px;
  box-shadow:0 18px 42px rgba(25,36,64,.045);
}

.about-info-icon{
  width:62px;
  height:62px;
  flex:0 0 62px;
  border-radius:8px;
  display:grid;
  place-items:center;
  background:#f3f5f9;
  color:var(--blue);
}

.about-info-icon svg{
  width:25px;
  height:25px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.about-info-card span:not(.about-info-icon){
  display:block;
  color:var(--blue);
  font-size:12px;
  line-height:1.35;
  font-weight:700;
}

.about-info-card strong{
  display:block;
  margin-top:4px;
  color:var(--text);
  font-size:15px;
  line-height:1.35;
  font-weight:900;
}

.about-hero-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(340px, 510px);
  align-items:center;
  gap:72px;
  margin-top:64px;
}

.about-hero-copy h1{
  max-width:620px;
  margin:8px 0 28px;
  color:var(--text);
  font-size:42px;
  line-height:1.06;
  letter-spacing:0;
  font-weight:900;
}

.about-hero-copy p{
  max-width:610px;
  margin:0 0 22px;
  color:var(--blue);
  font-size:15px;
  line-height:1.85;
}

.about-hero-media{
  position:relative;
  padding:0 24px 24px 0;
}

.about-hero-media:after{
  content:"";
  position:absolute;
  right:0;
  bottom:0;
  width:92%;
  height:92%;
  border-radius:10px;
  background:var(--green);
  z-index:0;
}

.about-hero-media img{
  position:relative;
  z-index:1;
  width:100%;
  aspect-ratio:1 / 1;
  border-radius:10px;
  object-fit:cover;
  box-shadow:0 24px 60px rgba(25,36,64,.08);
}

.about-tax-strip{
  margin-top:60px;
}

.about-nutrition-section{
  padding:72px 0;
  background:#edf2f7;
}

.about-nutrition-grid{
  display:grid;
  grid-template-columns:minmax(0, 1fr) minmax(280px, 360px) 160px;
  align-items:center;
  gap:58px;
}

.about-nutrition-copy h2{
  margin:6px 0 30px;
  color:var(--text);
  font-size:31px;
  line-height:1.18;
  font-weight:900;
}

.about-feature-list{
  display:grid;
  gap:23px;
}

.about-feature-list article{
  display:grid;
  grid-template-columns:42px minmax(0, 1fr);
  gap:18px;
  align-items:start;
}

.about-feature-list article>span{
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#fff;
  color:var(--green);
  box-shadow:0 12px 28px rgba(25,36,64,.06);
}

.about-feature-list svg{
  width:18px;
  height:18px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.about-feature-list strong{
  display:block;
  color:var(--text);
  font-size:16px;
  line-height:1.3;
  font-weight:900;
}

.about-feature-list p{
  margin:8px 0 0;
  color:var(--blue);
  font-size:14px;
  line-height:1.75;
}

.about-nutrition-media img{
  width:100%;
  aspect-ratio:386 / 520;
  border-radius:8px;
  object-fit:cover;
  box-shadow:0 24px 60px rgba(25,36,64,.08);
}

.about-side-stats{
  display:grid;
  gap:26px;
  text-align:center;
}

.about-side-stats div{
  padding-bottom:17px;
  border-bottom:1px solid rgba(11,108,150,.13);
}

.about-side-stats div:last-child{
  border-bottom:0;
  padding-bottom:0;
}

.about-side-stats strong{
  display:block;
  color:var(--text);
  font-size:34px;
  line-height:1;
  font-weight:900;
}

.about-side-stats span{
  display:block;
  margin-top:7px;
  color:var(--blue);
  font-size:12px;
  line-height:1.35;
  font-weight:700;
}

.about-team-section{
  padding:86px 0 72px;
  background:var(--soft);
}

.about-team-row{
  display:grid;
  grid-template-columns:repeat(3, minmax(0, 1fr));
  gap:30px;
  align-items:stretch;
}

.about-team-card{
  min-height:458px;
  border-radius:8px;
  background:#fff;
  padding:24px;
  box-shadow:0 18px 48px rgba(25,36,64,.045);
  transition:opacity .2s ease, transform .2s ease;
}

.about-team-card.is-soft{
  opacity:.58;
}

.about-team-card.is-active{
  transform:translateY(-10px);
  box-shadow:0 24px 64px rgba(25,36,64,.09);
}

.about-team-card img{
  width:100%;
  aspect-ratio:1 / 1;
  border-radius:7px;
  object-fit:cover;
  margin-bottom:24px;
}

.about-team-card h3{
  margin:0 0 15px;
  color:var(--text);
  font-size:21px;
  line-height:1.2;
  font-weight:900;
}

.about-team-card p{
  margin:0 0 16px;
  color:var(--blue);
  font-size:14px;
  line-height:1.75;
}

.about-team-card span{
  color:var(--blue);
  font-size:13px;
  font-weight:700;
}

.about-team-dots{
  display:flex;
  justify-content:center;
  align-items:center;
  gap:8px;
  margin-top:34px;
}

.about-team-dots span{
  width:9px;
  height:9px;
  border-radius:999px;
  background:#d5e2bb;
}

.about-team-dots span.active{
  width:58px;
  background:var(--green);
}

.about-testimonial-section{
  padding:0;
  background:var(--soft);
}

.about-testimonial-section .container{
  width:100%;
  max-width:none;
}

.about-testimonial-section .testimonial-fixed-grid{
  grid-template-columns:1fr 1fr;
}

.about-testimonial-section .testimonial-media img{
  min-height:455px;
  border-radius:0;
}

.about-testimonial-section .testimonial-text-carousel{
  min-height:455px;
  border-left:0;
  background:#f7f9fc;
}

.about-testimonial-section .testimonial-text-slide{
  padding:78px 80px 56px;
}

.about-testimonial-section .testimonial-text-slide h2{
  color:var(--text);
  font-size:30px;
  line-height:1.2;
}

.about-brand-strip{
  padding:45px 0 34px;
  background:var(--soft);
}

.about-page-template .map-section{
  padding-top:0;
  background:var(--soft);
}

@media(max-width:1050px){
  .about-hero-grid,
  .about-nutrition-grid{
    grid-template-columns:1fr;
    gap:38px;
  }

  .about-side-stats{
    grid-template-columns:repeat(4, minmax(0, 1fr));
  }

  .about-side-stats div{
    border-bottom:0;
    border-right:1px solid rgba(11,108,150,.13);
    padding:0 14px 0 0;
  }

  .about-side-stats div:last-child{
    border-right:0;
  }
}

@media(max-width:900px){
  .about-info-strip,
  .about-team-row{
    grid-template-columns:1fr;
  }

  .about-team-card.is-soft{
    opacity:1;
  }

  .about-team-card.is-active{
    transform:none;
  }

  .about-testimonial-section .testimonial-fixed-grid{
    grid-template-columns:1fr;
  }

  .about-testimonial-section .testimonial-text-slide{
    padding:48px 30px 42px;
  }
}

@media(max-width:640px){
  .about-intro-section{
    padding:38px 0 46px;
  }

  .about-page-template .header-inner{
    grid-template-columns:minmax(0, 1fr) 40px !important;
  }

  .about-page-template .header-inner > .btn.btn-green{
    display:none !important;
  }

  .about-page-template .mobile-toggle{
    display:inline-flex !important;
    background:#f3f5f9 !important;
    color:var(--text) !important;
  }

  .about-info-card{
    min-height:auto;
    padding:18px;
    gap:16px;
  }

  .about-info-icon{
    width:54px;
    height:54px;
    flex-basis:54px;
  }

  .about-hero-grid{
    margin-top:42px;
  }

  .about-hero-copy h1{
    font-size:31px;
  }

  .about-hero-copy p{
    font-size:14px;
  }

  .about-tax-strip{
    margin-top:38px;
  }

  .about-nutrition-section,
  .about-team-section{
    padding:52px 0;
  }

  .about-side-stats{
    grid-template-columns:repeat(2, minmax(0, 1fr));
    gap:18px;
  }

  .about-side-stats div{
    border-right:0;
    padding:16px;
    border-radius:8px;
    background:#fff;
  }

  .about-team-card{
    min-height:auto;
  }

  .about-testimonial-section .testimonial-media img,
  .about-testimonial-section .testimonial-text-carousel{
    min-height:360px;
  }
}


/* =========================================================
   V60 - MAINTENANCE PAGE + MOBILE COOKIE POLISH
   ========================================================= */

.maintenance-page{
  min-height:100vh;
  background:#18212b;
}

.maintenance-hero{
  position:relative;
  min-height:100vh;
  display:grid;
  align-items:center;
  padding:54px 0;
  overflow:hidden;
  background:
    linear-gradient(110deg, rgba(12,23,31,.88) 0%, rgba(12,23,31,.72) 48%, rgba(137,173,45,.42) 100%),
    var(--maintenance-bg, url("../images/real-dietitian-office.jpg")) center/cover no-repeat;
}

.maintenance-overlay{
  position:absolute;
  inset:0;
  background:radial-gradient(circle at 18% 18%, rgba(137,173,45,.18), transparent 34%),
             radial-gradient(circle at 86% 78%, rgba(11,108,150,.24), transparent 30%);
  pointer-events:none;
}

.maintenance-shell{
  position:relative;
  z-index:1;
  display:flex;
  justify-content:center;
}

.maintenance-card{
  width:min(620px, 100%);
  border:1px solid rgba(255,255,255,.22);
  border-radius:18px;
  padding:42px;
  background:rgba(255,255,255,.93);
  box-shadow:0 34px 90px rgba(0,0,0,.28);
  backdrop-filter:blur(14px);
  text-align:center;
}

.maintenance-logo{
  display:flex;
  width:max-content;
  max-width:100%;
  margin:0 auto 18px;
}

.maintenance-logo img{
  height:48px;
}

.maintenance-badge{
  width:max-content;
  max-width:100%;
  min-height:34px;
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  margin:0 auto;
  padding:0 15px;
  background:#eef7dc;
  color:#5f8217;
  font-size:12px;
  font-weight:900;
  text-transform:uppercase;
}

.maintenance-card h1{
  margin:18px 0 18px;
  color:var(--text);
  font-size:44px;
  line-height:1.08;
  letter-spacing:0;
  font-weight:900;
  overflow-wrap:break-word;
}

.maintenance-card p{
  margin:0 auto;
  max-width:540px;
  color:var(--blue);
  font-size:15px;
  line-height:1.8;
  font-weight:600;
  overflow-wrap:break-word;
}

.maintenance-contact-grid{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:28px;
}

.maintenance-contact-card{
  min-height:112px;
  border:1px solid #e7edf5;
  border-radius:12px;
  display:grid;
  gap:5px;
  padding:18px;
  background:#fff;
  color:var(--text);
  text-align:left;
}

.maintenance-contact-card span{
  width:42px;
  height:42px;
  border-radius:10px;
  display:grid;
  place-items:center;
  background:#f0f7df;
  color:var(--green);
}

.maintenance-contact-card svg,
.maintenance-social svg{
  width:21px;
  height:21px;
  fill:none;
  stroke:currentColor;
  stroke-width:2;
  stroke-linecap:round;
  stroke-linejoin:round;
}

.maintenance-contact-card small{
  color:var(--blue);
  font-size:12px;
  font-weight:800;
}

.maintenance-contact-card strong{
  color:var(--text);
  font-size:15px;
  line-height:1.35;
  font-weight:900;
}

.maintenance-social{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:28px;
  justify-content:center;
}

.maintenance-social a{
  width:42px;
  height:42px;
  border-radius:50%;
  display:grid;
  place-items:center;
  background:#f3f5f9;
  color:var(--blue);
}

.maintenance-social a:hover{
  background:var(--green);
  color:#fff;
}

.maintenance-page .cookie-consent{
  z-index:20;
}

@media(max-width:640px){
  .maintenance-hero{
    min-height:100svh;
    padding:28px 0 96px;
    align-items:start;
  }

  .maintenance-card{
    padding:26px 20px;
    border-radius:16px;
  }

  .maintenance-logo img{
    height:42px;
  }

  .maintenance-card h1{
    font-size:31px;
  }

  .maintenance-card p{
    font-size:14px;
  }

  .maintenance-contact-grid{
    grid-template-columns:1fr;
  }

  .maintenance-social{
    justify-content:center;
  }
}

@media(max-width:640px){
  .cookie-consent{
    left:10px !important;
    right:10px !important;
    top:auto !important;
    bottom:10px !important;
    width:auto !important;
    max-width:none !important;
    max-height:calc(100svh - 20px) !important;
    transform:none !important;
    border-radius:18px !important;
    padding:16px !important;
    overflow-y:auto !important;
  }

  .cookie-consent.show{
    animation:cookieMobileIn .22s ease both !important;
  }

  .cookie-head{
    display:grid !important;
    grid-template-columns:46px minmax(0, 1fr) !important;
    gap:12px !important;
    align-items:start !important;
  }

  .cookie-icon{
    width:46px !important;
    height:46px !important;
    min-width:46px !important;
    border-radius:14px !important;
    font-size:21px !important;
  }

  .cookie-title{
    margin-bottom:4px !important;
    font-size:18px !important;
    line-height:1.2 !important;
  }

  .cookie-text{
    font-size:13px !important;
    line-height:1.55 !important;
    overflow-wrap:anywhere !important;
  }

  .cookie-actions{
    display:grid !important;
    grid-template-columns:1fr !important;
    gap:8px !important;
    margin-top:14px !important;
  }

  .cookie-actions .btn,
  .cookie-link{
    width:100% !important;
    min-height:42px !important;
    justify-content:center !important;
    border-radius:10px !important;
  }
}

@keyframes cookieMobileIn{
  from{opacity:0; transform:translateY(14px);}
  to{opacity:1; transform:translateY(0);}
}

@media(max-width:640px){
  .header-inner{
    grid-template-columns:minmax(0, 1fr) 40px !important;
  }

  .header-inner > .btn.btn-green{
    display:none !important;
  }

  .mobile-toggle{
    display:inline-flex !important;
    background:#f3f5f9 !important;
    color:var(--text) !important;
  }
}

/* =========================================================
   V61 - HOME SLIDER VIDEO
   ========================================================= */

.slide.video-slide{
  overflow:hidden !important;
  background:#102015 !important;
}

.slide.video-slide:before{
  background:linear-gradient(90deg,rgba(238,245,240,.9) 0%,rgba(238,245,240,.58) 38%,rgba(238,245,240,.18) 72%,rgba(238,245,240,.04) 100%) !important;
}

.slide-video{
  position:absolute;
  inset:0;
  z-index:0;
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center;
  pointer-events:none;
}

.slide.video-slide .slide-card{
  background:rgba(255,255,255,.94) !important;
  backdrop-filter:blur(8px);
}

@media(max-width:760px){
  .slide.video-slide:before{
    background:linear-gradient(180deg,rgba(238,245,240,.94) 0%,rgba(238,245,240,.74) 58%,rgba(238,245,240,.28) 100%) !important;
  }

  .slide-video{
    object-position:center;
  }
}

/* =========================================================
   V62 - PROMOTION POPUP MOBILE RESPONSIVE HARDENING
   ========================================================= */

.promo-popup{
  box-sizing:border-box !important;
}

.promo-popup *,
.promo-popup *::before,
.promo-popup *::after{
  box-sizing:border-box !important;
}

@media(max-width:900px){
  .promo-popup{
    align-items:center !important;
    justify-content:center !important;
    padding:16px !important;
    overflow:hidden !important;
  }

  .promo-popup-panel{
    width:min(720px, calc(100vw - 32px)) !important;
    max-width:calc(100vw - 32px) !important;
    max-height:calc(100svh - 32px) !important;
    min-height:0 !important;
    overflow-y:auto !important;
    overscroll-behavior:contain !important;
    border-radius:18px !important;
  }

  .promo-popup-content{
    grid-template-columns:1fr !important;
    min-height:0 !important;
  }

  .promo-popup-copy{
    padding:42px 28px 24px !important;
  }

  .promo-popup-kicker{
    margin-bottom:10px !important;
    font-size:12px !important;
  }

  .promo-popup-copy h2{
    max-width:100% !important;
    font-size:clamp(24px, 6.2vw, 34px) !important;
    line-height:1.08 !important;
    letter-spacing:0 !important;
    overflow-wrap:anywhere !important;
  }

  .promo-popup-copy p:not(.promo-popup-kicker){
    max-width:100% !important;
    margin-top:16px !important;
    font-size:14px !important;
    line-height:1.55 !important;
    overflow-wrap:anywhere !important;
  }

  .promo-popup-cta{
    width:100% !important;
    min-width:0 !important;
    min-height:48px !important;
    margin-top:20px !important;
    padding:0 18px !important;
    border-radius:12px !important;
    text-align:center !important;
  }

  .promo-popup-visual{
    min-height:190px !important;
    height:190px !important;
    max-height:32svh !important;
  }

  .promo-popup-visual img{
    right:50% !important;
    bottom:0 !important;
    width:170px !important;
    height:185px !important;
    transform:translateX(50%) !important;
    object-fit:cover !important;
    object-position:center top !important;
    border-radius:120px 120px 0 0 !important;
  }

  .promo-popup-visual::before{
    right:50% !important;
    bottom:-140px !important;
    width:330px !important;
    height:280px !important;
    transform:translateX(50%) !important;
  }

  .promo-popup-visual::after,
  .promo-mail-three{
    display:none !important;
  }

  .promo-mail{
    width:44px !important;
    height:30px !important;
  }

  .promo-mail::after{
    right:9px !important;
    top:9px !important;
    width:8px !important;
    height:8px !important;
  }

  .promo-mail-one{
    left:22px !important;
    top:30px !important;
  }

  .promo-mail-two{
    right:24px !important;
    top:54px !important;
  }
}

@media(max-width:430px){
  .promo-popup{
    padding:10px !important;
  }

  .promo-popup-panel{
    width:calc(100vw - 20px) !important;
    max-width:calc(100vw - 20px) !important;
    max-height:calc(100svh - 20px) !important;
    border-radius:16px !important;
  }

  .promo-popup-close{
    top:8px !important;
    right:8px !important;
    width:32px !important;
    height:32px !important;
    font-size:22px !important;
  }

  .promo-popup-copy{
    padding:38px 18px 20px !important;
  }

  .promo-popup-copy h2{
    font-size:23px !important;
  }

  .promo-popup-visual{
    min-height:155px !important;
    height:155px !important;
  }

  .promo-popup-visual img{
    width:136px !important;
    height:152px !important;
  }
}

/* =========================================================
   V63 - HEADER MENU BREAKPOINT FOR CALCULATORS NAV
   ========================================================= */

@media(max-width:1120px){
  .header-inner{
    position:relative !important;
  }

  .nav{
    display:none !important;
    position:absolute !important;
    left:0 !important;
    right:0 !important;
    top:78px !important;
    z-index:140 !important;
    max-height:calc(100svh - 94px) !important;
    overflow-y:auto !important;
    flex-direction:column !important;
    align-items:stretch !important;
    gap:8px !important;
    padding:18px !important;
    border:1px solid var(--line) !important;
    border-radius:0 0 18px 18px !important;
    background:#fff !important;
    box-shadow:0 22px 54px rgba(25,36,64,.13) !important;
  }

  .nav.open{
    display:flex !important;
  }

  .mobile-toggle{
    display:inline-flex !important;
    align-items:center !important;
    justify-content:center !important;
  }

  .nav > a,
  .nav-item > a{
    width:100% !important;
    min-height:42px !important;
    padding:0 14px !important;
    border-radius:12px !important;
    background:#f6f8fb !important;
  }

  .nav-item{
    width:100% !important;
    flex-direction:column !important;
    align-items:stretch !important;
  }

  .dropdown-menu{
    position:static !important;
    display:none !important;
    min-width:100% !important;
    width:100% !important;
    margin-top:6px !important;
    padding:4px 0 0 14px !important;
    border:0 !important;
    border-radius:0 !important;
    background:transparent !important;
    box-shadow:none !important;
    opacity:1 !important;
    visibility:visible !important;
    transform:none !important;
  }

  .dropdown-menu::before{
    display:none !important;
  }

  .nav-item.open .dropdown-menu{
    display:block !important;
  }

  .dropdown-menu a{
    width:100% !important;
    margin:4px 0 !important;
    background:#f6f8fb !important;
  }
}
