@font-face {
  font-family: 'Baloo 2';
  src: url('baloo2.ttf') format('truetype');
  font-weight: 400 900;
  font-display: swap;
}

:root {
  --blue:       #5BB8FF;
  --blue-light: #D6EEFF;
  --blue-dark:  #2E8ED6;
  --logo-red:   #FF1A33;
  --logo-yellow:#FFCC00;
  --red:        #FF6B7A;
  --red-light:  #FFE0E3;
  --red-dark:   #E84A5A;
  --green:      #5DD87A;
  --green-light:#D8F5DF;
  --green-dark: #35B855;
  --yellow:     #FFD95A;
  --yellow-light:#FFF5CC;
  --yellow-dark: #E6BC2A;
  --white:      #FFFFFF;
  --bg:         #FAFCFF;
  --text:       #3A3A5C;
  --muted:      #5A5A7A;
  --shadow:     0 4px 15px rgba(0,0,0,0.04);
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: linear-gradient(135deg, #f1f5f9 0%, #e2e8f0 100%);
  color: var(--text);
  font-family: 'Baloo 2', sans-serif;
  overflow-x: hidden;
  width: 100%;
  -webkit-text-size-adjust: 100%;
}

.bg-blob-1,
.bg-blob-2,
.bg-blob-3 {
  position: fixed;
  border-radius: 50%;
  z-index: -1;
  pointer-events: none;
  filter: blur(60px);
}
.bg-blob-1 {
  top: -10%; right: -5%;
  width: 420px; height: 420px;
  background: radial-gradient(circle, rgba(59,130,246,0.35) 0%, transparent 70%);
}
.bg-blob-2 {
  bottom: -20%;
  left: -10%; width: 520px; height: 520px;
  background: radial-gradient(circle, rgba(236,72,153,0.25) 0%, transparent 70%);
}
.bg-blob-3 {
  top: 40%; left: 40%; width: 340px; height: 340px;
  background: radial-gradient(circle, rgba(234,179,8,0.25) 0%, transparent 70%);
}

img { max-width: 100%; height: auto; }

@keyframes pulseLogo { 0%,100%{transform:scale(1)} 50%{transform:scale(1.05)} }
@keyframes logoGlow {
  0%,100% { filter: drop-shadow(0 0 8px rgba(91,184,255,0.6)); }
  50%      { filter: drop-shadow(0 0 8px rgba(255,204,0,0.6)); }
}

.babysitter-box,
.gm-review-card,
.enroll-visual,
.activity-card,
.stat-item,
.gallery-cell,
.modal-box {
  background: rgba(255,255,255,0.55);
  border: 1px solid rgba(255,255,255,0.8);
  box-shadow: 0 8px 32px 0 rgba(31,38,135,0.05);
}
.modal-box {
  backdrop-filter: blur(16px);
  -webkit-backdrop-filter: blur(16px);
}

.brand-logo-container { display:flex; align-items:center; justify-content:center; gap:8px; direction:ltr; flex-wrap:nowrap; white-space:nowrap; }
.brand-logo-container .cl-ar { font-family:'Baloo 2',cursive; font-weight:800; word-spacing:2px; direction:rtl; flex-shrink:0; }
.brand-logo-container .cl-en { font-family:'Baloo 2',sans-serif; font-weight:900; letter-spacing:0.5px; flex-shrink:0; }

.brand-logo-img {
  object-fit:contain;
  animation: pulseLogo 3s infinite, logoGlow 4s infinite linear;
  flex-shrink:0;
  will-change: transform;
}
.cl-red    { color: var(--logo-red); }
.cl-yellow { color: var(--logo-yellow); }

.cursor-emoji { position:fixed; top:0; left:0; pointer-events:none; z-index:9999; font-size:24px; transform:translate(-50%,-50%); display:none; user-select:none; }
@media (hover: hover) and (pointer: fine) {
  .cursor-emoji { display:block; }
}

.touch-emoji { position:fixed; font-size:30px; pointer-events:none; z-index:9999; transform:translate(-50%,-50%) scale(0.5); opacity:1; animation:touchFade 0.6s ease-out forwards; }
@keyframes touchFade { 0%{transform:translate(-50%,-50%) scale(0.5) translateY(0);opacity:1} 100%{transform:translate(-50%,-50%) scale(1.5) translateY(-30px);opacity:0} }

.floating-shapes { position:fixed; inset:0; pointer-events:none; z-index:0; overflow:hidden; }

/* NAV */
nav.main-nav {
  position:fixed; top:0; left:0; right:0; z-index:200;
  display:flex; justify-content:space-between; align-items:center;
  padding:10px 48px;
  background: rgba(15,23,42,0.3);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid rgba(255,255,255,0.15);
  box-shadow: 0 4px 30px rgba(0,0,0,0.1);
}
.nav-logo-wrap { text-decoration:none; display:flex; flex-direction:column; align-items:center; padding:6px 24px; }
.header-tagline { color:var(--yellow-dark); font-family:'Baloo 2',sans-serif; font-weight:800; font-size:clamp(16px,2vw,20px); letter-spacing:0.5px; }

.floating-maps-btn {
  position:fixed; bottom:25px; left:25px; width:65px; height:65px;
  background:rgba(255,255,255,0.35);
  border:1px solid rgba(255,255,255,0.5);
  border-radius:50%; display:flex; justify-content:center; align-items:center;
  z-index:1000; box-shadow:0 8px 20px rgba(0,0,0,0.15);
  cursor:pointer; transition:transform 0.2s, box-shadow 0.2s;
}
.floating-maps-btn:hover { transform:translateY(-5px) scale(1.05); box-shadow:0 12px 25px rgba(0,0,0,0.2); }

/* HERO */
.hero { position:relative; min-height:100vh; display:flex; flex-direction:column; justify-content:center; padding:140px 48px 80px; overflow:hidden; background:transparent; }
.hero-clouds { position:absolute; top:0; left:0; right:0; height:100%; background:radial-gradient(ellipse 300px 120px at 15% 20%,rgba(255,255,255,0.9) 0%,transparent 70%),radial-gradient(ellipse 200px 80px at 70% 15%,rgba(255,255,255,0.8) 0%,transparent 70%),radial-gradient(ellipse 250px 100px at 85% 35%,rgba(255,255,255,0.7) 0%,transparent 70%); pointer-events:none; }
.hero-stars { position:absolute; inset:0; pointer-events:none; overflow:hidden; }
.star { position:absolute; font-size:clamp(16px,2vw,28px); animation:starFloat 4s ease-in-out infinite; }
.star:nth-child(1){top:12%;left:8%;animation-delay:0s}
.star:nth-child(2){top:25%;right:12%;animation-delay:1s}
.star:nth-child(3){top:55%;left:5%;animation-delay:2s}
.star:nth-child(4){bottom:20%;right:6%;animation-delay:0.5s}
.star:nth-child(5){top:70%;left:45%;animation-delay:1.5s}
.star:nth-child(6){top:35%;left:55%;animation-delay:3s}
@keyframes starFloat{0%,100%{transform:translateY(0) rotate(0);opacity:0.7}50%{transform:translateY(-14px) rotate(20deg);opacity:1}}

.hero-title { font-family:'Baloo 2',cursive; font-size:clamp(46px,8vw,110px); line-height:1.2; color:var(--text); position:relative; z-index:2; margin-top:30px; font-weight:900; min-height:200px; }
.hero-title .t-blue{color:var(--blue-dark)}.hero-title .t-red{color:var(--red-dark)}.hero-title .t-green{color:var(--green-dark)}.hero-title .t-yellow{color:var(--yellow-dark)}
.hero-subtitle { font-size:clamp(16px,2vw,24px); font-weight:700; color:var(--muted); margin-top:16px; z-index:2; position:relative; }

.hero-actions { display:flex; gap:12px; margin-top:36px; flex-wrap:wrap; z-index:2; position:relative; }
.hero-actions a {
  padding:14px 24px; border-radius:50px; font-size:18px; text-decoration:none;
  transition:transform 0.2s, box-shadow 0.2s;
  display:flex; align-items:center; justify-content:center;
  gap:8px; cursor:pointer; flex:1 1 auto; text-align:center;
  background:rgba(255,255,255,0.35);
  box-shadow:0 8px 20px rgba(0,0,0,0.15);
  border:1px solid rgba(255,255,255,0.5);
  font-weight:900; color:var(--text);
}
.hero-actions a:hover { transform:translateY(-4px); box-shadow:0 12px 28px rgba(0,0,0,0.2); }
.btn-highlight-blue { color:var(--blue-dark) !important; font-size:20px; }
.btn-highlight-red  { color:var(--logo-red) !important; font-size:20px; }

.hero-seq-container { position:absolute; bottom:30px; left:0; right:0; height:60px; overflow:hidden; z-index:1; pointer-events:none; }
#heroSeqAnim { position:absolute; font-size:50px; right:-80px; }

.rainbow-bar { height:10px; background:linear-gradient(90deg,var(--blue) 0%,var(--green) 25%,var(--logo-yellow) 50%,var(--logo-red) 75%,var(--blue) 100%); background-size:200% 100%; animation:rainbowMove 3s linear infinite; }
@keyframes rainbowMove{0%{background-position:0% 0}100%{background-position:200% 0}}

.marquee-wrap {
  overflow:hidden;
  background:rgba(255,255,255,0.5);
  border-top:1px solid rgba(255,255,255,0.6);
  border-bottom:1px solid rgba(255,255,255,0.6);
  padding:14px 0; direction:ltr;
}
.marquee-track {
  display:flex; gap:0;
  animation:marqueeRight 25s linear infinite;
  white-space:nowrap; width:max-content;
  will-change: transform;
}
.marquee-wrap.yellow .marquee-track { animation-duration:5s !important; }
.marquee-item { font-size:18px; font-weight:bold; color:var(--text); padding:0 30px; display:flex; align-items:center; gap:15px; direction:rtl; }
@keyframes marqueeRight { 0%{transform:translateX(-50%)} 100%{transform:translateX(0%)} }

/* Seasonal Rotator Styles */
.seasonal-rotator-wrap {
  position: relative;
  height: 60px;
  background: rgba(255,255,255,0.5);
  border-top: 1px solid rgba(255,255,255,0.6);
  border-bottom: 1px solid rgba(255,255,255,0.6);
  margin: 30px 0;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: hidden;
  border-radius: 20px;
}
.rotator-item {
  position: absolute;
  font-size: 20px;
  font-weight: bold;
  color: var(--text);
  opacity: 0;
  transition: opacity 0.5s ease-in-out;
  text-align: center;
  width: 100%;
  pointer-events: none;
}
.rotator-item.active {
  opacity: 1;
}

.about-section { padding:80px 48px; gap:60px; align-items:center; background:transparent; }

.about-img-wrap {
  position:relative; height:400px; border-radius:40px; overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:rgba(255,255,255,0.55);
  border:2px solid rgba(91,184,255,0.4);
  box-shadow: 0 0 40px rgba(91,184,255,0.2);
}
.about-big-emoji { font-size:100px; animation:sway 3s ease-in-out infinite; will-change:transform; }
@keyframes sway{0%,100%{transform:rotate(-5deg)}50%{transform:rotate(5deg)}}
.about-badge-wrap { position:absolute; bottom:20px; right:20px; background:var(--white); border-radius:20px; padding:10px 18px; box-shadow:var(--shadow); }
.about-badge-wrap span { font-size:15px; font-weight:bold; color:var(--blue-dark); }

.tag-pill { display:inline-block; padding:6px 14px; border-radius:20px; font-size:13px; font-weight:800; margin:4px; }
.tag-blue{background:var(--blue-light);color:#1a6ea8}
.tag-red{background:var(--red-light);color:#c0001f}
.tag-green{background:var(--green-light);color:#1f8c3e}
.tag-yellow{background:var(--yellow-light);color:#8a6200}

.section-h2 { font-size:clamp(32px,5vw,50px); line-height:1.2; margin-bottom:16px; }
.section-p { font-size:16px; line-height:1.8; color:var(--muted); margin-bottom:24px; }

.stats-bar { display:grid; grid-template-columns:repeat(4,1fr); padding:20px 48px; }
.stat-item { padding:30px 20px; text-align:center; margin:10px; border-radius:20px; }
.stat-emoji { font-size:32px; margin-bottom:8px; }
.stat-num { font-size:36px; font-weight:bold; line-height:1; }
.stat-item:nth-child(1) .stat-num{color:var(--blue-dark)}.stat-item:nth-child(2) .stat-num{color:var(--logo-red)}.stat-item:nth-child(3) .stat-num{color:var(--green-dark)}.stat-item:nth-child(4) .stat-num{color:var(--yellow-dark)}
.stat-label { font-size:14px; font-weight:800; color:var(--text); margin-top:6px; }

.babysitter-section { padding:80px 48px; background:transparent; text-align:center; }
.babysitter-box { max-width:700px; margin:0 auto; border-radius:30px; padding:40px; text-align:right; }
.babysitter-box p { font-size:18px; font-weight:bold; color:var(--text); margin-bottom:20px; text-align:center; }
.babysitter-list { list-style:none; padding:0; margin:0; font-size:16px; color:var(--text); line-height:2.2; }
.babysitter-list li { display:flex; align-items:center; gap:12px; margin-bottom:12px; font-weight:600; }
.babysitter-list span { font-size:22px; flex-shrink:0; }

.activities-section { padding:80px 48px; background:transparent; }
.activities-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:16px; margin-top:40px; }
.activity-card { border-radius:24px; padding:24px 16px; text-align:center; cursor:pointer; transition:transform 0.25s, box-shadow 0.25s; position:relative; overflow:hidden; }
.activity-card:hover { transform:translateY(-6px) scale(1.02); box-shadow:0 16px 40px rgba(0,0,0,0.1); }
.activity-emoji { font-size:40px; margin-bottom:10px; display:block; }
.activity-name { font-size:18px; font-weight:bold; color:var(--text); }
.activity-time { font-size:13px; font-weight:700; color:var(--muted); margin-top:4px; }
.activity-bar { position:absolute; bottom:0; left:0; height:4px; width:0; transition:width 0.4s; }
.activity-card:nth-child(4n+1) .activity-bar{background:var(--blue)}.activity-card:nth-child(4n+2) .activity-bar{background:var(--logo-red)}.activity-card:nth-child(4n+3) .activity-bar{background:var(--green)}.activity-card:nth-child(4n+4) .activity-bar{background:var(--yellow-dark)}
.activity-card:hover .activity-bar{width:100%}

.enrollment-section { padding:80px 48px; display:grid; grid-template-columns:1fr 1fr; gap:40px; align-items:center; background:transparent; }
.enroll-visual { border-radius:40px; padding:40px 30px; text-align:center; position:relative; overflow:hidden; z-index:1; }
.enroll-list { list-style:none; padding:0; margin:16px 0 0; }
.enroll-list li { display:flex; align-items:center; gap:10px; margin-bottom:14px; font-size:16px; font-weight:600; color:var(--text); }

.partners-section { padding:80px 48px; background:transparent; text-align:center; }
.branches-grid { display:grid; grid-template-columns:repeat(auto-fit,minmax(180px,1fr)); gap:15px; margin-top:40px; }
.branch-card { display:block; text-decoration:none; position:relative; height:160px; border-radius:20px; overflow:hidden; background-size:cover; background-position:center; cursor:pointer; border:3px solid transparent; transition:transform 0.3s, border-color 0.3s, box-shadow 0.3s; background-color: #e2e8f0; }
.branch-card:hover { transform:translateY(-5px); border-color:var(--green); box-shadow:0 12px 24px rgba(0,0,0,0.12); }
.branch-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.5),rgba(0,0,0,0)); pointer-events:none; }
.branch-info { position:absolute; bottom:15px; right:15px; color:white; text-align:right; pointer-events:none; text-shadow:0 2px 4px rgba(0,0,0,0.5); }
.branch-name { font-size:18px; font-weight:bold; }
.branch-dist { font-size:13px; color:var(--yellow); margin-top:4px; display:inline-block; }

/* Team Section Styles - Apple Glassmorphism */
.team-section { padding:80px 48px; background:transparent; }
.team-exec { display:flex; justify-content:center; gap:20px; flex-wrap:wrap; margin-bottom:20px; margin-top:40px; }
.team-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(220px, 1fr)); gap:20px; margin-top:20px; }
.glass-card {
  background: rgba(255, 255, 255, 0.45);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border: 1px solid rgba(255, 255, 255, 0.6);
  border-radius: 20px;
  box-shadow: 0 4px 20px rgba(0, 0, 0, 0.05);
  padding: 24px;
  text-align: center;
  transition: transform 0.3s ease, box-shadow 0.3s ease, background 0.3s ease;
  transform: translateZ(0);
  will-change: transform;
}
.glass-card:hover {
  transform: translateY(-5px);
  box-shadow: 0 12px 35px rgba(31, 38, 135, 0.08);
  background: rgba(255, 255, 255, 0.55);
}
.team-exec .glass-card { width: 100%; max-width: 320px; }
.team-role { font-size: 15px; color: var(--blue-dark); font-weight: 800; margin-bottom: 8px; }
.team-name { font-size: 18px; font-weight: 700; color: var(--text); line-height: 1.4; }

.testimonials-section { padding:80px 0; background:transparent; overflow:hidden; }
.gm-reviews-container { display:flex; gap:16px; overflow-x:auto; padding:20px 48px; scroll-snap-type:x mandatory; scrollbar-width:none; -webkit-overflow-scrolling:touch; margin-top:20px; }
.gm-reviews-container::-webkit-scrollbar { display:none; }
.gm-review-card { flex:0 0 320px; border-radius:12px; padding:20px; scroll-snap-align:center; text-align:right; direction:rtl; display:flex; flex-direction:column; align-items:flex-start; }
.gm-reviewer { display:flex; align-items:center; gap:12px; margin-bottom:12px; width:100%; }
.gm-avatar { width:40px; height:40px; border-radius:50%; display:flex; justify-content:center; align-items:center; font-size:18px; color:white; font-weight:bold; font-family:sans-serif; }
.gm-name-col { display:flex; flex-direction:column; align-items:flex-start; }
.gm-name { font-size:15px; font-weight:700; color:#202124; margin-bottom:2px; font-family:sans-serif; }
.gm-meta { font-size:13px; color:#5a5a6a; font-family:sans-serif; }
.gm-rating { display:flex; gap:2px; margin-bottom:10px; }
.gm-rating span { color:#fbbc04; font-size:16px; }
.gm-text { font-size:15px; color:#3c4043; line-height:1.6; font-family:sans-serif; }

.gallery-section { padding:80px 48px; background:transparent; }
.gallery-grid { display:grid; grid-template-columns:repeat(4,1fr); grid-template-rows:repeat(2,180px); gap:12px; margin-top:30px; }
.gallery-cell { border-radius:24px; overflow:hidden; position:relative; display:flex; flex-direction: column; align-items:center; justify-content:center; cursor:pointer; transition:transform 0.3s; background:rgba(255,255,255,0.55); border:1px solid rgba(255,255,255,0.8); box-shadow:0 8px 32px 0 rgba(31,38,135,0.05); text-align: center; padding: 20px; }
.gallery-cell:hover { transform:scale(1.03); z-index:2; }
.gallery-cell:nth-child(1){grid-column:1;grid-row:1}
.gallery-cell:nth-child(2){grid-column:2/4;grid-row:1}
.gallery-cell:nth-child(3){grid-column:4;grid-row:1}
.gallery-cell:nth-child(4){grid-column:1/3;grid-row:2}
.gallery-cell:nth-child(5){grid-column:3;grid-row:2}
.gallery-cell:nth-child(6){grid-column:4;grid-row:2}
.gallery-cell-label { font-size:15px; font-weight:800; color:var(--text); margin-top:12px; line-height:1.3; }

/* Quick Links Pre-Footer Section */
.quick-links-section {
  padding: 60px 48px;
  background: rgba(255, 255, 255, 0.4);
  border-top: 1px solid rgba(255, 255, 255, 0.8);
  margin-top: 40px;
}
.quick-links-list {
  display: flex;
  flex-wrap: wrap;
  gap: 15px;
  justify-content: center;
  list-style: none;
  margin-top: 30px;
}
.quick-links-list a {
  padding: 8px 20px;
  background: var(--white);
  border-radius: 50px;
  color: var(--blue-dark);
  font-weight: 800;
  font-size: 14px;
  text-decoration: none;
  box-shadow: 0 4px 15px rgba(0,0,0,0.05);
  transition: transform 0.3s, box-shadow 0.3s, background 0.3s, color 0.3s;
  display: flex;
  align-items: center;
  gap: 8px;
  border: 1px solid var(--blue-light);
}
.quick-links-list a:hover {
  transform: translateY(-5px);
  background: var(--blue-dark);
  color: var(--white);
  box-shadow: 0 10px 25px rgba(91,184,255,0.3);
  border-color: var(--blue-dark);
}

footer {
  background:rgba(255,255,255,0.55);
  backdrop-filter:blur(20px); -webkit-backdrop-filter:blur(20px);
  border-top:1px solid rgba(255,255,255,0.8);
  color:var(--text); padding:64px 48px 32px;
  position:relative; overflow:hidden;
}
footer::before { content:''; position:absolute; top:0; left:0; right:0; height:8px; background:linear-gradient(90deg,var(--blue),var(--logo-red),var(--green),var(--logo-yellow)); }
.footer-grid { display:grid; grid-template-columns:repeat(auto-fit, minmax(200px, 1fr)); gap:40px; margin-bottom:20px; }
@media (min-width: 1024px) {
  .footer-grid { grid-template-columns:2.5fr 1fr 1fr 1.5fr; }
}
.footer-desc { font-size:15px; color:var(--text); line-height:1.7; font-family:'Baloo 2',sans-serif; margin-top:15px; }
.footer-col h3 { font-size:18px; margin-bottom:14px; }
.footer-col.c-blue h3{color:var(--blue-dark)}.footer-col.c-red h3{color:var(--red-dark)}.footer-col.c-green h3{color:var(--green-dark)}
.footer-col a { display:block; color:var(--text); text-decoration:none; font-size:15px; font-weight:600; margin-bottom:10px; transition:color 0.2s; cursor:pointer; }
.footer-col.c-blue a:hover{color:var(--blue-dark)}.footer-col.c-red a:hover{color:var(--red-dark)}.footer-col.c-green a:hover{color:var(--green-dark)}
.footer-bottom { border-top:1px solid rgba(0,0,0,0.1); padding-top:24px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:12px; }
.footer-copy { font-size:13px; color:var(--text); }

.seo-text-block { font-size:12px; color:var(--muted); line-height:1.8; margin-top:20px; padding-top:15px; border-top:1px solid rgba(0,0,0,0.1); }

.social-icons { display:flex; gap:12px; align-items:center; justify-content:center; margin-top:15px; }
.social-icons a { display:flex; align-items:center; justify-content:center; width:36px; height:36px; border-radius:50%; background:rgba(255,255,255,0.6); color:var(--text); transition:transform 0.3s, background 0.3s, box-shadow 0.3s; text-decoration:none; }
.social-icons a:hover { transform:translateY(-3px); background:var(--blue-light); color:var(--blue-dark); box-shadow:0 4px 10px rgba(0,0,0,0.1); }
.social-icons svg { width:18px; height:18px; fill:currentColor; }

.fade-up { opacity:0; transform:translateY(30px); transition:opacity 0.6s ease, transform 0.6s ease; }
.fade-up.visible { opacity:1; transform:none; }

.modal-overlay { position:fixed; top:0; left:0; right:0; bottom:0; background:rgba(255,255,255,0.4); backdrop-filter:blur(15px); -webkit-backdrop-filter:blur(15px); z-index:3000; display:flex; align-items:center; justify-content:center; padding:20px; opacity:0; visibility:hidden; transition:opacity 0.3s, visibility 0.3s; overscroll-behavior: contain; }
.modal-overlay.active { opacity:1; visibility:visible; }
.modal-close { position:absolute; top:15px; right:15px; width:36px; height:36px; background:rgba(255,255,255,0.5); border-radius:50%; display:flex; align-items:center; justify-content:center; cursor:pointer; font-size:22px; color:var(--text); border:none; font-weight:bold; transition:background 0.2s, color 0.2s; z-index:10; }
.modal-close:hover { background:var(--red-light); color:var(--logo-red); }
.modal-box { width:100%; max-width:650px; padding:40px 20px; border-radius:30px; position:relative; max-height:90vh; overflow-y:auto; }
.modal-branches-grid { display:grid; grid-template-columns:repeat(2,1fr); gap:15px; margin-top:10px; }
.modal-branch-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(0,0,0,0.4),rgba(0,0,0,0.0)); pointer-events:none; }

.img-gallery-overlay { position:fixed; inset:0; background:rgba(255,255,255,0.6); backdrop-filter:blur(25px); -webkit-backdrop-filter:blur(25px); z-index:5000; display:none; align-items:center; justify-content:center; opacity:0; transition:opacity 0.3s; flex-direction:column; overscroll-behavior: contain; }
.img-gallery-overlay.active { display:flex; opacity:1; }
.img-gallery-track { display:flex; width:100vw; overflow-x:auto; scroll-snap-type:x mandatory; -webkit-overflow-scrolling:touch; scrollbar-width:none; height:100%; align-items:center; cursor:pointer; }
.img-gallery-track::-webkit-scrollbar { display:none; }
.img-gallery-item { flex:0 0 100vw; height:100vh; scroll-snap-align:center; display:flex; justify-content:center; align-items:center; padding:20px; cursor:default; position:relative; }

.img-gallery-item img { 
  width: 100%; 
  max-width: 500px; 
  height: auto;
  max-height: 80vh; 
  border-radius: 20px; 
  object-fit: cover;
  box-shadow: 0 15px 40px rgba(0,0,0,0.1); 
  user-select: none;
  cursor: pointer; 
  border: 2px solid rgba(255,255,255,0.4); 
  position: relative; 
  overflow: hidden;
}

/* RESPONSIVE */
@media (max-width:740px) {
  nav.main-nav { padding:10px 15px; flex-direction:column; gap:5px; justify-content:center; }
  .nav-logo-wrap { padding:4px 15px; width:100%; }
  .brand-logo-container .cl-ar { font-size:20px; }
  .brand-logo-container .cl-en { font-size:20px; }
  .brand-logo-img { width:40px; height:40px; }
  .header-tagline { font-size:14px; margin-top:2px; }

  .hero { padding:180px 20px 60px; text-align:center; }
  .hero-title { min-height:auto; }
  .hero-actions { justify-content:center; gap:10px; flex-direction:row; }
  .hero-actions a { flex:1 1 45%; font-size:16px; padding:12px 10px; }

  .about-section, .enrollment-section, .team-section { grid-template-columns:1fr; gap:40px; padding:60px 20px; text-align:center; }
  .babysitter-section { padding:60px 20px; }
  .about-img-wrap { height:300px; }

  .stats-bar { grid-template-columns:repeat(2,1fr); padding:20px; }
  .stat-item { padding:20px 10px; margin:5px; }
  .stat-num { font-size:28px; }

  .activities-section, .partners-section, .testimonials-section, .gallery-section, .quick-links-section { padding:60px 20px; }
  .activities-grid { grid-template-columns:repeat(2,1fr); gap:12px; }
  .gm-reviews-container { padding:20px; }

  .gallery-grid { grid-template-columns:repeat(2,1fr); grid-template-rows:auto; }
  .gallery-cell { grid-column:span 1 !important; grid-row:span 1 !important; height:160px; font-size:40px; }

  .modal-branches-grid { grid-template-columns:1fr; }

  .footer-grid { text-align:right; gap:30px; }
  .footer-logo .brand-logo-container { justify-content:center; }
  .footer-bottom { flex-direction:column; text-align:center; justify-content:center; }

  .marquee-track { animation-duration:15s !important; }
  .marquee-wrap.yellow .marquee-track { animation-duration:10s !important; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
