/*
Theme Name: Astra Child
Theme URI: https://kinderacademy.vip
Description: Kinder World Academy child theme. Fully admin-driven via Customizer (~330+ fields across 🎨 KWA Identity + 🏠 KWA Home panels) and Custom Post Types (slides + events). 9 home sections (Hero / Tiles / Different / Events / Curric / Gallery / Why / Articles / CTA) — each toggleable + reorderable. 3 custom slots × 8 types (testimonials / testimonials-rich / video / FAQ / newsletter / countdown / pricing / HTML). See CLAUDE.md for full architecture.
Author: Kinder World Academy
Template: astra
Version: 1.8.1780914068
Text Domain: astra-child
*/

/* === BRAND VARIABLES === */
:root {
  --kwa-pink:       #DD2478;
  --kwa-pink-dark:  #C61E68;
  --kwa-pink-soft:  #FCE0EE;
  --kwa-pink-wash:  #FFF5FA;
  --kwa-red:        #DD2478;
  --kwa-cyan:       #17B4D9;
  --kwa-cyan-dark:  #128CA8;
  --kwa-cyan-soft:  #D3F0F9;
  --kwa-dark:       #231F20;
  --kwa-white:      #FFFFFF;
  --kwa-slate:      #4A5562;
  --kwa-muted:      #9CA7AB;
}

/* === FONTS === */
html[lang^="ar"] body, body[dir="rtl"] { font-family:'Cairo','Tajawal',system-ui,-apple-system,sans-serif; }
html[lang^="en"] body, body[dir="ltr"] { font-family:'Poppins',system-ui,-apple-system,sans-serif; }
h1,h2,h3,h4,h5,h6,.site-title,.entry-title{ font-family:inherit; }

/* === TOPBAR (search icon 50% smaller) === */
.ast-above-header-wrap,.site-above-header-wrap{ background:var(--kwa-pink); color:#fff; font-size:13px; }
.ast-above-header-wrap a,.site-above-header-wrap a{ color:#fff!important; text-decoration:none; }
.ast-above-header-wrap a:hover{ text-decoration:underline; opacity:.95; color:#fff!important; }
.ast-above-header-section{ padding:6px 0; }
.kwa-topbar-full{ display:flex; align-items:center; justify-content:space-between; gap:24px; width:100%; font-size:13px; color:#fff; flex-wrap:wrap; }
.kwa-topbar-side{ display:flex; align-items:center; gap:18px; flex-wrap:wrap; }
.kwa-topbar-full a{ color:#fff!important; text-decoration:none; }
.kwa-topbar-full a:hover{ text-decoration:underline; opacity:.95; }
.kwa-topbar-full .ico{ opacity:.85; margin-inline-end:4px; font-size:12px; }

/* Search pill — 50% smaller */
.kwa-topbar-search{ display:inline-flex; align-items:center; background:rgba(255,255,255,.18); border-radius:999px; padding:1px 3px 1px 8px; transition:background .2s; }
.kwa-topbar-search:focus-within{ background:rgba(255,255,255,.30); }
.kwa-topbar-search input[type="search"]{ background:transparent; border:0; color:#fff; font-size:11px; width:90px; padding:3px 0; outline:none; font-family:inherit; }
.kwa-topbar-search input::placeholder{ color:rgba(255,255,255,.75); }
.kwa-topbar-search button{ background:transparent; border:0; color:#fff; cursor:pointer; padding:2px 4px; font-size:10px; line-height:1; }
.kwa-topbar-search button:hover{ opacity:.85; }
@media(max-width:768px){
  .kwa-topbar-full{ font-size:12px; gap:10px; justify-content:center; }
  .kwa-topbar-side{ gap:12px; }
  .kwa-topbar-full .hide-mobile{ display:none; }
  .kwa-topbar-search input[type="search"]{ width:75px; font-size:10px; }
}

/* === HEADER CTA BUTTON — red (was cyan) === */
.ast-custom-button,.ast-custom-button-link .ast-custom-button{
  white-space:nowrap!important; word-break:normal!important; letter-spacing:0!important;
  width:auto!important; min-width:max-content!important; height:auto!important;
  display:inline-flex!important; align-items:center!important; justify-content:center!important;
  background:var(--kwa-pink)!important; color:#fff!important;
  border-radius:999px!important; padding:10px 22px!important;
  font-weight:700!important; font-size:14px!important; line-height:1.2!important;
  transition:background .2s, transform .2s;
  box-shadow:0 6px 18px rgba(221,36,120,.25);
}
.ast-custom-button:hover,.ast-custom-button-link:hover .ast-custom-button{ background:var(--kwa-pink-dark)!important; transform:translateY(-1px); }
.ast-builder-button-wrap{ display:inline-flex; }

/* === HEADER LOGO — +50% bigger === */
.main-header-bar .custom-logo-link img{ max-height:108px; height:auto; width:auto; }
@media(max-width:768px){ .main-header-bar .custom-logo-link img{ max-height:72px; } }

/* === MAIN NAV — single line forced === */
.main-header-bar{ background:#fff!important; border-bottom:1px solid #f4eaef; }
.main-navigation .menu-item > a{ font-weight:700; font-size:14px; color:var(--kwa-dark); transition:color .2s; padding:8px 10px; }
.main-navigation .menu-item > a:hover,
.main-navigation .current-menu-item > a{ color:var(--kwa-pink)!important; }
.main-header-bar .main-header-bar-navigation .main-header-menu,
.main-header-menu.ast-nav-menu{ display:flex; flex-wrap:nowrap!important; white-space:nowrap; }
.main-header-bar .main-header-bar-navigation .menu-item{ flex-shrink:0; }
@media(min-width:1025px) and (max-width:1280px){
  .main-navigation .menu-item > a{ font-size:13px; padding:8px 7px; }
}

/* === FLOATING WHATSAPP — 50% smaller === */
.kwa-whatsapp-float{
  position:fixed; bottom:16px; right:16px; z-index:9999;
  width:42px; height:42px; border-radius:50%;
  background:#25D366; color:#fff;
  display:flex; align-items:center; justify-content:center;
  box-shadow:0 6px 18px rgba(37,211,102,.40);
  transition:transform .2s, box-shadow .2s; text-decoration:none;
}
.kwa-whatsapp-float:hover,.kwa-whatsapp-float:focus{ transform:scale(1.08); box-shadow:0 10px 24px rgba(37,211,102,.55); color:#fff; }
.kwa-whatsapp-float svg{ width:22px; height:22px; display:block; }
.kwa-whatsapp-float::before{ content:''; position:absolute; inset:0; border-radius:50%; animation:kwa-wa-pulse 2.4s ease-out infinite; pointer-events:none; }
@keyframes kwa-wa-pulse{ 0%{box-shadow:0 0 0 0 rgba(37,211,102,.55);} 70%{box-shadow:0 0 0 14px rgba(37,211,102,0);} 100%{box-shadow:0 0 0 0 rgba(37,211,102,0);} }
body[dir="rtl"] .kwa-whatsapp-float{ right:16px; left:auto; }

/* === RESPONSIVE IMAGES === */
.elementor-widget-image img,.elementor-image img{ max-width:100%; height:auto; display:block; }

/* === ANNOUNCEMENTS SLIDER (carousel: flex track + live drag + auto-height) === */
.kwa-slider{ position:relative; width:100%; overflow:hidden; isolation:isolate; touch-action:pan-y; -webkit-user-select:none; user-select:none; transition:height .35s ease; }
.kwa-slider:focus{ outline:none; }
.kwa-slider-track{ display:flex; direction:ltr; width:100%; align-items:stretch; will-change:transform; }
.kwa-slide{ flex:0 0 100%; width:100%; position:relative; display:flex; align-items:center; justify-content:center; padding:56px 24px 70px; direction:rtl; overflow:hidden; box-sizing:border-box; }
.kwa-slide-inner{ position:relative; z-index:2; max-width:880px; width:100%; text-align:center; color:#fff; }
.kwa-slide-eyebrow{ display:inline-block; font-size:17.5px; font-weight:700; letter-spacing:2px; background:rgba(255,255,255,.22); color:#fff; padding:7px 18px; border-radius:999px; margin-bottom:18px; }
.kwa-slide-title{ font-size:39px; font-weight:900; line-height:1.2; color:#fff; margin:0 0 14px; }
.kwa-slide-lead{ font-size:17px; line-height:1.75; color:rgba(255,255,255,.94); max-width:680px; margin:0 auto 26px; }
.kwa-slide-cta{ display:inline-block; background:#fff; color:var(--kwa-pink); padding:14px 32px; border-radius:999px; font-weight:800; font-size:15px; text-decoration:none; box-shadow:0 10px 26px rgba(0,0,0,.16); transition:transform .2s, background .2s; position:relative; z-index:3; }
.kwa-slide-cta:hover{ transform:translateY(-2px); background:var(--kwa-pink-soft); }
.kwa-slide--gradient-pink{ background:linear-gradient(135deg,var(--kwa-pink) 0%,var(--kwa-pink-dark) 100%); }
.kwa-slide--gradient-cyan{ background:linear-gradient(135deg,var(--kwa-cyan) 0%,var(--kwa-cyan-dark) 100%); }
.kwa-slide--gradient-mix{ background:linear-gradient(135deg,var(--kwa-pink) 0%,var(--kwa-cyan) 100%); }
.kwa-slider-dots{ position:absolute; bottom:18px; left:50%; transform:translateX(-50%); display:flex; gap:10px; z-index:5; }
.kwa-dot{ width:10px; height:10px; border-radius:50%; background:rgba(255,255,255,.4); border:0; cursor:pointer; padding:0; transition:background .2s, transform .2s; }
.kwa-dot.is-active{ background:#fff; transform:scale(1.25); }

/* Video slide: aspect-ratio drives slide height; refined via JS once video metadata loads */
.kwa-slide--has-video{ background:#000; padding:0; align-items:flex-end; }
.kwa-slide-video{ position:absolute; inset:0; width:100%; height:100%; object-fit:cover; z-index:1; background:#000; }
.kwa-slide-video::-webkit-media-controls-panel{ direction:ltr; z-index:4; }
.kwa-slide--has-video .kwa-slide-inner{ position:absolute; left:0; right:0; bottom:0; z-index:3; max-width:none; padding:36px 28px 76px; background:linear-gradient(180deg, rgba(0,0,0,0) 0%, rgba(0,0,0,.45) 60%, rgba(0,0,0,.78) 100%); pointer-events:auto; }
.kwa-slide--has-video .kwa-slide-inner > * { pointer-events:auto; }

/* Prev/next arrows */
.kwa-slider-nav{ position:absolute; bottom:14px; width:38px; height:38px; border-radius:50%; border:0; background:rgba(255,255,255,.92); color:var(--kwa-pink); font-size:22px; line-height:34px; font-weight:900; cursor:pointer; z-index:6; box-shadow:0 4px 12px rgba(0,0,0,.22); display:flex; align-items:center; justify-content:center; padding:0; transition:background .2s, transform .2s; -webkit-tap-highlight-color:transparent; outline:none; -webkit-appearance:none; appearance:none; }
.kwa-slider-nav:active, .kwa-slider-nav:focus, .kwa-slider-nav:focus-visible{ background:rgba(255,255,255,.92); color:var(--kwa-pink); outline:none; box-shadow:0 4px 12px rgba(0,0,0,.22); }
@media (hover: hover) and (pointer: fine) {
  .kwa-slider-nav:hover{ background:#fff; transform:scale(1.10); }
}
.kwa-slider-nav--prev{ right:18px; }
.kwa-slider-nav--next{ left:18px; }

@media(max-width:768px){
  .kwa-slide{ padding:42px 18px 60px; }
  .kwa-slide-title{ font-size:25.5px; }
  .kwa-slide-lead{ font-size:14px; }
  .kwa-slider-nav{ width:34px; height:34px; font-size:19px; line-height:30px; bottom:12px; }
  .kwa-slider-nav--prev{ right:10px; }
  .kwa-slider-nav--next{ left:10px; }
  .kwa-slide--has-video .kwa-slide-inner{ padding:26px 18px 60px; }
}
@media(max-width:480px){
  .kwa-slide-title{ font-size:21px; }
  .kwa-slider-nav{ width:30px; height:30px; font-size:17px; line-height:26px; bottom:10px; }
}

/* === MOBILE LOGO ALWAYS VISIBLE === */
@media (max-width: 921px) {
  /* CRITICAL: Astra core hides title_tagline element on mobile via the .ast-header-break-point rule. Force it visible. */
  .ast-header-break-point #ast-mobile-header .ast-builder-layout-element[data-section="title_tagline"],
  #ast-mobile-header .ast-builder-layout-element[data-section="title_tagline"],
  #ast-mobile-header .site-header-primary-section-left {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
    align-items: center;
  }
  #ast-mobile-header .ast-primary-header-bar,
  #ast-mobile-header .ast-main-header-wrap,
  #ast-mobile-header .site-branding,
  #ast-mobile-header .site-logo-img,
  #ast-mobile-header .custom-logo-link {
    display: inline-flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
  #ast-mobile-header .ast-primary-header-bar,
  #ast-mobile-header .ast-main-header-wrap {
    display: block !important;
  }
  #ast-mobile-header .custom-logo-link img,
  #ast-mobile-header .custom-logo {
    display: inline-block !important;
    visibility: visible !important;
    max-width: 120px !important;
    height: auto !important;
    width: auto !important;
  }
  /* Stay visible even when popup menu is open */
  body.ast-main-header-nav-open #ast-mobile-header .ast-primary-header-bar,
  body.ast-popup-nav-open #ast-mobile-header .ast-primary-header-bar {
    display: block !important;
    visibility: visible !important;
  }

  /* Astra's own rule hides the title_tagline container on mobile — override it: */
  .ast-header-break-point .ast-builder-layout-element[data-section="title_tagline"],
  #ast-mobile-header .ast-builder-layout-element[data-section="title_tagline"] {
    display: flex !important;
    visibility: visible !important;
    opacity: 1 !important;
  }
}

/* ============================================================
   .kwa-home — full home page body
   ============================================================ */
.kwa-home{ color:var(--kwa-dark); line-height:1.65; }
.kwa-home *,.kwa-home *::before,.kwa-home *::after{ box-sizing:border-box; }
.kwa-home img{ display:block; max-width:100%; }
.kwa-home h1,.kwa-home h2,.kwa-home h3,.kwa-home h4,.kwa-home h5,.kwa-home p{ margin:0; }

.kwa-home .kbtn{ display:inline-flex; align-items:center; gap:8px; padding:13px 28px; border-radius:999px; font-weight:700; font-size:14px; border:0; cursor:pointer; transition:all .2s; text-decoration:none; line-height:1.2; white-space:nowrap; }
.kwa-home .kbtn-pink{ background:var(--kwa-pink); color:#fff; box-shadow:0 8px 22px rgba(221,36,120,.28); }
.kwa-home .kbtn-pink:hover{ background:var(--kwa-pink-dark); color:#fff; transform:translateY(-2px); }
.kwa-home .kbtn-ghost{ background:transparent; color:var(--kwa-pink); border:2px solid var(--kwa-pink); }
.kwa-home .kbtn-ghost:hover{ background:var(--kwa-pink); color:#fff; }
.kwa-home .kbtn-white{ background:#fff; color:var(--kwa-pink); box-shadow:0 8px 22px rgba(0,0,0,.18); }
.kwa-home .kbtn-white:hover{ background:var(--kwa-pink-soft); }
.kwa-home .kbtn-dark-cyan{ background:var(--kwa-cyan-dark); color:#fff; }
.kwa-home .kbtn-dark-cyan:hover{ background:var(--kwa-cyan); color:#fff; }

.kwa-home .ktag{ display:inline-block; font-size:12px; letter-spacing:2px; color:var(--kwa-pink); font-weight:800; text-transform:uppercase; margin-bottom:10px; }
/* +50% bigger eyebrow variant */
.kwa-home .ktag-big{ font-size:18px; letter-spacing:3px; margin-bottom:14px; }

.kwa-home .kwa-section-head{ text-align:center; margin-bottom:36px; max-width:760px; margin-inline:auto; }
.kwa-home .kwa-section-head h2{ font-size:34px; font-weight:900; color:var(--kwa-dark); margin-bottom:10px; line-height:1.2; }
.kwa-home .kwa-section-head p{ font-size:15px; color:var(--kwa-slate); }
/* 2x bigger section heading variant */
.kwa-home .kwa-section-head--xl h2{ font-size:64px; line-height:1.15; margin-bottom:14px; }
.kwa-home .kwa-section-head--xl .ktag{ font-size:18px; letter-spacing:3px; margin-bottom:14px; }
.kwa-home .kwa-section-head--xl p{ font-size:17px; }
@media(max-width:768px){
  .kwa-home .kwa-section-head--xl h2{ font-size:42px; }
}
@media(max-width:480px){
  .kwa-home .kwa-section-head--xl h2{ font-size:32px; }
}

.kwa-home .kwa-section-foot{ text-align:center; margin-top:30px; }
.kwa-home section{ padding-inline:24px; }

/* HERO with slogan image carousel */
.kwa-home .kwa-hero{ position:relative; background:linear-gradient(135deg,var(--kwa-pink-wash) 0%,#fff 50%,var(--kwa-cyan-soft) 100%); overflow:hidden; padding:60px 24px 100px; }
.kwa-home .kwa-hero::before{ content:""; position:absolute; top:-80px; right:-80px; width:380px; height:380px; background:radial-gradient(closest-side,var(--kwa-pink-soft),transparent 70%); pointer-events:none; }
.kwa-home .kwa-hero::after{ content:""; position:absolute; bottom:-100px; left:-60px; width:340px; height:340px; background:radial-gradient(closest-side,var(--kwa-cyan-soft),transparent 70%); pointer-events:none; }
.kwa-home .kwa-hero-grid{ position:relative !important; max-width:1200px !important; margin-left:auto !important; margin-right:auto !important; display:flex !important; flex-direction:column !important; align-items:center !important; justify-content:center !important; text-align:center !important; gap:32px !important; z-index:1; width:100% !important; }
.kwa-home .kwa-hero-text h1{ font-size:25px !important; font-weight:900 !important; line-height:1.18 !important; color:#17B4D9 !important; margin-bottom:18px !important; text-align:center !important; }
.kwa-home .kwa-hero-text h1 .accent{ display:block; color:var(--kwa-pink); font-size:30px; font-weight:700; margin-top:6px; }
.kwa-home .kwa-hero-text{ width:100% !important; text-align:center !important; }
.kwa-home .kwa-hero-text .lead{ font-size:17px; color:var(--kwa-slate); margin:0 auto 28px !important; max-width:520px; line-height:1.85; text-align:center !important; }
.kwa-home .kwa-hero-text .cta-row{ display:flex; gap:14px; flex-wrap:wrap; justify-content:center; }
.kwa-home .kwa-hero-slogans{ position:relative; aspect-ratio:16/8.55; width:100%; max-width:675px; margin:0 auto; justify-self:center; border-radius:24px; overflow:hidden; box-shadow:0 24px 60px rgba(221,36,120,.18); order:2; background:#fff; }
.kwa-home .kwa-slogan-img{ position:absolute; inset:0; width:100%; height:100%; object-fit:contain; opacity:0; transition:opacity 1s ease; }
.kwa-home .kwa-slogan-img.is-active{ opacity:1; }

/* TILES */
.kwa-home .kwa-tiles{ position:relative; z-index:3; max-width:1200px; margin:-44px auto 0; padding:0 24px; display:grid; grid-template-columns:repeat(4,1fr); gap:18px; }
.kwa-home .kwa-tiles .tile{ padding:24px 22px; border-radius:18px; color:#fff; box-shadow:0 12px 28px rgba(35,31,32,.08); min-height:170px; display:flex; flex-direction:column; gap:10px; transition:transform .2s; }
.kwa-home .kwa-tiles .tile:hover{ transform:translateY(-6px); }
.kwa-home .kwa-tiles .icon{ font-size:30px; line-height:1; }
.kwa-home .kwa-tiles .tile h4{ font-size:18px; font-weight:800; }
.kwa-home .kwa-tiles .tile p{ font-size:13px; opacity:.95; line-height:1.65; }
.kwa-home .kwa-tiles .tile-1{ background:var(--kwa-pink); }
.kwa-home .kwa-tiles .tile-2{ background:var(--kwa-cyan); color:var(--kwa-dark); }
.kwa-home .kwa-tiles .tile-2 p{ color:var(--kwa-dark); opacity:.85; }
.kwa-home .kwa-tiles .tile-3{ background:var(--kwa-pink-dark); }
.kwa-home .kwa-tiles .tile-4{ background:var(--kwa-cyan-dark); }

/* DIFFERENT (eyebrow +50%, image -25%) */
.kwa-home .kwa-different{ padding:90px 24px; }
.kwa-home .kwa-different-grid{ max-width:1200px; margin:0 auto; display:grid; grid-template-columns:0.85fr 1.25fr; gap:60px; align-items:center; }
.kwa-home .kwa-different-img{ position:relative; aspect-ratio:1/1; max-width:420px; background-size:cover; background-position:center; border-radius:24px; box-shadow:0 24px 50px rgba(35,31,32,.10); }
.kwa-home .kwa-different-img::after{ content:""; position:absolute; width:100px; height:100px; background:var(--kwa-cyan); border-radius:50%; bottom:-26px; left:-26px; z-index:-1; opacity:.55; }
.kwa-home .kwa-different-img::before{ content:""; position:absolute; width:80px; height:80px; background:var(--kwa-pink); border-radius:50%; top:-22px; right:-22px; z-index:-1; opacity:.55; }
.kwa-home .kwa-different-txt h2{ font-size:36px; font-weight:900; color:var(--kwa-dark); line-height:1.2; margin-bottom:16px; }
.kwa-home .kwa-different-txt p{ color:var(--kwa-slate); margin-bottom:14px; font-size:15px; line-height:1.85; }
.kwa-home .phone-strip{ background:var(--kwa-pink-soft); border-radius:14px; padding:14px 20px; margin-top:22px; display:flex; align-items:center; justify-content:space-between; gap:14px; flex-wrap:wrap; }
.kwa-home .phone-strip .label{ font-size:11px; color:var(--kwa-slate); font-weight:700; letter-spacing:1px; margin-bottom:4px; }
.kwa-home .phone-strip .num{ color:var(--kwa-pink); font-weight:900; font-size:20px; letter-spacing:.5px; direction:ltr; }

/* EVENTS — RED background, bigger cards */
.kwa-home .kwa-events{ background:linear-gradient(135deg,var(--kwa-pink) 0%,var(--kwa-pink-dark) 100%); color:#fff; padding:80px 24px; }
.kwa-home .kwa-events-head{ max-width:1200px; margin:0 auto 36px; display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px; }
.kwa-home .kwa-events-head h2{ font-size:34px; font-weight:900; color:#fff; }
.kwa-home .kwa-events-head .all{ background:rgba(255,255,255,.20); color:#fff; padding:10px 22px; border-radius:999px; font-size:14px; font-weight:700; text-decoration:none; transition:background .2s; }
.kwa-home .kwa-events-head .all:hover{ background:rgba(255,255,255,.35); color:#fff; }
.kwa-home .kwa-events-grid{ max-width:1200px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:22px; }
/* +50% bigger cards: was 90px thumb, now 140px; was 2-col, now stays 3-col but with bigger thumbs and padding */
.kwa-home .event-card{ background:rgba(255,255,255,.10); backdrop-filter:blur(8px); padding:20px; border-radius:18px; display:grid; grid-template-columns:140px 1fr; gap:18px; align-items:center; }
.kwa-home .event-thumb{ aspect-ratio:1/1; border-radius:14px; background-size:cover; background-position:center; }
.kwa-home .event-body h5{ font-size:20px; font-weight:800; margin-bottom:10px; }
.kwa-home .event-body .event-meta{ font-size:13px; opacity:.95; display:flex; gap:10px; flex-wrap:wrap; }

/* CURRICULUM — 2x heading, 6 cards */
.kwa-home .kwa-curric{ padding:90px 24px; background:var(--kwa-pink-wash); }
.kwa-home .kwa-cards-3{ max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(3,1fr); gap:24px; }
/* 6-card grid (2 rows × 3 cols) */
.kwa-home .kwa-cards-6{ grid-template-columns:repeat(3,1fr); }
@media(max-width:980px){ .kwa-home .kwa-cards-6{ grid-template-columns:repeat(2,1fr); } }
@media(max-width:580px){ .kwa-home .kwa-cards-6{ grid-template-columns:1fr; } }
.kwa-home .ccard{ background:#fff; border-radius:18px; overflow:hidden; box-shadow:0 14px 30px rgba(35,31,32,.08); transition:transform .2s; text-decoration:none; color:inherit; display:block; }
.kwa-home .ccard:hover{ transform:translateY(-6px); }
.kwa-home .ccard .ph{ aspect-ratio:16/10; background-size:cover; background-position:center; }
.kwa-home .ccard-body{ padding:22px; }
.kwa-home .ccard .pill{ font-size:11px; background:var(--kwa-pink-soft); color:var(--kwa-pink); padding:5px 12px; border-radius:999px; font-weight:700; display:inline-block; margin-bottom:12px; }
.kwa-home .ccard h5{ font-size:18px; font-weight:800; margin-bottom:8px; color:var(--kwa-dark); }
.kwa-home .ccard p{ font-size:13px; color:var(--kwa-slate); margin-bottom:14px; line-height:1.75; }
.kwa-home .ccard .more{ color:var(--kwa-pink); font-weight:700; font-size:13px; }

/* GALLERY — 5 per row, heading 2x */
.kwa-home .kwa-gallery{ padding:90px 24px; }
.kwa-home .kwa-gallery-grid{ max-width:1280px; margin:0 auto; display:grid; grid-template-columns:repeat(5,1fr); gap:12px; }
.kwa-home .kwa-gallery-grid--5col{ grid-template-columns:repeat(5,1fr); }
.kwa-home .gphoto{ aspect-ratio:1/1; border-radius:14px; background-size:cover; background-position:center; position:relative; overflow:hidden; display:block; cursor:pointer; }
.kwa-home .gphoto::after{ content:""; position:absolute; inset:0; background:linear-gradient(180deg,transparent 60%,rgba(221,36,120,.45)); opacity:0; transition:opacity .2s; }
.kwa-home .gphoto:hover::after{ opacity:1; }
@media(max-width:980px){ .kwa-home .kwa-gallery-grid{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:580px){ .kwa-home .kwa-gallery-grid{ grid-template-columns:repeat(2,1fr); } }

/* WHY — 6 stat circles + 4-photo grid */
.kwa-home .kwa-why{ padding:90px 24px; background:linear-gradient(135deg,var(--kwa-pink-wash),#fff); }
.kwa-home .kwa-why-grid{ max-width:1280px; margin:0 auto; display:grid; grid-template-columns:1.2fr 1fr; gap:60px; align-items:center; }
.kwa-home .kwa-why-txt h2{ font-size:34px; font-weight:900; color:var(--kwa-dark); margin-bottom:14px; line-height:1.25; }
.kwa-home .kwa-why-txt p{ color:var(--kwa-slate); margin-bottom:28px; line-height:1.85; }
.kwa-home .kwa-stats{ display:grid; grid-template-columns:repeat(3,1fr); gap:20px; }
.kwa-home .kwa-stats--6{ grid-template-columns:repeat(3,1fr); gap:18px; row-gap:24px; }
@media(min-width:1024px){ .kwa-home .kwa-stats--6{ grid-template-columns:repeat(3,1fr); } }
@media(max-width:580px){ .kwa-home .kwa-stats--6{ grid-template-columns:repeat(2,1fr); } }
.kwa-home .kwa-stats .stat{ text-align:center; }
.kwa-home .kwa-stats .circle{ width:84px; height:84px; margin:0 auto 10px; border-radius:50%; display:flex; align-items:center; justify-content:center; font-size:22px; font-weight:900; color:#fff; }
.kwa-home .kwa-stats .circle.pink{ background:var(--kwa-pink); }
.kwa-home .kwa-stats .circle.cyan{ background:var(--kwa-cyan); }
.kwa-home .kwa-stats .circle.pink-dark{ background:var(--kwa-pink-dark); font-size:20px; }
.kwa-home .kwa-stats .circle.cyan-dark{ background:var(--kwa-cyan-dark); }
.kwa-home .kwa-stats .label{ font-size:13px; color:var(--kwa-slate); font-weight:700; }
/* 4 photos grid (replaces single big photo) */
.kwa-home .kwa-why-photos{ display:grid; grid-template-columns:repeat(2,1fr); gap:12px; }
.kwa-home .kwa-why-photos .ph{ aspect-ratio:1/1; background-size:cover; background-position:center; border-radius:18px; box-shadow:0 14px 30px rgba(35,31,32,.10); }

/* ARTICLES — 6 cards, heading 2x via section-head--xl */
.kwa-home .kwa-articles{ padding:90px 24px; background:var(--kwa-pink-wash); }
.kwa-home .kwa-articles .ccard .pill{ background:var(--kwa-cyan-soft); color:var(--kwa-cyan-dark); }
.kwa-home .kwa-articles .ccard .more{ color:var(--kwa-cyan-dark); }

/* CTA BAND — shorter (-25%) */
.kwa-home .kwa-cta-band{ padding:60px 24px; background:linear-gradient(135deg,var(--kwa-cyan) 0%,var(--kwa-cyan-dark) 100%); color:#fff; text-align:center; }
.kwa-home .kwa-cta-band--short{ padding:42px 24px; }
.kwa-home .kwa-cta-band h2{ font-size:30px; font-weight:900; color:#fff; margin-bottom:12px; line-height:1.25; }
.kwa-home .kwa-cta-band--short h2{ font-size:26px; margin-bottom:8px; }
.kwa-home .kwa-cta-band p{ font-size:15px; color:rgba(255,255,255,.92); margin-bottom:22px; max-width:560px; margin-inline:auto; }
.kwa-home .kwa-cta-band--short p{ font-size:14px; margin-bottom:18px; }
.kwa-home .kwa-cta-band .cta-row{ display:flex; gap:14px; justify-content:center; flex-wrap:wrap; }

/* ============================================================
   FOOTER — compact, WHITE BG (separated from cyan CTA band above)
   ============================================================ */
/* Background → white. Add a clean top border for separation from CTA above. */
.site-footer,
.site-footer .ast-footer-overlay,
.site-footer .site-primary-footer-wrap{
  background:#ffffff!important;
  background-color:#ffffff!important;
  background-image:none!important;
}
.site-below-footer-wrap,
.site-below-footer-section{
  background:#ffffff!important;
  background-color:#ffffff!important;
  background-image:none!important;
}
/* Visual separator strip between CTA band and footer */
.site-footer{ border-top:4px solid var(--kwa-pink-soft); }

/* Compact + centered — narrow content width, 2 columns sit in the middle of the page */
.site-footer .ast-builder-grid-row{
  padding-block:18px!important;
  max-width:780px!important;
  margin-inline:auto!important;
}
.site-footer .ast-builder-grid-row-container{
  padding:10px 24px!important;
  max-width:780px!important;
  margin-inline:auto!important;
}
.site-footer{ font-size:13px; color:var(--kwa-slate); }
.site-footer .footer-widget-area,
.site-footer .footer-widget-area-inner,
.site-footer .widget{ padding-block:6px!important; margin-bottom:0!important; }

/* 2-column desktop layout — centered + balanced */
@media (min-width:769px){
  .site-footer .site-primary-footer-section{ vertical-align:top; }
  .site-footer .ast-builder-grid-row-2-equal{
    display:grid;
    grid-template-columns:1fr 1fr;
    gap:30px;
    align-items:start;
  }
}
/* Tablet / mobile — stack to a single column, centered */
@media (max-width:768px){
  .site-footer .ast-builder-grid-row-2-equal{ grid-template-columns:1fr!important; }
  .site-footer .site-primary-footer-section{ text-align:center!important; }
  .site-footer .widget{ text-align:center!important; }
  .site-footer .ast-builder-grid-row{ max-width:100%!important; padding-block:14px!important; }
}

/* Column widget heading → RED + BOLD */
.site-footer h2,
.site-footer h6,
.site-footer .widget-title,
.site-footer .widget h2,
.site-footer .widget h3,
.site-footer .widget h4{
  font-size:16px!important;
  font-weight:900!important;
  color:var(--kwa-pink)!important;
  margin:0 0 10px!important;
  letter-spacing:.3px;
}
/* "Reaching Stars" tagline +50% bigger than before (13 → 20 px) */
.site-footer .kwa-footer-tagline{
  color:var(--kwa-pink)!important;
  font-weight:900!important;
  font-size:20px!important;
  letter-spacing:.5px;
  margin:6px 0 6px!important;
}

/* List items in footer columns — dark slate, compact */
.site-footer ul{ list-style:none; padding:0; margin:0; }
.site-footer ul li{ margin:0; line-height:1.9; }
.site-footer a{ color:var(--kwa-slate)!important; text-decoration:none; transition:color .15s; }
.site-footer a:hover{ color:var(--kwa-pink)!important; }

/* HTML widget (logo + Reaching Stars + blurb) */
.site-footer .ast-builder-html-element{ font-size:12.5px; line-height:1.6; color:var(--kwa-slate); }
.site-footer .ast-builder-html-element img{
  max-width:120px!important; height:auto;
  background:transparent!important; padding:0!important; border-radius:0!important;
  filter:none!important;
}

/* "Reaching Stars" inside html-1 → RED (handled via inline style in widget too, but enforce here) */
.site-footer .kwa-footer-tagline{ color:var(--kwa-pink)!important; font-weight:800!important; }
.site-footer .kwa-footer-blurb{ color:var(--kwa-slate); font-size:11.5px; }

/* Below-footer (copyright) — RED text */
.site-below-footer-section{
  padding-block:6px!important; font-size:12px!important;
  color:var(--kwa-pink)!important;
  border-top:1px solid var(--kwa-pink-soft);
}
.site-below-footer-section,
.site-below-footer-section *,
.site-below-footer-section a{
  color:var(--kwa-pink)!important;
}

/* Social icons compact */
.site-footer .ast-header-social-1-wrap,
.site-footer [class*="social-icons"]{ padding-top:4px; }
.site-footer [class*="social-icons"] a{ width:32px!important; height:32px!important; line-height:32px!important; }

/* ============== RESPONSIVE ============== */
@media(max-width:980px){
  .kwa-home .kwa-hero{ padding:48px 24px 90px; }
  .kwa-home .kwa-hero-grid,
  .kwa-home .kwa-different-grid,
  .kwa-home .kwa-why-grid{ grid-template-columns:1fr; gap:36px; }
  .kwa-home .kwa-tiles{ grid-template-columns:repeat(2,1fr); margin-top:-30px; }
  .kwa-home .kwa-cards-3,
  .kwa-home .kwa-events-grid,
  .kwa-home .kwa-stats{ grid-template-columns:repeat(2,1fr); }
  .kwa-home .kwa-hero-text h1{ font-size:18px; }
  .kwa-home .kwa-hero-text h1 .accent{ font-size:22px; }
  .kwa-home .kwa-hero-slogans{ aspect-ratio:16/8.55; max-width:450px; margin-inline:auto; justify-self:center; order:2; }
  .kwa-home .kwa-different-img{ max-width:340px; }
}
@media(max-width:580px){
  .kwa-home .kwa-tiles,
  .kwa-home .kwa-cards-3,
  .kwa-home .kwa-events-grid,
  .kwa-home .kwa-stats{ grid-template-columns:1fr; }
  .kwa-home .event-card{ grid-template-columns:90px 1fr; padding:14px; }
  .kwa-home .kwa-hero-text h1{ font-size:14px; }
  .kwa-home .kwa-hero-text h1 .accent{ font-size:20px; }
  .kwa-home .kwa-different-txt h2,
  .kwa-home .kwa-why-txt h2,
  .kwa-home .kwa-section-head h2{ font-size:26px; }
  .kwa-home .kwa-cta-band h2{ font-size:22px; }
  .kwa-home .kwa-events,
  .kwa-home .kwa-curric,
  .kwa-home .kwa-gallery,
  .kwa-home .kwa-why,
  .kwa-home .kwa-articles,
  .kwa-home .kwa-different{ padding-block:60px; }
}

/* === v1.5.1 — Gallery (معرض الصور) nav item in brand red === */
/* The Astra primary nav falls back to wp_list_pages, so each <li> gets
   .page-item-<post_id>. Gallery's page post ID is 1502. */
.main-header-menu .page-item-1502 > a,
.ast-builder-menu .page-item-1502 > a,
nav .page-item-1502 > a,
li.page-item-1502 > a,
.ast-mobile-popup-content .page-item-1502 > a {
  color: #DD2478 !important;
  font-weight: 700;
}
.main-header-menu .page-item-1502 > a:hover,
.ast-builder-menu .page-item-1502 > a:hover,
nav .page-item-1502 > a:hover,
li.page-item-1502 > a:hover,
.ast-mobile-popup-content .page-item-1502 > a:hover {
  color: #C61E68 !important;
}
/* ========================================================================
   Custom section types — Testimonials / Video / FAQ / Newsletter / HTML
   Appended to astra-child/style.css
   ======================================================================== */

.kwa-custom { padding: 60px 24px; }
.kwa-custom .kwa-section-head { text-align: center; margin-bottom: 30px; }

/* Testimonials */
.kwa-testimonials { background: var(--kwa-pink-wash, #FFF5FA); }
.kwa-testimonials-grid {
	display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
	max-width: 1100px; margin: 0 auto;
}
.kwa-testimonial {
	background: #fff; padding: 26px 24px; border-radius: 16px;
	box-shadow: 0 6px 20px rgba(0,0,0,.06); border-top: 4px solid var(--kwa-pink);
	display: flex; flex-direction: column; gap: 16px;
}
.kwa-testimonial-quote { font-size: 15px; line-height: 1.7; color: var(--kwa-ink); font-style: italic; flex: 1; }
.kwa-testimonial-author { display: flex; gap: 12px; align-items: center; }
.kwa-testimonial-photo {
	width: 50px; height: 50px; border-radius: 50%; background-size: cover; background-position: center;
	border: 3px solid var(--kwa-pink-soft, #FCE0EE); flex-shrink: 0;
}
.kwa-testimonial-name { font-weight: 700; color: var(--kwa-pink-dark, #C61E68); font-size: 14px; }
.kwa-testimonial-role { color: var(--kwa-cyan-dark, #128CA8); font-size: 12px; }
@media (max-width: 900px) { .kwa-testimonials-grid { grid-template-columns: 1fr; gap: 16px; } }

/* Video */
.kwa-video { background: #fff; }
.kwa-video-wrap {
	max-width: 900px; margin: 0 auto; position: relative; padding-bottom: 56.25%;
	border-radius: 16px; overflow: hidden; box-shadow: 0 12px 30px rgba(0,0,0,.12);
}
.kwa-video-wrap iframe { position: absolute; top:0; left:0; width:100%; height:100%; border:0; }

/* FAQ */
.kwa-faq { background: var(--kwa-cyan-soft, #D3F0F9); }
.kwa-faq-list { max-width: 800px; margin: 0 auto; display: flex; flex-direction: column; gap: 10px; }
.kwa-faq-item {
	background: #fff; border-radius: 12px; padding: 0; overflow: hidden;
	border: 1px solid rgba(0,0,0,.05); box-shadow: 0 2px 6px rgba(0,0,0,.04);
}
.kwa-faq-q {
	padding: 16px 22px; font-weight: 700; cursor: pointer; color: var(--kwa-ink);
	list-style: none; position: relative; padding-inline-end: 50px;
}
.kwa-faq-q::-webkit-details-marker { display: none; }
.kwa-faq-q::after {
	content: '+'; position: absolute; inset-inline-end: 22px; top: 50%; transform: translateY(-50%);
	width: 28px; height: 28px; background: var(--kwa-pink); color: #fff;
	border-radius: 50%; display: flex; align-items: center; justify-content: center;
	font-size: 18px; transition: transform .2s ease;
}
.kwa-faq-item[open] .kwa-faq-q::after { content: '–'; transform: translateY(-50%) rotate(180deg); }
.kwa-faq-a { padding: 0 22px 18px; color: var(--kwa-ink); line-height: 1.8; }

/* Newsletter */
.kwa-newsletter {
	background: linear-gradient(135deg, var(--kwa-pink) 0%, var(--kwa-cyan) 100%);
	color: #fff; text-align: center;
}
.kwa-newsletter .ktag { color: #fff; opacity: .9; }
.kwa-newsletter h2 { color: #fff !important; }
.kwa-newsletter p  { color: rgba(255,255,255,.92); }
.kwa-newsletter-form {
	max-width: 540px; margin: 14px auto 0; display: flex; gap: 8px; flex-wrap: wrap;
}
.kwa-newsletter-form input[type="email"] {
	flex: 1 1 220px; min-width: 200px; padding: 12px 18px; border: 0; border-radius: 999px;
	font-size: 14px; font-family: inherit; outline: none; background: #fff; color: var(--kwa-ink);
}
.kwa-newsletter-form button {
	padding: 12px 28px; border: 0; border-radius: 999px; background: var(--kwa-pink-dark, #C61E68);
	color: #fff; font-weight: 700; cursor: pointer; font-family: inherit; font-size: 14px;
}
.kwa-newsletter-form button:hover { background: var(--kwa-ink, #231F20); }
.kwa-newsletter-msg { margin-top: 14px; min-height: 22px; color: #fff; font-weight: 600; }

/* Custom HTML */
.kwa-html-block { background: #fff; }

/* === ABOUT PAGE (1468) — enlarged headings === */
body.page-id-1468 .elementor-widget-heading .elementor-heading-title {
  line-height: 1.25 !important;
  font-weight: 800 !important;
}
body.page-id-1468 h1.elementor-heading-title { font-size: 56px !important; }
body.page-id-1468 h2.elementor-heading-title { font-size: 44px !important; }
body.page-id-1468 h3.elementor-heading-title { font-size: 32px !important; }
@media (max-width: 921px) {
  body.page-id-1468 h1.elementor-heading-title { font-size: 38px !important; }
  body.page-id-1468 h2.elementor-heading-title { font-size: 30px !important; }
  body.page-id-1468 h3.elementor-heading-title { font-size: 22px !important; }
}
@media (max-width: 480px) {
  body.page-id-1468 h1.elementor-heading-title { font-size: 30px !important; }
  body.page-id-1468 h2.elementor-heading-title { font-size: 24px !important; }
}

/* === ABOUT PAGE (1468) — 4 tiles single row === */
/* Force the 4 feature tiles into a single row on desktop, regardless of inline-size math */
body.page-id-1468 .kwa-about-tiles {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: nowrap !important;
  align-items: stretch !important;
  gap: 18px !important;
}
body.page-id-1468 .kwa-about-tiles > .e-con,
body.page-id-1468 .kwa-about-tiles > .e-con-inner,
body.page-id-1468 .kwa-about-tiles > .elementor-element {
  flex: 1 1 0 !important;
  min-width: 0 !important;
  max-width: none !important;
  width: auto !important;
}
/* Tablet: 2 per row */
@media (max-width: 921px) {
  body.page-id-1468 .kwa-about-tiles {
    flex-wrap: wrap !important;
  }
  body.page-id-1468 .kwa-about-tiles > .e-con,
  body.page-id-1468 .kwa-about-tiles > .e-con-inner,
  body.page-id-1468 .kwa-about-tiles > .elementor-element {
    flex: 1 1 calc(50% - 12px) !important;
  }
}
/* Phone: 1 per row */
@media (max-width: 580px) {
  body.page-id-1468 .kwa-about-tiles > .e-con,
  body.page-id-1468 .kwa-about-tiles > .e-con-inner,
  body.page-id-1468 .kwa-about-tiles > .elementor-element {
    flex: 1 1 100% !important;
  }
}

/* === ABOUT PAGE (1468) — 8 tiles (top + قيمنا) centered === */
body.page-id-1468 .kwa-about-tiles .elementor-icon-box-wrapper,
body.page-id-1468 .kwa-about-tiles .elementor-icon-box-content,
body.page-id-1468 .kwa-about-tiles .elementor-icon-box-title,
body.page-id-1468 .kwa-about-tiles .elementor-icon-box-description {
  text-align: center !important;
}
body.page-id-1468 .kwa-about-tiles .elementor-icon-box-icon {
  text-align: center !important;
  margin: 0 auto 14px !important;
}
/* Make sure icon-box widget itself is transparent (no internal white card overlay) */
body.page-id-1468 .kwa-about-tiles .elementor-widget-icon-box {
  background: transparent !important;
  box-shadow: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
}

/* === Page gallery: 3-col desktop, 2-col mobile (handles Elementor .e-con-inner wrapper) === */
.kwa-page-gallery > .e-con-inner {
  display: flex !important;
  flex-direction: row !important;
  flex-wrap: wrap !important;
  gap: 18px !important;
  justify-content: center !important;
  align-items: stretch !important;
}
.kwa-page-gallery > .e-con-inner > * {
  flex: 0 0 calc(33.333% - 12px) !important;
  max-width: calc(33.333% - 12px) !important;
  min-width: 0 !important;
  margin: 0 !important;
  box-sizing: border-box !important;
}
.kwa-page-gallery img {
  width: 100% !important;
  height: auto !important;
  display: block !important;
  border-radius: 14px;
}
@media (max-width: 921px) {
  .kwa-page-gallery > .e-con-inner {
    gap: 14px !important;
  }
  .kwa-page-gallery > .e-con-inner > * {
    flex: 0 0 calc(50% - 7px) !important;
    max-width: calc(50% - 7px) !important;
  }
}
@media (max-width: 360px) {
  .kwa-page-gallery > .e-con-inner > * {
    flex: 0 0 100% !important;
    max-width: 100% !important;
  }
}

