/* IPD admission form — aligned with OPD register, step-based layout */

body.page-ipd-admit {
    overflow-x: hidden;
}

body.page-ipd-admit .main {
    overflow-x: clip;
    min-width: 0;
}

.ipd-admit.opd-register {
    margin: 1rem 0 2.5rem;
}

.ipd-admit .opd-register__form {
    display: flex;
    flex-direction: column;
    gap: 1rem;
}

/* —— Cards —— */
.ipd-admit__card .opd-register__card-head {
    flex-wrap: wrap;
}

.ipd-admit__card-body {
    padding: 0 1.15rem 1.15rem;
}

.ipd-admit__card-body > .ipd-admit__step + .ipd-admit__step {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--opd-border, #e2e8f0);
}

/* —— Step headers —— */
.ipd-admit__step-title {
    display: flex;
    align-items: center;
    gap: 0.55rem;
    margin: 0 0 0.75rem;
    font-size: 0.92rem;
    font-weight: 650;
    color: #0f172a;
}

.ipd-admit__step-num {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1.45rem;
    height: 1.45rem;
    border-radius: 999px;
    background: var(--opd-accent-soft, #e0f2fe);
    color: var(--opd-accent, #0369a1);
    font-size: 0.72rem;
    font-weight: 700;
    flex-shrink: 0;
}

.ipd-admit__step-lead {
    margin: -0.35rem 0 0.75rem;
    font-size: 0.82rem;
    color: var(--opd-muted, #64748b);
}

/* —— Segmented admission source —— */
.ipd-admit-segment {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    padding: 0.3rem;
    background: var(--opd-surface, #f8fafc);
    border: 1px solid var(--opd-border, #e2e8f0);
    border-radius: 10px;
}

.ipd-admit-segment__option {
    position: relative;
    margin: 0;
    cursor: pointer;
}

.ipd-admit-segment__option input {
    position: absolute;
    opacity: 0;
    width: 0;
    height: 0;
    pointer-events: none;
}

.ipd-admit-segment__label {
    display: block;
    padding: 0.45rem 0.95rem;
    border-radius: 7px;
    font-size: 0.84rem;
    font-weight: 600;
    color: #475569;
    transition: background 0.15s, color 0.15s, box-shadow 0.15s;
}

.ipd-admit-segment__option input:checked + .ipd-admit-segment__label {
    background: #fff;
    color: #0f172a;
    box-shadow: 0 1px 4px rgba(15, 23, 42, 0.08);
}

.ipd-admit-segment__option input:focus-visible + .ipd-admit-segment__label {
    outline: 2px solid var(--opd-accent, #0369a1);
    outline-offset: 2px;
}

.ipd-admit-segment--nested {
    margin-top: 0.5rem;
}

/* —— Patient source panels —— */
.ipd-admit-panel {
    margin-top: 0.25rem;
}

.ipd-admit-panel[hidden] {
    display: none !important;
}

.ipd-admit__lookup-row {
    display: grid;
    gap: 0.5rem;
    max-width: 36rem;
}

.ipd-admit__lookup-row .patient-register-search--inline {
    width: 100%;
}

.ipd-admit__lookup-row select.patient-register-control,
.ipd-admit__lookup-row select.opd-register-control {
    width: 100%;
    max-width: 100%;
}

/* —— Patient preview strip —— */
.ipd-patient-preview {
    margin-top: 1rem;
    padding: 0.85rem 1rem;
    background: linear-gradient(180deg, #f0f9ff 0%, #f8fafc 100%);
    border: 1px solid #bae6fd;
    border-radius: 10px;
}

.ipd-patient-preview[hidden] {
    display: none !important;
}

.ipd-patient-preview__title {
    margin: 0 0 0.65rem;
    font-size: 0.8rem;
    font-weight: 650;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: #0369a1;
}

.ipd-preview-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(10.5rem, 1fr));
    gap: 0.65rem 1rem;
    margin: 0;
}

.ipd-preview-grid dt {
    font-size: 0.68rem;
    text-transform: uppercase;
    letter-spacing: 0.04em;
    color: var(--opd-muted, #64748b);
    margin: 0 0 0.1rem;
}

.ipd-preview-grid dd {
    margin: 0;
    font-size: 0.88rem;
    font-weight: 550;
    color: #0f172a;
}

/* —— Direct new: OPD fields embedded —— */
.ipd-admit-opd-fields {
    margin-top: 0.75rem;
    padding-top: 0.85rem;
    border-top: 1px dashed var(--opd-border, #e2e8f0);
}

.ipd-admit-opd-fields .opd-register__setup--in-card {
    margin-bottom: 0.85rem;
}

.ipd-admit-opd-fields .opd-register__billing {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid var(--opd-border, #e2e8f0);
}

.ipd-admit-opd-fields .opd-register__collapse {
    margin-top: 0.65rem;
}

/* —— IPD details grid —— */
.ipd-admit__ipd-body {
    padding: 1rem 1.15rem 1.15rem;
}

.ipd-admit__ipd-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 1.25rem 1.5rem;
    align-items: start;
}

.ipd-admit__ipd-block-title {
    margin: 0 0 0.75rem;
    font-size: 0.88rem;
    font-weight: 650;
    color: #334155;
}

.ipd-admit__field {
    margin-bottom: 0.75rem;
}

.ipd-admit__field:last-child {
    margin-bottom: 0;
}

.ipd-admit__field-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 0.65rem 0.75rem;
}

.ipd-admit__field-grid--4 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
}

.ipd-admit__field-grid .ipd-admit__field {
    margin-bottom: 0;
}

.ipd-admit__attendant {
    margin-top: 1.25rem;
    padding-top: 1.25rem;
    border-top: 1px solid var(--opd-border, #e2e8f0);
}

.ipd-admit__actions {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.65rem;
    margin-top: 1.25rem;
    padding: 1rem 1.15rem;
    border-top: 1px solid var(--opd-border, #e2e8f0);
    background: var(--opd-surface, #f8fafc);
}

/* Labels inside IPD blocks — match OPD */
.ipd-admit .opd-register__label,
.ipd-admit .label-cap {
    font-size: 0.78rem;
}

.ipd-admit .patient-register-control,
.ipd-admit .opd-register-control {
    width: 100%;
    max-width: 100%;
    box-sizing: border-box;
}

/* —— Responsive —— */
@media (max-width: 960px) {
    .ipd-admit__ipd-grid {
        grid-template-columns: 1fr;
    }

    .ipd-admit__field-grid--4 {
        grid-template-columns: repeat(2, minmax(0, 1fr));
    }
}

@media (max-width: 560px) {
    .ipd-admit__field-grid,
    .ipd-admit__field-grid--4 {
        grid-template-columns: 1fr;
    }

    .ipd-admit-segment {
        display: flex;
        width: 100%;
    }

    .ipd-admit-segment__option {
        flex: 1;
    }

    .ipd-admit-segment__label {
        text-align: center;
        padding: 0.5rem 0.4rem;
        font-size: 0.78rem;
    }
}
