:root{
  /* Lisieux CMI Public School palette (matches the main website) */
  --maroon:#831206; --maroon-dark:#760000; --maroon-light:#96171a;
  --gold:#ffc907; --gold-light:#ffd84d; --gold-dark:#854208;
  --cream:#fbf7ef; --ink:#241a1a; --white:#fff;
  --muted:#8a7d76; --line:#ece3d6;
  --ok:#1d7a3d; --warn:#9a6206; --err:#b3261e;
  --font-serif:"Cormorant Garamond",Georgia,serif;
  --font-sans:"Inter",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
  --radius:16px; --shadow:0 8px 28px rgba(118,0,0,.10);
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--font-sans);color:var(--ink);
  background:var(--cream);min-height:100vh;
  background-image:radial-gradient(1200px 400px at 50% -120px, rgba(255,201,7,.12), transparent 60%);}

/* ---------- top bar (matches lisieuxcmi.ac.in: cream bar, full-colour crest) ---------- */
.topbar{display:flex;justify-content:space-between;align-items:center;gap:12px;padding:8px 20px;min-height:92px;
  background:rgba(251,247,239,.97);backdrop-filter:blur(6px);
  color:var(--maroon-dark);border-bottom:1px solid rgba(255,201,7,.5);box-shadow:0 2px 10px rgba(118,0,0,.07);
  position:sticky;top:0;z-index:50}
.brand{display:flex;gap:16px;align-items:center;text-decoration:none;color:var(--maroon-dark)}
.brand-logo{height:73px;width:auto;display:block}
.brand-text{display:flex;flex-direction:column;line-height:1.12}
.brand-name{font-family:var(--font-serif);font-weight:700;font-size:26px;color:var(--maroon);letter-spacing:.2px}
.brand-sub{font-size:11px;text-transform:uppercase;letter-spacing:3px;color:var(--gold-dark);font-weight:600}
.brand-badge{align-self:center;background:var(--maroon);color:var(--cream);font-size:11px;font-weight:700;
  text-transform:uppercase;letter-spacing:1px;padding:5px 11px;border-radius:999px;white-space:nowrap}
.topnav{display:flex;gap:12px;align-items:center}
.who{font-size:13px;color:var(--maroon-dark);opacity:.85}
@media(max-width:680px){.brand-badge{display:none}.brand-name{font-size:20px}.topbar{min-height:74px}.brand-logo{height:55px}}
@media(max-width:520px){.topbar{min-height:62px;padding:8px 14px}.brand-logo{height:45px}.brand-name{font-size:17px}
  .brand-sub{letter-spacing:2px;font-size:10px}.who{display:none}}

.wrap{max-width:980px;margin:24px auto;padding:0 16px}
.foot{text-align:center;color:var(--muted);font-size:12px;padding:26px}

.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);
  padding:24px;margin-bottom:18px;border:1px solid var(--line)}
h1,h2,h3{font-family:var(--font-serif);color:var(--maroon-dark);font-weight:700}
h1{margin:.1em 0 .35em;font-size:30px}
h2{font-size:24px;margin:.2em 0 .5em}
h3{font-size:19px}
.muted{color:var(--muted)}
.row-between{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

label{display:block;margin:12px 0;font-weight:600;font-size:14px}
input,select{width:100%;padding:12px;border:1px solid var(--line);border-radius:10px;font-size:16px;
  margin-top:6px;background:#fff;color:var(--ink)}
input:focus,select:focus{outline:none;border-color:var(--maroon-light);box-shadow:0 0 0 3px rgba(150,23,26,.12)}
input[type=file]{padding:8px;font-weight:400}

button{cursor:pointer;font-size:15px;border:0;border-radius:10px;font-family:var(--font-sans)}
.btn-primary{background:var(--maroon);color:#fff;padding:13px 22px;font-weight:600;box-shadow:0 3px 0 var(--maroon-dark)}
.btn-primary:hover{background:var(--maroon-light)}
.btn-primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.btn-danger{background:#a31a10;color:#fff;padding:13px 22px;font-weight:600}
.btn-ghost{background:#fff;color:var(--maroon);border:1.5px solid var(--line);padding:9px 14px;
  text-decoration:none;display:inline-block;font-weight:600}
.btn-ghost:hover{border-color:var(--maroon-light);color:var(--maroon-light)}
.btn-mini{background:#fdf3d6;color:var(--gold-dark);padding:6px 10px;font-size:13px;font-weight:600}
.btn-mini:hover{background:var(--gold-light)}
.inline-actions{margin:10px 0}
.links{display:flex;gap:10px;flex-wrap:wrap;margin-top:14px}

.alert{padding:12px 14px;border-radius:10px;margin:12px 0;font-size:14px;border:1px solid transparent}
.alert.error{background:#fdecea;color:#8f1a13;border-color:#f3c9c5}
.alert.ok{background:#e8f6ec;color:#15622f;border-color:#bfe3ca}
.alert.warn{background:#fdf3d6;color:var(--gold-dark);border-color:#f3dfa0}

/* ---------- login ---------- */
.login-card{max-width:400px;margin:7vh auto;text-align:center}
.login-card form{text-align:left}
.login-card h1{margin-top:8px}
.login-crest{height:126px;width:auto;margin:0 auto 10px}

/* ---------- device chooser ---------- */
.device-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:10px}
.device-pick{background:var(--cream);border:2px solid var(--line);border-radius:14px;padding:24px 12px;display:flex;
  flex-direction:column;gap:6px;align-items:center;text-align:center;color:var(--ink)}
.device-pick:hover{border-color:var(--gold);box-shadow:0 6px 18px rgba(118,0,0,.08)}
.device-pick .big{font-family:var(--font-serif);font-size:24px;font-weight:700;color:var(--maroon-dark)}
.device-pick small{color:var(--muted)}
@media(max-width:520px){.device-grid{grid-template-columns:1fr}}

/* ---------- status pills ---------- */
.status-pill{display:inline-block;padding:3px 11px;border-radius:999px;font-size:12px;font-weight:700;text-transform:uppercase}
.status-running,.status-ready,.status-voting{background:#e8f6ec;color:#15622f}
.status-not_started,.status-idle{background:#efe7da;color:#6b5d4f}
.status-closed,.status-done{background:#fdf3d6;color:var(--gold-dark)}

/* ---------- tables ---------- */
.grid{width:100%;border-collapse:collapse;margin-top:8px}
.grid th,.grid td{padding:9px 8px;border-bottom:1px solid var(--line);text-align:left;font-size:14px;vertical-align:middle}
.grid th{font-size:12px;text-transform:uppercase;color:var(--muted);letter-spacing:.5px}
.bar{display:inline-block;width:90px;height:9px;background:#efe7da;border-radius:999px;overflow:hidden;vertical-align:middle;margin-right:6px}
.bar span{display:block;height:100%;background:linear-gradient(90deg,var(--maroon),var(--maroon-light))}
.turnout,.turnout-grand{font-size:15px;margin:8px 0}
.turnout-grand{font-size:19px;font-family:var(--font-serif);font-weight:700;color:var(--maroon-dark)}

/* ---------- LSVD live ---------- */
.vote-live{display:flex;gap:14px;align-items:center;background:var(--cream);padding:16px;border-radius:12px;
  margin:12px 0;border:1px solid var(--line)}
.vote-live .big{font-family:var(--font-serif);font-size:22px;font-weight:700;color:var(--maroon-dark)}
.pulse{width:16px;height:16px;border-radius:50%;background:var(--ok);animation:pulse 1.2s infinite;flex:none}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(29,122,61,.5)}70%{box-shadow:0 0 0 12px rgba(29,122,61,0)}100%{box-shadow:0 0 0 0 rgba(29,122,61,0)}}

/* ---------- LEVM ---------- */
.levm{max-width:760px;margin:0 auto}
.levm-top{padding:0 4px 10px}
.levm-screen{min-height:70vh;display:flex;align-items:center;justify-content:center}
.waiting,.thankyou{text-align:center}
.spinner{width:46px;height:46px;border:5px solid #eaddc8;border-top-color:var(--maroon);border-radius:50%;
  margin:0 auto 16px;animation:spin 1s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.ballot{width:100%;background:#fff;border-radius:var(--radius);box-shadow:var(--shadow);padding:24px;border:1px solid var(--line)}
.ballot-head{display:flex;justify-content:space-between;color:var(--muted);font-size:14px}
.post-title{text-align:center;margin:8px 0 0;color:var(--maroon-dark)}
.tap-hint{text-align:center;color:var(--gold-dark);font-weight:600;margin:4px 0 18px}
.cands{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cand{background:var(--cream);border:3px solid transparent;border-radius:16px;padding:14px;display:flex;
  flex-direction:column;align-items:center;gap:10px;transition:.12s;color:var(--ink)}
.cand img{width:100%;max-width:160px;aspect-ratio:1;border-radius:14px;object-fit:cover;background:#fff;border:1px solid var(--line)}
.cand-name{font-weight:700;font-size:16px}
.cand:hover{border-color:var(--gold);box-shadow:0 6px 18px rgba(118,0,0,.08)}
.cand.sel{border-color:var(--maroon);background:#fbeceb}
.cand:active{transform:scale(.97)}
.thankyou .check{font-size:64px}
.thankyou h1{color:var(--maroon-dark)}
@media(max-width:560px){.cands{grid-template-columns:1fr;gap:10px}.cand{flex-direction:row;justify-content:flex-start}.cand img{width:84px}}

/* ---------- admin nominees ---------- */
.post-h{margin-top:18px;border-top:1px solid var(--line);padding-top:12px}
.cand-admin-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
.cand-admin{background:var(--cream);border-radius:12px;padding:12px;text-align:center;border:1px solid var(--line)}
.cand-admin img{width:90px;height:90px;border-radius:12px;object-fit:cover;background:#fff;border:1px solid var(--line)}
.cand-admin .file{font-size:12px;font-weight:600;text-align:left}
@media(max-width:620px){.cand-admin-grid{grid-template-columns:1fr}}

.filters{display:flex;gap:10px;flex-wrap:wrap;align-items:end}
.filters input,.filters select{width:auto;flex:1;min-width:140px;margin-top:0}
.results .res-av img{width:40px;height:40px;border-radius:8px;object-fit:cover;border:1px solid var(--line)}
.results tr.lead{background:#fdf8ec}
.pw{background:var(--ink);color:var(--gold-light);padding:3px 8px;border-radius:6px}
code{font-family:ui-monospace,Menlo,Consolas,monospace}
.actions{display:flex;gap:6px}

/* ---------- danger zone ---------- */
.danger-zone{border:1.5px solid #f0c4c0;background:#fdf6f5}
.danger-zone h2{color:#a31a10}
.reset-form{display:flex;gap:12px;align-items:end;flex-wrap:wrap}
.reset-form label{margin:0}
.reset-form input{width:auto;min-width:150px}
