/* ==========================================================================
   LogoLab – Mockup recreation stylesheet
   ========================================================================== */

:root {
  --navy: #2c3a59;
  --navy-soft: #3a4a6b;
  --red: #ef5544;
  --red-dark: #e2452f;
  --teal: #29a99e;
  --teal-dark: #1f8d83;
  --yellow: #f6c24a;
  --orange: #ef8a3c;
  --pink: #f49bb0;
  --purple: #7c5cbf;
  --gray: #6b7385;
  --gray-light: #8b93a4;
  --bg: #ffffff;
  --cream: #fcf8f1;
  --teal-bg: #e7f3f1;
  --card-border: #ecedf1;
  --shadow-sm: 0 6px 18px rgba(44, 58, 89, 0.06);
  --shadow-md: 0 14px 40px rgba(44, 58, 89, 0.10);
  --radius: 18px;
  --radius-lg: 26px;
  --maxw: 1120px;
}

* { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  font-family: 'Nunito Sans', 'Segoe UI', sans-serif;
  color: var(--gray);
  background: var(--bg);
  font-size: 16px;
  line-height: 1.6;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3, h4, .logo-text { font-family: 'Poppins', sans-serif; color: var(--navy); }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; display: block; }

.container {
  max-width: var(--maxw);
  margin: 0 auto;
  padding: 0 24px;
  position: relative;
  z-index: 2;
}

/* Local SEO CSS Classes */
.logoped-zemun { }
.logoped-beograd { }
.terapija-govora-beograd { }
.logoped-zemun-header { }
.logoped-zemun-nav { }
.logoped-zemun-hero { }
.logoped-beograd-container { }
.aak-zemun-header { }
.aak-zemun-hero { }
.autizam-zemun-header { }
.autizam-zemun-hero { }

/* ----------------------------- Buttons --------------------------------- */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: 'Poppins', sans-serif;
  font-weight: 600;
  font-size: 15px;
  border-radius: 40px;
  padding: 13px 26px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: all .2s ease;
  line-height: 1;
}
.btn-red { background: var(--red); color: #fff; box-shadow: 0 8px 20px rgba(239, 85, 68, .28); }
.btn-red:hover { background: var(--red-dark); transform: translateY(-2px); }
.btn-outline { background: transparent; color: var(--teal); border-color: var(--teal); }
.btn-outline:hover { background: var(--teal); color: #fff; }
.btn-sm { padding: 11px 22px; font-size: 14px; }

/* ----------------------------- Header ---------------------------------- */
.site-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255,255,255,.92);
  backdrop-filter: blur(8px);
}
.header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 0;
}
.brand { display: flex; align-items: center; gap: 12px; }
.brand .brand-logo { height: 70px; width: auto; }
.brand .logo-sub { display:block; font-family:'Poppins',sans-serif; font-size: 10px; font-weight:600; letter-spacing: 1.5px; color: var(--gray-light); }

.main-nav { display: flex; align-items: center; gap: 30px; }
.main-nav a {
  font-family: 'Poppins', sans-serif; font-weight: 500; font-size: 15px; color: var(--navy);
  position: relative; padding: 6px 0;
}
.main-nav a:hover { color: var(--red); }
.main-nav a.active { color: var(--red); }
.main-nav a.active::after {
  content: ""; position: absolute; left: 0; right: 0; bottom: -2px; height: 3px;
  background: var(--red); border-radius: 3px;
}
.nav-toggle { display: none; background: none; border: 0; font-size: 22px; color: var(--navy); cursor: pointer; }
.mobile-cta {
  display: none; width: 44px; height: 44px; border-radius: 50%;
  background: var(--red); color: #fff; align-items: center; justify-content: center;
  font-size: 18px; box-shadow: 0 4px 12px rgba(239,85,68,.28); transition: transform .15s ease;
}
.mobile-cta:active { transform: scale(0.94); }
.header-actions { display: flex; flex-direction: column; align-items: center; gap: 6px; }
.lang-switch { display: flex; align-items: center; gap: 8px; }
.nav-extras { display: none; }
.lang-switch img { width: 20px; height: 14px; border-radius: 2px; opacity: 0.6; transition: opacity .15s ease; }
.lang-switch a:hover img, .lang-switch a.active img { opacity: 1; }

/* ----------------------------- Page-wide decoration layer --------------- */
body { position: relative; }
.page-deco {
  position: absolute; inset: 0; width: 100%; height: 100%;
  overflow: hidden; z-index: 0; pointer-events: none;
}
.page-deco > * { position: absolute; }
/* large discreet speech-bubble symbols */
.bubble-deco { line-height: 0; opacity: .07; transform: rotate(-8deg); }
.bubble-deco svg { display: block; width: 100%; height: 100%; }

/* ----------------------------- Decorative blobs ------------------------- */
.deco { position: absolute; z-index: 0; pointer-events: none; }
.blob { border-radius: 50% 40% 55% 45% / 50% 55% 45% 50%; position:absolute; z-index:0; pointer-events:none; }
.dots-grid {
  position:absolute; z-index:0; pointer-events:none;
  background-image: radial-gradient(var(--gray-light) 1.6px, transparent 1.6px);
  background-size: 13px 13px; opacity: .35;
}
/* red 3x3 dot grid like the reference */
.dots-red {
  position:absolute; z-index:0; pointer-events:none;
  width:56px; height:56px;
  background-image: radial-gradient(var(--red) 3.5px, transparent 4px);
  background-size: 22px 22px; opacity:.85;
}
/* outline ring */
.ring {
  position:absolute; z-index:0; pointer-events:none;
  border-radius:50%; background:transparent;
}
.ring-teal { border:7px solid var(--teal); }
.ring-dark { border:2px solid var(--navy); }
.ring-yellow { border:7px solid var(--yellow); }
/* scattered plus sign */
.plus {
  position:absolute; z-index:0; pointer-events:none;
  font-family:'Poppins',sans-serif; font-weight:700; line-height:1;
}
/* solid dot */
.dot {
  position:absolute; z-index:0; pointer-events:none; border-radius:50%;
}
/* big soft corner blob */
.corner-blob {
  position:absolute; z-index:0; pointer-events:none;
  border-radius:0 0 60% 0;
}
/* flowing curved line (svg fills container) */
.squiggle { position:absolute; z-index:0; pointer-events:none; }
.squiggle svg { display:block; width:100%; height:100%; overflow:visible; }
/* overlapping red+teal circle cluster */
.circle-cluster { position:absolute; z-index:0; pointer-events:none; }
.circle-cluster .c1 { width:42px;height:42px;border-radius:50%;border:2px solid var(--navy);position:absolute;top:0;left:0; }
.circle-cluster .c2 { width:34px;height:34px;border-radius:50%;background:var(--red);position:absolute;top:18px;left:22px; }
.circle-cluster .c3 { width:30px;height:30px;border-radius:50%;background:var(--teal);position:absolute;top:-6px;left:30px;opacity:.9; }

/* ----------------------------- Hero ------------------------------------ */
.hero { position: relative; padding: 50px 0 30px; }
.hero-grid { display: grid; grid-template-columns: 1.05fr 1fr; gap: 50px; align-items: center; }
.hero h1 {
  font-size: 52px; font-weight: 800; line-height: 1.08; margin: 0 0 14px; letter-spacing: -1px;
}
.hero h1 .red { color: var(--red); }
.hero .hero-sub { font-family:'Poppins',sans-serif; color: var(--teal); font-weight: 700; font-size: 22px; margin: 0 0 18px; }
.hero p.lead { font-size: 17px; max-width: 460px; margin: 0 0 28px; }
.hero-actions { display: flex; gap: 16px; flex-wrap: wrap; }

.hero-media { position: relative; }
.hero-media .photo {
  border-radius: 50% 50% 48% 48% / 8% 8% 6% 6%;
  border-radius: 200px 200px 30px 30px;
  overflow: hidden; box-shadow: var(--shadow-md); position: relative; z-index: 2;
}
.hero-media .photo img { width: 100%; height: 420px; object-fit: cover; object-position: calc(50% - 150px) center; }

/* ----------------------------- Section base ----------------------------- */
.section { position: relative; padding: 56px 0; scroll-margin-top: 116px; }
.section-alt { background: #f8fbfb; }
.section-divider { border: 0; border-top: 1px dashed #d3d8e0; margin: 0; }
.section-head { text-align: center; max-width: 720px; margin: 0 auto 36px; }
.section-head h2 { font-size: 34px; font-weight: 800; margin: 0 0 12px; }
.section-head p { font-size: 16px; margin: 0; }

/* circle icon — irregular hand-drawn blob */
.circle-ico {
  width: 66px; height: 66px; display:flex; align-items:center; justify-content:center;
  font-size: 26px; color:#fff; margin: 0 auto;
  border-radius: 49% 51% 47% 53% / 52% 48% 52% 48%;
}
.value-item:nth-child(1) .circle-ico { border-radius: 47% 53% 52% 48% / 55% 46% 54% 45%; transform: rotate(-4deg); }
.value-item:nth-child(2) .circle-ico { border-radius: 54% 46% 49% 51% / 47% 55% 45% 53%; transform: rotate(5deg); }
.value-item:nth-child(3) .circle-ico { border-radius: 50% 50% 44% 56% / 53% 47% 53% 47%; transform: rotate(-6deg); }
.value-item:nth-child(4) .circle-ico { border-radius: 56% 44% 53% 47% / 46% 54% 46% 54%; transform: rotate(3deg); }
.value-item:nth-child(5) .circle-ico { border-radius: 45% 55% 50% 50% / 54% 45% 55% 46%; transform: rotate(-3deg); }
.circle-ico i { transform: rotate(2deg); }
.bg-teal   { background: #3eb5a3; }
.bg-yellow { background: #f0a820; }
.bg-red    { background: #e05c4a; }
.bg-indigo { background: #5c6bc0; }
.bg-plum   { background: #8b6b9b; }
.bg-olive  { background: #6a8f5b; }
.bg-orange { background: var(--orange); }
.bg-pink { background: var(--pink); }

/* ----------------------------- Nacin rada (5 values) -------------------- */
.values-grid { display: grid; grid-template-columns: repeat(5, 1fr); gap: 26px; }
.value-item { text-align: center; }
.value-item h4 { font-size: 16px; margin: 18px 0 8px; }
.value-item p { font-size: 14px; margin: 0; }
.nacin-note { max-width: 860px; margin: 40px auto 0; text-align: center; font-size: 15px; }
.nacin-note strong { color: var(--navy); }

/* ----------------------------- Usluge (4 cards) ------------------------- */
.service-links {
  display: flex; flex-wrap: wrap; justify-content: center; gap: 14px; margin: 16px 0 32px;
}
.usluge-note {
  max-width: 860px; margin: 30px auto 0; text-align: center; font-size: 15px; color: var(--gray);
}
.usluge-note a { text-decoration: underline; text-underline-offset: 2px; }
.usluge-note a:hover { color: var(--teal-dark); }
.service-link {
  display: inline-flex; align-items: center; gap: 9px;
  font-family:'Poppins',sans-serif; font-weight: 600; font-size: 14px;
  padding: 11px 20px; border-radius: 30px; transition: all .2s ease;
  background: #fff; color: var(--teal-dark); border: 1.5px solid;
}
.service-link i { font-size: 11px; color: var(--teal); opacity: .85; transition: transform .2s ease; }
.service-link:hover { transform: translateY(-2px); color: #fff; background: var(--teal); border-color: var(--teal); }
.service-link:hover i { color: #fff; opacity: 1; transform: translateX(3px); }
/* monochrome teal scale — graded outline tones */
.service-link.sl-teal { border-color: #bfe2dd; }
.service-link.sl-gray { border-color: #8fd0c8; }
.service-link.sl-blue { border-color: #5cb8ad; }
.service-link.sl-red  { border-color: var(--teal); }

.usluge-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 22px; }
.usluga-card {
  background: var(--teal-bg); border-radius: var(--radius); padding: 26px 22px; position: relative;
  border: 1px solid rgba(0,0,0,.02);
}
.usluga-card.c-teal { background: #e7f3f1; }
.usluga-card.c-yellow { background: #fdf3dc; }
.usluga-card.c-red { background: #fcebe8; }
.usluga-card.c-tealb { background: #e9f3f5; }
.usluga-head { display: flex; align-items: center; gap: 12px; margin-bottom: 12px; }
.usluga-ico { font-size: 28px; line-height: 1; flex-shrink: 0; }
.usluga-ico .ico-svg { width: 34px; height: 34px; display: block; }
.usluga-card h4 { font-size: 16px; margin: 0; line-height: 1.25; }
.usluga-card p { font-size: 14px; margin: 0; }
/* icon + title color per card */
.usluga-card.c-teal .usluga-ico,  .usluga-card.c-teal h4  { color: var(--teal); }
.usluga-card.c-yellow .usluga-ico, .usluga-card.c-yellow h4 { color: var(--orange); }
.usluga-card.c-red .usluga-ico,   .usluga-card.c-red h4   { color: var(--red); }
.usluga-card.c-tealb .usluga-ico, .usluga-card.c-tealb h4 { color: var(--teal); }

/* inline text link inside cards */
.usluga-card a { color: var(--teal); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
.usluga-card a:hover { color: var(--teal-dark); }

/* ----------------------------- Bottom split: koraci + o nama ------------ */
.split-grid { display: grid; grid-template-columns: 2.4fr 1fr; gap: 46px; align-items: start; }

.koraci { position: relative; }
.koraci h2 { font-size: 30px; text-align: center; margin: 0 0 36px; color: var(--teal); }
.koraci-line { display: grid; grid-template-columns: repeat(5, 1fr); gap: 14px; position: relative; }
.korak { text-align: center; position: relative; }
/* dashed connector line between numbers */
.korak:not(:last-child)::after {
  content: ""; position: absolute; top: 22px; left: 50%; width: 100%;
  border-top: 2px dashed #d3d8e0; z-index: 0;
}
.korak-num {
  position: relative; z-index: 1; display: inline-block;
  margin: 0 auto 16px; padding: 0 12px; background: #fff;
  color: var(--teal); font-family:'Poppins',sans-serif; font-weight: 800;
  font-size: 34px; line-height: 1;
}
.korak h4 { font-size: 15px; margin: 0 0 6px; }
.korak p { font-size: 13px; margin: 0; }

/* o nama */
.onama-box { text-align: left; }
.onama-box h2 { font-size: 30px; margin: 0 0 22px; }
.onama-photo { position: relative; width: 150px; float: left; margin: 0 22px 10px 0; }
.onama-photo img { width: 150px; height: 150px; border-radius: 50%; object-fit: cover; position: relative; z-index: 2; }
.onama-photo .blob { width: 150px; height: 150px; background: var(--teal); top: -10px; left: 12px; z-index: 1; opacity:.9; }
.onama-box p { font-size: 14px; }
.onama-box .btn { margin-top: 12px; }

/* ----------------------------- Pet memorial (Bubi i Rubi) --------------- */
.pet-section { background: var(--cream); overflow: hidden; }
.pet-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 54px; align-items: center; }
.pet-photo { position: relative; }
.pet-photo img {
  width: 100%; height: auto; display: block; position: relative; z-index: 2;
  border-radius: 46% 54% 52% 48% / 12% 12% 10% 10%;
  box-shadow: var(--shadow-sm);
}
.pet-photo .blob { width: 92%; height: 92%; background: var(--teal); top: -16px; left: -16px; z-index: 1; opacity: .25; }
.pet-badge {
  position: absolute; bottom: -14px; right: 28px; z-index: 3;
  width: 56px; height: 56px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  background: var(--red); color: #fff; font-size: 22px;
  box-shadow: 0 8px 20px rgba(0,0,0,.12);
}
.pet-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--teal-bg); color: var(--teal); font-family:'Poppins',sans-serif;
  font-weight: 600; font-size: 13px; padding: 7px 16px; border-radius: 30px; margin-bottom: 16px;
}
.pet-body h2 { font-size: 30px; margin: 0 0 16px; color: var(--navy); }
.pet-body p { font-size: 15px; margin: 0 0 16px; }
.pet-name-note { color: var(--navy); background: #fff; border-left: 4px solid var(--teal);
  padding: 14px 18px; border-radius: 0 12px 12px 0; box-shadow: var(--shadow-sm); }
.pet-name-note strong { color: var(--teal); }
.pet-memo { display: inline-flex; align-items: center; gap: 8px; margin: 4px 0 0 !important;
  color: var(--red); font-family:'Poppins',sans-serif; font-weight: 600; font-size: 14px; }
.pet-extra { margin: 0 0 16px; display: flex; gap: 16px; align-items: flex-start; }
.pet-extra img { width: 168px; height: 124px; object-fit: cover; border-radius: 14px;
  box-shadow: var(--shadow-sm); flex-shrink: 0; }
.pet-extra figcaption { font-size: 13px; color: var(--navy); opacity: .8; font-style: italic; align-self: center; }

/* reusable dog decoration symbol */
.dog-deco { color: var(--teal); opacity: .1; line-height: 1; transform: rotate(-6deg); }

/* ----------------------------- Testimonials ----------------------------- */
.heart-deco {
  position: absolute; top: -40px; left: 50%; transform: translateX(calc(-50% + 50px)) rotate(-8deg);
  font-size: 300px; line-height: 1; color: var(--red); opacity: .12; z-index: 0; pointer-events: none;
}
.testi-carousel { display: flex; align-items: center; gap: 14px; max-width: 980px; margin: 0 auto; position: relative; z-index: 1; }
.testi-viewport { flex: 1; overflow: hidden; }
.testi-track { display: flex; transition: transform .55s cubic-bezier(.4,0,.2,1); }
.testi-slide { min-width: 50%; box-sizing: border-box; padding: 8px 11px; }
@media (max-width: 720px) { .testi-slide { min-width: 100%; } }
.testi-arrow {
  flex-shrink: 0; width: 44px; height: 44px; border-radius: 50%;
  background: #fff; border: 1px solid var(--card-border); color: var(--navy);
  display: flex; align-items: center; justify-content: center; cursor: pointer;
  box-shadow: var(--shadow-sm); transition: all .2s ease; font-size: 14px;
}
.testi-arrow:hover { color: var(--red); border-color: var(--red); transform: translateY(-2px); }
.testi-dots { display: flex; justify-content: center; gap: 9px; margin-top: 26px; }
.testi-dot { width: 9px; height: 9px; padding: 0; border: 0; border-radius: 50%; background: #d7dbe2; cursor: pointer; transition: all .25s ease; }
.testi-dot.active { background: var(--teal); width: 24px; border-radius: 6px; }
.testi-card {
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius);
  padding: 30px 30px; box-shadow: var(--shadow-sm); position: relative; min-height: 170px;
}
.testi-quote { font-family: Georgia, serif; font-size: 46px; line-height: .5; font-weight: 700; }
.testi-card.q-red .testi-quote { color: var(--red); }
.testi-card.q-teal .testi-quote { color: var(--teal); }
.testi-card.q-yellow .testi-quote { color: var(--yellow); }
.testi-card p { font-style: italic; font-size: 14.5px; margin: 16px 0 18px; }
.testi-foot { display:flex; align-items:center; justify-content:space-between; }
.testi-foot .author { font-family:'Poppins',sans-serif; font-weight:600; font-size: 14px; color: var(--navy); }
.testi-foot .hrt { font-size: 14px; }
.q-red .hrt { color: var(--red);} .q-teal .hrt{color:var(--teal);} .q-yellow .hrt{color:var(--yellow);}

/* ----------------------------- Cenovnik --------------------------------- */
#cenovnik .section-head h2 { color: var(--gray-light); }
.cenovnik-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; }
.cena-card {
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius);
  padding: 24px 22px; box-shadow: var(--shadow-sm); text-align: left;
  display: flex; flex-direction: column;
}
.cena-head { display: flex; align-items: flex-start; gap: 14px; margin-bottom: 16px; }
.cena-ico {
  width: 46px; height: 46px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; color: #fff; font-size: 20px;
  border-radius: 49% 51% 47% 53% / 52% 48% 52% 48%;
}
.cenovnik-grid > *:nth-child(odd) .cena-ico { border-radius: 47% 53% 52% 48% / 55% 46% 54% 45%; transform: rotate(-4deg); }
.cenovnik-grid > *:nth-child(even) .cena-ico { border-radius: 54% 46% 49% 51% / 47% 55% 45% 53%; transform: rotate(5deg); }
.cenovnik-grid > *:nth-child(3n) .cena-ico { border-radius: 50% 50% 44% 56% / 53% 47% 53% 47%; transform: rotate(-6deg); }
.cena-ico i { transform: rotate(2deg); }
.cena-card h4 { font-size: 16px; margin: 0 0 6px; line-height: 1.25; }
.cena-price { font-family:'Poppins',sans-serif; font-weight: 800; font-size: 20px; }
.cena-card.c-teal   .cena-price { color: #3eb5a3; }
.cena-card.c-red    .cena-price { color: #e05c4a; }
.cena-card.c-yellow .cena-price { color: #d4930c; }
.cena-card.c-indigo .cena-price { color: #5c6bc0; }
.cena-card.c-plum   .cena-price { color: #8b6b9b; }
.cena-card.c-olive  .cena-price { color: #6a8f5b; }
.cena-desc { font-size: 13.5px; margin: 0 0 20px; flex: 1; }
.cena-btn {
  display: block; text-align: center; font-family:'Poppins',sans-serif; font-weight: 600; font-size: 14px;
  padding: 11px 18px; border-radius: 30px; border: 1.5px solid; transition: all .2s ease;
}
.cena-card.c-teal   .cena-btn { color: #3eb5a3; border-color: #3eb5a3; }
.cena-card.c-teal   .cena-btn:hover { background: #3eb5a3; color: #fff; }
.cena-card.c-red    .cena-btn { color: #e05c4a; border-color: #e05c4a; }
.cena-card.c-red    .cena-btn:hover { background: #e05c4a; color: #fff; }
.cena-card.c-yellow .cena-btn { color: #d4930c; border-color: #d4930c; }
.cena-card.c-yellow .cena-btn:hover { background: #d4930c; color: #fff; }
.cena-card.c-indigo .cena-btn { color: #5c6bc0; border-color: #5c6bc0; }
.cena-card.c-indigo .cena-btn:hover { background: #5c6bc0; color: #fff; }
.cena-card.c-plum   .cena-btn { color: #8b6b9b; border-color: #8b6b9b; }
.cena-card.c-plum   .cena-btn:hover { background: #8b6b9b; color: #fff; }
.cena-card.c-olive  .cena-btn { color: #6a8f5b; border-color: #6a8f5b; }
.cena-card.c-olive  .cena-btn:hover { background: #6a8f5b; color: #fff; }
.cenovnik-note { text-align: center; margin-top: 26px; font-size: 14px; color: var(--gray-light); }
.cenovnik-note i { color: var(--teal); }

/* ----------------------------- Footer ----------------------------------- */
.site-footer { background: var(--cream); margin-top: 30px; }
.footer-inner {
  display: grid; grid-template-columns: 1.4fr 1fr 1fr 0.8fr; gap: 24px; align-items: center;
  padding: 34px 0;
}
.footer-col { display: flex; align-items: center; gap: 14px; min-width: 0; }
.footer-col > div,
.footer-col > p { min-width: 0; }
.footer-col .ico { font-size: 26px; flex-shrink: 0; }
.footer-col.tag .ico { color: var(--red); }
.footer-col.loc .ico { color: var(--teal); }
.footer-col.svc .ico { color: var(--navy); }
.footer-col p { margin: 0; font-size: 14px; color: var(--gray); }
.footer-col.svc p { line-height: 1.5; }
.footer-col.svc a { color: var(--gray); text-decoration: none; }
.footer-col.svc a:hover { color: var(--red); text-decoration: underline; }
.footer-col p a { color: var(--red); font-weight: 600; }
.footer-social { display:flex; align-items:center; gap: 16px; justify-content: flex-end; flex-wrap: wrap; }
.footer-social .web { display:flex; align-items:center; gap:8px; font-size:14px; color: var(--navy); }
.footer-social .web i { color: var(--teal); font-size: 18px; }
.footer-social .soc { font-size: 22px; color: var(--navy); }
.footer-social .soc:hover { color: var(--red); }
.footer-info {
  grid-column: 1 / -1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px 24px;
  flex-wrap: wrap;
  padding-top: 4px;
  color: var(--gray);
  font-size: 14px;
  text-align: center;
}
.footer-info span { display: inline-flex; align-items: center; gap: 8px; }
.footer-info .email i { color: var(--red); }
.footer-info .addr i { color: var(--teal); }
.footer-info a { color: var(--navy); }
.footer-cert {
  display: flex; align-items: center; justify-content: center; gap: 18px;
  border-top: 1px dashed #e0ddd4; padding: 20px 0 30px; flex-wrap: wrap; text-align: center;
}
.footer-cert .cert-mark { flex-shrink: 0; transition: transform .2s ease; }
.footer-cert .cert-mark:hover { transform: translateY(-2px); }
.footer-cert img { height: 50px; width: auto; display: block; }
.footer-cert span { font-size: 13.5px; color: var(--gray); max-width: 360px; transform: translateY(-4px); }
.footer-cert strong { color: var(--navy); }
.footer-cyr-wrap { padding: 0 0 24px; text-align: center; }
.footer-cyr { font-size: 0.75em; opacity: 0.75; color: var(--gray); margin: 0; }
.footer-cyr-addr { font-size: 0.85em; opacity: 0.75; color: var(--gray); margin: 6px 0 0; }

/* =====================================================================
   BLOG PAGE
   ===================================================================== */
.blog-layout { display: grid; grid-template-columns: 1fr 320px; gap: 44px; padding: 44px 0 60px; position: relative; z-index: 2; }
.blog-main, .blog-side { position: relative; z-index: 1; }
.blog-main h1.blog-title { font-size: 52px; font-weight: 800; margin: 0 0 16px; }
.blog-intro { font-size: 18px; max-width: 520px; margin: 0 0 26px; }

.blog-filters { display: flex; flex-wrap: wrap; gap: 12px; margin-bottom: 30px; }
.filter-pill {
  font-family:'Poppins',sans-serif; font-weight: 500; font-size: 14px; color: var(--navy);
  background: #fff; border: 1px solid var(--card-border); border-radius: 30px; padding: 9px 18px; cursor: pointer;
  transition: all .2s ease;
}
.filter-pill:hover { border-color: var(--teal); color: var(--teal); }
.filter-pill.active { background: var(--teal); color: #fff; border-color: var(--teal); }

/* featured */
.featured {
  display: grid; grid-template-columns: 1fr 1fr; background: #fff; border: 1px solid var(--card-border);
  border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); margin-bottom: 34px;
}
.featured-img { position: relative; }
.featured-img img { width: 100%; height: 100%; min-height: 260px; object-fit: cover; }
.featured-body { padding: 32px 30px; }
.badge-featured {
  display:inline-block; background: var(--red); color:#fff; font-family:'Poppins',sans-serif; font-weight:600;
  font-size: 12px; padding: 6px 14px; border-radius: 20px; margin-bottom: 16px;
}
.featured-body h3 { font-size: 25px; margin: 0 0 14px; line-height: 1.2; }
.featured-body p { font-size: 14.5px; margin: 0 0 22px; }

/* blog grid */
.posts-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
.post-card {
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius);
  overflow: hidden; box-shadow: var(--shadow-sm); display: flex; flex-direction: column;
  transition: transform .2s ease, box-shadow .2s ease;
}
.post-card:hover { transform: translateY(-4px); box-shadow: var(--shadow-md); }
.post-card img { width: 100%; height: 150px; object-fit: cover; }
.post-body { padding: 18px 18px 22px; display:flex; flex-direction:column; flex:1; }
.post-cat { font-family:'Poppins',sans-serif; font-weight:600; font-size: 12px; margin-bottom: 8px; }
.cat-orange { color: var(--orange); } .cat-teal { color: var(--teal); } .cat-red { color: var(--red); } .cat-purple { color: var(--purple); }
.post-card h4 { font-size: 17px; margin: 0 0 10px; line-height: 1.25; }
.post-body p { font-size: 13.5px; margin: 0 0 16px; flex: 1; }
.read-more { font-family:'Poppins',sans-serif; font-weight:600; font-size: 14px; color: var(--teal); }
.read-more:hover { color: var(--teal-dark); }

/* sidebar */
.blog-sidebar { display: flex; flex-direction: column; gap: 24px; }
.search-box { position: relative; }
.search-box input {
  width: 100%; border: 1px solid var(--card-border); border-radius: 30px; padding: 14px 46px 14px 20px;
  font-family:'Nunito Sans',sans-serif; font-size: 14px; color: var(--navy); background:#fff;
}
.search-box input:focus { outline: none; border-color: var(--teal); }
.search-box i { position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--teal); }

.sidebar-card {
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius);
  padding: 24px; box-shadow: var(--shadow-sm);
}
.sidebar-card h3 { font-size: 19px; margin: 0 0 18px; }
.cat-list { list-style: none; margin: 0; padding: 0; }
.cat-list li { display: flex; align-items: center; gap: 12px; padding: 8px 0; font-size: 15px; color: var(--navy); cursor: pointer; border-radius: 6px; transition: background .15s ease, color .15s ease; }
.cat-list li:hover { color: var(--teal); }
.cat-list li.active { color: var(--teal); font-weight: 600; }

.blog-main .featured,
.blog-main .post-card { transition: opacity .25s ease, transform .25s ease; }
.blog-main .featured.hidden,
.blog-main .post-card.hidden { display: none; }
.blog-main .featured.dimmed,
.blog-main .post-card.dimmed { opacity: 0; transform: scale(.97); pointer-events: none; }
.cat-dot { width: 11px; height: 11px; border-radius: 50%; flex-shrink: 0; }
.dot-teal{background:var(--teal);} .dot-red{background:var(--red);} .dot-yellow{background:var(--yellow);} .dot-pink{background:var(--pink);} .dot-purple{background:var(--purple);}

.newsletter-card { background: var(--teal-bg); border: 0; text-align: center; }
.newsletter-card .nl-ico {
  width: 54px; height: 54px; border-radius: 50%; background: #fff; color: var(--teal);
  display:flex; align-items:center; justify-content:center; font-size: 22px; margin: 0 auto 14px;
}
.newsletter-card h3 { margin: 0 0 6px; font-size: 18px; }
.newsletter-card p { font-size: 14px; margin: 0 0 16px; }
.newsletter-card input {
  width: 100%; border: 1px solid #d8e6e3; border-radius: 30px; padding: 12px 18px; font-size: 14px; margin-bottom: 12px;
  font-family:'Nunito Sans',sans-serif;
}
.newsletter-card input:focus { outline: none; border-color: var(--teal); }
.newsletter-card .btn { width: 100%; justify-content: center; }
.nl-note { font-size: 12px; color: var(--gray-light); margin: 14px 0 0; }
.newsletter-card textarea {
  width: 100%; border: 1px solid #d8e6e3; border-radius: 16px; padding: 12px 18px;
  font-size: 14px; margin-bottom: 8px; font-family:'Nunito Sans',sans-serif; resize: vertical;
}
.newsletter-card textarea:focus { outline: none; border-color: var(--teal); }
.newsletter-card .field-error {
  display: block; font-size: 12px; color: var(--red); margin: -4px 0 10px; min-height: 14px;
}
.newsletter-card .form-status { font-size: 13px; margin: 10px 0 0; min-height: 16px; }
.newsletter-card .form-status.is-success { color: var(--teal); font-weight: 600; }
.newsletter-card .form-status.is-error { color: var(--red); font-weight: 600; }
.newsletter-card .hp-field { display: none; }

/* =====================================================================
   RESPONSIVE
   ===================================================================== */
@media (max-width: 980px) {
  .main-nav {
    display: none;
    position: absolute;
    top: 100%;
    left: 0;
    right: 0;
    background: rgba(255,255,255,.98);
    backdrop-filter: blur(8px);
    flex-direction: column;
    align-items: flex-start;
    gap: 0;
    padding: 12px 24px 18px;
    box-shadow: 0 12px 24px rgba(44,58,89,.08);
    border-radius: 0 0 18px 18px;
    border-top: 1px solid var(--card-border);
  }
  .main-nav.is-open { display: flex; }
  .main-nav a {
    width: 100%;
    padding: 10px 0;
    border-bottom: 1px solid var(--card-border);
  }
  .main-nav a:last-child { border-bottom: 0; }
  .main-nav a.active::after { display: none; }
  .nav-toggle {
    display: block;
    width: 44px;
    height: 44px;
    min-width: 44px;
    min-height: 44px;
    flex: 0 0 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 8px;
  }
  .nav-toggle[aria-expanded="true"] { background: var(--teal-bg); color: var(--teal); }
  .header-actions { flex-direction: row; gap: 10px; }
  .hero-grid { grid-template-columns: 1fr; gap: 36px; }
  .hero h1 { font-size: 40px; }
  .values-grid { grid-template-columns: repeat(2, 1fr); gap: 30px; }
  .usluge-grid { grid-template-columns: repeat(2, 1fr); }
  .split-grid { grid-template-columns: 1fr; }
  .pet-grid { grid-template-columns: 1fr; gap: 40px; }
  .about-row { grid-template-columns: 1fr; gap: 30px; margin: 38px 0; }
  .about-row.reverse .about-media { order: 0; }
  .book-row { grid-template-columns: 1fr; }
  .program-3col { grid-template-columns: 1fr; gap: 22px; }
  .program-3col .about-media { order: -1; }
  .program-includes { grid-template-columns: 1fr; }
  .koraci-line { grid-template-columns: repeat(2, 1fr); gap: 28px; }
  .korak::after { display: none; }
  .testi-grid { grid-template-columns: 1fr; }
  .cenovnik-grid { grid-template-columns: repeat(2, 1fr); }
  .footer-inner { grid-template-columns: 1fr; gap: 20px; }
  .footer-social { justify-content: flex-start; }
  .blog-layout { grid-template-columns: 1fr; }
  .featured { grid-template-columns: 1fr; }
  .posts-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .hero { padding: 28px 0 20px; }
  .hero .deco { display: none; }
  .hero h1 { font-size: 28px; letter-spacing: -0.5px; }
  .hero .hero-sub { font-size: 18px; }
  .hero p.lead { font-size: 15.5px; margin-bottom: 20px; }
  .hero-grid { gap: 24px; }
  .hero-media .photo img { height: 240px; object-position: center center; }
  .hero-actions { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero-actions .btn-red { width: 100%; justify-content: center; }
  .hero-actions .btn-outline {
    background: transparent; border: 0; padding: 0;
    color: var(--teal); font-weight: 600; font-size: 15px;
    justify-content: center; box-shadow: none;
  }
  .blog-main h1.blog-title { font-size: 38px; }
  .values-grid { grid-template-columns: 1fr; }
  .usluge-grid, .cenovnik-grid, .posts-grid { grid-template-columns: 1fr; }
  .section-head h2 { font-size: 28px; }
  .brand .brand-logo { height: 52px; }
  .svc-hero h1 { font-size: 26px; margin-bottom: 12px; }
  .svc-hero .svc-lead { font-size: 16px; }
  .svc-body { padding: 20px 16px 10px; }
  .svc-body > p { font-size: 15px; }
  .svc-body h2 { font-size: 22px; margin: 32px 0 12px; }
  .svc-body h3 { font-size: 16px; }
  .svc-body ul li { font-size: 15px; padding-left: 24px; }
  .svc-note { padding: 16px 18px; margin: 22px 0; }
  .svc-faq { padding: 22px 18px; margin-top: 28px; }
  .svc-cta { padding: 28px 20px; margin-top: 36px; }
  .svc-cta h2 { font-size: 22px; }
  .svc-related { padding: 0 8px; }
  .page-program .hanen-cert {
    flex-direction: column; align-items: center; text-align: center;
    gap: 12px; padding: 14px 18px;
  }
  .page-program .hanen-cert img { height: 48px; }
  .page-program .hanen-cert span { font-size: 14px; }
  .book-row .about-media { max-width: 200px; margin-bottom: 8px; }
  .header-actions { display: none; }
  .mobile-cta { display: inline-flex; }
  .logo-sub { display: none; }
  .main-nav a {
    min-height: 44px;
    display: flex;
    align-items: center;
  }
  .lang-switch a {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .lang-switch img { width: 24px; height: 17px; }
  .btn, .btn-sm { min-height: 44px; }
  .read-more {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 10px 0;
  }
  .footer-col.svc a {
    display: inline-flex;
    align-items: center;
    min-height: 44px;
    padding: 6px 0;
  }
  .footer-social .soc {
    width: 44px;
    height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  .site-footer { margin-top: 24px; }
  .footer-inner {
    gap: 18px;
    padding: 28px 0 20px;
  }
  .footer-col,
  .footer-social,
  .footer-info {
    width: min(100%, 420px);
    margin: 0 auto;
    padding-inline: 10px;
  }
  .footer-col {
    display: grid;
    grid-template-columns: 36px minmax(0, 1fr);
    align-items: start;
    gap: 12px;
  }
  .footer-col .ico {
    width: 36px;
    text-align: center;
    padding-top: 2px;
  }
  .footer-col.tag p,
  .footer-col.loc p,
  .footer-col.svc p {
    line-height: 1.65;
  }
  .footer-social {
    justify-content: center;
    gap: 10px 16px;
    padding-top: 2px;
  }
  .footer-social .web {
    width: 100%;
    justify-content: center;
  }
  .footer-info {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    text-align: left;
  }
  .footer-cert {
    gap: 14px;
    padding: 18px 0 22px;
    padding-inline: 10px;
  }
  .footer-cert img { height: 46px; }
  .footer-cert span {
    max-width: 300px;
    transform: none;
    line-height: 1.6;
  }
  .footer-cyr-wrap { padding: 0 24px 24px; }
  .footer-cyr {
    line-height: 1.75;
  }
  .main-nav .nav-extras {
    display: flex; flex-direction: column; gap: 14px;
    width: 100%; padding-top: 12px; margin-top: 4px;
    border-top: 1px solid var(--card-border);
  }
  .main-nav .nav-extras .btn { width: 100%; justify-content: center; }
  .main-nav .nav-extras .lang-switch { justify-content: center; }
}

@media (max-width: 767.98px) {
  .section,
  .hero,
  .svc-hero { overflow: hidden; }
  .heart-deco,
  .ig-bg-glyph,
  .dog-deco.deco,
  .bubble-deco { display: none; }
  .testi-carousel { gap: 8px; }
  .testi-arrow { width: 44px; height: 44px; font-size: 14px; }
  .testi-dots { gap: 2px; margin-top: 20px; }
  .testi-dot {
    width: 44px;
    height: 44px;
    flex: 0 0 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: transparent;
  }
  .testi-dot.active {
    width: 44px;
    background: transparent;
  }
  .testi-dot::before {
    content: "";
    width: 9px;
    height: 9px;
    border-radius: 50%;
    background: #d7dbe2;
    transition: all .25s ease;
  }
  .testi-dot.active::before {
    width: 24px;
    border-radius: 6px;
    background: var(--teal);
  }
}

@media (min-width: 561px) and (max-width: 767.98px) {
  .site-footer { margin-top: 26px; }
  .footer-inner {
    gap: 22px;
    padding: 30px 0 24px;
  }
  .footer-col,
  .footer-social,
  .footer-info {
    width: min(100%, 560px);
    margin: 0 auto;
    padding-inline: 18px;
  }
  .footer-col {
    display: grid;
    grid-template-columns: 42px minmax(0, 1fr);
    align-items: start;
    gap: 14px;
  }
  .footer-col .ico {
    width: 42px;
    text-align: center;
    padding-top: 2px;
  }
  .footer-col.tag p,
  .footer-col.loc p,
  .footer-col.svc p {
    line-height: 1.7;
  }
  .footer-social {
    justify-content: center;
    gap: 12px 18px;
    padding-top: 2px;
  }
  .footer-social .web {
    width: 100%;
    justify-content: center;
  }
  .footer-info {
    justify-content: center;
    gap: 12px 24px;
    text-align: center;
  }
  .footer-cert {
    gap: 16px;
    padding: 18px 18px 24px;
  }
  .footer-cert span {
    max-width: 380px;
    transform: none;
    line-height: 1.6;
  }
  .footer-cyr-wrap { padding: 0 24px 24px; }
}

/* =====================================================================
   SERVICE PAGES
   ===================================================================== */
.svc-hero { position: relative; z-index: 2; padding: 56px 0 6px; text-align: center; }
.svc-breadcrumb { font-size: 13px; color: var(--gray-light); margin: 0 0 18px; }
.svc-breadcrumb a { color: var(--teal); }
.svc-hero h1 { font-size: 42px; line-height: 1.12; max-width: 820px; margin: 0 auto 16px; }
.svc-hero .svc-lead { font-size: 18px; max-width: 700px; margin: 0 auto; }
.svc-eyebrow {
  display: inline-flex; align-items: center; gap: 8px; margin: 0 auto 18px;
  background: var(--teal-bg); color: var(--teal); font-family:'Poppins',sans-serif;
  font-weight: 600; font-size: 13px; padding: 8px 16px; border-radius: 30px;
}
.svc-body { position: relative; z-index: 2; max-width: 820px; margin: 0 auto; padding: 28px 0 10px; }
.svc-body > p { margin: 0 0 16px; font-size: 16px; }
.svc-body h2 { font-size: 26px; margin: 40px 0 14px; }
.svc-body h3 { font-size: 18px; margin: 24px 0 8px; color: var(--navy); }
.svc-body a { color: var(--teal); font-weight: 600; }
.svc-body a:hover { color: var(--teal-dark); }
.svc-body .btn-red { color: #fff; }
.svc-body ul { margin: 0 0 18px; padding: 0; list-style: none; }
.svc-body ul li { position: relative; padding-left: 30px; margin-bottom: 11px; font-size: 16px; }
.svc-body ul li::before {
  content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900;
  position: absolute; left: 0; top: 2px; color: var(--teal); font-size: 13px;
}
.svc-note {
  background: #fff7ec; border-left: 4px solid var(--orange); border-radius: 12px;
  padding: 20px 26px; margin: 30px 0;
}
.svc-note h2 { margin-top: 0; font-size: 22px; }
.svc-faq { background: var(--teal-bg); border-radius: var(--radius); padding: 30px 32px; margin-top: 40px; }
.svc-faq h2 { margin-top: 0; }
.svc-faq h3 { margin-top: 22px; }
.svc-faq h3:first-of-type { margin-top: 14px; }
.svc-cta {
  position: relative; z-index: 2; max-width: 820px; margin: 50px auto 0; text-align: center;
  background: linear-gradient(135deg, #fff 0%, var(--teal-bg) 100%);
  border: 1px solid var(--card-border); border-radius: var(--radius-lg);
  padding: 44px 36px; box-shadow: var(--shadow-sm);
}
.svc-cta h2 { font-size: 26px; margin: 0 0 12px; }
.svc-cta p { max-width: 560px; margin: 0 auto 24px; font-size: 15px; }
.svc-related { max-width: 980px; margin: 60px auto 0; text-align: center; }
.svc-related h2 { font-size: 24px; margin: 0 0 22px; }

/* =====================================================================
   ABOUT & PROGRAM PAGES
   ===================================================================== */
.about-row {
  display: grid; grid-template-columns: 0.78fr 1.22fr; gap: 44px; align-items: center;
  margin: 36px 0; position: relative;
}
.about-row + .about-row { margin-top: 8px; }
.about-row.reverse .about-media { order: 2; }
.about-row.about-feature { grid-template-columns: 1fr 1.05fr; gap: 50px; }
.about-row.about-feature .about-media { max-width: 440px; }
.about-media { position: relative; max-width: 320px; margin: 0 auto; width: 100%; }
.about-media img {
  width: 100%; height: auto; display: block; position: relative; z-index: 2;
  border-radius: 46% 54% 52% 48% / 12% 12% 10% 10%;
  box-shadow: var(--shadow-md);
}
.about-media .blob {
  width: 88%; height: 88%; background: var(--teal); top: -16px; left: -16px; z-index: 1; opacity: .22;
}
.about-row.reverse .about-media .blob { left: auto; right: -16px; background: var(--yellow); opacity: .3; }
.about-text h2 { font-size: 27px; margin: 0 0 16px; color: var(--navy); }
.about-text p { font-size: 15.5px; margin: 0 0 14px; }
.about-text p:last-child { margin-bottom: 0; }
.about-text ul { list-style: none; padding: 0; margin: 4px 0 0; }
.about-text ul li { position: relative; padding-left: 30px; margin-bottom: 11px; font-size: 15px; }
.about-text ul li::before {
  content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900;
  position: absolute; left: 0; top: 3px; color: var(--teal); font-size: 12px;
}
.about-eyebrow {
  display: inline-flex; align-items: center; gap: 8px; margin: 0 0 14px;
  background: var(--teal-bg); color: var(--teal); font-family:'Poppins',sans-serif;
  font-weight: 600; font-size: 12.5px; padding: 6px 14px; border-radius: 30px;
}
.about-fullrow { max-width: 820px; margin: 0 auto; }
.about-fullrow p { font-size: 15.5px; margin: 0 0 14px; }

/* program detail block (image + lists) */
.program-detail { align-items: start; }
.program-detail .about-media { max-width: 248px; }
.program-detail .about-text h3 { font-size: 18px; margin: 22px 0 8px; color: var(--navy); }
.program-detail .about-text h3:first-of-type { margin-top: 0; }

/* program: book cover (keep proportions, clean frame) */
.book-row { grid-template-columns: 0.7fr 1.3fr; gap: 48px; }
.book-row .about-media { max-width: 260px; }
.book-row .about-media img { border-radius: 14px; box-shadow: var(--shadow-md); }
.book-row .about-media .blob {
  width: 100%; height: 100%; top: 16px; left: 16px; right: auto;
  border-radius: 18px; background: var(--teal); opacity: .16;
}
.hanen-badge {
  display: inline-flex; align-items: center; gap: 8px; margin-top: 16px;
  background: #fff; border: 1px solid var(--card-border); border-radius: 30px;
  padding: 8px 16px; font-family:'Poppins',sans-serif; font-weight: 600; font-size: 12.5px;
  color: var(--teal); box-shadow: var(--shadow-sm);
}
.hanen-badge i { color: var(--red); }
.hanen-cert {
  display: flex; align-items: center; gap: 16px; margin-top: 20px;
  background: #fff; border: 1px solid var(--card-border); border-radius: 16px;
  padding: 12px 18px; box-shadow: var(--shadow-sm); max-width: 460px;
}
.hanen-cert img { height: 52px; width: auto; flex-shrink: 0; }
.hanen-cert span {
  font-family:'Poppins',sans-serif; font-weight: 600; font-size: 12.5px;
  color: var(--navy); line-height: 1.4;
}
.page-program .hanen-cert {
  gap: 22px; padding: 18px 26px; max-width: 620px; border-radius: 18px;
}
.page-program .hanen-cert img { height: 80px; }
.page-program .hanen-cert span { font-size: 16px; color: #4a7ab0; }
.page-program .hanen-cert .hanen-name { color: #1a1a1a; }

/* program: text — image (center) — text */
.program-3col {
  display: grid; grid-template-columns: 1fr minmax(210px, 250px) 1fr;
  gap: 32px; align-items: center; margin: 6px 0;
}
.program-3col .about-media { max-width: 250px; }
.prog-col {
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius-lg);
  padding: 28px 26px; box-shadow: var(--shadow-sm);
}
.prog-col h2 { font-size: 19px; line-height: 1.25; margin: 0 0 12px; color: var(--navy); }
.prog-col p { font-size: 14px; margin: 0 0 12px; color: var(--gray); }
.prog-col ul { list-style: none; padding: 0; margin: 0; }
.prog-col ul li {
  position: relative; padding-left: 28px; margin-bottom: 12px; font-size: 14px; line-height: 1.5;
}
.prog-col ul li:last-child { margin-bottom: 0; }
.prog-col ul li::before {
  content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900;
  position: absolute; left: 0; top: 2px; color: var(--teal); font-size: 11px;
}

.program-3col > * { min-width: 0; }

@media (max-width: 980px) {
  .program-3col {
    grid-template-columns: 1fr;
    gap: 22px;
  }

  .program-3col .about-media {
    order: -1;
    margin-inline: auto;
  }

  .prog-col {
    width: 100%;
  }
}

/* program: "Šta program obuhvata" cards */
.program-includes { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 18px; }
.pi-card {
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius);
  padding: 6px 22px 10px; box-shadow: var(--shadow-sm);
}
.pi-card .pi-ico {
  width: 46px; height: 46px; border-radius: 50%; display: flex; align-items: center;
  justify-content: center; color: #fff; font-size: 18px; margin-bottom: 14px;
}
.pi-card .pi-ico-img {
  width: 138px; height: 138px; object-fit: contain; margin-top: -8px; margin-bottom: -2px; display: block;
}
.pi-card h3 { font-size: 16px; margin: 0 0 2px; color: var(--navy); }
.pi-card p { font-size: 13.5px; margin: 0; color: var(--gray); }

/* =====================================================================
   INSTAGRAM SECTION
   ===================================================================== */
#instagram { position: relative; overflow: hidden; }
.ig-bg-glyph {
  position: absolute; top: -30px; left: 50%; transform: translateX(-50%) rotate(-8deg);
  font-size: 280px; line-height: 1; color: var(--red); opacity: .06; z-index: 0; pointer-events: none;
}
.ig-eyebrow {
  display: inline-flex; align-items: center; gap: 8px; margin-bottom: 12px;
  background: #fdeecf; color: var(--orange); font-family:'Poppins',sans-serif;
  font-weight: 600; font-size: 13px; padding: 7px 16px; border-radius: 30px;
}
.ig-sub { font-size: 15px; color: var(--gray); margin: 8px 0 0; }
.ig-card {
  position: relative; z-index: 1; max-width: 720px; margin: 34px auto 0;
  display: grid; grid-template-columns: 300px 1fr; gap: 0; align-items: stretch;
  background: #fff; border: 1px solid var(--card-border); border-radius: var(--radius);
  box-shadow: var(--shadow-sm); overflow: hidden;
}
.ig-media { position: relative; display: block; overflow: hidden; }
.ig-media img { width: 100%; height: 100%; min-height: 300px; object-fit: cover; transition: transform .5s ease; }
.ig-media:hover img { transform: scale(1.05); }
.ig-media-badge {
  position: absolute; top: 12px; right: 12px; width: 34px; height: 34px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center; color: #fff; font-size: 16px;
  background: linear-gradient(45deg, #f09433, #e6683c 30%, #dc2743 55%, #bc1888 90%);
}
.ig-body { padding: 26px 28px; display: flex; flex-direction: column; }
.ig-handle { display: flex; align-items: center; gap: 12px; margin-bottom: 14px; }
.ig-avatar {
  width: 40px; height: 40px; border-radius: 50%; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center; color: #fff; font-size: 16px;
  background: linear-gradient(135deg, var(--teal), var(--teal-dark));
}
.ig-name { display: block; font-family:'Poppins',sans-serif; font-weight: 700; font-size: 14px; color: var(--navy); }
.ig-loc { display: block; font-size: 12px; color: var(--gray-light); }
.ig-caption {
  font-size: 14.5px; margin: 0 0 16px; color: var(--gray);
  display: -webkit-box; -webkit-line-clamp: 4; line-clamp: 4; -webkit-box-orient: vertical; overflow: hidden;
}
.ig-meta { display: flex; align-items: center; justify-content: space-between; margin-bottom: 20px; }
.ig-stats { font-size: 13px; color: var(--gray); }
.ig-stats .fa-heart { color: var(--red); }
.ig-stats .fa-comment { color: var(--teal); }
.ig-date { font-size: 12px; color: var(--gray-light); }
.ig-body .btn { align-self: flex-start; margin-top: auto; background: var(--teal); border-color: var(--teal); color: #fff; box-shadow: 0 8px 20px rgba(62, 181, 163, .32); }
.ig-body .btn:hover { background: var(--teal-dark); border-color: var(--teal-dark); box-shadow: 0 10px 24px rgba(62, 181, 163, .42); }
@media (max-width: 980px) {
  .ig-card { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .ig-card { grid-template-columns: 1fr; }
  .ig-media img { min-height: 240px; }
  .ig-body .btn { align-self: stretch; justify-content: center; }
}

/* =====================================================================
   COOKIE CONSENT BANNER + MODAL
   ===================================================================== */
.consent-banner {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: #ffffff; padding: 20px;
  box-shadow: 0 -2px 16px rgba(44, 58, 89, 0.12);
  z-index: 9999; display: none;
  font-family: 'Nunito Sans', 'Segoe UI', sans-serif;
}
.consent-banner.show { display: block; }
.consent-content {
  max-width: var(--maxw); margin: 0 auto;
  display: flex; justify-content: space-between; align-items: center; gap: 24px;
}
.consent-text { flex: 1; }
.consent-text h3 { margin: 0 0 8px; font-size: 18px; color: var(--navy); font-family:'Poppins',sans-serif; }
.consent-text p { margin: 0; font-size: 14px; color: var(--gray); line-height: 1.5; }
.consent-buttons { display: flex; gap: 10px; flex-shrink: 0; }
.consent-buttons button, .consent-modal-footer .btn-primary {
  padding: 10px 20px; border: none; border-radius: 30px; cursor: pointer;
  font-family:'Poppins',sans-serif; font-size: 14px; font-weight: 600;
  transition: all .25s ease;
}
.consent-buttons .btn-primary, .consent-modal-footer .btn-primary {
  background: var(--red); color: #fff;
}
.consent-buttons .btn-primary:hover, .consent-modal-footer .btn-primary:hover {
  background: var(--red-dark);
}
.consent-buttons .btn-secondary { background: var(--navy); color: #fff; }
.consent-buttons .btn-secondary:hover { background: var(--navy-soft); }
.consent-buttons .btn-outline {
  background: transparent; border: 1.5px solid var(--teal); color: var(--teal);
}
.consent-buttons .btn-outline:hover { background: var(--teal); color: #fff; }
.consent-buttons .btn-link {
  background: transparent; border: none; color: var(--gray-light);
  padding: 0; font-weight: 500; font-size: 13px;
}
.consent-buttons .btn-link:hover { color: var(--teal); text-decoration: underline; }

.consent-modal {
  display: none; position: fixed; inset: 0;
  background: rgba(44, 58, 89, 0.5); z-index: 10000;
  align-items: center; justify-content: center;
  font-family: 'Nunito Sans', 'Segoe UI', sans-serif;
}
.consent-modal.show { display: flex; }
.consent-modal-content {
  background: #fff; border-radius: var(--radius);
  max-width: 500px; width: 90%; max-height: 90vh; overflow-y: auto;
  box-shadow: var(--shadow-md);
}
.consent-modal-header {
  display: flex; justify-content: space-between; align-items: center;
  padding: 20px; border-bottom: 1px solid var(--card-border);
}
.consent-modal-header h3 { margin: 0; font-size: 20px; color: var(--navy); font-family:'Poppins',sans-serif; }
.btn-close {
  background: none; border: none; font-size: 28px; cursor: pointer; color: var(--gray-light);
  padding: 0; width: 30px; height: 30px; display: flex; align-items: center; justify-content: center;
}
.btn-close:hover { color: var(--navy); }
.consent-modal-body { padding: 20px; }
.consent-option {
  display: flex; justify-content: space-between; align-items: flex-start;
  padding: 15px 0; border-bottom: 1px solid var(--card-border);
}
.consent-option:last-child { border-bottom: none; }
.consent-option-info { flex: 1; padding-right: 20px; }
.consent-option-info h4 { margin: 0 0 5px; font-size: 16px; color: var(--navy); font-family:'Poppins',sans-serif; }
.consent-option-info p { margin: 0; font-size: 14px; color: var(--gray); line-height: 1.4; }
.consent-toggle { flex-shrink: 0; }
.consent-toggle input[type="checkbox"] { display: none; }
.consent-toggle label {
  display: block; width: 50px; height: 26px; background: #ccd1da; border-radius: 13px;
  position: relative; cursor: pointer; transition: background .3s ease;
}
.consent-toggle label::after {
  content: ''; position: absolute; top: 3px; left: 3px; width: 20px; height: 20px;
  background: #fff; border-radius: 50%; transition: transform .3s ease;
}
.consent-toggle input[type="checkbox"]:checked + label { background: var(--teal); }
.consent-toggle input[type="checkbox"]:checked + label::after { transform: translateX(24px); }
.consent-toggle input[type="checkbox"]:disabled + label { background: var(--teal); cursor: not-allowed; }
.consent-modal-footer { padding: 20px; border-top: 1px solid var(--card-border); text-align: right; }
.consent-modal-footer .btn-primary { padding: 10px 30px; }
@media (max-width: 768px) {
  .consent-banner { padding: 14px 16px; }
  .consent-content { flex-direction: column; gap: 12px; }
  .consent-text h3 { font-size: 16px; margin-bottom: 4px; }
  .consent-text p { font-size: 13px; }
  .consent-buttons { flex-direction: row; flex-wrap: wrap; justify-content: center; gap: 8px; width: 100%; }
  .consent-buttons .btn-primary,
  .consent-buttons .btn-secondary { flex: 1 1 0; min-width: 0; min-height: 44px; padding: 10px 14px; font-size: 13px; }
  .consent-buttons .btn-link {
    width: 100%;
    min-height: 44px;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-top: 4px;
  }
  .consent-modal-footer .btn-primary { min-height: 44px; }
  .consent-option { flex-direction: column; }
  .consent-toggle { margin-top: 10px; }
}

/* =====================================================================
   BLOG ARTICLE  (legacy markup restyled into the new design system)
   ===================================================================== */
.ftco-section { position: relative; z-index: 2; background: transparent !important; padding: 48px 0 24px; }
.ftco-section .container { max-width: 820px; }
.ftco-section .row { margin: 0 0 4px; display: block; }
.ftco-section .row.justify-content-center { margin-bottom: 8px; }
.ftco-section [class*="col-"] { width: 100%; max-width: 100%; padding: 0; }

.article-breadcrumb { font-size: 13px; color: var(--gray-light); margin: 0 0 18px; text-align: center; }
.article-breadcrumb a { color: var(--teal); font-weight: 600; }
.article-eyebrow {
  display: inline-flex; align-items: center; gap: 8px; margin: 0 auto 14px;
  background: var(--teal-bg); color: var(--teal); font-family: 'Poppins', sans-serif;
  font-weight: 600; font-size: 13px; padding: 8px 16px; border-radius: 30px;
}

.heading-section { text-align: center; margin-bottom: 10px; }
.heading-section h1 { font-size: 40px; line-height: 1.14; max-width: 760px; margin: 0 auto 16px; color: var(--navy); }
.heading-section .home-text-weight { font-size: 18px; color: var(--gray); max-width: 700px; margin: 0 auto; }

.article-hero-img { max-width: 820px; margin: 14px auto 26px; }
.article-hero-img img { width: 100%; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); }

.text-about { font-size: 16px; color: var(--gray); }
.text-about p { margin: 0 0 16px; }
.text-about h2,
.text-about .blog-h2 { font-size: 26px; margin: 40px 0 14px; color: var(--navy); text-align: left !important; font-family: 'Poppins', sans-serif; }
.text-about h3 { font-size: 18px; margin: 24px 0 8px; color: var(--navy); font-family: 'Poppins', sans-serif; }
.text-about a { color: var(--teal); font-weight: 600; }
.text-about a:hover { color: var(--teal-dark); }
.text-about strong { color: var(--navy); }
.text-about ul { margin: 0 0 18px; padding: 0; list-style: none; }
.text-about ul li { position: relative; padding-left: 30px; margin-bottom: 11px; font-size: 16px; }
.text-about ul li::before {
  content: "\f00c"; font-family: "Font Awesome 6 Free"; font-weight: 900;
  position: absolute; left: 0; top: 2px; color: var(--teal); font-size: 13px;
}
.article-next {
  max-width: 820px; margin: 10px auto 0; padding: 22px 26px;
  background: var(--teal-bg); border-radius: var(--radius); text-align: center;
}
.article-next a { color: var(--teal-dark); font-weight: 700; font-family: 'Poppins', sans-serif; }
@media (max-width: 720px) {
  .heading-section h1 { font-size: 30px; }
}

/* =====================================================================
   BOOKING / CONTACT FORM
   ===================================================================== */
.booking-section {
  position: relative; padding: 90px 0 110px;
  background: linear-gradient(180deg, #e7f3f1 0%, #eef7f5 60%, #ffffff 100%);
  overflow: hidden;
}
.booking-section .section-head { margin-bottom: 52px; text-align: center; position: relative; z-index: 2; }
.booking-section .section-head .eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  background: #fff; color: var(--teal); font-family: 'Poppins', sans-serif;
  font-weight: 600; font-size: 13px; padding: 8px 18px; border-radius: 30px;
  margin-bottom: 18px; box-shadow: var(--shadow-sm); border: 1px solid var(--card-border);
}
.booking-section .section-head h1 { font-size: 46px; margin: 0 0 14px; }
.booking-section .section-head p { font-size: 17px; color: var(--gray); max-width: 520px; margin: 0 auto; }

/* decorative blobs behind the form */
.booking-section .blob-yellow { width: 220px; height: 220px; background: var(--yellow); top: -60px; left: -70px; opacity: .35; }
.booking-section .blob-red { width: 160px; height: 160px; background: var(--red); bottom: 40px; right: -50px; opacity: .15; }
.booking-section .dots-deco { width: 90px; height: 90px; top: 60px; right: 60px; opacity: .25; }
.booking-section .ring-deco { width: 70px; height: 70px; border: 4px solid var(--teal); bottom: 80px; left: 80px; opacity: .35; }

.booking-form {
  max-width: 680px; margin: 0 auto;
  background: #fff; border: 1px solid var(--card-border);
  border-radius: var(--radius-lg); padding: 0;
  box-shadow: 0 20px 60px rgba(44, 58, 89, 0.08);
  position: relative; z-index: 2; overflow: hidden;
}
.booking-form::before {
  content: ""; display: block; height: 5px;
  background: linear-gradient(90deg, var(--teal) 0%, var(--teal-dark) 100%);
}
.booking-form .form-inner { padding: 40px 48px 48px; }

.booking-form .form-row {
  display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-bottom: 22px;
}
.booking-form .form-group { display: flex; flex-direction: column; }
.booking-form label {
  font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 13px;
  text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--navy); margin-bottom: 8px;
}
.booking-form input,
.booking-form textarea {
  width: 100%; border: 1.5px solid #e2e5ea; border-radius: 14px;
  padding: 14px 18px; font-family: 'Nunito Sans', sans-serif; font-size: 15px;
  color: var(--navy); background: #fff;
  transition: border-color .2s ease, box-shadow .2s ease;
}
.booking-form input::placeholder,
.booking-form textarea::placeholder { color: var(--gray-light); opacity: .7; }
.booking-form input:focus,
.booking-form textarea:focus {
  outline: none; border-color: var(--teal);
  box-shadow: 0 0 0 4px rgba(41, 169, 158, 0.10);
}
.booking-form textarea { min-height: 140px; resize: vertical; }
.booking-form .field-error {
  font-size: 12px; color: var(--red); margin-top: 6px; min-height: 14px;
}
.booking-form .btn-submit {
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-family: 'Poppins', sans-serif; font-weight: 600; font-size: 15px;
  border-radius: 40px; padding: 15px 44px; cursor: pointer; border: none;
  background: var(--red); color: #fff;
  box-shadow: 0 10px 28px rgba(239, 85, 68, .32);
  transition: all .25s ease;
}
.booking-form .btn-submit:hover { background: var(--red-dark); transform: translateY(-3px); box-shadow: 0 14px 36px rgba(239, 85, 68, .38); }
.booking-form .btn-submit:disabled { opacity: .55; cursor: not-allowed; transform: none; box-shadow: none; }
.booking-form .form-status {
  text-align: center; margin-top: 22px; font-size: 14px; min-height: 20px;
}
.booking-form .form-status.is-success { color: var(--teal); font-weight: 600; }
.booking-form .form-status.is-error { color: var(--red); font-weight: 600; }
.booking-form .hp-field { display: none; }

@media (max-width: 560px) {
  .booking-section { padding: 50px 0 70px; }
  .booking-section .section-head h1 { font-size: 32px; }
  .booking-form .form-inner { padding: 28px 22px 32px; }
  .booking-form .form-row { grid-template-columns: 1fr; gap: 16px; margin-bottom: 16px; }
}
