/* ============================================================
   Premium Rebrandable Coaching Centre Website
   style.css  -  modern edtech UI, mobile-first
   Theme colours are injected as CSS variables from admin.
   ============================================================ */

:root{
  --c-primary:#0a1f44;
  --c-secondary:#1e6fff;
  --c-accent:#ff7a00;

  --c-dark:#0b1530;
  --c-ink:#1a2238;
  --c-muted:#5b6478;
  --c-line:#e7ebf3;
  --c-bg:#f6f8fc;
  --c-white:#ffffff;

  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 4px 14px rgba(10,31,68,.07);
  --shadow:0 18px 50px rgba(10,31,68,.12);
  --shadow-lg:0 30px 70px rgba(10,31,68,.20);
  --maxw:1200px;
  --grad:linear-gradient(135deg,var(--c-secondary),var(--c-primary));
  --grad-accent:linear-gradient(135deg,var(--c-accent),#ff9d3c);
  --ease:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:'Plus Jakarta Sans','Segoe UI',system-ui,-apple-system,Roboto,Arial,sans-serif;
  color:var(--c-ink);
  background:var(--c-bg);
  line-height:1.65;
  overflow-x:hidden;
}
img{max-width:100%;display:block}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{line-height:1.2;color:var(--c-primary);font-weight:800;letter-spacing:-.02em}
p{color:var(--c-muted)}
section{position:relative}

.container{width:100%;max-width:var(--maxw);margin:0 auto;padding:0 20px}
.section{padding:74px 0}
.section-sm{padding:46px 0}
.text-center{text-align:center}
.muted{color:var(--c-muted)}
.accent{color:var(--c-accent)}
.grad-text{background:var(--grad);-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- Section heading ---------- */
.eyebrow{
  display:inline-block;font-weight:700;font-size:.78rem;letter-spacing:.14em;
  text-transform:uppercase;color:var(--c-secondary);
  background:rgba(30,111,255,.10);padding:7px 16px;border-radius:50px;margin-bottom:14px;
}
.section-head{max-width:680px;margin:0 auto 46px}
.section-head.left{margin-left:0;text-align:left}
.section-head h2{font-size:clamp(1.7rem,3.4vw,2.55rem);margin-bottom:12px}
.section-head p{font-size:1.02rem}

/* ---------- Buttons ---------- */
.btn{
  display:inline-flex;align-items:center;gap:9px;justify-content:center;
  font-weight:700;font-size:.96rem;padding:14px 26px;border-radius:50px;
  border:0;cursor:pointer;transition:.3s var(--ease);white-space:nowrap;
  font-family:inherit;line-height:1;
}
.btn svg{width:18px;height:18px}
.btn-primary{background:var(--grad-accent);color:#fff;box-shadow:0 12px 30px rgba(255,122,0,.35)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 18px 40px rgba(255,122,0,.45)}
.btn-blue{background:var(--grad);color:#fff;box-shadow:0 12px 30px rgba(30,111,255,.32)}
.btn-blue:hover{transform:translateY(-3px)}
.btn-wa{background:#25D366;color:#fff}
.btn-wa:hover{transform:translateY(-3px);box-shadow:0 14px 30px rgba(37,211,102,.4)}
.btn-ghost{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.4);backdrop-filter:blur(8px)}
.btn-ghost:hover{background:rgba(255,255,255,.22)}
.btn-outline{background:transparent;color:var(--c-primary);border:1.6px solid var(--c-line)}
.btn-outline:hover{border-color:var(--c-secondary);color:var(--c-secondary)}
.btn-light{background:#fff;color:var(--c-primary);box-shadow:var(--shadow-sm)}
.btn-light:hover{transform:translateY(-3px)}
.btn-sm{padding:10px 18px;font-size:.85rem}
.btn-block{width:100%}

/* ============================================================
   HEADER / NAV
   ============================================================ */
.topbar{background:var(--c-primary);color:#cfe0ff;font-size:.82rem}
.topbar .container{display:flex;justify-content:space-between;align-items:center;gap:14px;padding-top:9px;padding-bottom:9px;flex-wrap:wrap}
.topbar a{color:#cfe0ff;transition:.2s}
.topbar a:hover{color:#fff}
.topbar .tb-left{display:flex;gap:20px;flex-wrap:wrap}
.topbar .tb-item{display:flex;align-items:center;gap:7px}
.topbar .tb-social{display:flex;gap:14px}

.site-header{
  position:sticky;top:0;z-index:900;background:rgba(255,255,255,.92);
  backdrop-filter:blur(14px);border-bottom:1px solid var(--c-line);
  transition:.3s;
}
.site-header.scrolled{box-shadow:var(--shadow-sm)}
.nav{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:14px 0}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand img{height:46px;width:auto}
.brand .brand-logo-fallback{
  width:46px;height:46px;border-radius:12px;background:var(--grad);
  color:#fff;display:grid;place-items:center;font-weight:800;font-size:1.25rem;flex-shrink:0;
}
.brand .brand-text strong{display:block;color:var(--c-primary);font-size:1.12rem;font-weight:800;line-height:1.1}
.brand .brand-text span{font-size:.72rem;color:var(--c-muted);font-weight:600}

.nav-menu{display:flex;align-items:center;gap:4px}
.nav-menu a{
  font-weight:600;font-size:.93rem;color:var(--c-ink);padding:10px 13px;border-radius:10px;
  transition:.2s;position:relative;
}
.nav-menu a:hover,.nav-menu a.active{color:var(--c-secondary);background:rgba(30,111,255,.08)}
.nav-actions{display:flex;align-items:center;gap:10px}

.hamburger{
  display:none;width:46px;height:46px;border:0;background:var(--grad);border-radius:12px;
  cursor:pointer;position:relative;flex-shrink:0;
}
.hamburger span{
  position:absolute;left:13px;right:13px;height:2.5px;background:#fff;border-radius:3px;
  transition:.3s var(--ease);
}
.hamburger span:nth-child(1){top:16px}
.hamburger span:nth-child(2){top:22px}
.hamburger span:nth-child(3){top:28px}
.hamburger.open span:nth-child(1){top:22px;transform:rotate(45deg)}
.hamburger.open span:nth-child(2){opacity:0}
.hamburger.open span:nth-child(3){top:22px;transform:rotate(-45deg)}

.nav-overlay{
  position:fixed;inset:0;background:rgba(10,21,48,.5);backdrop-filter:blur(3px);
  opacity:0;visibility:hidden;transition:.3s;z-index:940;
}
.nav-overlay.show{opacity:1;visibility:visible}

/* ============================================================
   HERO
   ============================================================ */
.hero{
  position:relative;color:#fff;overflow:hidden;
  background:linear-gradient(120deg,rgba(10,31,68,.94),rgba(11,21,48,.80)),var(--grad);
  background-size:cover;background-position:center;
}
.hero.has-bg{background-blend-mode:normal}
.hero::after{
  content:"";position:absolute;right:-160px;top:-160px;width:520px;height:520px;
  background:radial-gradient(circle,rgba(255,122,0,.30),transparent 65%);filter:blur(20px);
}
.hero .container{position:relative;z-index:2;display:grid;grid-template-columns:1.15fr .85fr;gap:46px;align-items:center;padding-top:70px;padding-bottom:80px}
.hero-badge{
  display:inline-flex;align-items:center;gap:9px;background:rgba(255,255,255,.12);
  border:1px solid rgba(255,255,255,.25);backdrop-filter:blur(8px);
  padding:8px 16px;border-radius:50px;font-size:.82rem;font-weight:600;margin-bottom:20px;
}
.hero-badge .dot{width:8px;height:8px;border-radius:50%;background:#34e89e;box-shadow:0 0 0 4px rgba(52,232,158,.3)}
.hero h1{color:#fff;font-size:clamp(2.1rem,4.7vw,3.5rem);margin-bottom:18px}
.hero h1 .hl{background:var(--grad-accent);-webkit-background-clip:text;background-clip:text;color:transparent}
.hero p.sub{color:rgba(255,255,255,.86);font-size:1.08rem;max-width:560px;margin-bottom:28px}
.hero-actions{display:flex;gap:13px;flex-wrap:wrap;margin-bottom:34px}
.hero-stats{display:flex;gap:30px;flex-wrap:wrap}
.hero-stats .hs{display:flex;flex-direction:column}
.hero-stats .hs b{font-size:1.7rem;color:#fff;font-weight:800}
.hero-stats .hs span{font-size:.82rem;color:rgba(255,255,255,.75)}

.hero-visual{position:relative}
.hero-visual .photo{
  border-radius:26px;overflow:hidden;box-shadow:var(--shadow-lg);
  border:1px solid rgba(255,255,255,.2);aspect-ratio:4/4.4;
  background:linear-gradient(160deg,#2a3a66,#0a1f44);
}
.hero-visual .photo img{width:100%;height:100%;object-fit:cover}
.float-card{
  position:absolute;background:rgba(255,255,255,.16);backdrop-filter:blur(14px);
  border:1px solid rgba(255,255,255,.28);border-radius:16px;padding:13px 17px;
  display:flex;align-items:center;gap:12px;box-shadow:var(--shadow);animation:float 4s ease-in-out infinite;
}
.float-card .fi{width:40px;height:40px;border-radius:11px;background:var(--grad-accent);display:grid;place-items:center;flex-shrink:0}
.float-card .fi svg{width:20px;height:20px;color:#fff}
.float-card b{display:block;color:#fff;font-size:1.05rem;line-height:1}
.float-card span{font-size:.74rem;color:rgba(255,255,255,.82)}
.float-card.fc1{top:18px;left:-26px;animation-delay:0s}
.float-card.fc2{top:42%;right:-30px;animation-delay:.8s}
.float-card.fc3{bottom:46px;left:-34px;animation-delay:1.6s}
.float-card.fc4{bottom:-14px;right:18px;animation-delay:2.2s}
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}

.hero-wave{display:block;width:100%;height:auto;margin-top:-2px}

/* ============================================================
   TRUST STRIP
   ============================================================ */
.trust-strip{background:var(--c-white);border-bottom:1px solid var(--c-line)}
.trust-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:14px;padding:26px 0}
.trust-item{display:flex;align-items:center;gap:11px;font-weight:600;font-size:.9rem;color:var(--c-ink)}
.trust-item .ti{width:42px;height:42px;border-radius:12px;background:rgba(30,111,255,.10);display:grid;place-items:center;flex-shrink:0}
.trust-item .ti svg{width:21px;height:21px;color:var(--c-secondary)}

/* ============================================================
   CARDS / GRID
   ============================================================ */
.grid{display:grid;gap:24px}
.g-2{grid-template-columns:repeat(2,1fr)}
.g-3{grid-template-columns:repeat(3,1fr)}
.g-4{grid-template-columns:repeat(4,1fr)}

.card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);box-shadow:var(--shadow-sm);transition:.35s var(--ease);overflow:hidden}
.card:hover{transform:translateY(-7px);box-shadow:var(--shadow);border-color:rgba(30,111,255,.25)}

/* Course card */
.course-card{display:flex;flex-direction:column}
.course-card .cc-media{position:relative;aspect-ratio:16/10;background:var(--grad);overflow:hidden}
.course-card .cc-media img{width:100%;height:100%;object-fit:cover}
.course-card .cc-tag{position:absolute;top:13px;left:13px;background:rgba(255,255,255,.92);color:var(--c-primary);font-size:.72rem;font-weight:700;padding:6px 12px;border-radius:50px}
.course-card .cc-fee{position:absolute;bottom:13px;right:13px;background:var(--grad-accent);color:#fff;font-weight:700;font-size:.85rem;padding:7px 13px;border-radius:50px;box-shadow:0 8px 20px rgba(255,122,0,.4)}
.course-card .cc-body{padding:20px;display:flex;flex-direction:column;gap:11px;flex:1}
.course-card h3{font-size:1.2rem}
.course-card .cc-desc{font-size:.9rem;flex:1}
.course-card .cc-meta{display:flex;gap:8px;flex-wrap:wrap}
.chip{font-size:.74rem;font-weight:600;color:var(--c-secondary);background:rgba(30,111,255,.09);padding:5px 11px;border-radius:50px}
.chip.alt{color:var(--c-accent);background:rgba(255,122,0,.10)}
.course-card .cc-actions{display:grid;grid-template-columns:1fr 1fr;gap:9px;margin-top:5px}

/* Bento feature cards */
.bento{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.bento .b-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:.35s var(--ease);position:relative;overflow:hidden}
.bento .b-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.bento .b-card .ico{width:50px;height:50px;border-radius:14px;background:var(--grad);display:grid;place-items:center;margin-bottom:15px}
.bento .b-card .ico svg{width:25px;height:25px;color:#fff}
.bento .b-card.span2{grid-column:span 2}
.bento .b-card h3{font-size:1.1rem;margin-bottom:7px}
.bento .b-card p{font-size:.9rem}
.bento .b-card.feature{background:var(--grad);color:#fff}
.bento .b-card.feature h3,.bento .b-card.feature p{color:#fff}
.bento .b-card.feature .ico{background:rgba(255,255,255,.2)}

/* Why choose us */
.why-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:24px;box-shadow:var(--shadow-sm);transition:.35s var(--ease)}
.why-card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:rgba(30,111,255,.25)}
.why-card .ico{width:52px;height:52px;border-radius:14px;background:rgba(255,122,0,.12);display:grid;place-items:center;margin-bottom:14px}
.why-card .ico svg{width:26px;height:26px;color:var(--c-accent)}
.why-card h3{font-size:1.08rem;margin-bottom:6px}
.why-card p{font-size:.88rem}

/* ============================================================
   COUNTERS
   ============================================================ */
.counters{background:var(--c-primary);color:#fff;position:relative;overflow:hidden}
.counters::before{content:"";position:absolute;left:-120px;bottom:-120px;width:420px;height:420px;background:radial-gradient(circle,rgba(30,111,255,.4),transparent 65%)}
.counters .container{position:relative;z-index:2}
.counter-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.counter{text-align:center;padding:18px;border-radius:var(--radius);background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.12)}
.counter .num{font-size:2.6rem;font-weight:800;color:#fff;line-height:1}
.counter .num .accent{color:var(--c-accent)}
.counter .lbl{font-size:.9rem;color:rgba(255,255,255,.8);margin-top:6px}

/* ============================================================
   RESULTS
   ============================================================ */
.result-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);transition:.35s var(--ease);text-align:center}
.result-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.result-card .avatar{width:88px;height:88px;border-radius:50%;margin:0 auto 14px;overflow:hidden;background:var(--grad);display:grid;place-items:center;color:#fff;font-weight:800;font-size:1.7rem;border:4px solid rgba(30,111,255,.12)}
.result-card .avatar img{width:100%;height:100%;object-fit:cover}
.result-card h3{font-size:1.1rem;margin-bottom:3px}
.result-card .exam{font-size:.85rem;color:var(--c-secondary);font-weight:700}
.result-card .ach{display:inline-block;background:var(--grad-accent);color:#fff;font-size:.78rem;font-weight:700;padding:6px 13px;border-radius:50px;margin:11px 0}
.result-card .quote{font-size:.86rem;font-style:italic}
.result-card .yr{font-size:.75rem;color:var(--c-muted);font-weight:600;margin-top:8px}

/* ============================================================
   FACULTY
   ============================================================ */
.faculty-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.35s var(--ease)}
.faculty-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.faculty-card .fphoto{aspect-ratio:1/1;background:var(--grad);display:grid;place-items:center;color:#fff;font-weight:800;font-size:3rem;overflow:hidden}
.faculty-card .fphoto img{width:100%;height:100%;object-fit:cover}
.faculty-card .fbody{padding:18px;text-align:center}
.faculty-card h3{font-size:1.1rem;margin-bottom:2px}
.faculty-card .subj{color:var(--c-secondary);font-weight:700;font-size:.86rem}
.faculty-card .meta{font-size:.82rem;color:var(--c-muted);margin-top:8px}
.faculty-card .spec{display:inline-block;margin-top:10px;font-size:.74rem;background:rgba(255,122,0,.1);color:var(--c-accent);padding:5px 12px;border-radius:50px;font-weight:600}

/* ============================================================
   BATCH TABLE
   ============================================================ */
.table-wrap{overflow-x:auto;border-radius:var(--radius);box-shadow:var(--shadow-sm);border:1px solid var(--c-line);background:#fff}
table.tbl{width:100%;border-collapse:collapse;min-width:720px}
table.tbl th{background:var(--c-primary);color:#fff;text-align:left;padding:15px 16px;font-size:.82rem;letter-spacing:.04em;text-transform:uppercase;font-weight:700}
table.tbl td{padding:14px 16px;border-bottom:1px solid var(--c-line);font-size:.92rem;color:var(--c-ink)}
table.tbl tr:last-child td{border-bottom:0}
table.tbl tr:hover td{background:rgba(30,111,255,.04)}
.badge{display:inline-block;font-size:.74rem;font-weight:700;padding:5px 11px;border-radius:50px}
.badge.green{background:rgba(16,185,129,.12);color:#0a8a5f}
.badge.blue{background:rgba(30,111,255,.12);color:var(--c-secondary)}
.badge.orange{background:rgba(255,122,0,.12);color:var(--c-accent)}
.badge.gray{background:#eef1f7;color:var(--c-muted)}
.badge.red{background:rgba(239,68,68,.12);color:#d92d20}

/* ============================================================
   STUDY MATERIAL
   ============================================================ */
.material-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:22px;box-shadow:var(--shadow-sm);transition:.3s var(--ease);display:flex;flex-direction:column;gap:12px}
.material-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.material-card .mtop{display:flex;align-items:center;gap:13px}
.material-card .micon{width:48px;height:48px;border-radius:12px;background:rgba(239,68,68,.1);display:grid;place-items:center;flex-shrink:0}
.material-card .micon svg{width:24px;height:24px;color:#e23b3b}
.material-card h3{font-size:1.03rem}
.material-card p{font-size:.86rem;flex:1}

/* ============================================================
   TESTIMONIALS
   ============================================================ */
.testi-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:26px;box-shadow:var(--shadow-sm);transition:.3s var(--ease)}
.testi-card:hover{transform:translateY(-5px);box-shadow:var(--shadow)}
.testi-card .stars{color:#ffb800;font-size:1rem;margin-bottom:10px;letter-spacing:2px}
.testi-card .review{font-size:.95rem;color:var(--c-ink);margin-bottom:18px}
.testi-card .who{display:flex;align-items:center;gap:12px}
.testi-card .who .av{width:48px;height:48px;border-radius:50%;background:var(--grad);color:#fff;display:grid;place-items:center;font-weight:800;overflow:hidden}
.testi-card .who .av img{width:100%;height:100%;object-fit:cover}
.testi-card .who b{display:block;color:var(--c-primary);font-size:.95rem}
.testi-card .who span{font-size:.8rem;color:var(--c-muted)}

/* ============================================================
   CTA BANNERS
   ============================================================ */
.cta-band{background:var(--grad);color:#fff;border-radius:26px;padding:48px;text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow)}
.cta-band::after{content:"";position:absolute;right:-90px;top:-90px;width:300px;height:300px;background:radial-gradient(circle,rgba(255,122,0,.4),transparent 60%)}
.cta-band h2{color:#fff;font-size:clamp(1.6rem,3.2vw,2.4rem);margin-bottom:12px;position:relative;z-index:2}
.cta-band p{color:rgba(255,255,255,.88);max-width:620px;margin:0 auto 26px;position:relative;z-index:2}
.cta-band .hero-actions{justify-content:center;position:relative;z-index:2;margin-bottom:0}

/* ============================================================
   FAQ
   ============================================================ */
.faq-item{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius-sm);margin-bottom:13px;overflow:hidden;transition:.3s}
.faq-item.open{border-color:rgba(30,111,255,.3);box-shadow:var(--shadow-sm)}
.faq-q{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:18px 20px;cursor:pointer;font-weight:700;color:var(--c-primary);font-size:1rem}
.faq-q .pm{width:28px;height:28px;border-radius:50%;background:rgba(30,111,255,.1);color:var(--c-secondary);display:grid;place-items:center;flex-shrink:0;transition:.3s;font-size:1.2rem}
.faq-item.open .pm{background:var(--c-secondary);color:#fff;transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .35s var(--ease)}
.faq-a p{padding:0 20px 18px;font-size:.92rem}

/* ============================================================
   PAGE HEADER (inner pages)
   ============================================================ */
.page-hero{background:linear-gradient(120deg,rgba(10,31,68,.95),rgba(11,21,48,.82)),var(--grad);color:#fff;padding:58px 0;position:relative;overflow:hidden}
.page-hero::after{content:"";position:absolute;right:-100px;bottom:-100px;width:340px;height:340px;background:radial-gradient(circle,rgba(255,122,0,.3),transparent 60%)}
.page-hero .container{position:relative;z-index:2}
.page-hero h1{color:#fff;font-size:clamp(1.9rem,4vw,2.8rem);margin-bottom:10px}
.page-hero p{color:rgba(255,255,255,.85);max-width:640px}
.breadcrumb{display:flex;gap:8px;font-size:.85rem;color:rgba(255,255,255,.75);margin-bottom:14px;flex-wrap:wrap}
.breadcrumb a:hover{color:#fff}
.breadcrumb .sep{opacity:.6}

/* ============================================================
   FILTER BAR
   ============================================================ */
.filter-bar{display:flex;gap:12px;flex-wrap:wrap;align-items:center;background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:16px;box-shadow:var(--shadow-sm);margin-bottom:30px}
.filter-bar input,.filter-bar select{
  padding:11px 14px;border:1.5px solid var(--c-line);border-radius:10px;font-family:inherit;font-size:.9rem;color:var(--c-ink);background:#fff;
}
.filter-bar input{flex:1;min-width:180px}
.filter-bar input:focus,.filter-bar select:focus{outline:none;border-color:var(--c-secondary)}

/* ============================================================
   FORMS
   ============================================================ */
.form-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);padding:30px;box-shadow:var(--shadow)}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.form-group.full{grid-column:1/-1}
.form-group label{font-weight:600;font-size:.88rem;color:var(--c-ink)}
.form-group label .req{color:#e23b3b}
.form-control{
  padding:12px 14px;border:1.5px solid var(--c-line);border-radius:10px;font-family:inherit;
  font-size:.94rem;color:var(--c-ink);background:#fff;transition:.2s;width:100%;
}
.form-control:focus{outline:none;border-color:var(--c-secondary);box-shadow:0 0 0 4px rgba(30,111,255,.12)}
textarea.form-control{resize:vertical;min-height:110px}
.form-hint{font-size:.78rem;color:var(--c-muted)}

/* ============================================================
   ALERTS
   ============================================================ */
.alert{padding:13px 16px;border-radius:12px;font-size:.9rem;font-weight:600;margin-bottom:16px;border:1px solid transparent}
.alert-success{background:rgba(16,185,129,.1);color:#0a8a5f;border-color:rgba(16,185,129,.3)}
.alert-error{background:rgba(239,68,68,.1);color:#d92d20;border-color:rgba(239,68,68,.3)}
.alert-info{background:rgba(30,111,255,.1);color:var(--c-secondary);border-color:rgba(30,111,255,.3)}

/* ============================================================
   GALLERY
   ============================================================ */
.gallery-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}
.gallery-grid .gitem{border-radius:var(--radius);overflow:hidden;position:relative;aspect-ratio:4/3;box-shadow:var(--shadow-sm);cursor:pointer;background:var(--grad)}
.gallery-grid .gitem img{width:100%;height:100%;object-fit:cover;transition:.4s var(--ease)}
.gallery-grid .gitem:hover img{transform:scale(1.08)}
.gallery-grid .gitem .gcap{position:absolute;inset:auto 0 0 0;padding:24px 14px 12px;background:linear-gradient(transparent,rgba(10,21,48,.85));color:#fff;font-weight:600;font-size:.88rem}

/* ============================================================
   BLOG
   ============================================================ */
.blog-card{background:#fff;border:1px solid var(--c-line);border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-sm);transition:.35s var(--ease);display:flex;flex-direction:column}
.blog-card:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.blog-card .bimg{aspect-ratio:16/9;background:var(--grad);overflow:hidden}
.blog-card .bimg img{width:100%;height:100%;object-fit:cover}
.blog-card .bbody{padding:20px;display:flex;flex-direction:column;gap:9px;flex:1}
.blog-card .bcat{font-size:.74rem;font-weight:700;color:var(--c-secondary);text-transform:uppercase;letter-spacing:.05em}
.blog-card h3{font-size:1.12rem}
.blog-card .bmeta{font-size:.8rem;color:var(--c-muted);margin-top:auto}
.post-content{font-size:1.02rem;color:var(--c-ink);line-height:1.8}
.post-content p{color:var(--c-ink);margin-bottom:18px}
.post-content h2,.post-content h3{margin:26px 0 12px}
.post-content img{border-radius:var(--radius);margin:18px 0}
.post-content ul{list-style:disc;padding-left:22px;margin-bottom:18px}
.post-content li{margin-bottom:8px}

/* ============================================================
   FLOATING / STICKY CTAs
   ============================================================ */
.float-actions{position:fixed;right:18px;bottom:18px;z-index:950;display:flex;flex-direction:column;gap:12px}
.fab{width:56px;height:56px;border-radius:50%;display:grid;place-items:center;box-shadow:var(--shadow);color:#fff;transition:.3s;position:relative}
.fab:hover{transform:scale(1.08)}
.fab svg{width:27px;height:27px}
.fab.wa{background:#25D366;animation:pulse 2.4s infinite}
.fab.call{background:var(--grad)}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,211,102,.5)}70%{box-shadow:0 0 0 16px rgba(37,211,102,0)}100%{box-shadow:0 0 0 0 rgba(37,211,102,0)}}

.demo-fab{
  position:fixed;left:18px;bottom:18px;z-index:950;background:var(--grad-accent);color:#fff;
  padding:14px 22px;border-radius:50px;font-weight:700;font-size:.92rem;box-shadow:0 14px 34px rgba(255,122,0,.45);
  display:inline-flex;align-items:center;gap:9px;transition:.3s;
}
.demo-fab:hover{transform:translateY(-3px)}
.demo-fab svg{width:19px;height:19px}

/* Sticky mobile call/whatsapp bar */
.mobile-bar{display:none;position:fixed;left:0;right:0;bottom:0;z-index:955;background:#fff;border-top:1px solid var(--c-line);box-shadow:0 -6px 22px rgba(10,31,68,.12)}
.mobile-bar .mb-grid{display:grid;grid-template-columns:1fr 1fr 1fr}
.mobile-bar a{display:flex;flex-direction:column;align-items:center;gap:3px;padding:10px 6px;font-size:.72rem;font-weight:700;color:var(--c-primary)}
.mobile-bar a svg{width:21px;height:21px}
.mobile-bar a.call{color:var(--c-secondary)}
.mobile-bar a.wa{color:#25D366}
.mobile-bar a.demo{color:var(--c-accent)}

/* ============================================================
   FOOTER
   ============================================================ */
.site-footer{background:var(--c-dark);color:#aeb9d4;padding-top:60px}
.site-footer h4{color:#fff;font-size:1.05rem;margin-bottom:18px;font-weight:700}
.footer-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1.2fr;gap:34px;padding-bottom:40px}
.site-footer .f-brand{display:flex;align-items:center;gap:12px;margin-bottom:16px}
.site-footer .f-brand strong{color:#fff;font-size:1.2rem}
.site-footer p{color:#9aa6c4;font-size:.9rem}
.site-footer a{color:#aeb9d4;font-size:.9rem;transition:.2s}
.site-footer a:hover{color:#fff;padding-left:4px}
.footer-links li{margin-bottom:10px}
.footer-contact li{display:flex;gap:10px;margin-bottom:13px;font-size:.9rem;align-items:flex-start}
.footer-contact svg{width:18px;height:18px;color:var(--c-accent);flex-shrink:0;margin-top:2px}
.f-social{display:flex;gap:11px;margin-top:18px}
.f-social a{width:40px;height:40px;border-radius:11px;background:rgba(255,255,255,.08);display:grid;place-items:center;color:#fff}
.f-social a:hover{background:var(--grad-accent);padding-left:0}
.f-social svg{width:19px;height:19px}
.footer-bottom{border-top:1px solid rgba(255,255,255,.1);padding:20px 0;display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;font-size:.84rem}
.footer-bottom a{color:#9aa6c4}

/* ============================================================
   REVEAL ANIMATION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:.7s var(--ease)}
.reveal.in{opacity:1;transform:none}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media(max-width:1024px){
  .hero .container{grid-template-columns:1fr;gap:50px}
  .hero-visual{max-width:430px;margin:0 auto}
  .g-4,.bento{grid-template-columns:repeat(2,1fr)}
  .counter-grid{grid-template-columns:repeat(2,1fr)}
  .trust-grid{grid-template-columns:repeat(3,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr}
  .bento .b-card.span2{grid-column:span 1}
}
@media(max-width:860px){
  .nav-menu{
    position:fixed;top:0;right:-100%;width:300px;max-width:85%;height:100vh;background:#fff;
    flex-direction:column;align-items:stretch;gap:4px;padding:84px 20px 30px;z-index:945;
    box-shadow:-12px 0 40px rgba(10,31,68,.18);transition:right .35s var(--ease);overflow-y:auto;
  }
  .nav-menu.open{right:0}
  .nav-menu a{padding:13px 14px;font-size:1rem;border-radius:10px}
  .nav-menu a:hover{background:rgba(30,111,255,.08)}
  .hamburger{display:block}
  .topbar .tb-left .tb-item.hide-sm{display:none}
  .nav-actions .btn span.full-label{display:none}
  body.has-mobile-bar{padding-bottom:62px}
  .mobile-bar{display:block}
  .float-actions{bottom:74px}
  .demo-fab{bottom:74px;padding:12px 16px;font-size:.84rem}
}
@media(max-width:680px){
  .section{padding:52px 0}
  .g-2,.g-3,.g-4,.bento,.counter-grid{grid-template-columns:1fr}
  .form-grid{grid-template-columns:1fr}
  .trust-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr}
  .course-card .cc-actions{grid-template-columns:1fr}
  .cta-band{padding:34px 22px}
  .hero-stats{gap:20px}
  .hero-stats .hs b{font-size:1.4rem}
  .float-card{display:none}
  .float-card.fc4{display:flex;right:6px;bottom:6px}
  .form-card{padding:20px}
}
@media(max-width:420px){
  .gallery-grid{grid-template-columns:1fr}
  .topbar{display:none}
}
