.cvme-eoc-shell,
.cvme-eoc-section {
    box-sizing: border-box;
    max-width: 1100px;
    margin: 0 auto 24px;
}

.cvme-eoc-shell {
    padding: 22px;
    border: 1px solid #d9e2ec;
    border-radius: 22px;
    background: #f5f7fa;
    box-shadow: 0 18px 48px rgba(11, 31, 58, 0.08);
}

.cvme-eoc-hero {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 18px;
    margin: 0 0 18px;
    padding: 22px;
    border-radius: 18px;
    background: #ffffff;
    border: 1px solid #d9e2ec;
}

.cvme-eoc-kicker {
    margin: 0 0 6px;
    color: #064191;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.12em;
    text-transform: uppercase;
}

.cvme-eoc-hero h2,
.cvme-eoc-section h2,
.cvme-eoc-section h3,
.cvme-eoc-card h3,
.cvme-eoc-doc-card h3 {
    color: #064191;
}

.cvme-eoc-hero h2 {
    margin: 0 0 8px;
    font-size: clamp(24px, 3vw, 38px);
    line-height: 1.05;
}

.cvme-eoc-hero p {
    max-width: 720px;
    margin: 0;
}

.cvme-eoc-hero-status {
    min-width: 180px;
    padding: 16px;
    border-radius: 16px;
    background: #064191;
    color: #fff;
    text-align: center;
}

.cvme-eoc-hero-status span,
.cvme-eoc-hero-status strong {
    display: block;
}

.cvme-eoc-hero-status span {
    margin-bottom: 4px;
    font-size: 12px;
    font-weight: 800;
    letter-spacing: 0.08em;
    text-transform: uppercase;
}

.cvme-eoc-hero-status strong {
    font-size: 18px;
}

.cvme-eoc-tabs {
    display: grid;
    grid-template-columns: repeat(6, minmax(0, 1fr));
    gap: 8px;
    margin: 18px 0;
    padding: 8px;
    border: 1px solid #d9e2ec;
    border-radius: 18px;
    background: #ffffff;
}

.cvme-eoc-tab {
    min-height: 44px;
    border: 1px solid #d9e2ec;
    border-radius: 999px;
    background: #f5f7fa;
    color: #0b1f3a;
    font-weight: 800;
    cursor: pointer;
}

.cvme-eoc-tab.is-active {
    border-color: #064191;
    background: #064191;
    color: #fff;
}

.cvme-eoc-panels {
    position: relative;
}

.cvme-eoc-panel {
    display: none;
}

.cvme-eoc-panel.is-active {
    display: block;
}

.cvme-eoc-panel > .cvme-eoc-section,
.cvme-eoc-section {
    padding: 18px;
    border: 1px solid #d9e2ec;
    border-radius: 18px;
    background: #ffffff;
}

.cvme-eoc-form {
    display: grid;
    gap: 16px;
}

.cvme-eoc-form label,
.cvme-eoc-slot-upload label {
    display: grid;
    gap: 6px;
    font-weight: 700;
}

.cvme-eoc-form input,
.cvme-eoc-form textarea,
.cvme-eoc-form select,
.cvme-eoc-slot-upload input,
.cvme-eoc-slot-upload textarea,
.cvme-eoc-slot-upload select {
    box-sizing: border-box;
    width: 100%;
    max-width: 100%;
    padding: 10px 12px;
    border: 1px solid #ccd3dc;
    border-radius: 10px;
    background: #fff;
}

.cvme-eoc-form button,
.cvme-eoc-slot-upload button,
.cvme-eoc-button {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: fit-content;
    min-height: 42px;
    padding: 0 18px;
    border: 1px solid #064191;
    border-radius: 999px;
    background: #064191;
    color: #fff;
    font-weight: 800;
    text-decoration: none;
    cursor: pointer;
}

.cvme-eoc-form button:hover,
.cvme-eoc-slot-upload button:hover,
.cvme-eoc-button:hover {
    background: #053676;
    color: #fff;
}

.cvme-eoc-notice {
    margin: 0 0 16px;
    padding: 12px 14px;
    border-left: 4px solid #064191;
    border-radius: 10px;
    background: #fff;
}

.cvme-eoc-success {
    border-color: #22c55e;
}

.cvme-eoc-error {
    border-color: #b32d2e;
}

.cvme-eoc-warning {
    border-color: #dba617;
}

.cvme-eoc-info {
    border-color: #064191;
}

.cvme-eoc-status,
.cvme-eoc-muted,
.cvme-eoc-pill {
    display: inline-flex;
    align-items: center;
    min-height: 26px;
    padding: 4px 12px;
    border-radius: 999px;
    background: #e8eef7;
    color: #064191;
    font-weight: 800;
}

.cvme-eoc-muted {
    color: #3f4a56;
    background: #eef1f4;
    font-weight: 700;
}

.cvme-eoc-muted-block {
    margin: 0 0 18px;
    color: #3f4a56;
}

.cvme-eoc-cards,
.cvme-eoc-overview-grid,
.cvme-eoc-doc-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}

.cvme-eoc-card,
.cvme-eoc-checklist,
.cvme-eoc-agreement-text,
.cvme-eoc-doc-card,
.cvme-eoc-doc-mini-list,
.cvme-eoc-locked-card {
    padding: 16px;
    border: 1px solid #d9e0e8;
    border-radius: 16px;
    background: #fff;
}

.cvme-eoc-overview-card {
    display: grid;
    gap: 10px;
}

.cvme-eoc-doc-card {
    display: grid;
    gap: 12px;
}

.cvme-eoc-doc-card-head {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
}

.cvme-eoc-doc-card h3,
.cvme-eoc-card h3 {
    margin: 0 0 6px;
}

.cvme-eoc-doc-card p {
    margin: 0;
}

.cvme-eoc-doc-status-approved {
    border-color: rgba(34, 197, 94, 0.55);
    background: #f0fdf4;
}

.cvme-eoc-doc-status-rejected,
.cvme-eoc-doc-status-rejected_needs_replacement {
    border-color: rgba(179, 45, 46, 0.55);
    background: #fff7f7;
}

.cvme-eoc-doc-status-pending_review,
.cvme-eoc-doc-status-needs_review {
    border-color: rgba(219, 166, 23, 0.6);
    background: #fffbeb;
}

.cvme-eoc-doc-file {
    padding: 10px 12px;
    border-radius: 12px;
    background: #f5f7fa;
}

.cvme-eoc-doc-missing {
    color: #5b6470;
}

.cvme-eoc-note {
    padding: 10px 12px;
    border-left: 4px solid #dba617;
    border-radius: 10px;
    background: #fffbeb;
}

.cvme-eoc-slot-upload {
    display: grid;
    gap: 10px;
}

.cvme-eoc-records {
    width: 100%;
    margin: 0 0 18px;
    border-collapse: separate;
    border-spacing: 0;
    overflow: hidden;
    border: 1px solid #d9e0e8;
    border-radius: 12px;
    background: #fff;
}

.cvme-eoc-records th,
.cvme-eoc-records td {
    padding: 10px;
    border-bottom: 1px solid #e2e7ee;
    text-align: left;
    vertical-align: top;
}

.cvme-eoc-records tr:last-child th,
.cvme-eoc-records tr:last-child td {
    border-bottom: 0;
}

.cvme-eoc-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.cvme-eoc-check {
    display: flex;
    grid-template-columns: auto 1fr;
    align-items: center;
}

.cvme-eoc-check input {
    width: auto;
}

.cvme-eoc-mini-grid {
    display: grid;
    grid-template-columns: repeat(5, minmax(0, 1fr));
    gap: 10px;
}

.cvme-eoc-mini-grid div {
    padding: 12px;
    border: 1px solid #d9e2ec;
    border-radius: 12px;
    background: #f5f7fa;
}

.cvme-eoc-mini-grid strong,
.cvme-eoc-mini-grid span {
    display: block;
}

.cvme-eoc-mini-grid span {
    margin-top: 6px;
    color: #064191;
    font-weight: 800;
}

.cvme-eoc-legacy-docs {
    margin-top: 18px;
}

@media (max-width: 900px) {
    .cvme-eoc-tabs {
        grid-template-columns: repeat(3, minmax(0, 1fr));
    }

    .cvme-eoc-mini-grid {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 720px) {
    .cvme-eoc-shell,
    .cvme-eoc-section {
        padding: 14px;
        border-radius: 14px;
    }

    .cvme-eoc-hero {
        display: grid;
    }

    .cvme-eoc-tabs,
    .cvme-eoc-cards,
    .cvme-eoc-overview-grid,
    .cvme-eoc-doc-grid,
    .cvme-eoc-mini-grid {
        grid-template-columns: 1fr;
    }

    .cvme-eoc-form button,
    .cvme-eoc-slot-upload button,
    .cvme-eoc-button {
        width: 100%;
    }

    .cvme-eoc-records th,
    .cvme-eoc-records td {
        display: block;
        width: 100%;
        box-sizing: border-box;
    }
}

.cvme-eoc-esign-box,
.cvme-eoc-signed-copy,
.cvme-eoc-signed-record-link {
    border: 1px solid #d9e2ec;
    border-radius: 14px;
    background: #f8fafc;
    padding: 14px;
    margin: 14px 0;
}

.cvme-eoc-esign-box h3,
.cvme-eoc-signed-copy h3 {
    margin-top: 0;
    color: #064191;
}

.cvme-eoc-signature-form .cvme-eoc-check {
    align-items: flex-start;
    gap: 10px;
}

.cvme-eoc-signature-form .cvme-eoc-check input {
    margin-top: 4px;
}

/* v0.1.4 step navigation fixes */
.cvme-eoc-step-wrap {
    border: 1px solid #d9e2ec;
    background: #ffffff;
    border-radius: 18px;
    padding: 10px;
    margin: 12px 0 16px;
    box-shadow: 0 8px 24px rgba(11,31,58,.06);
}
.cvme-eoc-step-wrap-top {
    position: sticky;
    top: 32px;
    z-index: 50;
}
.cvme-eoc-step-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    justify-content: center;
    align-items: center;
    margin-top: 10px;
}
.cvme-eoc-button-secondary {
    background: #ffffff !important;
    color: #064191 !important;
    border: 1px solid #a9bfdb !important;
}
.cvme-eoc-button-small {
    padding: 7px 12px !important;
    font-size: 12px !important;
    margin-left: 8px;
}
.cvme-eoc-saved-notice {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    align-items: center;
    justify-content: space-between;
}
.cvme-eoc-admin-diagnostic {
    border: 1px dashed #064191;
    background: #f8fbff;
    border-radius: 14px;
    padding: 14px;
    margin-top: 16px;
}
.cvme-eoc-admin-diagnostic ul {
    margin: 8px 0 0 18px;
}
@media (max-width: 700px) {
    .cvme-eoc-step-wrap-top {
        position: static;
    }
    .cvme-eoc-step-actions .cvme-eoc-button,
    .cvme-eoc-saved-notice .cvme-eoc-button {
        width: 100%;
        text-align: center;
    }
}

/* v0.1.6 official application and declination form additions */
.cvme-eoc-fieldset {
    border: 1px solid #d9e2ec;
    border-radius: 16px;
    background: #f8fafc;
    padding: 16px;
    margin: 0;
}
.cvme-eoc-fieldset legend {
    padding: 0 8px;
    color: #064191;
    font-weight: 900;
}
.cvme-eoc-form-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
}
.cvme-eoc-form-full {
    grid-column: 1 / -1;
}
.cvme-eoc-declination-details {
    border: 1px solid #d9e2ec;
    border-radius: 14px;
    background: #f8fafc;
    padding: 12px;
}
.cvme-eoc-declination-details summary {
    color: #064191;
    font-weight: 900;
    cursor: pointer;
}
.cvme-eoc-declination-form {
    margin-top: 12px;
}
@media (max-width: 720px) {
    .cvme-eoc-form-grid {
        grid-template-columns: 1fr;
    }
}


.cvme-eoc-official-form-header{display:flex;justify-content:space-between;gap:12px;align-items:center;background:#f5f7fa;border:1px solid #d9e2ec;border-left:5px solid #064191;border-radius:12px;padding:12px 14px;margin:12px 0 16px;color:#0b1f3a}.cvme-eoc-official-form-header strong{font-size:.95rem;color:#064191;text-transform:uppercase;letter-spacing:.04em}.cvme-eoc-official-form-header span{font-size:.88rem;color:#334155}.cvme-eoc-scroll-panel{max-height:520px;overflow:auto;border:1px solid #d9e2ec;border-radius:14px;background:#fff;padding:18px}.cvme-eoc-inline-choice{border:1px solid #d9e2ec;border-radius:12px;padding:12px;margin:12px 0}.cvme-eoc-inline-choice legend{font-weight:800;color:#064191}.cvme-eoc-inline-choice label{display:block;margin:8px 0}

/* v0.2.1 CASAS testing gate */
.cvme-eoc-casas-section .cvme-eoc-casas-call-card {
    border-left: 4px solid #064191;
}
.cvme-eoc-inline-list {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(150px, 1fr));
    gap: 8px;
    margin: 10px 0 0;
    padding: 0;
    list-style: none;
}
.cvme-eoc-inline-list li {
    background: #f5f7fa;
    border: 1px solid #d9e2ec;
    border-radius: 10px;
    padding: 8px 10px;
    font-weight: 700;
}
