/* ====================================================
   Dhakane Academy – Main Stylesheet
   Blue + White + Gold accent theme
   ==================================================== */

:root {
  --primary:     #1565C0;
  --primary-dark:#0D47A1;
  --primary-light:#1976D2;
  --accent:      #FFC107;
  --accent-dark: #F9A825;
  --text-dark:   #1a1a2e;
  --text-muted:  #6c757d;
  --bg-light:    #f4f7ff;
  --white:       #ffffff;
  --shadow:      0 4px 24px rgba(21,101,192,.12);
  --radius:      12px;
  --font:        'Poppins', sans-serif;
  --transition:  all .3s ease;
}

/* ── Base ──────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { font-family: var(--font); color: var(--text-dark); background: var(--white); overflow-x: hidden; }
a { text-decoration: none; color: inherit; }
img { max-width: 100%; }

/* ── Notification Ticker ─────────────────────────── */
.notification-ticker { font-size: 0.82rem; font-weight: 500; }
.ticker-label       { white-space: nowrap; }
.ticker-inner       { animation: ticker 30s linear infinite; }
@keyframes ticker   { 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
.ticker-item        { white-space: nowrap; }

/* ── Top Bar ─────────────────────────────────────── */
.top-bar            { background: var(--primary-dark); color: #e3eeff; font-size: .82rem; }
.top-bar a          { color: #e3eeff; transition: var(--transition); }
.top-bar a:hover    { color: var(--accent); }

/* ── Navbar ──────────────────────────────────────── */
#mainNav {
  background: var(--white);
  border-bottom: 3px solid var(--accent);
  transition: var(--transition);
  z-index: 1000;
}
#mainNav.scrolled   { box-shadow: var(--shadow); }
.navbar-brand       { gap: .6rem; }
.logo-img           { border-radius: 8px; }
.logo-text          { display: flex; flex-direction: column; line-height: 1.1; }
.brand-main         { font-size: 1.05rem; font-weight: 700; color: var(--primary); }
.brand-sub          { font-size: .68rem; color: var(--text-muted); }
.nav-link           { font-size: .88rem; font-weight: 500; color: var(--text-dark) !important;
                      padding: .4rem .75rem !important; border-radius: 6px; transition: var(--transition); }
.nav-link:hover,
.nav-link.active    { color: var(--primary) !important; background: var(--bg-light); }

/* ── Hero Slider ─────────────────────────────────── */
.hero-slider        { position: relative; overflow: hidden; }
.hero-slider .carousel-item { height: 90vh; min-height: 500px; }
.hero-slider .carousel-item img { width:100%; height:100%; object-fit:cover; object-position:center; }
.hero-overlay       { position:absolute; inset:0; background: linear-gradient(135deg,rgba(13,71,161,.75) 0%,rgba(21,101,192,.45) 100%); }
.hero-caption       { position:absolute; inset:0; display:flex; flex-direction:column;
                      justify-content:center; align-items:flex-start; padding:2rem 8%; z-index:5; }
.hero-caption h1    { font-size: clamp(1.8rem,4vw,3.2rem); font-weight:800; color:#fff;
                      text-shadow:0 2px 12px rgba(0,0,0,.3); line-height:1.15; }
.hero-caption p     { font-size: clamp(.9rem,1.6vw,1.15rem); color:rgba(255,255,255,.9);
                      max-width:560px; margin-top:.75rem; }
.hero-buttons       { margin-top:1.5rem; display:flex; gap:1rem; flex-wrap:wrap; }
.carousel-control-prev-icon,
.carousel-control-next-icon { background-color: rgba(255,255,255,.3); border-radius:50%; padding:1rem; }

/* ── Section ─────────────────────────────────────── */
.section-title      { font-size: clamp(1.5rem,3vw,2.2rem); font-weight:700; color:var(--text-dark); }
.section-subtitle   { color:var(--text-muted); max-width:640px; margin:0 auto; }
.section-divider    { width:60px; height:4px; background:var(--accent); border-radius:4px; margin:.75rem auto 0; }

/* ── Stats ───────────────────────────────────────── */
.stats-section      { background: linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%); }
.stat-card          { text-align:center; padding:2rem 1rem; }
.stat-number        { font-size:2.8rem; font-weight:800; color:var(--accent); line-height:1; }
.stat-label         { font-size:.9rem; color:rgba(255,255,255,.85); margin-top:.35rem; }

/* ── Course Cards ────────────────────────────────── */
.course-card        { border:none; border-radius:var(--radius); overflow:hidden;
                      box-shadow: var(--shadow); transition:var(--transition); height:100%; }
.course-card:hover  { transform:translateY(-6px); box-shadow:0 8px 32px rgba(21,101,192,.18); }
.course-card img    { height:200px; object-fit:cover; width:100%; }
.course-card .card-body { padding:1.25rem; }
.course-badge       { background:var(--bg-light); color:var(--primary); font-size:.72rem;
                      font-weight:600; border-radius:20px; padding:.2rem .7rem; display:inline-block; }
.course-price       { font-size:1.25rem; font-weight:700; color:var(--primary); }
.course-fee-old     { font-size:.8rem; text-decoration:line-through; color:var(--text-muted); }

/* ── Team Cards ──────────────────────────────────── */
.team-card          { border:none; border-radius:var(--radius); text-align:center;
                      overflow:hidden; box-shadow:var(--shadow); transition:var(--transition); }
.team-card:hover    { transform:translateY(-6px); }
.team-avatar        { width:120px; height:120px; border-radius:50%; object-fit:cover;
                      border:4px solid var(--accent); margin:1.5rem auto .75rem; display:block; }
.team-card .card-body { padding:0 1rem 1.5rem; }

/* ── Event Cards ─────────────────────────────────── */
.event-card         { border:none; border-radius:var(--radius); box-shadow:var(--shadow);
                      display:flex; gap:1rem; padding:1.25rem; transition:var(--transition); }
.event-card:hover   { transform:translateX(4px); }
.event-date-box     { min-width:60px; height:60px; background:var(--primary); color:#fff;
                      border-radius:10px; display:flex; flex-direction:column;
                      align-items:center; justify-content:center; }
.event-date-box .day  { font-size:1.4rem; font-weight:800; line-height:1; }
.event-date-box .month{ font-size:.6rem; font-weight:600; text-transform:uppercase; opacity:.85; }

/* ── Gallery ─────────────────────────────────────── */
.gallery-item       { overflow:hidden; border-radius:var(--radius); cursor:pointer; }
.gallery-item img   { height:220px; object-fit:cover; width:100%; transition:var(--transition); }
.gallery-item:hover img { transform:scale(1.06); }
.gallery-overlay    { position:absolute; inset:0; background:rgba(21,101,192,.55);
                      display:flex; align-items:center; justify-content:center;
                      opacity:0; transition:var(--transition); border-radius:var(--radius); }
.gallery-item:hover .gallery-overlay { opacity:1; }

/* ── Contact ─────────────────────────────────────── */
.contact-card       { border:none; border-radius:var(--radius); box-shadow:var(--shadow); padding:2rem; }
.map-container      { border-radius:var(--radius); overflow:hidden; height:350px; }
.map-container iframe{ width:100%; height:100%; border:0; }

/* ── Footer ──────────────────────────────────────── */
.footer             { background: var(--text-dark); color: rgba(255,255,255,.8); }
.footer-heading     { color: var(--white); font-weight:600; font-size:1rem;
                      padding-bottom:.5rem; border-bottom:2px solid var(--accent);
                      display:inline-block; margin-bottom:1rem; }
.footer-links       { list-style:none; padding:0; margin:0; }
.footer-links li    { margin-bottom:.45rem; }
.footer-links a     { color:rgba(255,255,255,.75); font-size:.85rem; transition:var(--transition); }
.footer-links a:hover{ color:var(--accent); padding-left:4px; }
.footer-contact     { list-style:none; padding:0; font-size:.85rem; }
.footer-contact li  { margin-bottom:.6rem; }
.footer-text        { font-size:.85rem; line-height:1.7; }
.footer-bottom      { background: rgba(0,0,0,.3); font-size:.8rem; color:rgba(255,255,255,.6); }
.footer-bottom a    { color:var(--accent); }
.social-links .social-icon { width:36px; height:36px; background:rgba(255,255,255,.1);
                      border-radius:50%; display:inline-flex; align-items:center; justify-content:center;
                      color:#fff; margin-right:.4rem; transition:var(--transition); font-size:.9rem; }
.social-links .social-icon:hover { background:var(--accent); color:var(--text-dark); transform:translateY(-3px); }

/* ── Social links top bar ────────────────────────── */
.social-link        { color:rgba(255,255,255,.75); font-size:.9rem; transition:var(--transition); }
.social-link:hover  { color:var(--accent); }

/* ── Page Hero Banner ────────────────────────────── */
.page-hero          { background: linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%);
                      padding:5rem 0 3rem; position:relative; overflow:hidden; }
.page-hero::after   { content:''; position:absolute; bottom:-1px; left:0; right:0;
                      height:50px; background:var(--white);
                      clip-path:polygon(0 100%,100% 0,100% 100%); }
.page-hero h1       { font-size:clamp(1.8rem,4vw,2.8rem); font-weight:800; color:#fff; }
.page-hero .breadcrumb { background:transparent; }
.page-hero .breadcrumb-item a { color:rgba(255,255,255,.75); }
.page-hero .breadcrumb-item.active { color:var(--accent); }
.page-hero .breadcrumb-item + .breadcrumb-item::before { color:rgba(255,255,255,.5); }

/* ── About section ───────────────────────────────── */
.feature-icon       { width:56px; height:56px; border-radius:14px; background:var(--bg-light);
                      display:flex; align-items:center; justify-content:center;
                      font-size:1.4rem; color:var(--primary); flex-shrink:0; }
.about-img-wrapper  { border-radius:var(--radius); overflow:hidden; box-shadow:var(--shadow);
                      position:relative; }
.about-img-wrapper img { width:100%; height:450px; object-fit:cover; }
.about-badge        { position:absolute; bottom:1.5rem; left:1.5rem;
                      background:var(--accent); color:var(--text-dark);
                      border-radius:10px; padding:.75rem 1.25rem; text-align:center; }
.about-badge .number{ font-size:2rem; font-weight:800; line-height:1; display:block; }
.about-badge .label { font-size:.7rem; font-weight:600; text-transform:uppercase; }

/* ── Timetable ───────────────────────────────────── */
.timetable-table th { background:var(--primary); color:#fff; font-weight:600; }
.timetable-table td { vertical-align:middle; font-size:.88rem; }
.time-slot          { background:var(--bg-light); border-radius:6px; padding:.3rem .6rem;
                      font-size:.78rem; font-weight:500; color:var(--primary); white-space:nowrap; }

/* ── Admission Form ──────────────────────────────── */
.admission-section  { background: linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%); }
.admission-card     { background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.15);
                      border-radius:var(--radius); padding:2rem; backdrop-filter:blur(6px); }

/* ── Buttons ─────────────────────────────────────── */
.btn-primary        { background:var(--primary); border-color:var(--primary); }
.btn-primary:hover  { background:var(--primary-dark); border-color:var(--primary-dark); }
.btn-warning        { background:var(--accent); border-color:var(--accent); color:var(--text-dark); font-weight:600; }
.btn-warning:hover  { background:var(--accent-dark); border-color:var(--accent-dark); color:var(--text-dark); }

/* ── Utility ─────────────────────────────────────── */
.bg-primary-gradient{ background:linear-gradient(135deg,var(--primary) 0%,var(--primary-dark) 100%); }
.text-primary       { color:var(--primary) !important; }
.bg-light-blue      { background:var(--bg-light); }
.card-hover         { transition:var(--transition); }
.card-hover:hover   { transform:translateY(-4px); box-shadow:var(--shadow); }

/* ── Scroll to top ───────────────────────────────── */
#scrollTop          { position:fixed; bottom:1.5rem; right:1.5rem; width:44px; height:44px;
                      background:var(--primary); color:#fff; border:none; border-radius:50%;
                      font-size:1.1rem; cursor:pointer; opacity:0; transition:var(--transition);
                      z-index:999; display:flex; align-items:center; justify-content:center; }
#scrollTop.visible  { opacity:1; }
#scrollTop:hover    { background:var(--primary-dark); transform:translateY(-3px); }

/* ── Preloader ───────────────────────────────────── */
#preloader          { position:fixed; inset:0; background:#fff; z-index:9999;
                      display:flex; align-items:center; justify-content:center; }
.spinner-ring       { width:52px; height:52px; border:5px solid var(--bg-light);
                      border-top-color:var(--primary); border-radius:50%;
                      animation:spin .8s linear infinite; }
@keyframes spin     { to{transform:rotate(360deg)} }

/* ── Animations ──────────────────────────────────── */
@keyframes fadeInUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.animate-fadeInUp   { animation:fadeInUp .7s ease forwards; }

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 768px) {
  .hero-slider .carousel-item { height:60vh; min-height:380px; }
  .hero-caption h1 { font-size:1.6rem; }
  .team-avatar     { width:90px; height:90px; }
}
@media (max-width: 480px) {
  .hero-slider .carousel-item { height:50vh; }
}
