:root{
    --orange:#FF3700;
    --orange-dark:#D92F00;
    --ink:#16130f;
    --ink-soft:#5a534c;
    --line:#e6e1db;
    --bg:#f6f4f1;
    --card:#ffffff;
    --danger:#c0341d;
    --ok:#1f8a4c;
    --radius:14px;
    --shadow:0 1px 2px rgba(22,19,15,.06),0 8px 24px rgba(22,19,15,.05);
}
*{box-sizing:border-box}
html{-webkit-text-size-adjust:100%}
body{
    margin:0;background:var(--bg);color:var(--ink);
    font-family:"IBM Plex Sans",system-ui,-apple-system,Segoe UI,Roboto,sans-serif;
    line-height:1.55;font-size:16px;
}
h1,h2,h3{font-family:"Bricolage Grotesque","IBM Plex Sans",sans-serif;line-height:1.12;margin:0 0 .5em}
h1{font-size:1.9rem;font-weight:800;letter-spacing:-.01em}
h2{font-size:1.25rem;font-weight:700}
h3{font-size:1rem;font-weight:700;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.04em}
a{color:var(--orange);text-decoration:none}
a:hover{text-decoration:underline}
.muted{color:var(--ink-soft)}
.small{font-size:.86rem}
code{font-family:"IBM Plex Mono",ui-monospace,monospace;font-size:.85em;background:#f1ede8;padding:.1em .4em;border-radius:6px}

/* topbar */
.topbar{
    display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap;
    background:#000;color:#fff;padding:.7rem 1.25rem;
}
.brand{display:flex;align-items:center;gap:.65rem;color:#fff;font-weight:700;font-family:"Bricolage Grotesque",sans-serif}
.brand:hover{text-decoration:none}
.brand img{display:block}
.nav{display:flex;align-items:center;gap:1.1rem;flex-wrap:wrap}
.nav a{color:#e9e4de;font-size:.92rem}
.nav a:hover{color:#fff}
.nav .who{color:#b7afa6;font-size:.82rem;border-left:1px solid #3a342e;padding-left:1rem}
.inline{display:inline}

/* layout */
.wrap{max-width:1000px;margin:2rem auto;padding:0 1.25rem;min-height:60vh}
.is-bare .wrap{max-width:440px;margin-top:6vh}
.footer{text-align:center;color:var(--ink-soft);font-size:.82rem;padding:2.5rem 1rem}

/* cards */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
    box-shadow:var(--shadow);padding:1.4rem 1.5rem;margin-bottom:1.4rem}
.auth-card h1{margin-bottom:.2em}
.grid-cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1.1rem;margin-bottom:1.4rem}
.grid-cards .card{margin:0}
.row-between{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:1.4rem}
.three-col{display:grid;grid-template-columns:1fr 1fr 1fr;gap:1rem}
@media(max-width:640px){.two-col,.three-col{grid-template-columns:1fr}}

/* forms */
label{display:block;font-weight:600;font-size:.9rem;margin:.7rem 0 .3rem}
input,textarea,select{
    width:100%;font:inherit;color:var(--ink);background:#fff;
    border:1px solid var(--line);border-radius:10px;padding:.6rem .7rem;
}
input:focus,textarea:focus,select:focus{outline:2px solid rgba(255,55,0,.35);border-color:var(--orange)}
textarea{resize:vertical}

/* buttons */
.btn{display:inline-block;cursor:pointer;font:inherit;font-weight:600;border:1px solid transparent;
    border-radius:10px;padding:.6rem 1.1rem;margin-top:.6rem;line-height:1.1;transition:.12s}
.btn:hover{text-decoration:none}
.btn-sm{padding:.35rem .7rem;font-size:.85rem;margin-top:0}
.btn-primary{background:var(--orange);color:#fff}
.btn-primary:hover{background:var(--orange-dark)}
.btn-primary:disabled{background:#d8b7ab;cursor:not-allowed}
.btn-ghost{background:#fff;border-color:var(--line);color:var(--ink)}
.btn-ghost:hover{border-color:var(--ink-soft)}
.btn-danger{background:#fff;border-color:#e7c3bb;color:var(--danger)}
.btn-danger:hover{background:var(--danger);color:#fff;border-color:var(--danger)}
.actions{display:flex;gap:.6rem;flex-wrap:wrap;align-items:center;margin-top:1rem}

/* flash */
.flash{border-radius:10px;padding:.7rem 1rem;margin-bottom:1rem;border:1px solid}
.flash-success{background:#eafaf0;border-color:#bfe6cd;color:#176638}
.flash-error{background:#fdece8;border-color:#f2c4b8;color:#8f2515}

/* tables */
.table{width:100%;border-collapse:collapse}
.table th,.table td{text-align:left;padding:.6rem .7rem;border-bottom:1px solid var(--line);vertical-align:middle}
.table th{font-size:.78rem;text-transform:uppercase;letter-spacing:.04em;color:var(--ink-soft)}
.table tr:last-child td{border-bottom:none}
.right{text-align:right}

/* badges */
.badge{display:inline-block;font-size:.74rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;
    padding:.2rem .55rem;border-radius:999px;margin-bottom:.5rem}
.badge-open{background:#eafaf0;color:#176638}
.badge-upcoming{background:#fff4e6;color:#9a5a00}
.badge-closed{background:#efeae5;color:#6a625a}

/* stats */
.stat{display:flex;flex-direction:column;gap:.2rem}
.stat .num{font-family:"Bricolage Grotesque",sans-serif;font-size:2.2rem;font-weight:800;color:var(--orange);line-height:1}
.stat .lbl{color:var(--ink-soft);font-size:.9rem}

/* candidates / ballot */
.cat-head{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}
.counter{font-weight:600;font-size:.9rem;background:#f1ede8;padding:.35rem .7rem;border-radius:999px}
.counter-ok{background:#eafaf0;color:#176638}
.counter-over{background:#fdece8;color:#8f2515}
.cand{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;
    padding:.8rem 0;border-bottom:1px solid var(--line);flex-wrap:wrap}
.cand:last-child{border-bottom:none}
.cand-info{flex:1;min-width:220px}
.cand-edit{flex:1;min-width:260px;display:flex;flex-direction:column;gap:.3rem}
.cand-add{margin-top:1rem;border-top:1px dashed var(--line);padding-top:1rem}
.stepper{display:flex;align-items:center;gap:.4rem}
.stepper .vote-input{width:64px;text-align:center}
.step-up,.step-down{width:38px;height:38px;border:1px solid var(--line);background:#fff;border-radius:10px;
    font-size:1.2rem;cursor:pointer;line-height:1}
.step-up:hover,.step-down:hover{border-color:var(--orange);color:var(--orange)}
.vlist{list-style:none;padding:0;margin:0}
.vlist li{padding:.25rem 0;border-bottom:1px dotted var(--line)}
.amt{display:inline-block;min-width:2.2em;font-weight:700;color:var(--orange)}

/* filter bar */
.filterbar{display:flex;align-items:end;gap:1rem;flex-wrap:wrap;margin-bottom:1.2rem}
.filterbar label{margin:0}
.filterbar select{width:auto;min-width:220px}

.nonvoter-emails{width:100%;font-family:monospace;font-size:.85rem;padding:.5rem;border:1px solid var(--line,#ddd);border-radius:6px}
