:root{
  --container: 1180px;
  --nav-height: 68px;
  --accent: #0b4a6f; /* deep blue */
  --accent-2: #ff8a00; /* orange */
  --muted: #f3fbfb;
}
*{box-sizing:border-box}
body{font-family:Inter, system-ui, -apple-system, 'Segoe UI', Roboto, 'Helvetica Neue', Arial; color:#111; margin:0;background:#fff; font-size: 17px; line-height: 1.7}
.container{max-width:var(--container);margin:0 auto;padding:0 20px}
.topbar{background:#eaf7f6;padding:8px 0;font-size:13px;color:#0b4a6f}
.topbar .container{display:flex;justify-content:space-between}
.navbar{background:#fff;box-shadow:0 1px 0 rgba(11,74,111,0.06)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;padding:14px 0}
.brand{font-weight:700;color:var(--accent);display:flex;align-items:center;gap:10px}
.brand-logo{width:48px;height:48px;object-fit:contain;margin-right:12px;vertical-align:middle}
.nav-links {
  display: flex;
  gap: 12px;
  align-items: center;
}
.nav-links a{margin-left:18px;text-decoration:none;color:#274b5e;padding:8px 12px;font-size:15px}
.nav-links .cta{background:var(--accent-2);color:#fff;padding:8px 12px;border-radius:8px}

/* HERO */
.hero{background:linear-gradient(180deg,#08345a 0%, #08345a 100%);color:#fff;padding:48px 0}
.hero-inner{display:flex;gap:28px;align-items:center}
.hero-text{flex:1}
.hero-text h1{font-size:36px;margin:0 0 12px}
.hero-text p{color:rgba(255,255,255,0.85);max-width:620px}
.hero-buttons{margin-top:18px}
.btn{display:inline-block;padding:10px 16px;border-radius:8px;background:#fff;color:#08345a;text-decoration:none;margin-right:10px}
.btn.ghost{background:transparent;border:1px solid rgba(255,255,255,0.15);color:#fff}
.btn.orange{background:var(--accent-2);color:#fff}
.hero-image img{width:520px;max-width:100%;height:auto;border-radius:14px}

/* Responsive improvements */
.hero-inner { align-items: center; }
.hero-image img { width: 520px; max-width: 100%; height: auto; }
@media (max-width: 1000px) {
  .hero-inner{flex-direction:column;align-items:flex-start;gap:18px}
  .hero-image{order:2;width:100%;display:flex;justify-content:center}
  .hero-text{order:1}
  .hero-text h1{font-size:28px}
  .hero-image img { width: 520px; max-width: 80%; }
}
@media (max-width: 700px){
  .services-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .hero-text h1{font-size:22px}
  .hero-image img{width:420px;max-width:90%;height:auto}
  .service-media{height:160px}
  .service-card{padding:18px}
  .container{padding:0 14px}
}
@media (min-width: 700px) and (max-width: 980px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}

/* sections */
.section {
  padding-top: 14px;
  padding-bottom: 14px;
}
.section.pale {
  padding-top: 10px;
  padding-bottom: 10px;
}
p {
  margin-bottom: 5px;
  text-align: justify;
}

/* Global: slightly reduce paragraph text size for the whole site */
p {
  font-size: 0.95rem; /* slightly smaller than base for a more compact layout */
  line-height: 1.6;   /* maintain readable spacing */
}

@media (max-width: 700px) {
  .section, .section.pale {
    padding-top: 5px;
    padding-bottom: 5px;
  }
  p {
    margin-bottom: 5px;
  }
}
.pale{background:#eaf7f6}
h2{font-size:2rem;color:#0b4a6f;margin-bottom:24px;font-weight:800;letter-spacing:0.5px;display:flex;align-items:center;gap:10px;opacity:0;animation:fadeInTitle 1s forwards}
@keyframes fadeInTitle {
  to { opacity: 1; }
}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;gap:18px;grid-template-columns:repeat(3,1fr);align-items:start}
.card{background:#fff;padding:18px;border-radius:10px;box-shadow:0 6px 18px rgba(16,24,40,0.04)}
.card.small{padding:14px}
.image-row img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 0;
}
/* services */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.service-card{background:#fff;padding:28px 18px 18px 18px;border-radius:16px;box-shadow:0 8px 32px rgba(16,24,40,0.10);position:relative;transition:box-shadow 0.3s}
.service-card:hover { box-shadow: 0 12px 36px rgba(11,74,111,0.18); }
.service-card .num{position:absolute;left:12px;top:12px;background:var(--accent-2);color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}
.service-card h4 {
  font-size: 1.05rem;
  margin-top: 10px;
  font-weight: 700;
  color: #0b4a6f;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
  justify-content: center;
  text-align: center;
}
.service-card p {
  font-size: 0.95rem;
  line-height: 1.45;
  color: #1a2633;
  font-weight: 500;
  margin-bottom: 0;
}
.service-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 10px;
  margin-top: 12px;
  position: relative;
  transition: transform 0.4s, box-shadow 0.4s;
  z-index: 1;
}
.service-card:hover img {
  transform: scale(1.06);
  box-shadow: 0 4px 24px #ff8a00a0;
}
.service-card .img-overlay {
  position: absolute;
  left: 0; top: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.22);
  border-radius: 10px;
  z-index: 2;
  pointer-events: none;
}
.service-icon {
  width: 22px;
  height: 22px;
  margin-right: 6px;
  vertical-align: middle;
}
.service-image-caption {
  position: absolute;
  left: 12px;
  top: 12px;
  background: transparent !important;
  color: inherit;
  box-shadow: none;
}
.service-media {
  width:100%;
  height:180px;
  background-size:cover;
  background-position:center;
  border-radius:10px;
  position:relative;
  overflow:hidden;
  margin-top:12px;
}
.service-media .img-overlay { position:absolute; left:0; top:0; right:0; bottom:0; background:linear-gradient(180deg, rgba(0,0,0,0.12) 0%, rgba(0,0,0,0.18) 100%); z-index:1; }
.service-media .service-image-caption { position:absolute; left:12px; top:12px; z-index:3; background:rgba(255,255,255,0.9); padding:6px 10px; border-radius:8px; font-weight:700; color:var(--accent); }
.service-card:hover .service-media { transform: scale(1.03); transition: transform 0.4s; }

/* Services: keep large visuals and responsive grid */
.services-grid { display: grid; gap: 20px; grid-template-columns: repeat(3, 1fr); }
.service-card { display: flex; flex-direction: column; }
.service-media { height: 320px; }
.service-card img { width: 100%; height: 100%; object-fit: cover; border-radius: 10px; }

@media (max-width: 1200px) and (min-width: 901px) {
  .services-grid { grid-template-columns: repeat(3, 1fr); }
  .service-media { height: 320px; }
}
@media (max-width: 900px) and (min-width: 700px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
  .service-media { height: 320px; }
}
@media (max-width: 699px) {
  .services-grid { grid-template-columns: 1fr; }
  .service-media { height: 320px; }
  .service-card { padding: 18px; }
}

/* Our principes — improved responsive grid and card layout (override) */
.grid-3 {
  display: grid;
  gap: 20px;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  align-items: start;
}
.grid-3 .card.small{
  padding: 20px;
  border-radius: 12px;
  transition: transform 260ms cubic-bezier(.22,.9,.37,1), box-shadow 260ms ease;
  display: flex;
  flex-direction: column;
  gap: 10px;
  background: linear-gradient(180deg, rgba(255,255,255,0.98), #fff);
}
.grid-3 .card.small .card-head{display:flex;align-items:center;gap:12px}
.grid-3 .card.small .card-icon{font-size:28px;color:var(--accent-2);flex-shrink:0}
.grid-3 .card.small h4{font-size:1.08rem;margin:0}
.grid-3 .card.small p{font-size:0.98rem;line-height:1.6;color:#324552;margin:0}
.grid-3 .card.small:hover{transform:translateY(-8px);box-shadow:0 22px 48px rgba(11,74,111,0.08)}

@media (max-width:1000px){
  .grid-3{grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));gap:16px}
  .grid-3 .card.small{padding:18px}
}
@media (max-width:700px){
  /* transform principes grid into a horizontal scroll row on small devices */
  .grid-3 {
    display: flex;
    flex-direction: row;
    gap: 12px;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 8px; /* space for scrollbar on some devices */
    scroll-snap-type: x mandatory;
  }
  .grid-3 .card.small {
    flex: 0 0 86%; /* almost full viewport width so one card is prominent */
    min-width: 260px; /* enforce readable card width */
    scroll-snap-align: start;
    margin: 0; /* reset grid margins */
  }
  /* nicer scrollbar on WebKit */
  .grid-3::-webkit-scrollbar { height: 8px; }
  .grid-3::-webkit-scrollbar-thumb { background: rgba(11,74,111,0.12); border-radius: 6px; }
}

/* blog */
.blog-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.post-card{background:#fff;border-radius:12px;overflow:hidden;box-shadow:0 6px 18px rgba(16,24,40,0.04)}
.post-card a{display:flex;text-decoration:none;color:inherit}
.post-image img{width:220px;height:140px;object-fit:cover}
.post-body{padding:12px}
.post-body .meta{font-size:13px;color:#7b8c95}
.excerpt{color:#516871}

/* footer */
.footer {
  background: #0b4a6f;
  color: #fff;
  padding: 28px 0 14px 0;
  border-top: none;
}
.footer-inner {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  align-items: flex-start;
  gap: 14px;
  max-width: 1180px;
  margin: 0 auto;
  padding: 0 20px;
}
.footer h4, .footer h5 {
  color: #fff;
  margin-bottom: 10px;
  font-weight: 700;
}
.footer p, .footer ul, .footer li, .footer a {
  color: #eaf7f6;
  font-size: 1rem;
  margin: 0;
  text-decoration: none;
}
.footer ul {
  list-style: none;
  padding: 0;
  margin: 0;
}
.footer li {
  margin-bottom: 4px;
}
.footer a:hover {
  color: #ff8a00;
  text-decoration: underline;
}
.footer .footer-brand {
  font-size: 1.2rem;
  font-weight: 700;
  margin-bottom: 4px;
}
.footer .footer-contact {
  margin-bottom: 6px;
  line-height: 1.15;
}
.footer .footer-contact span {
  display: block;
  margin-bottom: 4px;
  line-height: 1.15;
}
.footer .footer-copyright {
  width: 100%;
  text-align: center;
  margin-top: 18px;
  color: #b3c6d6;
  font-size: 0.95rem;
}
@media (max-width: 700px) {
  .footer-inner {
    flex-direction: column;
    gap: 5px;
    align-items: flex-start;
  }
  .footer {
    padding: 24px 0 10px 0;
  }
}

/* Footer — tighter spacing */
.footer-inner { gap: 10px; }
.footer { padding: 32px 0 16px 0; }
.footer p, .footer ul, .footer li, .footer a { line-height: 1.25; margin: 0; }
.footer li { margin-bottom: 6px; }

/* Header / Navbar improvements (responsive) */
.brand{display:flex;align-items:center;gap:10px}
.navbar{position:sticky;top:0;z-index:300;background:#fff}
.nav-links a{padding:8px 12px;font-size:15px}

/* Fix broken hero-image rule */
.hero-image img { width: 520px; max-width: 100%; height: auto; }

@media (max-width:900px){
  .nav-inner{padding:10px 0}
  .nav-links{padding:1rem 1rem}
  .dropdown{width:100%}
  .dropdown-btn{width:100%;display:flex;justify-content:space-between;align-items:center;padding:12px 16px}
  .dropdown-menu{position:static;right:auto;top:auto;background:transparent;box-shadow:none;padding:0;margin-top:8px;display:none}
  .dropdown.open .dropdown-menu{display:block}
  .dropdown-menu li a{display:block;background:#fff;color:var(--accent);padding:10px 16px;margin:6px 0;border-radius:8px}
  .brand-logo{width:36px;height:36px}
}
@media (max-width: 1000px) {
  .hero-inner{flex-direction:column;align-items:flex-start;gap:18px}
  .hero-image{order:2;width:100%;display:flex;justify-content:center}
  .hero-text{order:1}
  .hero-text h1{font-size:28px}
  .hero-image img { width: 520px; max-width: 80%; }
}
@media (max-width: 700px){
  .services-grid{grid-template-columns:1fr}
  .blog-grid{grid-template-columns:1fr}
  .grid-2{grid-template-columns:1fr}
  .grid-3{grid-template-columns:1fr}
  .hero-text h1{font-size:22px}
  .hero-image img{width:420px;max-width:90%;height:auto}
  .service-media{height:160px}
  .service-card{padding:18px}
  .container{padding:0 14px}
}
@media (min-width: 700px) and (max-width: 980px){
  .services-grid{grid-template-columns:repeat(2,1fr)}
  .blog-grid{grid-template-columns:repeat(2,1fr)}
}

/* sections */
.section {
  padding-top: 24px;
  padding-bottom: 24px;
}
.section.pale {
  padding-top: 20px;
  padding-bottom: 20px;
}
p {
  margin-bottom: 10px;
  text-align: justify;
}

/* Global: slightly reduce paragraph text size for the whole site */
p {
  font-size: 0.95rem; /* slightly smaller than base for a more compact layout */
  line-height: 1.6;   /* maintain readable spacing */
}

@media (max-width: 700px) {
  .section, .section.pale {
    padding-top: 12px;
    padding-bottom: 12px;
  }
  p {
    margin-bottom: 7px;
  }
}
.pale{background:#eaf7f6}
h2{font-size:2rem;color:#0b4a6f;margin-bottom:24px;font-weight:800;letter-spacing:0.5px;display:flex;align-items:center;gap:10px;opacity:0;animation:fadeInTitle 1s forwards}
@keyframes fadeInTitle {
  to { opacity: 1; }
}
.grid-2{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}
.grid-3{display:grid;gap:18px;grid-template-columns:repeat(3,1fr);align-items:start}
.card{background:#fff;padding:18px;border-radius:10px;box-shadow:0 6px 18px rgba(16,24,40,0.04)}
.card.small{padding:14px}
.image-row img {
  width: 100%;
  height: 220px;
  object-fit: cover;
  border-radius: 12px;
  margin-bottom: 0;
}
/* services */
.services-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}
.service-card{background:#fff;padding:28px 18px 18px 18px;border-radius:16px;box-shadow:0 8px 32px rgba(16,24,40,0.10);position:relative;transition:box-shadow 0.3s}
.service-card:hover { box-shadow: 0 12px 36px rgba(11,74,111,0.18); }
.service-card .num{position:absolute;left:12px;top:12px;background:var(--accent-2);color:#fff;width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700}
.service-card h4 {
  font-size: 1.05rem;
  margin-top: 10px;
  font-weight: 700;
  color: #0b4a6f;
  margin-bottom: 4px;
  display: flex;
  align-items: center;
  gap: 4px;
  justify-content: center;
  text-align: center;
}
.service-card p {
  font-size: 0.95rem;
  line-height: 1.45;
  color: #1a2633;
  font-weight: 500;
  margin-bottom: 0;
}
.service-card img {
  width: 100%;
  height: 180px;
  object-fit: cover;
  border-radius: 10px;
  margin-top: 12px;
  position: relative;
  transition: transform 0.4s, box-shadow 0.4s;
  z-index: 1;
}
.service-card:hover img {
  transform: scale(1.06);
  box-shadow: 0 4px 24px #ff8a00a0;
}
.service-card .img-overlay {
  position: absolute;
  left: 0; top: 0; right: 0; bottom: 0;
  background: rgba(0,0,0,0.22);
  border-radius: 10px;
  z-index: 2;
  pointer-events: none;
}
.service-icon {
  width: 22px;
  height: 22px;
  margin-right: 6px;
  vertical-align: middle;
}
.service-image-caption {
  position: absolute;
  left: 12px;
  top: 12px;
  background: transparent !important;
  color: inherit;
  box-shadow: none;
}
.service-media {
  width:100%;
  height:180px;
  background-size:cover;
  background-position:center;
  border-radius:10px;
  position:relative;
  overflow:hidden;
  margin-top:12px;
}
.service-media .img-overlay { position:absolute; left:0; top:0; right:0; bottom:0; background:linear-gradient(180deg, rgba(0,0,0,0.12) 0%, rgba(0,0,0,0.18) 100%); z-index:1; }
.service-media .service-image-caption { position:absolute; left:12px; top:12px; z-index:3; background:rgba(255,255,255,0.9); padding:6px 10px; border-radius:8px; font-weight:700; color:var(--accent); }
.service-card:hover .service-media { transform: scale(1.03); transition: transform 0.4s; }

/* Our Values responsive: grid on desktop, horizontal scroll on small screens */
.values-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  align-items: start;
}
.value-card {
  width: 100%;
  box-sizing: border-box;
  flex: 0 0 auto;
}

@media (max-width: 1000px) {
  .values-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 720px) {
  /* switch to horizontal scroll row on small screens */
  .values-grid {
    display: flex;
    flex-direction: row;
    gap: 12px;
    overflow-x: auto;
    padding-bottom: 6px; /* allow space for scrollbar */
    -webkit-overflow-scrolling: touch;
  }
  .values-grid::-webkit-scrollbar { height: 8px; }
  .values-grid::-webkit-scrollbar-thumb { background: rgba(0,0,0,0.12); border-radius: 8px; }

  .value-card {
    min-width: 240px;
    max-width: 320px;
    width: 80%;
    flex: 0 0 auto;
    margin: 0;
  }
}

/* Small-screen layout: stack main content and sidebar vertically */
@media (max-width: 900px) {
  /* common two-column containers */
  .grid-2, .layout-sidebar, .container.two-column {
    display: flex !important;
    flex-direction: column;
    gap: 18px;
  }
  .main-content, .content, .article, .post-list {
    order: 1;
    width: 100%;
  }
  .sidebar, .aside, .widget-area {
    order: 2;
    width: 100%;
  }
}

/* Our Values: ensure vertical stacking on small screens and disable horizontal scroll */
@media (max-width: 720px) {
  .values-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 16px !important;
    overflow-x: visible !important;
    padding-bottom: 0 !important;
  }
  .value-card {
    min-width: auto !important;
    max-width: none !important;
    width: 100% !important;
    flex: none !important;
  }
}

/* Hero dropdown: centered modal on small screens + overlay */
.hero-dropdown-overlay{position:fixed;left:0;top:0;right:0;bottom:0;background:rgba(0,0,0,0.45);z-index:54}
.hero-quote .hero-dropdown-menu.centered{
  position:fixed;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  width:min(92%,480px);
  max-height:80vh;
  overflow:auto;
  padding:8px 0;
  box-shadow:0 30px 80px rgba(4,12,30,0.45);
  border-radius:12px;
  z-index: 60;
}
.hero-quote .hero-dropdown-menu.centered li a{padding:12px 18px}
/* ensure original absolute dropdown still works on large screens */
@media (min-width:900px){
  .hero-quote .hero-dropdown-menu.centered{position:absolute;transform:none;left:auto;top:auto;width:auto;max-height:none}
}

/* Navbar hamburger button */
.nav-toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  width: 32px;
  height: 32px;
  background: none;
  border: none;
  cursor: pointer;
  margin-left: auto;
  margin-right: 12px; /* add space to the right */
  color: black;
}
.nav-toggle .bar {
  height: 4px;
  width: 100%;
  background: #000; /* black color for hamburger bars */
  margin: 5px 0;
  border-radius: 2px;
  transition: 0.3s;
}
.nav-toggle.active svg {
  animation: rotateBurger 0.4s;
}
@keyframes rotateBurger {
  0% { transform: rotate(0deg); }
  60% { transform: rotate(30deg); }
  100% { transform: rotate(0deg); }
}

/* Responsive navbar */
@media (max-width: 900px) {
  .nav-inner {
    flex-direction: row;
    align-items: center;
  }
  .nav-links {
    position: absolute;
    top: 60px;
    left: 0;
    right: 0;
    background: #fff;
    flex-direction: column;
    align-items: flex-start;
    padding: 1rem 2rem;
    display: none;
    box-shadow: 0 2px 8px rgba(0,0,0,0.05);
    z-index: 100;
    opacity: 0;
    transform: translateY(-20px);
    transition: opacity 0.3s, transform 0.3s;
  }
  .nav-links.open {
    display: flex;
    opacity: 1;
    transform: translateY(0);
  }
  .nav-toggle {
    display: flex;
  }
  .navbar .brand {
    font-size: 1.2rem;
  }
  .nav-links a {
    margin: 12px 0;
    margin-left: 0;
  }
}

/* Dropdown: show when parent has .open */
.dropdown.open .dropdown-menu {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

/* Quote dropdown in the nav */
.dropdown { position:relative; }
.dropdown-btn { background:var(--accent-2); color:#fff; border:none; padding:8px 12px; border-radius:8px; cursor:pointer; }
.dropdown-menu { display:none; position:absolute; right:0; top:calc(100% + 8px); background:#fff; list-style:none; padding:8px 0; margin:0; border-radius:8px; box-shadow:0 8px 24px rgba(16,24,40,0.12); min-width:180px; z-index:40; }
.dropdown-menu li { padding:0; }
.dropdown-menu li a { display:block; padding:10px 16px; color:#0b4a6f; text-decoration:none; }
.dropdown-menu li a:hover { background:rgba(11,74,111,0.06); }

/* Hero dropdown menu styling (mirrors header dropdown) */
.hero-quote{position:relative;display:inline-block}
.hero-quote .hero-dropdown-menu{display:none;position:absolute;right:0;top:calc(100% + 8px);background:#fff;list-style:none;padding:8px 0;margin:0;border-radius:8px;box-shadow:0 8px 24px rgba(16,24,40,0.12);min-width:220px;z-index:60}
.hero-quote .hero-dropdown-menu li a{display:block;padding:10px 14px;color:#0b4a6f;text-decoration:none}
.hero-quote .hero-dropdown-menu li a:hover{background:rgba(11,74,111,0.06)}
.hero-quote.open .hero-dropdown-menu{display:block}

/* Who We Are section */
.who-we-are .who-inner { padding: 28px 16px; }
.who-we-are .who-top h2 { font-size: 2rem; }
.who-we-are .who-grid { gap: 24px; }
.who-we-are .who-list { font-size: 1rem; line-height: 1.6; }
.who-we-are .dark-box { box-shadow: 0 6px 18px rgba(15,23,36,0.12); }
@media (max-width: 860px) {
  .who-we-are .who-grid { flex-direction: column-reverse; }
  .who-we-are .who-photos { display:flex; gap:12px; }
  .who-we-are .who-top h2 { font-size:1.6rem; }
  .who-we-are .who-inner { padding:18px 12px; }
}

/* Wellbeing / Therapy styles */
.stats-banner { border-radius:12px; }
.stats-banner .stat { padding:12px; }
.stats-banner .stat-icon { font-size:24px; }
.therapy-services { margin-top:8px; }
.therapy-grid .therapy-card { display:flex; flex-direction:column; justify-content:space-between; }
.therapy-card:hover { transform: translateY(-6px); box-shadow:0 18px 40px rgba(16,24,40,0.12); border-color: #d4af37; }
.therapy-card a.therapy-read { transition: color 0.18s, transform 0.18s; }
.therapy-card a.therapy-read:hover { transform: translateX(6px); color:#b98f2a; }
@media (max-width: 980px){
  .therapy-grid { grid-template-columns:repeat(2,1fr); }
}
@media (max-width: 600px){
  .stats-banner{flex-direction:column;}
  .therapy-grid { grid-template-columns:1fr; }
  .service-card { grid-template-columns:1fr; }
}

/* About scroll */
.about-scroll {
  max-height: 260px;
  overflow-y: auto;
  padding-right: 8px;
  transition: box-shadow 0.25s ease;
  animation: fadeInUp 0.6s ease both;
}
.about-scroll:focus { outline: 2px solid rgba(11,74,111,0.12); }
@media (max-width: 900px) {
  .about-scroll { max-height: 220px; }
}
@media (max-width: 600px) {
  .about-scroll { max-height: 180px; }
}
@keyframes fadeInUp {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Override: remove orange border/frame from About section */
.orange-frame {
  border: none !important;
  background: transparent !important;
  box-shadow: none !important;
}

/* Features section */
.features-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
.feature-card{border:2px solid #ff8a00;padding:14px;border-radius:10px;background:linear-gradient(180deg, rgba(255,138,0,0.03), rgba(255,138,0,0.01));box-shadow:0 8px 20px rgba(11,74,111,0.04)}
.feature-card h4{margin:0 0 8px;color:var(--accent);display: flex; align-items: center; justify-content: center; gap: 8px; text-align: center;}
.feature-card p{margin:0;color:#475569}

/* Center h4 and icon in service and feature cards */
.service-card h4, .feature-card h4 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
}

/* About & Services responsive adjustments */
.about-row { display: flex; gap: 32px; align-items: center; }
.about-row > div { flex: 1; min-width: 0; }

/* Preserve large visuals on narrow screens while stacking content */
@media (max-width: 900px) {
  .about-row { flex-direction: column; align-items: stretch; gap: 18px; }
  .about-row iframe { width: 100%; max-width: 100%; height: 340px; border-radius: 12px; }
  .about-row .card { width: 100%; }
  .orange-frame { padding: 12px; }
}

/* Services grid breakpoints: keep images tall so they don't appear reduced */
@media (min-width: 1100px) {
  .services-grid { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 1099px) and (min-width: 700px) {
  .services-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 699px) {
  .services-grid { grid-template-columns: 1fr; }
  .service-card { padding: 20px; }
  /* keep service visuals large on mobile */
  .service-media { height: 260px; }
  .service-card img { height: 260px; object-fit: cover; }
}

/* Ensure background images keep cover behavior */
.service-media, .service-card img { background-size: cover; background-position: center; }

/* Allaccesstrip & Our Principes responsive tweaks
   - features grid: 3 / 2 / 1 columns
   - reduce only paragraph font-size on smaller screens (no image size changes)
*/
.allaccesstrip .features-grid { grid-template-columns: repeat(3, 1fr); }
@media (max-width: 1100px) {
  .allaccesstrip .features-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .allaccesstrip .features-grid { grid-template-columns: 1fr; }
  /* only scale down paragraph text for these sections */
  .allaccesstrip p, .section.pale p { font-size: 15px; line-height: 1.55; }
}
@media (max-width: 480px) {
  .allaccesstrip p, .section.pale p { font-size: 13px; line-height: 1.5; }
}

/* Allaccesstrip CTA button: orange background + hover glow */
.allaccesstrip .btn {
  background: var(--accent-2);
  color: #fff;
  padding: 10px 18px;
  border-radius: 10px;
  box-shadow: 0 6px 18px rgba(255,138,0,0.18);
  transition: box-shadow 0.25s ease, transform 0.12s ease;
  display: inline-block;
}
.allaccesstrip .btn:hover,
.allaccesstrip .btn:focus {
  box-shadow: 0 10px 30px rgba(255,138,0,0.32), 0 0 18px rgba(255,138,0,0.16);
  transform: translateY(-3px);
  outline: none;
}
.allaccesstrip .btn:active { transform: translateY(-1px); }

/* Allaccesstrip background video */
.allaccesstrip{position:relative;overflow:hidden;padding:48px 0}
.allaccesstrip-video{position:absolute;left:50%;top:50%;transform:translate(-50%, -50%);min-width:100%;min-height:100%;width:auto;height:auto;z-index:0;object-fit:cover;filter:brightness(0.7);}
.allaccesstrip .video-overlay{position:absolute;left:0;top:0;right:0;bottom:0;background:linear-gradient(180deg, rgba(11,74,111,0.22) 0%, rgba(255,138,0,0.06) 100%);z-index:1}
.allaccesstrip .container{position:relative;z-index:2}
@media (max-width:700px){
  .allaccesstrip{padding:28px 0}
  .allaccesstrip-video{min-height:140%;}
}

/* Topbar marquee / banner ad scroll */
.topbar { overflow: hidden; }
.topbar-marquee { position: relative; height: 40px; display: flex; align-items: center; overflow: hidden; }
.marquee-track { display: flex; align-items: center; width: 200%; /* will contain two copies */ animation: marqueeAnim 20s linear infinite; }
.marquee-content { display: inline-flex; align-items: center; gap: 48px; white-space: nowrap; padding: 0 6px; font-weight:600 }
.topbar-marquee:hover .marquee-track { animation-play-state: paused; }
@keyframes marqueeAnim { from { transform: translateX(0); } to { transform: translateX(-50%); } }
/* smaller screens: slower and smaller height */
@media (max-width: 700px){
  .topbar-marquee { height: 36px; }
  .marquee-track { animation-duration: 28s; }
  .marquee-content { gap: 22px; font-size: 13px }
}

/* AOS: only apply hide/transition when AOS has initialized elements (prevents content being invisible if AOS fails to load) */
.aos-init {
  opacity: 0;
  transform: translateY(8px);
  transition: opacity 420ms ease, transform 520ms cubic-bezier(.22,.9,.37,1);
}
.aos-animate {
  opacity: 1;
  transform: translateY(0);
}
@media (max-width:700px){
  .aos-init { transition-duration: 360ms; transform: translateY(6px); }
}
@media (prefers-reduced-motion: reduce) {
  .aos-init, .aos-animate { transition: none !important; transform: none !important; opacity: 1 !important; }
}

/* Contact form responsiveness */
.contact-form { display: flex; flex-direction: column; gap: 14px; width: 100%; box-sizing: border-box; }
.contact-form > div { display: flex; gap: 12px; width: 100%; }
.contact-form input[type="text"], .contact-form input[type="email"], .contact-form textarea, .contact-form button {
  box-sizing: border-box;
  width: 100%;
}
.contact-form textarea { min-height: 120px; resize: vertical; }
.contact-form button { max-width: 320px; }

@media (max-width: 700px){
  .contact-form > div { flex-direction: column; }
  .contact-form button { width: 100%; max-width: none; }
}

/* FAQ styles: framed cards, reduced paragraph size and gentle open animation */
.faq-list details {
  border: 1px solid rgba(11,74,111,0.08);
  border-radius: 10px;
  padding: 12px 14px;
  margin-bottom: 12px;
  background: #fff;
  box-shadow: 0 6px 18px rgba(16,24,40,0.03);
}
.faq-list summary {
  cursor: pointer;
  list-style: none;
  font-weight: 700;
  font-size: 1.02rem;
  padding: 6px 0;
}
/* hide default marker for WebKit */
.faq-list summary::-webkit-details-marker { display: none; }

.faq-list .faq-body {
  margin-top: 8px;
  color: #324552;
  font-size: 15px; /* reduced size */
  line-height: 1.6;
  max-height: 0;
  overflow: hidden;
  opacity: 0;
  transform: translateY(-6px);
  transition: max-height 320ms ease, opacity 260ms ease, transform 260ms ease;
}
.faq-list details[open] .faq-body {
  max-height: 800px; /* large enough for content */
  opacity: 1;
  transform: translateY(0);
}

.faq-list .faq-body p { font-size: 14px; margin: 6px 0; }
.faq-list .faq-body ul, .faq-list .faq-body ol { margin: 6px 0 12px 20px; }

@media (max-width: 700px) {
  .faq-list .faq-body { font-size: 14px; }
  .faq-list .faq-body p { font-size: 13px; }
  .faq-list details { padding: 10px; }
  .faq-list summary { font-size: 1rem; }
}

/* FAQ: reduce strong size in summaries for better visual balance */
.faq-list summary strong { font-size: 0.98rem; font-weight:700; line-height:1.15; }

/* FAQ summary icons: orange dot + toggle sign */
.faq-list summary { position: relative; padding-left: 36px; padding-right: 28px; }
.faq-list summary::before {
  content: '';
  position: absolute;
  left: 8px;
  top: 50%;
  transform: translateY(-50%);
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background: var(--accent-2);
  box-shadow: 0 2px 6px rgba(255,138,0,0.18);
}
.faq-list summary::after {
  content: '+';
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  font-weight: 700;
  color: var(--accent);
  background: rgba(11,74,111,0.03);
  width: 22px;
  height: 22px;
  line-height: 22px;
  text-align: center;
  border-radius: 6px;
}
.faq-list details[open] > summary::after {
  content: '\2212'; /* minus sign */
}
/* Slightly dim the dot when open to indicate active state */
.faq-list details[open] > summary::before { box-shadow: 0 1px 3px rgba(0,0,0,0.08); opacity: 0.95; }

/* Partners section */
.partners-section { background: transparent; padding-top: 24px; padding-bottom: 24px; }
.partners-section .muted { color: #6b7c86; margin-bottom: 14px; }
.partners-grid { display: flex; gap: 24px; align-items: center; overflow: hidden; white-space: nowrap; -webkit-overflow-scrolling: touch; }
.partner-item { display:flex; align-items:center; justify-content:center; padding: 16px; }
.partner-logo { max-width: 220px; width: 100%; height: auto; object-fit: contain; display:block; }
/* hide native scrollbar */
.partners-grid::-webkit-scrollbar { display: none; }
.partners-grid { -ms-overflow-style: none; scrollbar-width: none; }

@media (max-width: 1000px){
  .partners-grid{grid-template-columns:repeat(3,1fr)}
  .partner-logo{max-width:120px}
}
@media (max-width: 700px){
  /* horizontal scroll row on mobile */
  .partners-grid{display:flex;flex-direction:row;gap:12px;overflow-x:auto;padding-bottom:6px;-webkit-overflow-scrolling:touch;scroll-snap-type:x mandatory}
  .partner-item{flex:0 0 70%;min-width:180px;scroll-snap-align:start}
  .partner-logo{max-width:160px}
}

/* Careers section */
.careers-section { padding-top: 24px; padding-bottom: 24px; }
.job-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; margin-top: 18px; }
.job-card { background: #fff; border-radius: 12px; padding: 18px; box-shadow: 0 10px 30px rgba(11,74,111,0.06); }
.job-card h4 { margin: 0 0 8px; color: var(--accent); }
.job-card p { margin: 6px 0; color: #31474f; }
.job-meta { color: #6b7c86; font-size:0.95rem; }
.careers-note { margin-top: 14px; color: #546b73; }
@media (max-width: 900px){ .job-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px){ .job-grid { grid-template-columns: 1fr; } }

/* Job card preview: limit to ~5 lines */
.job-card .job-excerpt {
  max-height: 8.4em; /* roughly 5 lines at 1.6em line-height */
  overflow: hidden;
  transition: max-height 280ms ease;
  line-height: 1.6em;
}
.job-card.expanded .job-excerpt {
  max-height: 2000px;
}
.job-card .btn { margin-right: 8px; }

/* Ensure mobile full-width */
@media (max-width: 720px) {
  .job-card { width: 100%; }
}

/* Careers preview collapse */
.careers-preview {
  position: relative;
}
.careers-preview .jobs-grid {
  max-height: 14.5em;
  /*approx7linesoftextdependingonfont-size*/overflow: hidden;
  transition: max-height 300ms ease;
  -webkit-transition: max-height 300ms ease;
  -moz-transition: max-height 300ms ease;
  -ms-transition: max-height 300ms ease;
  -o-transition: max-height 300ms ease;
}
.careers-preview.expanded .jobs-grid {
  max-height: 2000px; /* allow full expansion */
}

.careers-actions .btn {
  padding: 10px 16px;
}

/* Ensure careers section responsive */
@media (max-width: 900px) {
  .careers-preview .jobs-grid { grid-template-columns: 1fr; }
}

/* Terms & Conditions modal */
.tc-modal { position: fixed; inset: 0; display:flex; align-items:center; justify-content:center; z-index:9999; }
.tc-hidden { display: none; }
.tc-modal-overlay { position: absolute; inset: 0; background: rgba(4,8,12,0.6); }
.tc-modal-content { position: relative; background: #fff; width: 92%; max-width: 980px; max-height: 86vh; overflow:auto; border-radius: 12px; box-shadow: 0 30px 80px rgba(2,6,23,0.6); padding: 18px 20px; z-index: 5; }
.tc-modal-header { border-bottom: 1px solid #eef3f6; padding-bottom: 8px; margin-bottom: 8px; }
.tc-modal-body { color: #24343a; line-height:1.55; }
.tc-modal-body h4 { margin-top: 12px; color: var(--accent); }
.tc-modal-footer { border-top:1px solid #eef3f6; padding-top: 12px; margin-top: 12px; text-align:right; }
.tc-actions .btn { margin-left:8px; }
@media (max-width:700px){ .tc-modal-content { padding:12px; width:96%; } }

/* Our Values appearance improvements */
.our-values { padding: 28px 0; background: linear-gradient(180deg, #fbfdfe 0%, #ffffff 100%); }
.our-values .container { max-width:1100px; }
.our-values h2 { color: #0b4a6f; margin-bottom:10px; }
.our-values-lead { color:#334d52; max-width:900px; margin-bottom:18px; }
/* values-grid originally used fixed columns */
.values-grid { display:grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap:18px; }
.value-card { background: #fff; border-radius: 14px; padding: 18px; box-shadow: 0 12px 30px rgba(11,74,111,0.06); display:flex; flex-direction:column; align-items:center; text-align:center; transition: transform .18s ease, box-shadow .18s ease; }
.value-card:hover { transform: translateY(-6px); box-shadow: 0 22px 50px rgba(11,74,111,0.10); }
.value-icon { width:64px; height:64px; border-radius:50%; display:flex; align-items:center; justify-content:center; margin-bottom:12px; background: linear-gradient(135deg, #ff8a00 0%, #0b4a6f 100%); color: #fff; }
.value-icon .value-svg { width:34px; height:34px; }
.value-card h5 { margin:6px 0 8px; color:#0b4a6f; font-size:1.05rem; }
.value-card p { color:#51686e; font-size:0.95rem; line-height:1.45; }

/* Entrance animation for value cards with stagger */
.value-card { opacity: 0; transform: translateY(18px) scale(0.995); animation: valueIn 560ms cubic-bezier(.2,.9,.2,1) forwards; }
.values-grid .value-card:nth-child(1){ animation-delay: 0.06s; }
.values-grid .value-card:nth-child(2){ animation-delay: 0.12s; }
.values-grid .value-card:nth-child(3){ animation-delay: 0.18s; }
.values-grid .value-card:nth-child(4){ animation-delay: 0.24s; }
.values-grid .value-card:nth-child(5){ animation-delay: 0.30s; }

@keyframes valueIn {
  from { opacity: 0; transform: translateY(18px) scale(0.995); }
  to { opacity: 1; transform: translateY(0) scale(1); }
}

/* Respect user preference for reduced motion */
@media (prefers-reduced-motion: reduce){
  .value-card { animation: none !important; transform: none !important; opacity: 1 !important; }
}

/* Our Values: horizontal scroll row */
.values-grid { display: flex; gap: 18px; overflow-x: auto; -webkit-overflow-scrolling: touch; scroll-snap-type: x mandatory; padding-bottom:6px; }
.values-grid::-webkit-scrollbar { height: 8px; }
.values-grid::-webkit-scrollbar-thumb { background: rgba(11,74,111,0.12); border-radius: 6px; }
.value-card { flex: 0 0 280px; scroll-snap-align: start; min-width: 220px; max-width: 320px; }
@media (max-width:900px){ .value-card { flex: 0 0 78%; max-width: none; } }
/* add subtle indicator when scrollable */
.our-values { position: relative; }
.our-values::after { content: ''; position: absolute; right: 0; top: 0; bottom: 0; width: 72px; pointer-events:none; background: linear-gradient(90deg, rgba(255,255,255,0) 0%, rgba(255,255,255,1) 85%); }
.our-values.scrolling-paused::after { opacity:0.0; }
/* ensure reduced-motion users won't get auto-scroll */
@media (prefers-reduced-motion: reduce){
  .values-grid { scroll-behavior: auto; }
}

/* Responsive images and background media */
img { max-width: 100%; height: auto; display: block; }

/* Hero image: keep preferred width on desktop, scale down on small screens */
.hero-image img { width: 520px; max-width: 100%; height: auto; }

/* Careers grid responsive layout - updated for no-sidebar */
.careers-grid {
  display: block; /* simple flow since no sidebar */
}
.careers-content {
  width: 100%;
}

/* Jobs grid: show two cards side-by-side on wide screens, stacked on small screens */
.jobs-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 18px;
}

.jobs-grid .job-card { margin-top: 0; }

@media (max-width: 880px) {
  .jobs-grid {
    grid-template-columns: 1fr;
  }
}

/* Careers buttons: orange background + white text */
#careers .job-card .btn,
#careers .careers-content .btn {
  background: #ff8a00;
  color: #ffffff;
  border: none;
  padding: 10px 16px;
  border-radius: 8px;
  text-decoration: none;
  display: inline-block;
  font-weight: 700;
}
#careers .job-card .btn:hover,
#careers .careers-content .btn:hover {
  background: #e67a00;
  color: #fff;
}

/* job-more hidden content */
.job-more {
  max-height: 0;
  overflow: hidden;
  transition: max-height 0.4s ease, padding 0.3s ease;
  padding: 0 0;
}
.job-card.expanded .job-more {
  max-height: 1000px; /* large enough to show content */
  padding: 12px 0 0 0;
}

.job-readmore { cursor: pointer; }

/* Careers jobs grid: 3 columns, equal height cards */
.jobs-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  align-items: stretch; /* ensure grid items stretch vertically */
}
.job-card {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 360px; /* baseline height to help match sizes */
  padding: 16px;
  box-sizing: border-box;
}
.job-card .job-excerpt {
  /* excerpt stays at top */
  margin-bottom: 12px;
}
.job-card .job-more {
  /* allow expansion area to take remaining space when visible */
  flex: 1 1 auto;
  overflow: auto;
}
.job-card .job-more[hidden] {
  display: none;
}

/* Buttons row pinned to bottom for consistent alignment */
.job-card > div[style*="display:flex"] {
  margin-top: 12px;
}

/* Responsive: 2 columns on medium screens, 1 column on narrow screens */
@media (max-width: 900px) {
  .jobs-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}
@media (max-width: 600px) {
  .jobs-grid {
    grid-template-columns: 1fr;
  }
}

/* Compact careers cards: reduce height and padding for denser layout */
.jobs-grid .job-card {
  min-height: 240px; /* reduced from 360px */
  padding: 12px;     /* slightly reduced padding */
}

/* Make the excerpt area a bit tighter */
.job-card .job-excerpt p {
  margin-bottom: 8px;
  line-height: 1.3;
}

/* Ensure buttons row remains visible without large gap */
.job-card > div[style*="display:flex"] {
  margin-top: 8px;
}

/* Optional utility to make individual cards even more compact */
.job-card.compact {
  min-height: 180px;
  padding: 10px;
}

@media (max-width: 900px) {
  .jobs-grid .job-card { min-height: 220px; }
}
@media (max-width: 600px) {
  .jobs-grid .job-card { min-height: auto; }
}

/* 4-line clamp utility for previews */
.line-clamp-4 {
  display: -webkit-box;
  -webkit-line-clamp: 4;
  -webkit-box-orient: vertical;
  overflow: hidden;
  /* modern browsers */
  line-clamp: 4;
}

/* ===========================
   Modals
=========================== */
.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: #fff; /* Fond blanc pour que le contenu soit visible */
  color: #333; /* Texte sombre */
  padding: 30px;
  border-radius: 10px;
  box-shadow: 0 8px 20px rgba(0,0,0,0.3);
  z-index: 9999; /* Toujours au-dessus */
  max-width: 500px;
  width: 90%;
  display: none; /* par défaut */
}

/* Bouton de fermeture ou action */
.modal button {
  background: #0f7abf; /* Couleur primaire visible */
  color: #fff;
  border: none;
  border-radius: 6px;
  padding: 10px 18px;
  cursor: pointer;
  transition: all 0.3s ease;
  display: inline-block;
  margin-top: 20px;
  z-index: 10000;
}

.modal button:hover {
  background: #e67e22;
  box-shadow: 0 4px 12px rgba(230,126,34,0.25);
}

/* Afficher le modal actif */
.modal.active {
  display: block;
  opacity: 1;
  transform: translate(-50%, -50%);
  transition: all 0.3s ease;
}

/* Responsive */
@media (max-width: 768px) {
  .modal {
    padding: 20px;
  }
  .modal button {
    width: 100%;
    margin-top: 15px;
  }
}
