﻿:root{--green:#007a35;--green2:#004d2a;--yellow:#ffd100;--black:#101214;--bg:#f5f7f5;--muted:#6b7280;--red:#ef4444;--line:#e5e7eb;--card:#fff}*{box-sizing:border-box}html,body{margin:0;width:100%;max-width:100%;overflow-x:hidden;font-family:Inter,Arial,sans-serif;background:var(--bg);color:#111}body{min-height:100vh}.auth-page{min-height:100vh;background:linear-gradient(160deg,#002d20,#00843d 55%,#001f17);display:flex;flex-direction:column;padding:32px 14px}.auth-brand{text-align:center;color:#fff;margin:18px auto 28px}.brand-logo{width:72px;height:72px;flex:0 0 auto}.auth-brand .brand-logo{width:112px;height:112px;filter:drop-shadow(0 12px 24px #0006)}.auth-brand h1{margin:8px 0 0;font-size:18px;text-transform:uppercase}.auth-brand p{margin:4px 0;color:var(--yellow);font-weight:800;text-transform:uppercase}.auth-card,.white-card{background:#fff;border-radius:18px;padding:20px;box-shadow:0 18px 45px rgba(0,0,0,.12)}.auth-card{width:100%;max-width:430px;margin:0 auto}.auth-card h2{font-size:17px;text-align:center;margin:0 0 6px}.auth-card p{text-align:center;color:#555;margin:0 0 18px;font-size:13px}.field{margin-bottom:14px}.input-wrap{position:relative}.input-wrap .svg-icon{position:absolute;left:13px;top:50%;transform:translateY(-50%);color:#59616b}.input-wrap input,.input-wrap select,.input-wrap textarea{width:100%;border:1px solid #e5e7eb;border-radius:12px;padding:15px 42px;background:#fff;font-size:14px;outline:none}.input-wrap input:focus,.input-wrap select:focus,.input-wrap textarea:focus{border-color:var(--green);box-shadow:0 0 0 4px rgba(0,132,61,.12)}.eye-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:0;background:transparent;width:38px;height:38px;color:#555}.eye-btn svg,.svg-icon svg{width:22px;height:22px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}.btn{border:0;border-radius:12px;padding:14px 16px;font-weight:900;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;width:auto}.btn-green{background:linear-gradient(90deg,#006b35,#00843d);color:#fff}.btn-yellow{background:var(--yellow);color:#111}.btn-dark{background:#111;color:var(--yellow)}.btn-light{background:#f0f0f0;color:#111}.btn-danger{background:#fff0f0;color:var(--red)}.btn-block{width:100%}.auth-foot{text-align:center;font-size:12px;margin-top:auto;color:#e5e7eb}.link{text-align:center;margin-top:14px;color:var(--green);font-weight:800;text-decoration:none;display:block}.app-shell{min-height:100vh;background:radial-gradient(circle at top left,rgba(0,132,61,.35),transparent 35%),linear-gradient(180deg,#041b16 0,#101214 28%,#f5f7f5 28%)}.admin-shell{background:linear-gradient(180deg,#041b16 0,#101214 48%,#f5f7f5 48%)}.mobile-topbar{height:92px;background:linear-gradient(90deg,#004d2a,#00843d);color:#fff;display:flex;align-items:center;justify-content:space-between;padding:14px 18px;box-shadow:0 8px 25px rgba(0,0,0,.18);position:sticky;top:0;z-index:30}.topbar-left{display:flex;align-items:center;gap:12px;min-width:0}.topbar-left strong{display:block;text-transform:uppercase;font-size:16px;line-height:1.1}.topbar-left span{display:block;color:var(--yellow);font-weight:900;font-size:12px;text-transform:uppercase}.mobile-topbar .brand-logo{width:54px;height:54px}.hamburger,.icon-btn,.drawer-close{border:0;background:transparent;color:#fff;width:42px;height:42px;display:grid;place-items:center;text-decoration:none}.hamburger .svg-icon,.icon-btn .svg-icon,.drawer-close .svg-icon{margin:0}.mobile-main{padding:18px 14px 28px}.section-title{color:#fff;text-transform:uppercase;margin:10px 0 14px;text-shadow:0 0 14px rgba(0,132,61,.8);font-size:19px}.dark-card{background:linear-gradient(145deg,#151719,#0b0c0d);border:1px solid rgba(255,255,255,.08);border-radius:18px;padding:16px;color:#fff;box-shadow:0 18px 36px rgba(0,0,0,.18)}.positions-card{margin-bottom:22px}.positions-title{display:flex;align-items:center;gap:10px;font-size:18px;font-weight:900;margin-bottom:14px}.positions-title .dot{width:40px;height:40px;border-radius:50%;background:#00843d;display:grid;place-items:center}.position-list{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.position-link{border-radius:12px;padding:12px 10px;background:#17191b;color:#fff;text-decoration:none;font-weight:700;display:flex;align-items:center;gap:10px;min-height:52px}.position-link.active,.position-link:hover{background:var(--yellow);color:#111}.num{width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:#00843d;color:#fff;font-weight:900;flex:0 0 auto}.position-link.active .num{background:#00843d;color:#fff}.page-heading{text-align:center;margin:24px 0 18px}.page-heading h2{font-size:31px;margin:0;text-transform:uppercase}.page-heading p{color:#5e6268;margin:8px 0 0;font-size:17px}.candidate-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.candidate-card{background:#fff;border:2px solid #e4e4e4;border-radius:16px;padding:12px 8px;text-align:center;box-shadow:0 10px 25px rgba(0,0,0,.06);min-width:0}.candidate-card.selected,.candidate-card:has(input:checked){border-color:var(--green);box-shadow:0 0 0 2px rgba(0,132,61,.15)}.candidate-card img,.avatar-svg{width:100%;height:128px;object-fit:contain}.candidate-card h3{font-size:15px;margin:8px 0 5px}.candidate-card p{margin:0 0 7px;color:#6b7280;font-size:12px}.candidate-card input{width:22px;height:22px;accent-color:var(--green)}.action-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-top:18px}.action-row.single{grid-template-columns:1fr}.notice{background:#fff4c2;border-radius:12px;padding:12px;color:#403400;font-weight:700;font-size:13px}.success-icon{width:92px;height:92px;border-radius:50%;background:var(--green);color:#fff;display:grid;place-items:center;margin:10px auto 18px}.success-icon .svg-icon{margin:0}.success-icon svg{width:58px;height:58px}.center-card{text-align:center;margin-top:30px}.center-card h2{font-size:22px;margin:0 0 10px}.center-card p{color:#555;line-height:1.5}.review-list,.result-list,.admin-list{background:#fff;border-radius:16px;overflow:hidden}.review-row,.result-row,.list-row{display:grid;grid-template-columns:1fr auto;gap:10px;padding:14px;border-bottom:1px solid var(--line);align-items:center}.review-row span,.result-row span,.list-row span{color:#6b7280;font-size:12px}.result-row b{color:var(--green)}.menu-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);opacity:0;visibility:hidden;z-index:48;transition:.2s}.side-drawer{position:fixed;right:-310px;top:0;height:100vh;width:min(310px,86vw);background:#151719;color:#fff;z-index:49;transition:.25s;padding:20px;box-shadow:-20px 0 50px rgba(0,0,0,.4)}.side-drawer.open{right:0}.menu-overlay.open{opacity:1;visibility:visible}.drawer-close{position:absolute;right:12px;top:12px}.drawer-brand{display:flex;gap:12px;align-items:center;margin:36px 0 20px}.drawer-brand .brand-logo{width:60px;height:60px}.drawer-brand b{display:block;text-transform:uppercase}.drawer-brand span{font-size:12px;color:var(--yellow);font-weight:800}.side-drawer nav{display:grid;gap:6px}.side-drawer a{display:flex;align-items:center;gap:10px;color:#fff;text-decoration:none;padding:13px;border-radius:12px}.side-drawer a:hover{background:#222}.side-drawer a.danger{color:#ff5b5b}.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:16px}.stat-card{background:#1b1e21;border-radius:14px;padding:14px;color:#fff}.stat-card span{display:block;color:#cdd1d5;font-size:12px}.stat-card b{font-size:26px;color:#fff}.admin-white{background:#fff;border-radius:16px;padding:14px;margin-top:12px}.toolbar{display:flex;gap:10px;margin-bottom:12px}.toolbar input,.toolbar select{width:100%;border:1px solid #e5e7eb;border-radius:12px;padding:13px}.small-actions{display:flex;gap:8px}.round-btn{width:36px;height:36px;border-radius:50%;border:0;display:grid;place-items:center;text-decoration:none}.round-btn.edit{background:#f0fdf4;color:var(--green)}.round-btn.del{background:#fff1f2;color:var(--red)}.form-card{background:#fff;border-radius:16px;padding:16px;margin-top:12px}.form-card label{font-size:12px;color:#555;font-weight:800;display:block;margin:12px 0 6px}.form-card input,.form-card select,.form-card textarea{width:100%;padding:14px;border:1px solid #e5e7eb;border-radius:12px}.footer{text-align:center;color:#555;padding:22px 12px;font-size:12px}.published-pill{display:inline-block;background:#dcfce7;color:#166534;border-radius:99px;padding:5px 10px;font-size:12px;font-weight:900}.unpublished-pill{display:inline-block;background:#fff4c2;color:#5c4400;border-radius:99px;padding:5px 10px;font-size:12px;font-weight:900}@media(min-width:700px){body{max-width:430px;margin:0 auto;background:#e5e5e5;box-shadow:0 0 0 1px #ddd}.auth-page{max-width:430px;margin:0 auto}.candidate-card img,.avatar-svg{height:142px}}@media(max-width:380px){.position-list{gap:8px}.position-link{font-size:13px}.candidate-grid{gap:8px}.candidate-card{padding:9px 6px}.candidate-card img,.avatar-svg{height:108px}.page-heading h2{font-size:25px}.mobile-main{padding-left:10px;padding-right:10px}}

.positions-page {
    padding: 20px 14px;
    color: #ffffff;
}

.positions-page h2 {
    font-size: 19px;
    font-weight: 500;
    margin: 0 0 8px;
    color: #ffffff;
}

.positions-page p {
    font-size: 13px;
    font-weight: 400;
    margin: 0 0 16px;
    color: rgba(255,255,255,.88);
}

.positions-box {
    background: #ffffff;
    border-radius: 18px;
    overflow: hidden;
    box-shadow: 0 12px 28px rgba(0,0,0,.10);
}

.position-item-card {
    display: grid;
    grid-template-columns: 38px 1fr 22px;
    align-items: center;
    gap: 10px;
    min-height: 72px;
    padding: 13px 14px;
    text-decoration: none;
    color: #111111;
    border-bottom: 1px solid #edf0ef;
}

.position-item-card:last-child {
    border-bottom: none;
}

.position-number {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    background: #00843D;
    color: #ffffff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-size: 13px;
    font-weight: 400;
}

.position-title {
    font-size: 14px;
    font-weight: 400;
    color: #111111;
}

.position-next {
    font-size: 24px;
    color: #111111;
    font-weight: 400;
    line-height: 1;
    text-align: right;
}
/* ===== VOTER IMPORT UI ===== */

.admin-actions-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 10px;
    margin: 12px 0;
}

.import-box {
    margin-top: 12px;
}

.import-form {
    margin-top: 14px;
}

.import-form input[type="file"] {
    background: #ffffff;
    border: 1px dashed #00843d;
    padding: 14px;
    border-radius: 12px;
}

.import-summary h3 {
    margin: 0 0 12px;
    font-size: 16px;
    font-weight: 500;
}

.summary-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 10px;
    margin: 12px 0;
}

.summary-grid div {
    background: #f6f8f7;
    border-radius: 14px;
    padding: 12px;
    text-align: center;
}

.summary-grid span {
    display: block;
    font-size: 12px;
    color: #6b7280;
}

.summary-grid b {
    display: block;
    font-size: 20px;
    color: #00843d;
    font-weight: 500;
}

.import-errors {
    background: #fff1f2;
    color: #991b1b;
    border-radius: 14px;
    padding: 12px;
    margin: 14px 0;
}

.import-errors strong {
    display: block;
    margin-bottom: 8px;
    font-weight: 500;
}

.import-errors p {
    margin: 6px 0;
    font-size: 12px;
}

.muted-text {
    color: #6b7280;
    font-size: 13px;
    line-height: 1.5;
}

@media (max-width: 420px) {
    .admin-actions-grid {
        grid-template-columns: 1fr;
    }

    .summary-grid {
        grid-template-columns: 1fr;
    }
}

/* ===== END VOTER IMPORT UI ===== */

/* ===== ADMIN EDIT CANDIDATE UI ===== */

.admin-alert {
    padding: 12px 14px;
    border-radius: 14px;
    margin: 10px 0 14px;
    font-size: 13px;
}

.error-alert {
    background: #fff1f2;
    color: #991b1b;
    border: 1px solid #fecdd3;
}

.candidate-edit-form {
    margin-top: 12px;
    margin-bottom: 14px;
}

.form-heading {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 10px;
    margin-bottom: 10px;
}

.form-heading h3 {
    margin: 0;
    font-size: 16px;
    font-weight: 500;
}

.mini-link {
    font-size: 12px;
    color: #00843d;
    text-decoration: none;
}

.form-note {
    margin: 6px 0 12px;
    color: #6b7280;
    font-size: 12px;
}

.current-photo {
    display: flex;
    align-items: center;
    gap: 10px;
    background: #f6f8f7;
    border-radius: 14px;
    padding: 10px;
    margin-bottom: 10px;
}

.current-photo img,
.current-photo .avatar-svg {
    width: 58px;
    height: 58px;
    object-fit: contain;
}

.current-photo span {
    font-size: 12px;
    color: #6b7280;
}

.candidates-list {
    margin-top: 14px;
}

.candidate-list-row {
    align-items: center;
}

.candidate-list-left {
    display: flex;
    align-items: center;
    gap: 10px;
    min-width: 0;
}

.candidate-photo-mini {
    width: 58px;
    min-width: 58px;
    height: 58px;
    border-radius: 14px;
    overflow: hidden;
    background: #f4f4f4;
    display: grid;
    place-items: center;
}

.candidate-photo-mini img,
.candidate-photo-mini .avatar-svg {
    width: 58px;
    height: 58px;
    object-fit: contain;
}

.round-btn.edit {
    background: #fff7cc;
    color: #111111;
}

.round-btn.edit .svg-icon {
    color: #111111;
}

@media (max-width: 420px) {
    .candidate-list-left {
        gap: 8px;
    }

    .candidate-photo-mini,
    .candidate-photo-mini img,
    .candidate-photo-mini .avatar-svg {
        width: 52px;
        height: 52px;
    }

    .form-heading {
        align-items: flex-start;
        flex-direction: column;
    }
}

/* ===== END ADMIN EDIT CANDIDATE UI ===== */