/* ============================================================
   Dynamic Public School — dpschool.edu.np
   Shared stylesheet for all pages
   ============================================================ */
:root{
  --navy:#12355b;
  --navy-dark:#0c2440;
  --gold:#f5a623;
  --gold-dark:#d98c0f;
  --bg:#f7f9fc;
  --text:#2a2f36;
  --muted:#6b7480;
  --white:#ffffff;
  --radius:14px;
}
*{margin:0;padding:0;box-sizing:border-box}
body{font-family:'Segoe UI',system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.65}
a{text-decoration:none;color:inherit}
img{max-width:100%;display:block}
.container{max-width:1140px;margin:0 auto;padding:0 20px}

/* ---------- Top bar ---------- */
.topbar{background:var(--navy-dark);color:#c9d6e6;font-size:.82rem;padding:6px 0}
.topbar .container{display:flex;justify-content:space-between;flex-wrap:wrap;gap:8px}
.topbar a{color:var(--gold)}

/* ---------- Header / nav ---------- */
header{background:var(--navy);position:sticky;top:0;z-index:50;box-shadow:0 2px 10px rgba(0,0,0,.15)}
.nav{display:flex;align-items:center;justify-content:space-between;padding:12px 0}
.brand{display:flex;align-items:center;gap:12px;color:var(--white)}
.brand .logo{width:44px;height:44px;border-radius:50%;background:var(--gold);display:flex;align-items:center;justify-content:center;font-weight:800;color:var(--navy);font-size:1rem;flex-shrink:0}
.brand b{font-size:1.02rem;display:block;line-height:1.2}
.brand span{font-size:.7rem;color:#b9c8db;letter-spacing:.06em}
nav ul{display:flex;gap:20px;list-style:none;align-items:center}
nav a{color:#dbe5f0;font-size:.9rem;font-weight:500;padding:6px 2px}
nav a:hover,nav a.active{color:var(--gold)}
nav a.active{border-bottom:2px solid var(--gold)}
.btn{display:inline-block;background:var(--gold);color:var(--navy-dark);font-weight:700;padding:10px 22px;border-radius:30px;font-size:.9rem;border:none;cursor:pointer}
.btn:hover{background:var(--gold-dark)}
.btn.ghost{background:transparent;border:2px solid var(--gold);color:var(--gold)}
.btn.navy{background:var(--navy);color:var(--white)}
.menu-toggle{display:none;background:none;border:none;color:var(--white);font-size:1.6rem;cursor:pointer}

/* ---------- Notice ticker ---------- */
.ticker{background:var(--gold);color:var(--navy-dark);font-size:.85rem;font-weight:600;padding:7px 0}
.ticker .container{display:flex;gap:14px;align-items:center;overflow:hidden;white-space:nowrap}
.ticker .tag{background:var(--navy);color:var(--white);border-radius:4px;padding:2px 10px;font-size:.72rem;letter-spacing:.05em;flex-shrink:0}
.ticker a{overflow:hidden;text-overflow:ellipsis}

/* ---------- Hero (home) ---------- */
.hero{background:linear-gradient(115deg,var(--navy) 55%,#1d4a7a);color:var(--white);padding:70px 0 90px;position:relative;overflow:hidden}
.hero::after{content:"";position:absolute;right:-120px;top:-120px;width:420px;height:420px;border-radius:50%;background:rgba(245,166,35,.12)}
.hero .container{display:grid;grid-template-columns:1.2fr .8fr;gap:40px;align-items:center;position:relative;z-index:2}
.hero h1{font-size:2.5rem;line-height:1.15;margin-bottom:16px}
.hero h1 em{color:var(--gold);font-style:normal}
.hero p{color:#c9d6e6;max-width:520px;margin-bottom:28px}
.hero .hero-np{color:var(--white);font-size:2.5rem;font-weight:700;margin:-4px 0 18px;line-height:1.35;max-width:none}
.hero .hero-np em{color:var(--gold);font-style:normal}
.hero .cta{display:flex;gap:14px;flex-wrap:wrap}
.hero-card{background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.15);border-radius:var(--radius);padding:24px}
.hero-card h3{color:var(--gold);font-size:.85rem;letter-spacing:.1em;margin-bottom:12px}
.hero-card ul{list-style:none}
.hero-card li{padding:9px 0;border-bottom:1px solid rgba(255,255,255,.1);font-size:.88rem;display:flex;justify-content:space-between;gap:10px}
.hero-card li:last-child{border:none}
.hero-card .date{color:#9fb3c9;font-size:.76rem;white-space:nowrap}
.hero-card a.all{color:var(--gold);font-size:.82rem;font-weight:600}

/* ---------- Page hero (inner pages) ---------- */
.page-hero{background:linear-gradient(115deg,var(--navy) 60%,#1d4a7a);color:var(--white);padding:48px 0}
.page-hero h1{font-size:2rem}
.page-hero p{color:#c9d6e6;max-width:640px;margin-top:8px}
.crumbs{font-size:.8rem;color:#9fb3c9;margin-bottom:10px}
.crumbs a{color:var(--gold)}

/* ---------- Stats ---------- */
.stats{margin-top:-46px;position:relative;z-index:5}
.stats .container{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.stat{background:var(--white);border-radius:var(--radius);padding:20px;text-align:center;box-shadow:0 8px 24px rgba(18,53,91,.10)}
.stat b{font-size:1.8rem;color:var(--navy);display:block}
.stat span{color:var(--muted);font-size:.85rem}

/* ---------- Sections ---------- */
section{padding:60px 0}
.kicker{color:var(--gold-dark);font-weight:700;letter-spacing:.12em;font-size:.78rem;text-transform:uppercase}
h2.title{font-size:1.8rem;color:var(--navy);margin:6px 0 14px}
h3.sub{font-size:1.15rem;color:var(--navy);margin:26px 0 10px}
.lead{color:var(--muted);max-width:660px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:22px;margin-top:30px}
.grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:22px;margin-top:30px}
.grid4{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:30px}
.card{background:var(--white);border-radius:var(--radius);padding:24px;box-shadow:0 4px 16px rgba(18,53,91,.07);transition:transform .2s}
.card:hover{transform:translateY(-3px)}
.card .icon{width:48px;height:48px;border-radius:12px;background:#eef4fb;display:flex;align-items:center;justify-content:center;font-size:1.4rem;margin-bottom:12px}
.card h3{color:var(--navy);font-size:1.02rem;margin-bottom:8px}
.card p{font-size:.88rem;color:var(--muted)}
.card p[lang="ne"]{margin-top:8px;line-height:1.75}
.card a.more{color:var(--gold-dark);font-weight:600;font-size:.85rem}

/* ---------- Dark band ---------- */
.band{background:var(--navy);color:var(--white)}
.band .card{background:rgba(255,255,255,.06);box-shadow:none;border:1px solid rgba(255,255,255,.12)}
.band .card h3{color:var(--gold)}
.band .card p{color:#c9d6e6}
.band h2.title{color:var(--white)}
.band .lead{color:#c9d6e6}

/* ---------- Gold CTA strip ---------- */
.strip{background:linear-gradient(100deg,var(--gold),#f7b84b);color:var(--navy-dark);padding:42px 0}
.strip .container{display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap}
.strip h2{font-size:1.5rem}
.strip p{max-width:560px;font-size:.95rem}

/* ---------- Quote / testimonial ---------- */
.quote{background:var(--white);border-left:5px solid var(--gold);border-radius:var(--radius);padding:24px;box-shadow:0 4px 16px rgba(18,53,91,.07)}
.quote p{font-style:italic;font-size:.94rem;margin-bottom:12px}
.quote b{color:var(--navy);font-size:.88rem}

/* ---------- Portals ---------- */
.portals{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-top:24px}
.portal{background:var(--white);border:2px solid #e3eaf3;border-radius:12px;padding:16px;text-align:center;font-weight:600;color:var(--navy);font-size:.9rem}
.portal:hover{border-color:var(--gold)}
.portal span{display:block;font-size:1.3rem;margin-bottom:6px}

/* ---------- Team ---------- */
.team-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-top:26px}
.member{background:var(--white);border-radius:var(--radius);padding:22px;text-align:center;box-shadow:0 4px 16px rgba(18,53,91,.07)}
.member .avatar{width:84px;height:84px;border-radius:50%;background:var(--navy);color:var(--gold);display:flex;align-items:center;justify-content:center;font-weight:800;font-size:1.5rem;margin:0 auto 12px}
.member img.avatar{width:130px;height:130px;border-radius:0;background:transparent;object-fit:contain}
.member b{color:var(--navy);font-size:.95rem;display:block}
.member span{color:var(--muted);font-size:.8rem}

/* ---------- Steps ---------- */
.steps{counter-reset:step;margin-top:26px;display:grid;gap:16px}
.step{background:var(--white);border-radius:var(--radius);padding:22px 22px 22px 74px;position:relative;box-shadow:0 4px 16px rgba(18,53,91,.07)}
.step::before{counter-increment:step;content:counter(step,decimal-leading-zero);position:absolute;left:20px;top:20px;width:40px;height:40px;border-radius:10px;background:var(--gold);color:var(--navy-dark);font-weight:800;display:flex;align-items:center;justify-content:center}
.step h3{color:var(--navy);font-size:1rem;margin-bottom:6px}
.step p{font-size:.9rem;color:var(--muted)}

/* ---------- FAQ ---------- */
details{background:var(--white);border-radius:12px;box-shadow:0 4px 16px rgba(18,53,91,.07);margin-top:12px;overflow:hidden}
summary{cursor:pointer;padding:16px 20px;font-weight:600;color:var(--navy);list-style:none;position:relative;padding-right:44px}
summary::after{content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);color:var(--gold-dark);font-size:1.3rem;font-weight:700}
details[open] summary::after{content:"–"}
details .body{padding:0 20px 16px;font-size:.9rem;color:var(--muted)}

/* ---------- Notices list ---------- */
.notice-list{margin-top:26px;display:grid;gap:14px}
.notice{background:var(--white);border-radius:12px;padding:18px 20px;box-shadow:0 4px 16px rgba(18,53,91,.07);display:flex;gap:16px;align-items:flex-start}
.notice .nd{background:#eef4fb;border-radius:10px;padding:8px 12px;text-align:center;min-width:64px}
.notice .nd b{display:block;color:var(--navy);font-size:1.1rem;line-height:1.1}
.notice .nd span{font-size:.7rem;color:var(--muted);text-transform:uppercase}
.notice h3{color:var(--navy);font-size:1rem;margin-bottom:4px}
.notice p{font-size:.88rem;color:var(--muted)}
.notice .cat{display:inline-block;background:var(--gold);color:var(--navy-dark);font-size:.68rem;font-weight:700;border-radius:4px;padding:1px 8px;margin-bottom:6px;text-transform:uppercase;letter-spacing:.05em}

/* ---------- Forms ---------- */
form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px}
label{display:block;font-size:.85rem;font-weight:600;color:var(--navy);margin:14px 0 6px}
input,textarea,select{width:100%;padding:12px 14px;border:2px solid #e3eaf3;border-radius:10px;font-size:.92rem;font-family:inherit;background:var(--white)}
input:focus,textarea:focus,select:focus{outline:none;border-color:var(--gold)}

/* ---------- Contact info cards ---------- */
.info-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:26px}

/* ---------- Video / map embeds ---------- */
.embed{position:relative;padding-bottom:56.25%;border-radius:var(--radius);overflow:hidden;box-shadow:0 4px 16px rgba(18,53,91,.1);margin-top:26px}
.embed iframe{position:absolute;inset:0;width:100%;height:100%;border:0}

/* ---------- BS calendar grid ---------- */
.bs-cal{width:100%;border-collapse:collapse;background:var(--white);border-radius:14px;overflow:hidden;box-shadow:0 4px 16px rgba(18,53,91,.1);table-layout:fixed}
.bs-cal th{background:var(--navy);color:var(--white);padding:10px 4px;font-size:.88rem;font-weight:600}
.bs-cal th small{display:block;color:#b9c8db;font-weight:500;font-size:.68rem;letter-spacing:.03em}
.bs-cal th.we{background:#d64545;color:var(--white)}
.bs-cal th.we small{color:#ffd6d6}
.bs-cal td{border:1px solid #e3eaf3;height:80px;vertical-align:top;padding:6px 8px;position:relative}
.bs-cal .bs{font-size:1.35rem;font-weight:700;color:var(--navy);line-height:1.1}
.bs-cal td.we .bs,.bs-cal td.hol .bs{color:#d64545}
.bs-cal .ad{position:absolute;bottom:5px;right:8px;font-size:.7rem;color:var(--muted)}
.bs-cal .ev{display:block;font-size:.68rem;color:#d64545;font-weight:600;line-height:1.35;margin-top:2px}
.bs-cal td.today{outline:3px solid var(--gold);outline-offset:-3px;background:#fffaf0}
.cal-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-top:24px}
.cal-tabs button{padding:8px 16px;border-radius:20px;border:2px solid #e3eaf3;background:var(--white);cursor:pointer;font-size:.9rem;font-weight:600;color:var(--navy);font-family:inherit}
.cal-tabs button.on{background:var(--navy);color:var(--gold);border-color:var(--navy)}
.cal-note{margin-top:14px;font-size:.85rem;color:var(--muted)}
.cal-note b{color:#d64545}
@media(max-width:700px){
  .bs-cal td{height:64px;padding:4px 5px}
  .bs-cal .bs{font-size:1rem}
  .bs-cal .ev{font-size:.56rem}
  .bs-cal .ad{font-size:.58rem;bottom:3px;right:4px}
  .bs-cal th{font-size:.68rem;padding:8px 2px}
  .bs-cal th small{display:none}
}

/* ---------- Level pages (elementary / middle / high) ---------- */
.chips{display:flex;flex-wrap:wrap;gap:16px;margin-top:26px}
.chip{
  position:relative;overflow:hidden;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  min-width:104px;padding:20px 22px 18px;border-radius:16px;
  color:#fff;background:linear-gradient(160deg,#1f5f8b,#12355b);
  box-shadow:0 10px 24px rgba(18,53,91,.18);
  transition:transform .25s ease, box-shadow .25s ease;
}
.chip::before{content:"";position:absolute;top:0;left:0;right:0;height:5px;background:var(--gold)}
.chip small{
  order:-1;display:block;font-weight:700;font-size:.66rem;
  letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.72);margin-bottom:4px
}
.chip .num{font-size:2rem;font-weight:800;line-height:1;letter-spacing:.02em}
.chip:hover{transform:translateY(-6px);box-shadow:0 16px 32px rgba(18,53,91,.28)}
/* colour progression so the grades read as a journey */
.chip:nth-child(1){background:linear-gradient(160deg,#1a4a7a,#0c2440)}
.chip:nth-child(2){background:linear-gradient(160deg,#1f5f8b,#12355b)}
.chip:nth-child(3){background:linear-gradient(160deg,#2f74a3,#164a6e)}
.chip:nth-child(4){background:linear-gradient(160deg,#3f88b8,#1f5f8b)}
.chip:nth-child(5){background:linear-gradient(160deg,#5b9dca,#2f74a3)}
.eval-bar{display:flex;height:52px;border-radius:12px;overflow:hidden;margin-top:22px;font-weight:700;box-shadow:0 4px 16px rgba(18,53,91,.1)}
.eval-bar .cas{background:var(--navy);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:.95rem}
.eval-bar .exam{background:var(--gold);color:var(--navy-dark);display:flex;align-items:center;justify-content:center;font-size:.95rem}
.level-nav{display:flex;gap:12px;flex-wrap:wrap;margin-top:24px}

/* ---------- Footer ---------- */
footer{background:var(--navy-dark);color:#b9c8db;padding:52px 0 22px;font-size:.88rem;margin-top:40px}
.fgrid{display:grid;grid-template-columns:1.3fr 1fr 1fr 1fr;gap:32px;margin-bottom:32px}
footer h4{color:var(--white);margin-bottom:12px;font-size:.95rem}
footer ul{list-style:none}
footer li{padding:4px 0}
footer a:hover{color:var(--gold)}
.copy{border-top:1px solid rgba(255,255,255,.12);padding-top:16px;text-align:center;font-size:.8rem;color:#7f93aa}

/* ---------- Responsive ---------- */
@media(max-width:900px){
  nav ul{display:none;position:absolute;top:100%;left:0;right:0;background:var(--navy-dark);flex-direction:column;padding:16px 20px;gap:4px;align-items:flex-start}
  nav ul.open{display:flex}
  nav ul li{width:100%}
  nav a{display:block;padding:10px 0}
  .menu-toggle{display:block}
  .hero .container,.grid2{grid-template-columns:1fr}
  .stats .container,.grid4,.portals,.team-grid,.fgrid,.info-cards{grid-template-columns:repeat(2,1fr)}
  .grid3{grid-template-columns:1fr}
  .hero h1,.hero .hero-np{font-size:1.9rem}
  form .row{grid-template-columns:1fr}
}
@media(max-width:520px){
  .stats .container,.portals,.team-grid{grid-template-columns:1fr 1fr}
  .fgrid,.info-cards{grid-template-columns:1fr}
}

/* ---------- Logo image ---------- */
.brand img.logo{width:auto;height:50px;background:transparent;border-radius:0;object-fit:contain;padding:0;overflow:visible;filter:drop-shadow(0 0 1px rgba(255,255,255,.95)) drop-shadow(0 0 1px rgba(255,255,255,.9))}
