/* ============ Bright Future Academy — Design System v2 ============ */
:root{
  /* Brand palette — Manara Elwady School (from logo) */
  --navy:#3a1a5c;        /* deep purple */
  --primary:#5b2b86;     /* brand purple (logo ring) */
  --primary-700:#46206a;
  --primary-50:#f1ebf8;
  --royal:#2d7dc5;       /* logo blue (lighthouse / wave) */
  --accent:#f6a91b;      /* logo gold (sun) */
  --accent-600:#d98f0a;
  --accent-50:#fdf3da;
  --green:#67bc46;       /* logo green (arc) */
  --teal:#67bc46;        /* alias kept for existing references */

  /* Neutrals */
  --bg:#ffffff;
  --surface:#f5f8fd;
  --surface-2:#eaf0fa;
  --text:#0b1220;
  --muted:#5a6b86;
  --border:#e5ebf4;
  --success:#16a34a;
  --danger:#dc2626;

  /* Gradients */
  --grad-primary:linear-gradient(135deg,#5b2b86 0%,#2d7dc5 100%);
  --grad-deep:linear-gradient(135deg,#3a1a5c 0%,#5b2b86 55%,#2d7dc5 100%);
  --grad-gold:linear-gradient(135deg,#f9c349 0%,#e2920d 100%);
  --grad-sheen:linear-gradient(120deg,transparent 30%,rgba(255,255,255,.35) 50%,transparent 70%);

  /* Shape */
  --radius:18px;
  --radius-lg:24px;
  --radius-sm:10px;
  --shadow-sm:0 1px 2px rgba(15,23,42,.05),0 2px 6px rgba(91,43,134,.06);
  --shadow:0 12px 28px -14px rgba(91,43,134,.32),0 6px 14px -8px rgba(15,23,42,.10);
  --shadow-lg:0 30px 60px -24px rgba(70,32,106,.42);
  --ring:0 0 0 4px var(--primary-50);

  --container:1200px;
  --header-h:80px;
  --font-en:'Poppins','Segoe UI',Arial,sans-serif;
  --font-display:'Fraunces','Poppins','Segoe UI',Georgia,serif;
  --font-ar:'Tajawal','Segoe UI',Tahoma,Arial,sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font-en);
  color:var(--text);
  background:var(--bg);
  line-height:1.7;
  font-size:16px;
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
html[lang="ar"] body{font-family:var(--font-ar);direction:rtl}
html[dir="rtl"] body{direction:rtl}
/* Use Tajawal for headings in Arabic, keep the serif display only for English */
html[lang="ar"] h1,html[lang="ar"] h2,html[lang="ar"] h3,html[lang="ar"] h4,
html[dir="rtl"] h1,html[dir="rtl"] h2,html[dir="rtl"] h3,html[dir="rtl"] h4{font-family:var(--font-ar)}

img{max-width:100%;height:auto;display:block}
a{color:var(--royal);text-decoration:none;transition:color .2s}
a:hover{color:var(--accent-600)}
button{font-family:inherit;cursor:pointer;border:none;background:none}
::selection{background:var(--accent);color:#1a1200}

h1,h2,h3,h4{line-height:1.18;color:var(--text);font-weight:700;letter-spacing:-.015em}
h1,h2{font-family:var(--font-display);font-weight:600}
h1{font-size:clamp(2.1rem,4.6vw,3.6rem)}
h2{font-size:clamp(1.7rem,3.2vw,2.6rem)}
h3{font-size:1.3rem;letter-spacing:-.01em}
p{color:var(--muted)}

.container{max-width:var(--container);margin:0 auto;padding:0 1.25rem}
section{padding:clamp(3.5rem,7vw,5.5rem) 0}
.section-head{text-align:center;max-width:740px;margin:0 auto 3.25rem}
.section-head p{margin-top:.85rem;font-size:1.05rem}

/* Eyebrow label with accent line */
.eyebrow,.section-head .eyebrow{
  display:inline-flex;align-items:center;gap:.6rem;
  color:var(--accent-600);font-weight:700;letter-spacing:.14em;
  text-transform:uppercase;font-size:.78rem;margin-bottom:.65rem;
}
.section-head .eyebrow{justify-content:center}
.eyebrow::before{content:"";width:26px;height:2px;background:var(--grad-gold);border-radius:2px}
.section-head .eyebrow::after{content:"";width:26px;height:2px;background:var(--grad-gold);border-radius:2px}

/* ===== Buttons ===== */
.btn{
  position:relative;overflow:hidden;
  display:inline-flex;align-items:center;justify-content:center;gap:.5rem;
  padding:.9rem 1.7rem;border-radius:999px;font-weight:600;font-size:.95rem;
  transition:transform .25s cubic-bezier(.34,1.56,.64,1),box-shadow .25s,background .25s,color .25s;
  white-space:nowrap;
}
.btn::after{ /* moving sheen */
  content:"";position:absolute;inset:0;background:var(--grad-sheen);
  transform:translateX(-130%);transition:transform .7s ease;
}
.btn:hover::after{transform:translateX(130%)}
.btn-primary{background:var(--grad-primary);color:#fff;box-shadow:var(--shadow)}
.btn-primary:hover{color:#fff;transform:translateY(-3px);box-shadow:var(--shadow-lg)}
.btn-accent{background:var(--grad-gold);color:#231600;box-shadow:0 10px 22px -10px rgba(217,138,0,.6)}
.btn-accent:hover{color:#231600;transform:translateY(-3px);box-shadow:0 18px 32px -12px rgba(217,138,0,.7)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1px solid rgba(255,255,255,.45);backdrop-filter:blur(6px)}
.btn-ghost:hover{background:#fff;color:var(--primary)}
.btn-outline{border:2px solid var(--primary);color:var(--primary)}
.btn-outline:hover{background:var(--primary);color:#fff;transform:translateY(-3px)}

/* ===== Scroll progress bar ===== */
.scroll-progress{
  position:fixed;top:0;left:0;height:3px;width:0;z-index:60;
  background:var(--grad-gold);box-shadow:0 0 12px rgba(245,166,35,.6);
}

/* ===== Skip to content (accessibility) ===== */
.skip-link{
  position:fixed;top:.6rem;left:50%;transform:translate(-50%,-150%);z-index:100;
  background:var(--primary);color:#fff;padding:.7rem 1.2rem;border-radius:999px;
  font-weight:600;font-size:.9rem;box-shadow:var(--shadow);transition:transform .2s ease;
}
.skip-link:focus{transform:translate(-50%,0);color:#fff}

/* ===== Header ===== */
.site-header{
  position:sticky;top:0;z-index:50;background:rgba(255,255,255,.82);
  backdrop-filter:saturate(1.6) blur(14px);
  border-bottom:1px solid transparent;transition:box-shadow .3s,border-color .3s,background .3s;
}
.site-header.scrolled{background:rgba(255,255,255,.94);border-bottom-color:var(--border);box-shadow:0 8px 30px -18px rgba(70,32,106,.4)}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  height:var(--header-h);max-width:var(--container);margin:0 auto;padding:0 1.25rem;
}
.brand{display:flex;align-items:center;gap:.7rem;font-weight:800;color:var(--primary);font-size:1.15rem}
.brand img{width:46px;height:46px;border-radius:50%;object-fit:contain}
.brand-name{line-height:1.1;font-family:var(--font-display);font-weight:600;letter-spacing:-.01em}
.brand-name small{display:block;font-size:.66rem;color:var(--muted);font-weight:600;letter-spacing:.18em;text-transform:uppercase;font-family:var(--font-en)}

.nav-links{display:flex;align-items:center;justify-content:center;gap:1.7rem;list-style:none;flex:1}
.nav-links a{color:var(--text);font-weight:500;font-size:.95rem;position:relative;padding:.4rem 0}
.nav-links a.active,.nav-links a:hover{color:var(--primary)}
.nav-links a::after{
  content:"";position:absolute;left:0;right:100%;bottom:-4px;height:3px;
  background:var(--grad-gold);border-radius:3px;transition:right .3s ease;
}
.nav-links a.active::after,.nav-links a:hover::after{right:0}
.nav-actions{display:flex;align-items:center;gap:.75rem}
.lang-switch{
  border:1px solid var(--border);background:#fff;padding:.5rem .9rem;border-radius:999px;
  font-weight:600;font-size:.85rem;color:var(--text);display:inline-flex;align-items:center;gap:.4rem;transition:all .2s;
}
.lang-switch:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}
.menu-toggle{display:none;width:44px;height:44px;border-radius:12px;background:var(--surface);align-items:center;justify-content:center}
.menu-toggle span{display:block;width:22px;height:2px;background:var(--text);position:relative;transition:.3s}
.menu-toggle span::before,.menu-toggle span::after{content:"";position:absolute;left:0;width:22px;height:2px;background:var(--text);transition:.3s}
.menu-toggle span::before{top:-7px}.menu-toggle span::after{top:7px}

@media (max-width:960px){
  .nav-links{
    position:fixed;inset:var(--header-h) 0 auto 0;background:#fff;flex-direction:column;
    padding:1.5rem;gap:1rem;border-bottom:1px solid var(--border);box-shadow:var(--shadow);
    transform:translateY(-130%);transition:transform .35s ease;
  }
  .nav-links.open{transform:translateY(0)}
  .nav-links a{font-size:1.05rem}
  .menu-toggle{display:inline-flex}
  .nav-actions .btn-primary{display:none}
}

/* ===== Hero ===== */
.hero{
  position:relative;color:#fff;min-height:clamp(560px,calc(100svh - var(--header-h)),820px);display:flex;align-items:center;overflow:hidden;
  background:linear-gradient(115deg,rgba(40,18,66,.80) 0%,rgba(74,32,106,.60) 45%,rgba(45,125,197,.36) 100%),var(--hero-bg,url('../images/hero.jpg')) center/cover no-repeat;
}
/* animated glow blobs */
.hero::before,.hero::after{
  content:"";position:absolute;border-radius:50%;filter:blur(70px);opacity:.5;z-index:0;pointer-events:none;
}
.hero::before{width:480px;height:480px;background:radial-gradient(circle,#7a3fb0,transparent 70%);top:-120px;right:-80px;animation:float1 14s ease-in-out infinite}
.hero::after{width:420px;height:420px;background:radial-gradient(circle,#f6a91b,transparent 70%);bottom:-140px;left:-60px;opacity:.38;animation:float2 18s ease-in-out infinite}
@keyframes float1{50%{transform:translate(-30px,40px) scale(1.1)}}
@keyframes float2{50%{transform:translate(40px,-30px) scale(1.08)}}
/* Full-width container; content constrained to an editorial column on the start side */
.hero-inner{position:relative;z-index:1;width:100%;padding-block:clamp(1.5rem,4vh,3rem)}
.hero-inner > *{max-width:760px}
.hero h1{color:#fff;letter-spacing:-.02em;text-shadow:0 2px 30px rgba(0,0,0,.25);font-size:clamp(2.4rem,5vw,4rem)}
.hero h1 .hl{background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}
.hero p{color:rgba(255,255,255,.92);font-size:1.2rem;margin:1.1rem 0 1.8rem;max-width:680px}
.hero-cta{display:flex;gap:.85rem;flex-wrap:wrap}
.hero-badge{
  display:inline-flex;align-items:center;gap:.55rem;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.3);padding:.45rem 1.05rem;border-radius:999px;
  font-size:.85rem;font-weight:600;margin-bottom:1.1rem;backdrop-filter:blur(6px);
}
.hero-badge .dot{width:9px;height:9px;background:var(--accent);border-radius:50%;box-shadow:0 0 0 0 rgba(245,166,35,.7);animation:pulse 2s infinite}
@keyframes pulse{70%{box-shadow:0 0 0 10px rgba(245,166,35,0)}100%{box-shadow:0 0 0 0 rgba(245,166,35,0)}}

/* floating glass stat strip inside hero */
.hero-trust{
  display:grid;grid-template-columns:repeat(3,1fr);margin-top:1.9rem;padding:1.15rem 1rem;
  background:rgba(255,255,255,.10);border:1px solid rgba(255,255,255,.2);
  border-radius:var(--radius);backdrop-filter:blur(8px);max-width:600px;
}
.hero-trust .t{display:flex;flex-direction:column;align-items:center;text-align:center;padding-inline:1rem;transition:transform .25s ease}
.hero-trust .t:hover{transform:translateY(-3px)}
.hero-trust .t + .t{border-inline-start:1px solid rgba(255,255,255,.22)}
.hero-trust .t b{
  font-family:var(--font-display);font-weight:700;font-size:clamp(1.55rem,2.3vw,2rem);line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  /* Keep numbers + symbols (+, %) in logical LTR order regardless of page direction */
  direction:ltr;unicode-bidi:isolate;
}
.hero-trust .t span{font-size:.82rem;color:rgba(255,255,255,.85);margin-top:.45rem;line-height:1.45}
@media (max-width:520px){
  .hero-trust{padding:1rem .4rem}
  .hero-trust .t{padding-inline:.5rem}
}

.scroll-cue{position:absolute;bottom:max(1rem,env(safe-area-inset-bottom));left:50%;transform:translateX(-50%);z-index:1;color:rgba(255,255,255,.8);display:flex;flex-direction:column;align-items:center;gap:.4rem;font-size:.72rem;letter-spacing:.2em;text-transform:uppercase}
@media (max-height:760px){.scroll-cue{display:none}}
.scroll-cue .mouse{width:24px;height:38px;border:2px solid rgba(255,255,255,.6);border-radius:14px;position:relative}
.scroll-cue .mouse::before{content:"";position:absolute;top:7px;left:50%;transform:translateX(-50%);width:4px;height:7px;background:#fff;border-radius:2px;animation:scrolldot 1.6s infinite}
@keyframes scrolldot{0%{opacity:0;top:7px}40%{opacity:1}80%{opacity:0;top:18px}}

/* ===== Trust / accreditation bar ===== */
.trustbar{background:var(--surface);border-bottom:1px solid var(--border);padding:1.4rem 0}
.trustbar .inner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:2.4rem;color:var(--muted);font-weight:600;font-size:.92rem}
.trustbar .inner span{display:inline-flex;align-items:center;gap:.5rem;white-space:nowrap}
.trustbar .inner .ic{color:var(--accent-600);font-size:1.15rem}

/* ===== Page hero (smaller) ===== */
.page-hero{
  position:relative;overflow:hidden;background:var(--grad-deep);
  color:#fff;padding:6.5rem 0 4.5rem;text-align:center;
}
.page-hero::after{content:"";position:absolute;width:520px;height:520px;border-radius:50%;background:radial-gradient(circle,rgba(245,166,35,.25),transparent 70%);top:-200px;right:-120px;pointer-events:none}
.page-hero .container{position:relative;z-index:1}
.page-hero h1{color:#fff}
.page-hero p{color:rgba(255,255,255,.88);margin-top:.85rem;max-width:680px;margin-inline:auto;font-size:1.08rem}
.breadcrumb{display:flex;justify-content:center;gap:.5rem;margin-top:1.4rem;font-size:.9rem;color:rgba(255,255,255,.8)}
.breadcrumb a{color:rgba(255,255,255,.95)}
.breadcrumb a:hover{color:var(--accent)}

/* ===== Cards / Grids ===== */
.grid{display:grid;gap:1.75rem}
.grid-3{grid-template-columns:repeat(3,1fr)}
.grid-4{grid-template-columns:repeat(4,1fr)}
.grid-2{grid-template-columns:repeat(2,1fr)}
@media (max-width:900px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}}
@media (max-width:600px){.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}

.card{
  position:relative;background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2rem 1.85rem;box-shadow:var(--shadow-sm);overflow:hidden;
  transition:transform .3s,box-shadow .3s,border-color .3s;
}
.card::before{ /* gradient top reveal */
  content:"";position:absolute;top:0;left:0;right:0;height:4px;
  background:var(--grad-primary);transform:scaleX(0);transform-origin:left;transition:transform .35s ease;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:transparent}
.card:hover::before{transform:scaleX(1)}
.card .icon{
  width:60px;height:60px;border-radius:16px;background:var(--primary-50);
  color:var(--primary);display:flex;align-items:center;justify-content:center;
  font-size:1.7rem;margin-bottom:1.15rem;transition:transform .3s,background .3s;
}
.card:hover .icon{transform:scale(1.08) rotate(-4deg);background:var(--accent-50)}
.card h3{margin-bottom:.5rem}

/* Feature cards with image */
.feature-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;
}
.feature-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.feature-card img{width:100%;height:230px;object-fit:cover;transition:transform .6s ease}
.feature-card:hover img{transform:scale(1.07)}
.feature-card .body{padding:1.6rem}
.feature-card h3{margin-bottom:.5rem}
.feature-card .tag{
  display:inline-block;background:var(--accent-50);color:var(--accent-600);
  font-size:.72rem;font-weight:700;padding:.3rem .7rem;border-radius:999px;
  text-transform:uppercase;letter-spacing:.08em;margin-bottom:.75rem;
}

/* ===== Stats ===== */
.stats{position:relative;overflow:hidden;background:var(--grad-deep);color:#fff}
.stats::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 20% 20%,rgba(124,63,176,.45),transparent 50%);pointer-events:none}
.stats .container{position:relative;z-index:1}
.stats .section-head h2,.stats .section-head p{color:#fff}
.stats .section-head p{color:rgba(255,255,255,.85)}
.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1.5rem;text-align:center}
@media (max-width:700px){.stats-grid{grid-template-columns:repeat(2,1fr)}}
.stat{padding:1.5rem 1rem;border-radius:var(--radius);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.1);transition:transform .3s,background .3s}
.stat:hover{transform:translateY(-5px);background:rgba(255,255,255,.1)}
.stat .num{font-family:var(--font-display);font-size:clamp(2.3rem,4vw,3.3rem);font-weight:600;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;line-height:1}
.stat .label{margin-top:.6rem;color:rgba(255,255,255,.9);font-weight:500}

/* ===== Welcome / about row ===== */
.split{display:grid;grid-template-columns:1.05fr 1fr;gap:3.5rem;align-items:center}
@media (max-width:900px){.split{grid-template-columns:1fr;gap:2.5rem}}
.split .media{position:relative}
.split img{border-radius:var(--radius-lg);box-shadow:var(--shadow-lg)}
.split .media::before{content:"";position:absolute;inset:-14px -14px auto auto;width:120px;height:120px;border-radius:20px;background:var(--grad-gold);opacity:.18;z-index:-1}
.split h2{margin-bottom:1rem}
.split ul{list-style:none;margin-top:1.5rem}
.split ul li{padding:.55rem 0;display:flex;gap:.7rem;color:var(--text);align-items:flex-start}
.split ul li::before{content:"✓";display:inline-flex;align-items:center;justify-content:center;flex-shrink:0;width:24px;height:24px;border-radius:50%;background:var(--primary-50);color:var(--success);font-weight:800;font-size:.85rem}

/* ===== Stages ===== */
.stages{background:var(--surface)}

/* ===== Testimonials ===== */
.testimonial{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:2.5rem 1.85rem 1.85rem;box-shadow:var(--shadow-sm);position:relative;transition:transform .3s,box-shadow .3s;
}
.testimonial:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.testimonial::before{
  content:"\201C";position:absolute;top:.4rem;left:1.4rem;font-size:4.5rem;line-height:1;
  background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;
  font-family:Georgia,serif;
}
html[dir="rtl"] .testimonial::before{left:auto;right:1.4rem}
.testimonial p{color:var(--text);margin-bottom:1.25rem;font-size:1.02rem}
.testimonial .stars{color:var(--accent);margin-bottom:.5rem;letter-spacing:.1em}
.testimonial .who{display:flex;align-items:center;gap:.85rem}
.testimonial .avatar{
  width:48px;height:48px;border-radius:50%;background:var(--grad-primary);
  display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;
}
.testimonial .name{font-weight:700;color:var(--text);font-size:.95rem}
.testimonial .role{font-size:.82rem;color:var(--muted)}

/* ===== CTA band ===== */
.cta-band{
  position:relative;overflow:hidden;background:var(--grad-deep);color:#fff;text-align:center;
  padding:4.5rem 1.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);
}
.cta-band::before{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(245,166,35,.3),transparent 70%);top:-150px;left:-100px}
.cta-band::after{content:"";position:absolute;width:400px;height:400px;border-radius:50%;background:radial-gradient(circle,rgba(103,188,70,.38),transparent 70%);bottom:-160px;right:-80px}
.cta-band > *{position:relative;z-index:1}
.cta-band h2{color:#fff;margin-bottom:.75rem}
.cta-band p{color:rgba(255,255,255,.92);max-width:620px;margin:0 auto 1.85rem}

/* ===== News ===== */
.news-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .3s,box-shadow .3s;
  display:flex;flex-direction:column;
}
.news-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.news-card img{height:200px;width:100%;object-fit:cover;transition:transform .6s ease}
.news-card:hover img{transform:scale(1.07)}
.news-card .body{padding:1.6rem;flex:1;display:flex;flex-direction:column}
.news-card .meta{font-size:.78rem;color:var(--accent-600);font-weight:600;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.55rem}
.news-card h3{font-size:1.15rem;margin-bottom:.5rem}
.news-card .more{margin-top:auto;font-weight:700;color:var(--primary);display:inline-flex;gap:.35rem;align-items:center}
.news-card .more:hover{gap:.6rem;color:var(--accent-600)}
.news-card h3 a{color:inherit}
.news-card h3 a:hover{color:var(--primary)}
.news-card-img{display:block;overflow:hidden}

/* ===== Pagination ===== */
.pagination{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-top:3rem}
.pagination .page{
  min-width:42px;height:42px;padding:0 .6rem;border-radius:12px;
  display:inline-flex;align-items:center;justify-content:center;
  border:1px solid var(--border);background:#fff;color:var(--text);font-weight:600;
  transition:background .2s,color .2s,border-color .2s,transform .2s;
}
.pagination a.page:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.pagination .page.active{background:var(--grad-primary);border-color:transparent;color:#fff}
.pagination .page.disabled{opacity:.4;pointer-events:none}
.pagination .page.dots{border:none;background:none}
.pagination .page svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
html[dir="rtl"] .pagination .page svg{transform:scaleX(-1)}

/* ===== Event details page ===== */
.event-hero-meta{display:flex;justify-content:center;flex-wrap:wrap;gap:.5rem;margin-bottom:1.1rem}
.event-hero-meta .chip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.28);color:#fff;font-size:.82rem;font-weight:600;padding:.35rem .9rem;border-radius:999px}
.event-cover{width:100%;max-height:480px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:1.8rem}
.event-lead{font-size:1.15rem;color:var(--text);font-weight:500;margin-bottom:1.4rem}
.event-body{color:var(--muted);line-height:1.9;font-size:1.05rem}
.event-body h2,.event-body h3{color:var(--text);margin:1.6rem 0 .7rem}
.event-body p{margin-bottom:1rem}
.event-body ul,.event-body ol{margin:0 0 1rem;padding-inline-start:1.4rem}
.event-body li{margin-bottom:.4rem}
.event-body img{border-radius:var(--radius);margin:1rem 0}
.event-back{margin-top:2.5rem;text-align:center}

/* ===== Forms ===== */
.form{
  background:#fff;padding:2.4rem;border-radius:var(--radius-lg);
  border:1px solid var(--border);box-shadow:var(--shadow);
}
.form .row{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}
@media (max-width:700px){.form .row{grid-template-columns:1fr}}
.field{margin-bottom:1.15rem}
.field label{display:block;font-weight:600;font-size:.9rem;margin-bottom:.45rem;color:var(--text)}
.field input,.field select,.field textarea{
  width:100%;padding:.85rem 1rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);
  font-family:inherit;font-size:.95rem;background:#fff;color:var(--text);transition:border-color .2s,box-shadow .2s;
}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--primary);box-shadow:var(--ring);
}
.field textarea{min-height:130px;resize:vertical}
.field .help{font-size:.8rem;color:var(--muted);margin-top:.35rem}
.field.error input,.field.error select,.field.error textarea{border-color:var(--danger)}
.field .err-msg{display:none;color:var(--danger);font-size:.82rem;margin-top:.35rem}
.field.error .err-msg{display:block}
.form .submit{margin-top:.5rem}
.form-success{
  display:none;background:#ecfdf5;border:1px solid #a7f3d0;color:#065f46;
  padding:1rem 1.25rem;border-radius:var(--radius-sm);margin-bottom:1rem;font-weight:600;
}
.form-success.show{display:block}

fieldset{border:1px solid var(--border);border-radius:var(--radius-sm);padding:1.25rem;margin-bottom:1.25rem}
fieldset legend{padding:0 .5rem;font-weight:700;color:var(--primary)}

/* ===== Contact info ===== */
.info-card{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.6rem;box-shadow:var(--shadow-sm);display:flex;gap:1rem;align-items:flex-start;
  transition:transform .3s,box-shadow .3s;
}
.info-card:hover{transform:translateY(-4px);box-shadow:var(--shadow)}
.info-card .icon{
  flex-shrink:0;width:50px;height:50px;border-radius:14px;background:var(--primary-50);
  color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:1.35rem;
}
.info-card h4{font-size:1rem;margin-bottom:.25rem}
.info-card p{font-size:.92rem;color:var(--muted);margin:0}

.map-wrap{
  border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow);
  border:1px solid var(--border);height:380px;
}
.map-wrap iframe{width:100%;height:100%;border:0}

/* ===== Gallery ===== */
.gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}
@media (max-width:700px){.gallery{grid-template-columns:repeat(2,1fr)}}
.gallery img{
  border-radius:var(--radius-sm);height:220px;width:100%;object-fit:cover;
  transition:transform .4s,box-shadow .4s,filter .4s;cursor:pointer;
}
.gallery img:hover{transform:scale(1.04);box-shadow:var(--shadow);filter:saturate(1.15)}

/* ===== Job list ===== */
.job{
  background:#fff;border:1px solid var(--border);border-radius:var(--radius);
  padding:1.6rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;gap:1rem;
  transition:border-color .25s,box-shadow .25s,transform .25s;
}
.job:hover{border-color:var(--primary);box-shadow:var(--shadow);transform:translateX(4px)}
html[dir="rtl"] .job:hover{transform:translateX(-4px)}
.job h3{font-size:1.1rem;margin-bottom:.25rem}
.job .meta{font-size:.85rem;color:var(--muted)}
.job .tag{display:inline-block;background:var(--primary-50);color:var(--primary);padding:.22rem .65rem;border-radius:999px;font-size:.75rem;font-weight:700;margin-right:.4rem}
html[dir="rtl"] .job .tag{margin-right:0;margin-left:.4rem}
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}
.filter-btn{
  padding:.55rem 1.1rem;border-radius:999px;border:1.5px solid var(--border);background:#fff;
  font-weight:600;font-size:.85rem;color:var(--text);transition:all .2s;
}
.filter-btn.active,.filter-btn:hover{background:var(--grad-primary);border-color:transparent;color:#fff}

/* ===== Footer ===== */
.site-footer{position:relative;background:#0a1330;color:#cbd5e1;padding:4.5rem 0 1.5rem;margin-top:0;overflow:hidden}
.site-footer::before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--grad-gold)}
.footer-grid{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.2fr;gap:2.5rem}
@media (max-width:900px){.footer-grid{grid-template-columns:repeat(2,1fr)}}
@media (max-width:550px){.footer-grid{grid-template-columns:1fr}}
.footer-grid h4{color:#fff;margin-bottom:1rem;font-size:.95rem;letter-spacing:.08em;text-transform:uppercase}
.footer-grid a{color:#cbd5e1;display:block;padding:.32rem 0;font-size:.92rem;transition:color .2s,padding .2s}
.footer-grid a:hover{color:var(--accent);padding-inline-start:.3rem}
/* Links inside paragraphs (phone/email) stay inline, not block nav links */
.footer-grid p a{display:inline;padding:0}
.footer-grid p a:hover{padding-inline-start:0}
.footer-grid p{color:#94a3b8;font-size:.92rem;margin-bottom:.5rem}
.footer-grid .brand{color:#fff;margin-bottom:1rem}
.footer-grid .brand small{color:#94a3b8}
.socials{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1.1rem}
/* Default (on light backgrounds, e.g. contact page) */
.socials a{
  width:42px;height:42px;border-radius:12px;background:var(--surface);border:1px solid var(--border);
  display:flex;align-items:center;justify-content:center;color:var(--primary);padding:0;transition:all .25s;
}
.socials a:hover{background:var(--grad-primary);color:#fff;border-color:transparent;transform:translateY(-3px);box-shadow:var(--shadow)}
/* Dark variant inside the footer */
.site-footer .socials a{background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15);color:#fff}
.site-footer .socials a:hover{background:var(--grad-gold);border-color:transparent;color:#231600}

/* ===== Stages page ===== */
.stage-nav{position:sticky;top:var(--header-h);z-index:40;background:rgba(255,255,255,.92);backdrop-filter:saturate(1.4) blur(12px);border-bottom:1px solid var(--border)}
.stage-nav .container{display:flex;gap:.5rem;justify-content:center;flex-wrap:wrap;padding-block:.7rem}
.stage-nav a{padding:.5rem 1.1rem;border-radius:999px;font-weight:600;font-size:.9rem;color:var(--muted);transition:background .2s,color .2s}
.stage-nav a:hover{background:var(--primary-50);color:var(--primary)}
.stage{scroll-margin-top:calc(var(--header-h) + 64px)}
.stage-badge{
  width:54px;height:54px;border-radius:16px;display:grid;place-items:center;margin-bottom:1rem;
  font-family:var(--font-display);font-weight:700;font-size:1.5rem;color:#fff;
  background:var(--grad-primary);box-shadow:var(--shadow);
}
.stage-facts{display:flex;flex-wrap:wrap;gap:.5rem;margin:.25rem 0 1.1rem}
.stage-facts .chip{
  display:inline-flex;align-items:center;padding:.4rem .85rem;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);font-size:.82rem;font-weight:600;color:var(--primary);
}
/* Reuse the working .split ul check layout; just give stages a gold check. */
.split ul.stage-features{margin-top:1.1rem}
.split ul.stage-features li::before{background:var(--grad-gold);color:#231600}
/* Alternating stages: flip the image to the opposite column on even rows */
@media (min-width:901px){.split-reverse > img{order:2}}

/* ===== Activities listing + cards ===== */
.news-card-img{display:block;overflow:hidden}
.news-card h3 a,.feature-card h3 a{color:inherit}
.news-card h3 a:hover,.feature-card h3 a:hover{color:var(--primary)}

/* ===== Pagination ===== */
.pagination{display:flex;justify-content:center;align-items:center;gap:.4rem;margin-top:2.75rem;flex-wrap:wrap}
.pagination .page{
  min-width:42px;height:42px;padding:0 .6rem;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;
  font-weight:600;font-size:.95rem;color:var(--text);background:#fff;border:1px solid var(--border);transition:all .2s;
}
.pagination a.page:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px);box-shadow:var(--shadow-sm)}
.pagination .page.active{background:var(--grad-primary);color:#fff;border-color:transparent}
.pagination .page.disabled{opacity:.4;cursor:not-allowed}
.pagination .page.dots{border:none;background:transparent}
.pagination .page svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
html[dir="rtl"] .pagination .page svg{transform:scaleX(-1)}

/* ===== Activity (event) details page ===== */
.event-hero-meta{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:center;margin-bottom:1rem}
.event-hero-meta .chip{background:rgba(255,255,255,.14);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:999px;padding:.35rem .9rem;font-size:.82rem;font-weight:600;backdrop-filter:blur(6px)}
.event-cover{width:100%;max-height:460px;object-fit:cover;border-radius:var(--radius-lg);box-shadow:var(--shadow);margin-bottom:1.75rem}
.event-lead{font-size:1.2rem;color:var(--text);font-weight:500;line-height:1.7;margin-bottom:1.25rem}
.event-body{font-size:1.05rem;line-height:1.9;color:var(--muted)}
.event-body h2,.event-body h3{color:var(--text);margin:1.6rem 0 .6rem}
.event-body p{margin-bottom:1rem}
.event-body ul,.event-body ol{margin:0 0 1rem;padding-inline-start:1.4rem}
.event-body li{margin-bottom:.4rem}
.event-body img{border-radius:var(--radius);margin:1rem 0}
.event-back{margin-top:2.5rem;text-align:center}

/* ===== Multi-step wizard (careers application) ===== */
.container-narrow{max-width:820px;margin-inline:auto}
.wizard{background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:clamp(1.5rem,4vw,2.5rem)}
.wizard-steps{list-style:none;display:flex;gap:.5rem;margin:0 0 1rem;padding:0;counter-reset:none}
.wizard-steps li{flex:1;display:flex;flex-direction:column;align-items:center;gap:.4rem;text-align:center;font-size:.82rem;font-weight:600;color:var(--muted);position:relative}
.wizard-steps li span{
  width:38px;height:38px;border-radius:50%;display:grid;place-items:center;font-family:var(--font-display);
  background:var(--surface);border:2px solid var(--border);color:var(--muted);transition:all .25s;
}
.wizard-steps li.active{color:var(--primary)}
.wizard-steps li.active span{background:var(--grad-primary);border-color:transparent;color:#fff}
.wizard-steps li.done span{background:var(--green);border-color:transparent;color:#fff}
.wizard-progress{height:6px;border-radius:999px;background:var(--surface-2);overflow:hidden;margin-bottom:1.8rem}
.wizard-progress span{display:block;height:100%;background:var(--grad-primary);border-radius:999px;transition:width .4s ease}
.wizard-actions{display:flex;gap:.75rem;justify-content:space-between;margin-top:1.5rem}
.wizard-actions .btn{min-width:130px}
.wizard-actions .btn-primary{margin-inline-start:auto}
.radio-row{display:flex;gap:.75rem;margin-top:.3rem}
.radio-pill{display:inline-flex;align-items:center;gap:.5rem;padding:.6rem 1.2rem;border:1px solid var(--border);border-radius:999px;cursor:pointer;font-weight:600;transition:border-color .2s,background .2s}
.radio-pill:has(input:checked){border-color:var(--primary);background:var(--primary-50);color:var(--primary)}
.wizard-success{text-align:center;padding:2rem 1rem}
.wizard-success-icon{
  width:72px;height:72px;border-radius:50%;margin:0 auto 1.2rem;display:grid;place-items:center;
  background:var(--grad-gold);color:#231600;font-size:2rem;font-weight:800;
}
.wizard-success h3{font-size:1.5rem;margin-bottom:.5rem}
.wizard-success p{max-width:460px;margin-inline:auto}
@media (max-width:560px){
  .wizard-steps li{font-size:0}
  .wizard-steps li span{font-size:1rem}
}

/* ===== Contact page sidebar ===== */
.contact-side{display:flex;flex-direction:column;gap:1.5rem}
.contact-actions{display:flex;gap:.7rem;flex-wrap:wrap}
.contact-actions .btn{flex:1;min-width:170px}
.contact-actions .btn svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.contact-hours{display:flex;align-items:center;gap:1rem;padding:1.1rem 1.25rem;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius)}
.contact-hours .icon{flex:0 0 auto;width:48px;height:48px;border-radius:14px;background:var(--primary-50);color:var(--primary);display:grid;place-items:center}
.contact-hours .icon svg{width:24px;height:24px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.contact-hours h4{font-size:1rem;margin:0}
.contact-hours p{font-size:.9rem;color:var(--muted);margin:0}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.1);margin-top:3rem;padding-top:1.5rem;
  display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:#94a3b8;
}
.footer-bottom a{color:#cbd5e1}
.footer-bottom a:hover{color:var(--accent)}

/* ===== Back to top ===== */
.to-top{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:55;width:48px;height:48px;border-radius:14px;
  background:var(--grad-primary);color:#fff;display:flex;align-items:center;justify-content:center;
  font-size:1.2rem;box-shadow:var(--shadow);opacity:0;visibility:hidden;transform:translateY(12px);
  transition:opacity .3s,transform .3s,visibility .3s;
}
html[dir="rtl"] .to-top{right:auto;left:1.5rem}
.to-top.show{opacity:1;visibility:visible;transform:translateY(0)}
.to-top:hover{transform:translateY(-3px);box-shadow:var(--shadow-lg)}

/* ===== Animations ===== */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s ease,transform .7s cubic-bezier(.22,1,.36,1)}
.reveal.in{opacity:1;transform:none}
.reveal[data-delay="1"]{transition-delay:.1s}
.reveal[data-delay="2"]{transition-delay:.2s}
.reveal[data-delay="3"]{transition-delay:.3s}

@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition-duration:.01ms!important;scroll-behavior:auto}
  .reveal{opacity:1;transform:none}
}

/* RTL micro-tweaks */
html[dir="rtl"] .nav-links a::after{right:0;left:100%}
html[dir="rtl"] .nav-links a.active::after,html[dir="rtl"] .nav-links a:hover::after{left:0;right:0}

/* Focus accessibility */
:focus-visible{outline:3px solid var(--accent);outline-offset:2px;border-radius:6px}

/* ============ v3 additions: SVG icons, dividers, bento, timeline ============ */

/* ----- SVG line icons (replace emoji) ----- */
.icon svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}
.card .icon{background:linear-gradient(135deg,var(--primary-50),#fff);box-shadow:inset 0 0 0 1px var(--border)}
.card:hover .icon{background:linear-gradient(135deg,var(--accent-50),#fff);color:var(--accent-600)}
.info-card .icon svg{width:24px;height:24px}
.trustbar .inner .ic svg{width:18px;height:18px;stroke-width:2}

/* ----- Curved / wave section dividers ----- */
.wave-top,.wave-bottom{position:absolute;left:0;width:100%;height:64px;display:block;z-index:1;pointer-events:none}
.wave-top{top:-1px}
.wave-bottom{bottom:-1px}
.stats .container{z-index:2}
@media (max-width:600px){.wave-top,.wave-bottom{height:36px}}

/* subtle dotted/grid texture for alternating sections */
.section-pattern{position:relative}
.section-pattern::before{
  content:"";position:absolute;inset:0;z-index:0;pointer-events:none;opacity:.5;
  background-image:radial-gradient(var(--border) 1.1px,transparent 1.1px);
  background-size:26px 26px;
  -webkit-mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
          mask-image:linear-gradient(180deg,transparent,#000 30%,#000 70%,transparent);
}
.section-pattern > .container{position:relative;z-index:1}

/* ----- Bento grid (feature highlights) ----- */
.bento{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:1fr;gap:1.4rem}
.bento .card{margin:0}
.bento .b-wide{grid-column:span 2}
.bento .b-feature{
  grid-row:span 2;color:#fff;border:none;
  background:var(--grad-deep);display:flex;flex-direction:column;justify-content:flex-end;
  position:relative;overflow:hidden;
}
.bento .b-feature::after{content:"";position:absolute;width:240px;height:240px;border-radius:50%;background:radial-gradient(circle,rgba(245,166,35,.35),transparent 70%);top:-70px;right:-50px}
.bento .b-feature::before{display:none}
.bento .b-feature .icon{background:rgba(255,255,255,.12);box-shadow:none;color:#fff}
.bento .b-feature h3{color:#fff;font-family:var(--font-display);font-size:1.6rem}
.bento .b-feature p{color:rgba(255,255,255,.85)}
.bento .b-feature .eyebrow{color:var(--accent)}
@media (max-width:900px){
  .bento{grid-template-columns:repeat(2,1fr)}
  .bento .b-wide,.bento .b-feature{grid-column:span 2;grid-row:auto}
}
@media (max-width:600px){.bento{grid-template-columns:1fr}.bento .b-wide,.bento .b-feature{grid-column:auto}}

/* ----- Timeline (stages on homepage / about) ----- */
.timeline{position:relative;max-width:940px;margin:0 auto;padding-inline-start:0}
.timeline::before{content:"";position:absolute;top:8px;bottom:8px;left:50%;width:2px;background:linear-gradient(var(--accent),var(--primary));transform:translateX(-50%)}
.tl-item{position:relative;width:50%;padding:0 2.1rem 1.6rem}
/* Logical offsets so the alternating layout mirrors correctly in RTL */
.tl-item:nth-child(odd){inset-inline-start:0;text-align:end}
.tl-item:nth-child(even){inset-inline-start:50%;text-align:start}
.tl-item .dot{position:absolute;top:2px;width:16px;height:16px;border-radius:50%;background:var(--accent);border:3px solid #fff;box-shadow:0 0 0 2px var(--accent)}
.tl-item:nth-child(odd) .dot{inset-inline-end:-8px}
.tl-item:nth-child(even) .dot{inset-inline-start:-8px}
.tl-item .tl-tag{display:inline-block;font-size:.82rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--accent-600);margin-bottom:.4rem}
.tl-item h3{font-family:var(--font-display);font-size:1.55rem;margin-bottom:.55rem}
.tl-item p{font-size:1.06rem;line-height:1.75}
.tl-item .more{font-size:1rem;display:inline-block;margin-top:.5rem}
@media (max-width:680px){
  .timeline::before{inset-inline-start:9px;left:auto;right:auto}
  .tl-item{width:100%;inset-inline-start:0!important;text-align:start!important;padding:0 0 2.2rem;padding-inline-start:2.2rem}
  .tl-item .dot{inset-inline-start:1px!important;inset-inline-end:auto!important}
}

/* ----- Principal message ----- */
.principal{background:var(--surface)}
.principal-card{
  display:grid;grid-template-columns:.85fr 1.15fr;gap:0;align-items:stretch;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-lg);
  overflow:hidden;box-shadow:var(--shadow);
}
.principal-card .photo{position:relative;min-height:380px}
.principal-card .photo img{width:100%;height:100%;object-fit:cover;position:absolute;inset:0}
.principal-card .photo::after{content:"";position:absolute;inset:0;background:linear-gradient(120deg,transparent,rgba(70,32,106,.25))}
.principal-card .text{padding:3rem 2.75rem;position:relative}
.principal-card .quote-mark{font-family:Georgia,serif;font-size:5rem;line-height:.7;background:var(--grad-gold);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;display:block;margin-bottom:.5rem}
.principal-card blockquote{font-family:var(--font-display);font-size:1.3rem;line-height:1.5;color:var(--text);font-weight:500;margin-bottom:1.5rem}
.principal-card .sign .name{font-weight:700;color:var(--primary)}
.principal-card .sign .title{font-size:.88rem;color:var(--muted)}
@media (max-width:780px){.principal-card{grid-template-columns:1fr}.principal-card .photo{min-height:300px}.principal-card .text{padding:2.25rem 1.75rem}}

/* ----- Accreditation logo strip ----- */
.accred{display:flex;flex-wrap:wrap;justify-content:center;align-items:center;gap:1rem}
.accred .badge{
  display:flex;align-items:center;gap:.7rem;padding:.85rem 1.4rem;border-radius:999px;
  background:#fff;border:1px solid var(--border);box-shadow:var(--shadow-sm);font-weight:600;color:var(--text);font-size:.92rem;
  transition:transform .25s,box-shadow .25s,border-color .25s;
}
.accred .badge:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--accent)}
.accred .badge svg{width:24px;height:24px;color:var(--accent-600);fill:none;stroke:currentColor;stroke-width:1.7;stroke-linecap:round;stroke-linejoin:round}

/* ----- Step number badges (admission) ----- */
.card .icon.step{font-family:var(--font-display);font-weight:600;font-size:1.7rem;color:var(--primary);background:linear-gradient(135deg,var(--primary-50),#fff)}

/* ============ Preloader ============ */
.preloader{
  position:fixed;inset:0;z-index:9999;
  display:grid;place-items:center;
  background:var(--bg);
  transition:opacity .5s ease,visibility .5s ease;
}
.preloader.is-hidden{opacity:0;visibility:hidden;pointer-events:none}
.preloader-box{position:relative;display:grid;place-items:center;width:88px;height:88px}
.preloader-ring{
  position:absolute;inset:0;border-radius:50%;
  border:3px solid var(--surface-2);
  border-top-color:var(--accent);
  animation:bfa-spin .9s linear infinite;
}
.preloader-logo{
  width:48px;height:48px;object-fit:contain;
  animation:bfa-pulse 1.4s ease-in-out infinite;
}
@keyframes bfa-spin{to{transform:rotate(360deg)}}
@keyframes bfa-pulse{0%,100%{transform:scale(1);opacity:.85}50%{transform:scale(1.08);opacity:1}}
@media (prefers-reduced-motion:reduce){
  .preloader-ring,.preloader-logo{animation:none}
  .preloader{transition:none}
}

/* ============ Nav dropdown (Stages) ============ */
.has-dropdown{position:relative}
.dropdown-trigger{display:inline-flex;align-items:center;gap:.3rem}
.dropdown-trigger .caret{width:14px;height:14px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round;transition:transform .25s}
.has-dropdown:hover .dropdown-trigger .caret,.has-dropdown.open .dropdown-trigger .caret{transform:rotate(180deg)}
.dropdown-menu{
  position:absolute;inset-inline-start:0;top:calc(100% + .6rem);min-width:230px;
  background:#fff;border:1px solid var(--border);border-radius:var(--radius-sm);
  box-shadow:var(--shadow);padding:.5rem;list-style:none;display:grid;gap:.15rem;
  opacity:0;visibility:hidden;transform:translateY(8px);transition:opacity .22s,transform .22s,visibility .22s;z-index:60;
}
.has-dropdown:hover .dropdown-menu,.has-dropdown:focus-within .dropdown-menu,.has-dropdown.open .dropdown-menu{opacity:1;visibility:visible;transform:translateY(0)}
.dropdown-menu a{display:block;padding:.6rem .85rem;border-radius:8px;font-size:.92rem;font-weight:500;color:var(--text);transition:background .2s,color .2s}
.dropdown-menu a:hover{background:var(--primary-50);color:var(--primary)}
.nav-cta-mobile{display:none}

@media (max-width:960px){
  .has-dropdown .dropdown-menu{
    position:static;opacity:1;visibility:visible;transform:none;box-shadow:none;border:none;
    padding:.25rem 0 .25rem 1rem;min-width:0;display:none;
  }
  .has-dropdown.open .dropdown-menu{display:grid}
  .nav-cta-mobile{display:block;margin-top:.5rem}
  .nav-cta-mobile .btn{width:100%}
}

/* ============ Testimonials slider ============ */
.tst-slider{position:relative;display:flex;align-items:center;gap:.5rem}
.tst-viewport{overflow:hidden;flex:1;padding:.5rem 0}
.tst-track{display:flex;gap:1.75rem;will-change:transform;transition:transform .55s cubic-bezier(.4,0,.2,1)}
.tst-track .testimonial{flex:0 0 auto}
.tst-nav{
  flex:0 0 auto;width:46px;height:46px;border-radius:50%;background:#fff;
  border:1px solid var(--border);box-shadow:var(--shadow-sm);
  display:inline-flex;align-items:center;justify-content:center;color:var(--primary);
  transition:transform .25s,box-shadow .25s,background .25s,color .25s;
}
.tst-nav svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
.tst-nav:hover{background:var(--primary);color:#fff;transform:translateY(-2px);box-shadow:var(--shadow)}
.tst-nav:disabled{opacity:.4;cursor:not-allowed;transform:none;background:#fff;color:var(--primary)}
html[dir="rtl"] .tst-nav svg{transform:scaleX(-1)}
.tst-dots{position:absolute;bottom:-2.4rem;left:0;right:0;display:flex;justify-content:center;gap:.5rem}
.tst-dots button{width:9px;height:9px;border-radius:50%;background:var(--surface-2);border:none;transition:all .25s}
.tst-dots button.active{background:var(--accent);width:26px;border-radius:999px}
@media (max-width:600px){.tst-nav{display:none}}

/* ============ Gallery + Lightbox ============ */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);grid-auto-rows:200px;gap:1rem}
.gallery-item{position:relative;overflow:hidden;border-radius:var(--radius);display:block;box-shadow:var(--shadow-sm)}
.gallery-item.lg{grid-column:span 2;grid-row:span 2}
.gallery-item img{width:100%;height:100%;object-fit:cover;transition:transform .6s ease}
.gallery-item:hover img{transform:scale(1.08)}
.gallery-item::after{content:"";position:absolute;inset:0;background:linear-gradient(to top,rgba(11,18,40,.45),transparent 55%);opacity:0;transition:opacity .3s}
.gallery-item:hover::after{opacity:1}
.gallery-zoom{
  position:absolute;inset-inline-end:.9rem;bottom:.9rem;width:42px;height:42px;border-radius:50%;
  background:rgba(255,255,255,.9);display:grid;place-items:center;color:var(--primary);
  transform:scale(.6);opacity:0;transition:transform .3s,opacity .3s;z-index:1;
}
.gallery-item:hover .gallery-zoom{transform:scale(1);opacity:1}
.gallery-zoom svg{width:20px;height:20px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round}
@media (max-width:760px){
  .gallery{grid-template-columns:repeat(2,1fr);grid-auto-rows:150px}
  .gallery-item.lg{grid-column:span 2;grid-row:span 1}
}

.lightbox{
  position:fixed;inset:0;z-index:9998;display:flex;align-items:center;justify-content:center;
  background:rgba(8,12,28,.88);backdrop-filter:blur(4px);padding:2rem;
  opacity:0;visibility:hidden;transition:opacity .3s,visibility .3s;
}
.lightbox.open{opacity:1;visibility:visible}
.lightbox img{max-width:min(92vw,1100px);max-height:82vh;border-radius:var(--radius);box-shadow:var(--shadow-lg);transform:scale(.95);transition:transform .3s}
.lightbox.open img{transform:scale(1)}
.lightbox-cap{position:absolute;bottom:1.4rem;left:0;right:0;text-align:center;color:#fff;font-weight:500;padding:0 1rem}
.lightbox-close,.lightbox-arrow{
  position:absolute;width:50px;height:50px;border-radius:50%;background:rgba(255,255,255,.14);
  border:1px solid rgba(255,255,255,.3);color:#fff;display:grid;place-items:center;
  transition:background .2s,transform .2s;
}
.lightbox-close:hover,.lightbox-arrow:hover{background:rgba(255,255,255,.28)}
.lightbox-close{top:1.4rem;inset-inline-end:1.4rem}
.lightbox-arrow{top:50%;transform:translateY(-50%)}
.lightbox-arrow.prev{inset-inline-start:1.4rem}
.lightbox-arrow.next{inset-inline-end:1.4rem}
.lightbox-arrow:hover{transform:translateY(-50%) scale(1.06)}
.lightbox svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:2.2;stroke-linecap:round;stroke-linejoin:round}
html[dir="rtl"] .lightbox-arrow svg{transform:scaleX(-1)}

/* ============ FAQ accordion ============ */
.faq{max-width:820px;margin:0 auto;display:grid;gap:.9rem}
.faq-item{background:#fff;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;transition:box-shadow .3s,border-color .3s}
.faq-item.open{box-shadow:var(--shadow);border-color:transparent}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:1rem;
  padding:1.2rem 1.5rem;font-size:1.05rem;font-weight:600;color:var(--text);text-align:start;line-height:1.5;
}
.faq-q .faq-icon{flex:0 0 auto;width:22px;height:22px;fill:none;stroke:var(--primary);stroke-width:2.2;stroke-linecap:round;transition:transform .3s}
.faq-item.open .faq-q .faq-icon{transform:rotate(45deg);stroke:var(--accent-600)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s ease}
.faq-a p{padding:0 1.5rem 1.3rem;margin:0}

/* ============ Floating WhatsApp ============ */
.wa-float{
  position:fixed;inset-inline-end:1.25rem;bottom:1.25rem;z-index:80;
  width:58px;height:58px;border-radius:50%;background:#25d366;color:#fff;
  display:grid;place-items:center;box-shadow:0 12px 28px -8px rgba(37,211,102,.6);
  transition:transform .25s,box-shadow .25s;
}
.wa-float:hover{transform:translateY(-3px) scale(1.05);color:#fff;box-shadow:0 18px 34px -10px rgba(37,211,102,.7)}
.wa-float svg{width:30px;height:30px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round;position:relative;z-index:1}
.wa-pulse{position:absolute;inset:0;border-radius:50%;background:#25d366;opacity:.55;animation:wa-ping 2s ease-out infinite}
@keyframes wa-ping{0%{transform:scale(1);opacity:.55}80%,100%{transform:scale(1.8);opacity:0}}

/* ============ Mobile sticky CTA bar ============ */
.mobile-cta{
  position:fixed;left:0;right:0;bottom:0;z-index:70;display:none;align-items:center;gap:.55rem;
  padding:.6rem .8rem calc(.6rem + env(safe-area-inset-bottom));
  background:rgba(255,255,255,.97);backdrop-filter:saturate(1.4) blur(12px);
  border-top:1px solid var(--border);box-shadow:0 -10px 30px -18px rgba(70,32,106,.55);
}
.mobile-cta-icon{
  flex:0 0 auto;width:50px;height:50px;border-radius:14px;
  display:grid;place-items:center;background:var(--surface);color:var(--primary);
  border:1px solid var(--border);transition:background .2s,color .2s,transform .2s;
}
.mobile-cta-icon:active{transform:scale(.94)}
.mobile-cta-icon:hover{background:var(--primary);color:#fff}
.mobile-cta-icon svg{width:22px;height:22px;fill:none;stroke:currentColor;stroke-width:1.9;stroke-linecap:round;stroke-linejoin:round}
.mobile-cta .mobile-cta-main{
  flex:1;height:50px;padding:0 1rem;border-radius:14px;font-size:1rem;font-weight:700;
}
.mobile-cta .mobile-cta-main:hover{transform:none}
@media (max-width:760px){
  .mobile-cta{display:flex}
  .wa-float{bottom:5.4rem}
  body{padding-bottom:4.8rem}
}

/* ============ Social icons ============ */
.socials a svg{width:18px;height:18px;fill:none;stroke:currentColor;stroke-width:1.8;stroke-linecap:round;stroke-linejoin:round}

/* ============ Accessibility: focus-visible ============ */
:focus-visible{outline:3px solid var(--royal);outline-offset:3px;border-radius:6px}
.btn:focus-visible,.lang-switch:focus-visible,.nav-links a:focus-visible{outline-offset:4px}
.wa-float:focus-visible,.tst-nav:focus-visible{outline:3px solid var(--accent);outline-offset:3px}

/* ============ Custom scrollbar ============ */
@supports (scrollbar-color: auto){html{scrollbar-color:var(--primary) var(--surface);scrollbar-width:thin}}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:var(--surface)}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--primary),var(--royal));border-radius:999px;border:3px solid var(--surface)}
::-webkit-scrollbar-thumb:hover{background:var(--primary-700)}

/* ============ Respect reduced motion globally ============ */
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{
    animation-duration:.001ms !important;animation-iteration-count:1 !important;
    transition-duration:.001ms !important;scroll-behavior:auto !important;
  }
  .reveal{opacity:1 !important;transform:none !important}
}
