/* ==========================================================================
   AFSA Voting System — Stylesheet
   ========================================================================== */

:root {
    --afsa-blue:        #2563EB;
    --afsa-blue-dark:   #1D4ED8;
    --afsa-blue-light:  #EFF6FF;
    --afsa-blue-ring:   #BFDBFE;
    --afsa-green:       #16A34A;
    --afsa-green-light: #F0FDF4;
    --afsa-amber:       #D97706;
    --afsa-amber-light: #FFFBEB;
    --afsa-red:         #DC2626;
    --afsa-red-light:   #FEF2F2;
    --afsa-purple:      #7C3AED;
    --afsa-purple-light:#F5F3FF;
    --afsa-cyan:        #0891B2;
    --afsa-cyan-light:  #ECFEFF;

    --afsa-gray-50:  #F9FAFB;
    --afsa-gray-100: #F3F4F6;
    --afsa-gray-200: #E5E7EB;
    --afsa-gray-300: #D1D5DB;
    --afsa-gray-400: #9CA3AF;
    --afsa-gray-500: #6B7280;
    --afsa-gray-600: #4B5563;
    --afsa-gray-700: #374151;
    --afsa-gray-900: #111827;

    --afsa-radius:    12px;
    --afsa-radius-sm: 8px;
    --afsa-radius-xs: 6px;
    --afsa-shadow-sm: 0 1px 2px rgba(0,0,0,.06);
    --afsa-shadow:    0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);
    --afsa-shadow-md: 0 4px 6px -1px rgba(0,0,0,.1), 0 2px 4px -1px rgba(0,0,0,.06);
    --afsa-shadow-lg: 0 10px 15px -3px rgba(0,0,0,.1), 0 4px 6px -2px rgba(0,0,0,.05);
    --afsa-shadow-xl: 0 20px 25px -5px rgba(0,0,0,.1), 0 10px 10px -5px rgba(0,0,0,.04);
    --afsa-t:         0.18s ease;
}

/* ==========================================================================
   SHARED UTILITIES
   ========================================================================== */

.afsa-notice {
    padding: 12px 16px;
    border-radius: var(--afsa-radius-sm);
    font-size: 14px;
}
.afsa-notice--warning {
    background: var(--afsa-amber-light);
    color: var(--afsa-amber);
    border: 1px solid #FDE68A;
}

/* Buttons */
.afsa-btn {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 10px 20px;
    border-radius: var(--afsa-radius-sm);
    font-size: 14px;
    font-weight: 600;
    cursor: pointer;
    border: 1px solid transparent;
    transition: background var(--afsa-t), color var(--afsa-t), border-color var(--afsa-t), box-shadow var(--afsa-t), transform var(--afsa-t);
    text-decoration: none;
    white-space: nowrap;
}
.afsa-btn svg { width: 16px; height: 16px; flex-shrink: 0; }
.afsa-btn:active { transform: scale(.98); }
.afsa-btn:disabled { opacity: .5; cursor: not-allowed; }

.afsa-btn--primary {
    background: var(--afsa-blue);
    color: #fff;
    border-color: var(--afsa-blue);
}
.afsa-btn--primary:hover { background: var(--afsa-blue-dark); border-color: var(--afsa-blue-dark); }

.afsa-btn--outline {
    background: #fff;
    color: var(--afsa-blue);
    border-color: var(--afsa-blue-ring);
}
.afsa-btn--outline:hover { background: var(--afsa-blue-light); }

.afsa-btn--ghost {
    background: var(--afsa-gray-100);
    color: var(--afsa-gray-700);
    border-color: var(--afsa-gray-200);
}
.afsa-btn--ghost:hover { background: var(--afsa-gray-200); }

.afsa-btn--danger-ghost {
    background: transparent;
    color: var(--afsa-red);
    border-color: transparent;
}
.afsa-btn--danger-ghost:hover { background: var(--afsa-red-light); }

.afsa-btn-link {
    background: none;
    border: none;
    color: var(--afsa-blue);
    cursor: pointer;
    font-size: 13px;
    padding: 0;
    text-decoration: underline;
    transition: color var(--afsa-t);
}
.afsa-btn-link:hover { color: var(--afsa-blue-dark); }

.afsa-btn-add-row {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    margin-top: 8px;
    background: none;
    border: 1px dashed var(--afsa-gray-300);
    border-radius: var(--afsa-radius-xs);
    padding: 7px 14px;
    font-size: 13px;
    color: var(--afsa-blue);
    cursor: pointer;
    transition: all var(--afsa-t);
}
.afsa-btn-add-row svg { width: 15px; height: 15px; }
.afsa-btn-add-row:hover { border-color: var(--afsa-blue); background: var(--afsa-blue-light); }

/* Form elements */
.afsa-input,
.afsa-textarea,
.afsa-select {
    width: 100%;
    padding: 10px 14px;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    font-size: 14px;
    color: var(--afsa-gray-900);
    background: #fff;
    transition: border-color var(--afsa-t), box-shadow var(--afsa-t);
    box-sizing: border-box;
    font-family: inherit;
    line-height: 1.5;
}
.afsa-input:focus,
.afsa-textarea:focus,
.afsa-select:focus {
    outline: none;
    border-color: var(--afsa-blue);
    box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.afsa-textarea { resize: vertical; min-height: 100px; }
.afsa-textarea--lg { min-height: 160px; }

.afsa-select-wrap { position: relative; }
.afsa-select { appearance: none; padding-right: 36px; cursor: pointer; }
.afsa-select-wrap::after {
    content: '';
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px;
    height: 10px;
    background: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke='%236B7280' stroke-width='2'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E") no-repeat center;
    pointer-events: none;
}

.afsa-label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    color: var(--afsa-gray-700);
    margin-bottom: 6px;
}
.afsa-req { color: var(--afsa-red); margin-left: 2px; }
.afsa-optional { font-weight: 400; color: var(--afsa-gray-400); font-size: 12px; }
.afsa-hint { font-size: 12px; color: var(--afsa-gray-400); margin: 4px 0 0; }
.afsa-char-count { font-size: 11px; color: var(--afsa-gray-400); text-align: right; margin-top: 3px; }
.afsa-mt-sm { margin-top: 8px; }
.afsa-file-hidden { position: absolute; width: 0; height: 0; opacity: 0; pointer-events: none; }

/* Overlay / Modal */
.afsa-overlay {
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 999999;
    display: flex;
    flex-direction: column;
    align-items: center;
    overflow-y: auto;
    backdrop-filter: blur(2px);
    -webkit-overflow-scrolling: touch;
}
/* Spacer pseudo-elements: share leftover vertical space equally so the modal
   is centered when it fits; they collapse to their min when the modal overflows
   and the overlay scrolls cleanly from the top. */
.afsa-overlay::before,
.afsa-overlay::after {
    content: '';
    flex: 1 0 24px;
}
.afsa-modal {
    background: #fff;
    border-radius: var(--afsa-radius);
    box-shadow: var(--afsa-shadow-xl);
    width: calc(100% - 32px);
    max-width: 640px;
    max-height: calc(100vh - 48px);
    overflow: hidden;
    display: flex;
    flex-direction: column;
    flex-shrink: 0;
    animation: afsaModalIn .2s ease;
}
@keyframes afsaModalIn {
    from { opacity: 0; transform: scale(.96) translateY(8px); }
    to   { opacity: 1; transform: scale(1) translateY(0); }
}
.afsa-modal-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 20px 24px 16px;
    border-bottom: 1px solid var(--afsa-gray-100);
}
.afsa-modal-head h3 { margin: 0; font-size: 18px; color: var(--afsa-gray-900); }
.afsa-modal-body { padding: 24px; overflow-y: auto; }
.afsa-modal-x {
    width: 32px;
    height: 32px;
    border: none;
    background: var(--afsa-gray-100);
    border-radius: 50%;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--afsa-gray-500);
    transition: all var(--afsa-t);
    flex-shrink: 0;
    padding: 0;
}
.afsa-modal-x:hover { background: var(--afsa-gray-200); color: var(--afsa-gray-900); }
.afsa-modal-x svg { width: 16px; height: 16px; }
.afsa-modal-x--float {
    position: absolute;
    top: 14px;
    right: 14px;
    z-index: 2;
    background: rgba(255,255,255,.9);
}

/* ==========================================================================
   BALLOT FORM
   ========================================================================== */

.afsa-form-wrap {
    max-width: 820px;
    margin: 0 auto;
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
}

/* Progress */
.afsa-form-progress {
    background: #fff;
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius);
    padding: 20px 24px 16px;
    margin-bottom: 20px;
    box-shadow: var(--afsa-shadow-sm);
}
.afsa-progress-track {
    height: 5px;
    background: var(--afsa-gray-100);
    border-radius: 99px;
    overflow: hidden;
    margin-bottom: 16px;
}
.afsa-progress-fill {
    height: 100%;
    background: linear-gradient(90deg, var(--afsa-blue), #60A5FA);
    border-radius: 99px;
    transition: width .35s cubic-bezier(.4,0,.2,1);
}
.afsa-steps-nav {
    display: flex;
    gap: 4px;
    flex-wrap: wrap;
}
.afsa-step-dot {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    padding: 6px 8px;
    background: none;
    border: none;
    border-radius: var(--afsa-radius-xs);
    cursor: pointer;
    transition: background var(--afsa-t);
    min-width: 60px;
}
.afsa-step-dot:hover { background: var(--afsa-gray-100); }
.afsa-step-dot.is-active { background: var(--afsa-blue-light); }
.afsa-dot-num {
    width: 26px;
    height: 26px;
    border-radius: 50%;
    background: var(--afsa-gray-200);
    color: var(--afsa-gray-500);
    font-size: 12px;
    font-weight: 700;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: all var(--afsa-t);
}
.afsa-step-dot.is-active .afsa-dot-num {
    background: var(--afsa-blue);
    color: #fff;
}
.afsa-step-dot.is-done .afsa-dot-num {
    background: var(--afsa-green);
    color: #fff;
}
.afsa-dot-label {
    font-size: 10px;
    color: var(--afsa-gray-400);
    font-weight: 500;
    text-align: center;
    line-height: 1.2;
}
.afsa-step-dot.is-active .afsa-dot-label { color: var(--afsa-blue); }

/* Form card */
.afsa-ballot-form { position: relative; }
.afsa-section {
    display: none;
    background: #fff;
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius);
    padding: 28px 32px;
    margin-bottom: 16px;
    box-shadow: var(--afsa-shadow-sm);
    animation: afsaSectionIn .2s ease;
}
.afsa-section.is-active { display: block; }
@keyframes afsaSectionIn {
    from { opacity: 0; transform: translateY(6px); }
    to   { opacity: 1; transform: translateY(0); }
}
.afsa-section-head {
    display: flex;
    align-items: flex-start;
    gap: 14px;
    margin-bottom: 24px;
    padding-bottom: 20px;
    border-bottom: 1px solid var(--afsa-gray-100);
}
.afsa-section-icon-wrap {
    width: 42px;
    height: 42px;
    border-radius: var(--afsa-radius-sm);
    background: var(--afsa-blue-light);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    color: var(--afsa-blue);
}
.afsa-section-icon-wrap svg { width: 20px; height: 20px; }
.afsa-section-head h2 {
    margin: 0 0 4px;
    font-size: 18px;
    font-weight: 700;
    color: var(--afsa-gray-900);
}
.afsa-section-head p { margin: 0; font-size: 13px; color: var(--afsa-gray-500); }

/* Fields grid */
.afsa-fields {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 20px;
}
.afsa-field { display: flex; flex-direction: column; }
.afsa-field--full { grid-column: 1 / -1; }

/* Priority pills */
.afsa-pill-group { display: flex; gap: 8px; flex-wrap: wrap; }
.afsa-pill {
    cursor: pointer;
    border-radius: 99px;
    overflow: hidden;
}
.afsa-pill input { position: absolute; opacity: 0; width: 0; height: 0; }
.afsa-pill span {
    display: block;
    padding: 6px 16px;
    font-size: 13px;
    font-weight: 600;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: 99px;
    background: #fff;
    color: var(--afsa-gray-500);
    transition: all var(--afsa-t);
    white-space: nowrap;
    cursor: pointer;
}
.afsa-pill--low  input:checked ~ span { background: var(--afsa-green-light);  border-color: var(--afsa-green);  color: var(--afsa-green); }
.afsa-pill--medium input:checked ~ span { background: var(--afsa-blue-light);  border-color: var(--afsa-blue);  color: var(--afsa-blue); }
.afsa-pill--high input:checked ~ span { background: var(--afsa-amber-light); border-color: var(--afsa-amber); color: var(--afsa-amber); }
.afsa-pill--critical input:checked ~ span { background: var(--afsa-red-light);  border-color: var(--afsa-red);   color: var(--afsa-red); }

/* Repeater */
.afsa-repeater { display: flex; flex-direction: column; gap: 8px; }
.afsa-repeater-row {
    display: flex;
    gap: 8px;
    align-items: center;
}
.afsa-repeater-row .afsa-input { flex: 1; }
.afsa-repeater-remove {
    width: 32px;
    height: 32px;
    flex-shrink: 0;
    border: none;
    background: var(--afsa-gray-100);
    border-radius: var(--afsa-radius-xs);
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--afsa-gray-400);
    transition: all var(--afsa-t);
    padding: 0;
}
.afsa-repeater-remove:hover { background: var(--afsa-red-light); color: var(--afsa-red); }
.afsa-repeater-remove svg { width: 14px; height: 14px; }

/* Dropzone */
.afsa-dropzone {
    border: 2px dashed var(--afsa-gray-200);
    border-radius: var(--afsa-radius);
    background: var(--afsa-gray-50);
    transition: all var(--afsa-t);
    position: relative;
    overflow: hidden;
}
.afsa-dropzone.is-drag-over {
    border-color: var(--afsa-blue);
    background: var(--afsa-blue-light);
}
.afsa-dz-body {
    padding: 36px 24px;
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
}
.afsa-dz-icon {
    width: 40px;
    height: 40px;
    color: var(--afsa-gray-300);
    margin-bottom: 4px;
}
.afsa-dz-body p { margin: 0; font-size: 14px; color: var(--afsa-gray-500); }
.afsa-dz-hint { font-size: 12px; color: var(--afsa-gray-400); }
.afsa-dropzone--docs .afsa-dz-body { padding: 24px; }
.afsa-dz-preview {
    position: absolute;
    inset: 0;
    background: var(--afsa-gray-50);
    display: flex;
    align-items: center;
    justify-content: center;
}
.afsa-dz-preview img {
    max-width: 100%;
    max-height: 200px;
    border-radius: var(--afsa-radius-sm);
    object-fit: cover;
}
.afsa-dz-remove {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 30px;
    height: 30px;
    border: none;
    background: rgba(0,0,0,.5);
    border-radius: 50%;
    color: #fff;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    transition: background var(--afsa-t);
    padding: 0;
}
.afsa-dz-remove:hover { background: rgba(0,0,0,.75); }
.afsa-dz-remove svg { width: 14px; height: 14px; }
.afsa-dz-progress {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    height: 3px;
    background: var(--afsa-gray-100);
}
.afsa-dz-progress-bar {
    height: 100%;
    background: var(--afsa-blue);
    transition: width .2s ease;
}
.afsa-doc-list { margin-top: 10px; display: flex; flex-direction: column; gap: 6px; }
.afsa-doc-item {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 10px 14px;
    background: var(--afsa-gray-50);
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    font-size: 13px;
    color: var(--afsa-gray-700);
}
.afsa-doc-item svg { width: 16px; height: 16px; flex-shrink: 0; color: var(--afsa-blue); }
.afsa-doc-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.afsa-doc-remove {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--afsa-gray-400);
    padding: 0;
    transition: color var(--afsa-t);
    display: flex;
}
.afsa-doc-remove:hover { color: var(--afsa-red); }

/* Voting type grid */
.afsa-type-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
    gap: 10px;
    position: relative;
}
.afsa-type-card {
    cursor: pointer;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    padding: 12px 12px 10px;
    background: #fff;
    display: flex;
    flex-direction: column;
    gap: 0;
    transition: all var(--afsa-t);
    position: relative;
}
.afsa-type-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.afsa-type-card:hover { border-color: var(--afsa-blue-ring); background: var(--afsa-blue-light); }
.afsa-type-card.is-selected { border-color: var(--afsa-blue); background: var(--afsa-blue-light); box-shadow: 0 0 0 3px rgba(37,99,235,.1); }
.afsa-type-card-body {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 6px;
}
.afsa-type-label { font-size: 12px; font-weight: 600; color: var(--afsa-gray-700); line-height: 1.4; flex: 1; }
.afsa-type-info-btn {
    width: 20px;
    height: 20px;
    border: none;
    background: none;
    padding: 0;
    cursor: pointer;
    color: var(--afsa-gray-300);
    display: flex;
    align-items: center;
    justify-content: center;
    flex-shrink: 0;
    border-radius: 50%;
    transition: color var(--afsa-t), background var(--afsa-t);
}
.afsa-type-info-btn:hover { color: var(--afsa-blue); background: rgba(37,99,235,.08); }
.afsa-type-info-btn svg { width: 14px; height: 14px; pointer-events: none; }
.afsa-type-tooltip {
    position: fixed;
    background: #fff;
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    padding: 14px 16px;
    box-shadow: var(--afsa-shadow-lg);
    z-index: 99999;
    min-width: 200px;
    max-width: 260px;
    pointer-events: auto;
}
.afsa-type-tooltip::before {
    content: '';
    position: absolute;
    top: -6px;
    left: 20px;
    width: 10px;
    height: 10px;
    background: #fff;
    border-left: 1px solid var(--afsa-gray-200);
    border-top: 1px solid var(--afsa-gray-200);
    transform: rotate(45deg);
}
.afsa-type-tooltip-title {
    font-size: 11px;
    font-weight: 700;
    color: var(--afsa-gray-400);
    text-transform: uppercase;
    letter-spacing: .5px;
    margin-bottom: 10px;
}

/* Timezone note */
.afsa-tz-note { font-size: 11px; font-weight: 400; color: var(--afsa-gray-400); margin-left: 4px; }

/* Toggle */
.afsa-toggle-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 14px 0;
    border-bottom: 1px solid var(--afsa-gray-100);
}
.afsa-toggle-row:last-child { border-bottom: none; }
.afsa-toggle-info { flex: 1; }
.afsa-toggle-info .afsa-label { margin-bottom: 2px; }
.afsa-toggle-info p { margin: 0; font-size: 12px; color: var(--afsa-gray-400); }
.afsa-toggle { position: relative; cursor: pointer; flex-shrink: 0; }
.afsa-toggle input { position: absolute; opacity: 0; width: 0; height: 0; }
.afsa-toggle-track {
    display: block;
    width: 44px;
    height: 24px;
    background: var(--afsa-gray-200);
    border-radius: 99px;
    transition: background var(--afsa-t);
    position: relative;
}
.afsa-toggle input:checked ~ .afsa-toggle-track { background: var(--afsa-blue); }
.afsa-toggle-thumb {
    position: absolute;
    top: 3px;
    left: 3px;
    width: 18px;
    height: 18px;
    background: #fff;
    border-radius: 50%;
    transition: transform var(--afsa-t);
    box-shadow: 0 1px 3px rgba(0,0,0,.2);
}
.afsa-toggle input:checked ~ .afsa-toggle-track .afsa-toggle-thumb { transform: translateX(20px); }

/* Tag input */
.afsa-tag-wrap {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    padding: 8px 10px;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    min-height: 44px;
    background: #fff;
    cursor: text;
    transition: border-color var(--afsa-t), box-shadow var(--afsa-t);
}
.afsa-tag-wrap:focus-within {
    border-color: var(--afsa-blue);
    box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.afsa-tag-chip {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: var(--afsa-blue-light);
    color: var(--afsa-blue);
    border: 1px solid var(--afsa-blue-ring);
    border-radius: 99px;
    padding: 3px 10px 3px 12px;
    font-size: 12px;
    font-weight: 600;
}
.afsa-tag-x {
    background: none;
    border: none;
    cursor: pointer;
    color: var(--afsa-blue);
    padding: 0;
    font-size: 14px;
    line-height: 1;
    opacity: .7;
    transition: opacity var(--afsa-t);
}
.afsa-tag-x:hover { opacity: 1; }
.afsa-tag-input {
    border: none;
    outline: none;
    font-size: 13px;
    padding: 2px 4px;
    min-width: 140px;
    background: transparent;
    color: var(--afsa-gray-900);
    flex: 1;
}

/* Status grid */
.afsa-status-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: 8px;
}
.afsa-status-card {
    cursor: pointer;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    padding: 10px 12px;
    background: #fff;
    text-align: center;
    font-size: 13px;
    font-weight: 600;
    color: var(--afsa-gray-500);
    transition: all var(--afsa-t);
}
.afsa-status-card input { position: absolute; opacity: 0; width: 0; height: 0; }
.afsa-status-card--draft.is-selected          { border-color: var(--afsa-gray-400);  background: var(--afsa-gray-100);   color: var(--afsa-gray-700); }
.afsa-status-card--pending_review.is-selected { border-color: var(--afsa-amber);     background: var(--afsa-amber-light); color: var(--afsa-amber); }
.afsa-status-card--approved.is-selected       { border-color: var(--afsa-cyan);      background: var(--afsa-cyan-light);  color: var(--afsa-cyan); }
.afsa-status-card--live.is-selected           { border-color: var(--afsa-green);     background: var(--afsa-green-light); color: var(--afsa-green); }
.afsa-status-card--closed.is-selected         { border-color: var(--afsa-red);       background: var(--afsa-red-light);   color: var(--afsa-red); }
.afsa-status-card--archived.is-selected       { border-color: var(--afsa-purple);    background: var(--afsa-purple-light);color: var(--afsa-purple); }

/* Checkbox group */
.afsa-check-group { display: flex; flex-direction: column; gap: 12px; }
.afsa-check-row {
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
    font-size: 14px;
    color: var(--afsa-gray-700);
}
.afsa-check-row input[type="checkbox"] {
    width: 16px;
    height: 16px;
    accent-color: var(--afsa-blue);
    cursor: pointer;
    flex-shrink: 0;
}

/* Summary card */
.afsa-summary-card {
    background: var(--afsa-gray-50);
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    padding: 20px;
    min-height: 80px;
}
.afsa-summary-placeholder { color: var(--afsa-gray-400); font-size: 14px; margin: 0; }
.afsa-summary-title { font-size: 18px; font-weight: 700; margin: 0 0 6px; color: var(--afsa-gray-900); }
.afsa-summary-cat { display: inline-block; padding: 3px 10px; border-radius: 99px; font-size: 11px; font-weight: 700; background: var(--afsa-blue-light); color: var(--afsa-blue); margin-bottom: 10px; }
.afsa-summary-meta { display: flex; gap: 16px; font-size: 12px; color: var(--afsa-gray-500); }

/* Submit row */
.afsa-submit-row {
    display: flex;
    gap: 10px;
    flex-wrap: wrap;
    align-items: center;
}

.afsa-form-feedback {
    margin-top: 16px;
    padding: 12px 16px;
    border-radius: var(--afsa-radius-sm);
    font-size: 14px;
    font-weight: 500;
}
.afsa-form-feedback.is-success { background: var(--afsa-green-light); color: var(--afsa-green); border: 1px solid #BBF7D0; }
.afsa-form-feedback.is-error   { background: var(--afsa-red-light);   color: var(--afsa-red);   border: 1px solid #FECACA; }

/* Form footer */
.afsa-form-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 0;
    gap: 12px;
}
.afsa-step-counter {
    font-size: 13px;
    color: var(--afsa-gray-400);
    font-weight: 500;
}

/* ==========================================================================
   VOTING DASHBOARD
   ========================================================================== */

.afsa-dash {
    font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
    color: var(--afsa-gray-900);
}

/* Header */
.afsa-dash-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 20px;
    margin-bottom: 24px;
    flex-wrap: wrap;
}
.afsa-dash-title {
    font-size: 28px;
    font-weight: 800;
    margin: 0 0 4px;
    color: var(--afsa-gray-900);
    line-height: 1.2;
}
.afsa-dash-sub { margin: 0; font-size: 15px; color: var(--afsa-gray-500); }
.afsa-dash-controls {
    display: flex;
    align-items: center;
    gap: 10px;
    flex-wrap: wrap;
}
.afsa-search-box {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #fff;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    padding: 9px 14px;
    transition: border-color var(--afsa-t), box-shadow var(--afsa-t);
}
.afsa-search-box:focus-within {
    border-color: var(--afsa-blue);
    box-shadow: 0 0 0 3px rgba(37,99,235,.12);
}
.afsa-search-box svg { width: 16px; height: 16px; color: var(--afsa-gray-400); flex-shrink: 0; }
.afsa-search-input {
    border: none;
    outline: none;
    font-size: 14px;
    width: 200px;
    background: transparent;
    color: var(--afsa-gray-900);
}
.afsa-filter-toggle {
    display: flex;
    align-items: center;
    gap: 6px;
    padding: 9px 16px;
    background: #fff;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    font-size: 14px;
    font-weight: 600;
    color: var(--afsa-gray-600);
    cursor: pointer;
    transition: all var(--afsa-t);
}
.afsa-filter-toggle svg { width: 15px; height: 15px; }
.afsa-filter-toggle:hover { border-color: var(--afsa-blue); color: var(--afsa-blue); }
.afsa-filter-toggle.is-active { background: var(--afsa-blue-light); border-color: var(--afsa-blue); color: var(--afsa-blue); }

/* Category tabs */
.afsa-cat-bar {
    display: flex;
    gap: 6px;
    flex-wrap: wrap;
    margin-bottom: 20px;
    padding-bottom: 16px;
    border-bottom: 1px solid var(--afsa-gray-100);
}
.afsa-cat-btn {
    padding: 7px 16px;
    border-radius: 99px;
    border: 1.5px solid var(--afsa-gray-200);
    background: #fff;
    font-size: 13px;
    font-weight: 600;
    color: var(--afsa-gray-500);
    cursor: pointer;
    transition: all var(--afsa-t);
    white-space: nowrap;
}
.afsa-cat-btn:hover { border-color: var(--afsa-blue-ring); color: var(--afsa-blue); background: var(--afsa-blue-light); }
.afsa-cat-btn.is-active { background: var(--afsa-blue); border-color: var(--afsa-blue); color: #fff; }

/* Filter panel */
.afsa-filter-panel {
    background: var(--afsa-gray-50);
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    padding: 16px 20px;
    margin-bottom: 20px;
    animation: afsaSectionIn .15s ease;
}
.afsa-filter-inner {
    display: flex;
    gap: 20px;
    flex-wrap: wrap;
}
.afsa-filter-label {
    display: flex;
    flex-direction: column;
    gap: 6px;
    font-size: 12px;
    font-weight: 600;
    color: var(--afsa-gray-600);
    min-width: 160px;
}
.afsa-filter-label .afsa-select { padding: 8px 32px 8px 12px; }

/* Grid */
.afsa-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
    gap: 20px;
}
.afsa-grid-loading {
    grid-column: 1 / -1;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 12px;
    padding: 60px 0;
    color: var(--afsa-gray-400);
    font-size: 14px;
}
.afsa-grid-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 60px 0;
    color: var(--afsa-gray-400);
    font-size: 15px;
}
.afsa-grid-empty svg { width: 48px; height: 48px; margin: 0 auto 12px; display: block; opacity: .4; }

/* Spinner */
.afsa-spinner-ring {
    width: 36px;
    height: 36px;
    border: 3px solid var(--afsa-gray-100);
    border-top-color: var(--afsa-blue);
    border-radius: 50%;
    animation: afsaSpin .7s linear infinite;
}
@keyframes afsaSpin { to { transform: rotate(360deg); } }

/* Ballot card */
.afsa-ballot-card {
    background: #fff;
    border: 1px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius);
    overflow: hidden;
    box-shadow: var(--afsa-shadow);
    transition: box-shadow var(--afsa-t), transform var(--afsa-t), border-color var(--afsa-t);
    cursor: pointer;
    display: flex;
    flex-direction: column;
}
.afsa-ballot-card:hover {
    box-shadow: var(--afsa-shadow-lg);
    transform: translateY(-2px);
    border-color: var(--afsa-blue-ring);
}
.afsa-ballot-card.is-featured { border-color: #FCD34D; box-shadow: 0 0 0 2px #FCD34D, var(--afsa-shadow-md); }

.afsa-card-image {
    position: relative;
    height: 160px;
    overflow: hidden;
    background: var(--afsa-gray-100);
}
.afsa-card-image img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .4s ease;
}
.afsa-ballot-card:hover .afsa-card-image img { transform: scale(1.04); }
.afsa-card-no-image {
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    background: linear-gradient(135deg, var(--afsa-blue-light) 0%, #DBEAFE 100%);
    color: var(--afsa-blue);
}
.afsa-card-no-image svg { width: 48px; height: 48px; opacity: .4; }

.afsa-cat-badge {
    position: absolute;
    top: 10px;
    left: 10px;
    padding: 4px 10px;
    border-radius: 99px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .4px;
    backdrop-filter: blur(6px);
}
.afsa-featured-badge {
    position: absolute;
    top: 10px;
    right: 10px;
    width: 28px;
    height: 28px;
    background: #FCD34D;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 14px;
}

/* category badge colors */
.afsa-cat--environment { background: rgba(22,163,74,.15); color: #15803D; }
.afsa-cat--economy     { background: rgba(217,119,6,.15);  color: #B45309; }
.afsa-cat--education   { background: rgba(124,58,237,.15); color: #6D28D9; }
.afsa-cat--health      { background: rgba(220,38,38,.15);  color: #B91C1C; }
.afsa-cat--infrastructure { background: rgba(37,99,235,.15); color: #1D4ED8; }
.afsa-cat--justice     { background: rgba(8,145,178,.15);  color: #0E7490; }
.afsa-cat--housing     { background: rgba(234,88,12,.15);  color: #C2410C; }
.afsa-cat--technology  { background: rgba(30,64,175,.15);  color: #1E40AF; }
.afsa-cat--default     { background: rgba(107,114,128,.15);color: #374151; }

.afsa-card-body {
    padding: 18px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.afsa-card-title {
    font-size: 16px;
    font-weight: 700;
    color: var(--afsa-gray-900);
    margin: 0;
    line-height: 1.35;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}
.afsa-card-summary {
    font-size: 13px;
    color: var(--afsa-gray-500);
    margin: 0;
    line-height: 1.55;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}
.afsa-card-footer {
    display: flex;
    align-items: center;
    gap: 10px;
    padding: 14px 18px;
    border-top: 1px solid var(--afsa-gray-100);
    background: var(--afsa-gray-50);
}
.afsa-card-stats {
    display: flex;
    align-items: center;
    gap: 12px;
    flex: 1;
}
.afsa-stat {
    display: flex;
    align-items: center;
    gap: 5px;
    font-size: 12px;
    color: var(--afsa-gray-500);
    font-weight: 500;
}
.afsa-stat svg { width: 13px; height: 13px; }
.afsa-card-ring-wrap {
    display: flex;
    align-items: center;
    gap: 8px;
    flex-shrink: 0;
}
.afsa-ring-svg { width: 52px; height: 52px; }
.afsa-ring-bg   { fill: none; stroke: var(--afsa-gray-100); stroke-width: 3; }
.afsa-ring-fill { fill: none; stroke: var(--afsa-blue); stroke-width: 3; stroke-linecap: round; transform: rotate(-90deg); transform-origin: 50% 50%; transition: stroke-dasharray .6s ease; }
.afsa-ring-pct  { font-size: 8px; font-weight: 800; fill: var(--afsa-blue); text-anchor: middle; dominant-baseline: middle; }
.afsa-ring-lbl  { font-size: 4px; fill: var(--afsa-gray-400); text-anchor: middle; }
.afsa-card-vote-btn {
    padding: 8px 16px;
    background: var(--afsa-blue);
    color: #fff;
    border: none;
    border-radius: var(--afsa-radius-sm);
    font-size: 13px;
    font-weight: 700;
    cursor: pointer;
    transition: background var(--afsa-t), transform var(--afsa-t);
    white-space: nowrap;
    flex-shrink: 0;
}
.afsa-card-vote-btn:hover { background: var(--afsa-blue-dark); transform: scale(1.03); }
.afsa-card-vote-btn.is-voted { background: var(--afsa-green); cursor: default; }
.afsa-card-vote-btn.is-voted:hover { transform: none; }

/* Priority indicator */
.afsa-priority-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    display: inline-block;
    flex-shrink: 0;
}
.afsa-priority-dot--low      { background: var(--afsa-green); }
.afsa-priority-dot--medium   { background: var(--afsa-blue); }
.afsa-priority-dot--high     { background: var(--afsa-amber); }
.afsa-priority-dot--critical { background: var(--afsa-red); }

/* Vote recorded confirmation card */
.afsa-vote-recorded {
    background: #fff;
}

/* Load more */
.afsa-load-more-wrap {
    text-align: center;
    margin-top: 28px;
}
.afsa-btn--load-more { padding: 12px 32px; }

/* ==========================================================================
   BALLOT DETAIL MODAL
   ========================================================================== */

.afsa-overlay--detail .afsa-modal--detail {
    position: relative;
    max-width: 860px;
    max-height: none;
    overflow: visible;
    flex-shrink: 0;
}
.afsa-detail-layout {
    display: grid;
    grid-template-columns: 1fr 340px;
    /* Use height (not max-height) so grid children have a definite size
       and their overflow-y: auto actually creates a scrollbar. */
    height: clamp(400px, calc(85vh - 80px), calc(100vh - 120px));
    overflow: hidden;
}

/* Voting window status banners */
.afsa-vote-status-banner {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
    border-radius: var(--afsa-radius-sm);
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 16px;
}
.afsa-vote-status-banner svg { width: 18px; height: 18px; flex-shrink: 0; margin-top: 1px; }
.afsa-vote-status-banner--pending {
    background: var(--afsa-amber-light);
    color: var(--afsa-amber);
    border: 1px solid #FDE68A;
}
.afsa-vote-status-banner--closed {
    background: var(--afsa-gray-100);
    color: var(--afsa-gray-500);
    border: 1px solid var(--afsa-gray-200);
}
.afsa-vote-status-banner p { margin: 2px 0 0; font-weight: 400; font-size: 12px; color: inherit; opacity: .8; }

/* Card voting-closed state */
.afsa-card-vote-btn.is-pending { background: var(--afsa-amber); cursor: default; }
.afsa-card-vote-btn.is-pending:hover { background: var(--afsa-amber); transform: none; }
.afsa-card-vote-btn.is-closed { background: var(--afsa-gray-400); cursor: default; }
.afsa-card-vote-btn.is-closed:hover { background: var(--afsa-gray-400); transform: none; }

/* Disabled vote options */
.afsa-vote-opts.is-disabled .afsa-vote-opt {
    opacity: .5;
    pointer-events: none;
    cursor: not-allowed;
}
.afsa-vote-opts.is-disabled { pointer-events: none; }
.afsa-detail-left {
    overflow-y: auto;
    padding: 28px;
    border-right: 1px solid var(--afsa-gray-100);
}
.afsa-detail-right {
    overflow-y: auto;
    padding: 28px;
    background: var(--afsa-gray-50);
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.afsa-detail-cover {
    width: 100%;
    height: 200px;
    border-radius: var(--afsa-radius-sm);
    object-fit: cover;
    margin-bottom: 18px;
    display: block;
}
.afsa-detail-cat { display: inline-block; padding: 4px 12px; border-radius: 99px; font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: .4px; margin-bottom: 10px; }
.afsa-detail-title { font-size: 22px; font-weight: 800; color: var(--afsa-gray-900); margin: 0 0 10px; line-height: 1.3; }
.afsa-detail-summary { font-size: 15px; color: var(--afsa-gray-500); margin: 0 0 20px; line-height: 1.6; }
.afsa-detail-section { margin-bottom: 20px; }
.afsa-detail-section h4 { font-size: 13px; font-weight: 700; color: var(--afsa-gray-400); text-transform: uppercase; letter-spacing: .6px; margin: 0 0 8px; }
.afsa-detail-section p, .afsa-detail-section li { font-size: 14px; color: var(--afsa-gray-700); line-height: 1.65; margin: 0 0 6px; }
.afsa-detail-section ul { margin: 0; padding-left: 18px; }
.afsa-detail-tags { display: flex; flex-wrap: wrap; gap: 6px; }
.afsa-detail-tag { padding: 4px 10px; background: var(--afsa-gray-100); border-radius: 99px; font-size: 12px; color: var(--afsa-gray-500); font-weight: 500; }

/* Voting panel */
.afsa-vote-panel h3 { font-size: 17px; font-weight: 700; margin: 0 0 4px; color: var(--afsa-gray-900); }
.afsa-vote-panel p  { font-size: 13px; color: var(--afsa-gray-400); margin: 0 0 16px; }

.afsa-vote-opts { display: flex; flex-direction: column; gap: 10px; }
.afsa-vote-opt {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 12px 16px;
    background: #fff;
    border: 1.5px solid var(--afsa-gray-200);
    border-radius: var(--afsa-radius-sm);
    cursor: pointer;
    transition: all var(--afsa-t);
}
.afsa-vote-opt:hover { border-color: var(--afsa-blue-ring); background: var(--afsa-blue-light); }
.afsa-vote-opt.is-selected { border-color: var(--afsa-blue); background: var(--afsa-blue-light); box-shadow: 0 0 0 2px rgba(37,99,235,.15); }
.afsa-vote-opt input { display: none; }
.afsa-vote-opt-icon {
    width: 34px;
    height: 34px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 16px;
    flex-shrink: 0;
    background: var(--afsa-gray-100);
}
.afsa-vote-opt--support .afsa-vote-opt-icon  { background: var(--afsa-green-light); }
.afsa-vote-opt--neutral .afsa-vote-opt-icon  { background: var(--afsa-amber-light); }
.afsa-vote-opt--oppose  .afsa-vote-opt-icon  { background: var(--afsa-red-light); }
.afsa-vote-opt--yes     .afsa-vote-opt-icon  { background: var(--afsa-green-light); }
.afsa-vote-opt--no      .afsa-vote-opt-icon  { background: var(--afsa-red-light); }
.afsa-vote-opt-radio {
    width: 18px;
    height: 18px;
    border: 2px solid var(--afsa-gray-300);
    border-radius: 50%;
    margin-left: auto;
    flex-shrink: 0;
    transition: all var(--afsa-t);
    position: relative;
}
.afsa-vote-opt.is-selected .afsa-vote-opt-radio {
    border-color: var(--afsa-blue);
    background: var(--afsa-blue);
}
.afsa-vote-opt.is-selected .afsa-vote-opt-radio::after {
    content: '';
    position: absolute;
    width: 6px;
    height: 6px;
    border-radius: 50%;
    background: #fff;
    top: 50%;
    left: 50%;
    transform: translate(-50%,-50%);
}
.afsa-vote-opt-text { flex: 1; }
.afsa-vote-opt-text strong { display: block; font-size: 14px; color: var(--afsa-gray-900); font-weight: 700; }
.afsa-vote-opt-text span { font-size: 12px; color: var(--afsa-gray-400); }

/* Rating stars */
.afsa-star-row { display: flex; gap: 8px; justify-content: center; margin: 8px 0; }
.afsa-star-btn {
    font-size: 28px;
    background: none;
    border: none;
    cursor: pointer;
    opacity: .3;
    transition: opacity var(--afsa-t), transform var(--afsa-t);
    padding: 0;
    line-height: 1;
}
.afsa-star-btn.is-active { opacity: 1; transform: scale(1.15); }
.afsa-star-btn:hover     { opacity: .8; transform: scale(1.1); }

/* Vote submit area */
.afsa-vote-submit-wrap {
    display: flex;
    flex-direction: column;
    gap: 8px;
}
.afsa-vote-submit-btn {
    width: 100%;
    padding: 13px;
    background: var(--afsa-blue);
    color: #fff;
    border: none;
    border-radius: var(--afsa-radius-sm);
    font-size: 15px;
    font-weight: 700;
    cursor: pointer;
    transition: background var(--afsa-t);
}
.afsa-vote-submit-btn:hover:not(:disabled) { background: var(--afsa-blue-dark); }
.afsa-vote-submit-btn:disabled { opacity: .5; cursor: not-allowed; }
.afsa-vote-closing { font-size: 12px; color: var(--afsa-gray-400); text-align: center; display: flex; align-items: center; justify-content: center; gap: 5px; }
.afsa-vote-closing svg { width: 13px; height: 13px; }

/* Results */
.afsa-results-panel { display: flex; flex-direction: column; gap: 12px; }
.afsa-results-panel h4 { font-size: 14px; font-weight: 700; color: var(--afsa-gray-700); margin: 0; }
.afsa-result-bar-row { display: flex; flex-direction: column; gap: 4px; }
.afsa-result-bar-label { display: flex; justify-content: space-between; font-size: 12px; color: var(--afsa-gray-600); font-weight: 600; }
.afsa-result-bar-track { height: 8px; background: var(--afsa-gray-100); border-radius: 99px; overflow: hidden; }
.afsa-result-bar-fill { height: 100%; border-radius: 99px; transition: width .6s cubic-bezier(.4,0,.2,1); background: var(--afsa-blue); }
.afsa-result-bar-fill--support { background: var(--afsa-green); }
.afsa-result-bar-fill--oppose  { background: var(--afsa-red); }
.afsa-result-bar-fill--neutral { background: var(--afsa-amber); }
.afsa-result-bar-fill--yes     { background: var(--afsa-green); }
.afsa-result-bar-fill--no      { background: var(--afsa-red); }
.afsa-result-total { text-align: center; font-size: 13px; color: var(--afsa-gray-400); font-weight: 500; }

/* ==========================================================================
   ADMIN BADGE
   ========================================================================== */

.afsa-admin-badge {
    display: inline-block;
    padding: 3px 8px;
    border-radius: 4px;
    font-size: 11px;
    font-weight: 700;
    text-transform: uppercase;
    letter-spacing: .3px;
}
.afsa-admin-badge--draft          { background: var(--afsa-gray-100);   color: var(--afsa-gray-600); }
.afsa-admin-badge--pending_review { background: var(--afsa-amber-light); color: var(--afsa-amber); }
.afsa-admin-badge--approved       { background: var(--afsa-cyan-light);  color: var(--afsa-cyan); }
.afsa-admin-badge--live           { background: var(--afsa-green-light); color: var(--afsa-green); }
.afsa-admin-badge--closed         { background: var(--afsa-red-light);   color: var(--afsa-red); }
.afsa-admin-badge--archived       { background: var(--afsa-purple-light);color: var(--afsa-purple); }

/* ==========================================================================
   Dark Theme  (body.is-dark-theme)
   ========================================================================== */

body.is-dark-theme {
    /* Gray scale remapped: light values become dark, dark values become light */
    --afsa-gray-50:  #141724;
    --afsa-gray-100: #1a2035;
    --afsa-gray-200: #252e42;
    --afsa-gray-300: #2f3d56;
    --afsa-gray-400: #6b7a94;
    --afsa-gray-500: #8899aa;
    --afsa-gray-600: #a0b0c4;
    --afsa-gray-700: #c8d5e0;
    --afsa-gray-900: #e8edf5;

    /* Semantic light backgrounds → translucent on dark */
    --afsa-blue-light:   rgba(59, 130, 246, 0.15);
    --afsa-blue-ring:    rgba(59, 130, 246, 0.4);
    --afsa-green-light:  rgba(22, 163, 74, 0.15);
    --afsa-amber-light:  rgba(217, 119, 6, 0.15);
    --afsa-red-light:    rgba(220, 38, 38, 0.15);
    --afsa-purple-light: rgba(124, 58, 237, 0.15);
    --afsa-cyan-light:   rgba(8, 145, 178, 0.15);

    /* Shadows deepened */
    --afsa-shadow-sm: 0 1px 2px rgba(0,0,0,.3);
    --afsa-shadow:    0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);
    --afsa-shadow-md: 0 4px 6px -1px rgba(0,0,0,.4), 0 2px 4px -1px rgba(0,0,0,.3);
    --afsa-shadow-lg: 0 10px 15px -3px rgba(0,0,0,.4), 0 4px 6px -2px rgba(0,0,0,.3);
    --afsa-shadow-xl: 0 20px 25px -5px rgba(0,0,0,.45), 0 10px 10px -5px rgba(0,0,0,.3);
}

/* Hardcoded white surfaces */
body.is-dark-theme .afsa-vote-recorded,
body.is-dark-theme .afsa-modal,
body.is-dark-theme .afsa-section,
body.is-dark-theme .afsa-ballot-card,
body.is-dark-theme .afsa-type-card,
body.is-dark-theme .afsa-status-card,
body.is-dark-theme .afsa-vote-opt,
body.is-dark-theme .afsa-form-progress,
body.is-dark-theme .afsa-type-tooltip,
body.is-dark-theme .afsa-btn--outline,
body.is-dark-theme .afsa-search-box,
body.is-dark-theme .afsa-filter-toggle,
body.is-dark-theme .afsa-cat-btn,
body.is-dark-theme .afsa-tag-wrap,
body.is-dark-theme .afsa-pill span,
body.is-dark-theme .afsa-input,
body.is-dark-theme .afsa-textarea,
body.is-dark-theme .afsa-select {
    background: #1e2638;
}

body.is-dark-theme .afsa-type-tooltip::before {
    background: #1e2638;
    border-color: var(--afsa-gray-200);
}

body.is-dark-theme .afsa-modal-x--float {
    background: rgba(30, 38, 56, 0.9);
}

body.is-dark-theme .afsa-card-no-image {
    background: linear-gradient(135deg, rgba(37, 99, 235, 0.2) 0%, rgba(37, 99, 235, 0.1) 100%);
}

/* Hardcoded coloured borders on tinted banners */
body.is-dark-theme .afsa-notice--warning,
body.is-dark-theme .afsa-vote-status-banner--pending {
    border-color: rgba(217, 119, 6, 0.4);
}
body.is-dark-theme .afsa-form-feedback.is-success {
    border-color: rgba(22, 163, 74, 0.4);
}
body.is-dark-theme .afsa-form-feedback.is-error {
    border-color: rgba(220, 38, 38, 0.4);
}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */

@media (max-width: 768px) {
    .afsa-fields { grid-template-columns: 1fr; }
    .afsa-field--full { grid-column: 1; }
    .afsa-section { padding: 20px 16px; }
    .afsa-type-grid { grid-template-columns: 1fr 1fr; }
    .afsa-status-grid { grid-template-columns: 1fr 1fr; }

    .afsa-dash-head { flex-direction: column; }
    .afsa-dash-controls { width: 100%; }
    .afsa-search-input { width: 100%; }
    .afsa-search-box { flex: 1; }
    .afsa-grid { grid-template-columns: 1fr; }

    .afsa-detail-layout { grid-template-columns: 1fr; height: auto; overflow: visible; }
    .afsa-detail-left { border-right: none; border-bottom: 1px solid var(--afsa-gray-100); max-height: 55vh; overflow-y: auto; }
    .afsa-detail-right { max-height: none; overflow-y: visible; }

    .afsa-steps-nav { gap: 2px; }
    .afsa-step-dot { min-width: 40px; padding: 4px; }
    .afsa-dot-label { display: none; }

    .afsa-submit-row { flex-direction: column; }
    .afsa-submit-row .afsa-btn { width: 100%; justify-content: center; }

    .afsa-filter-inner { flex-direction: column; }
}

@media (max-width: 480px) {
    .afsa-dash-title { font-size: 22px; }
    .afsa-type-grid { grid-template-columns: 1fr; }
    .afsa-status-grid { grid-template-columns: repeat(2, 1fr); }
    .afsa-card-footer { flex-wrap: wrap; }
}
