﻿/* =========================================================
   Shelvera Inventory Add Drawer
   Desktop: right-side drawer.
   Mobile: near-full-screen bottom sheet.
   ========================================================= */

.entity-add-modal {
    --entity-add-width: min(92vw, 600px);
}

.entity-add-dialog {
    width: var(--entity-add-width);
    max-width: var(--entity-add-width);
    height: 100vh;
    min-height: 100vh;
    margin: 0 0 0 auto;
}

.entity-add-modal .modal-content {
    height: 100vh;
    min-height: 100vh;
    border: 0;
    border-radius: 1.35rem 0 0 1.35rem;
    overflow: hidden;
    background: #ffffff;
    box-shadow: -1.2rem 0 3.5rem rgba(15, 23, 42, 0.16);
}

.modal.fade .entity-add-dialog {
    transform: translateX(2.25rem);
    transition: transform .22s ease-out;
}

.modal.show .entity-add-dialog {
    transform: none;
}

.entity-add-header {
    align-items: flex-start;
    gap: 1rem;
    padding: 1.35rem 1.45rem 1rem;
    border-bottom: 1px solid rgba(19, 37, 75, .08);
    background: #ffffff;
}

.entity-add-heading .sv-eyebrow {
    display: block;
    margin: 0 0 .22rem;
}

.entity-add-heading h2 {
    margin: 0;
    color: #0f172a;
    font-family: "Montserrat", sans-serif;
    font-size: 1.42rem;
    font-weight: 700;
}

.entity-add-body {
    padding: 1.15rem 1.45rem 1.35rem;
    background: #ffffff;
}

.entity-add-type-switch {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: .72rem;
    margin-bottom: 1rem;
}

.entity-add-type-choice {
    display: flex;
    align-items: center;
    gap: .62rem;
    min-height: 4.15rem;
    padding: .65rem .72rem;
    border: 1px solid #dbe4f3;
    border-radius: .95rem;
    background: #ffffff;
    color: #475569;
    text-align: left;
    transition: border-color .16s ease, background-color .16s ease, box-shadow .16s ease, color .16s ease;
}

    .entity-add-type-choice:hover:not(:disabled),
    .entity-add-type-choice:focus-visible:not(:disabled) {
        border-color: #bdcaf5;
        background: #f7f9ff;
    }

    .entity-add-type-choice.is-selected {
        border-color: rgba(75, 99, 255, .48);
        background: linear-gradient(145deg, #f4f6ff 0%, #ffffff 100%);
        color: #1735a5;
        box-shadow: 0 0 0 3px rgba(75, 99, 255, .08);
    }

    .entity-add-type-choice:disabled {
        opacity: .58;
        cursor: not-allowed;
    }

.entity-add-choice-icon {
    display: grid;
    width: 2.15rem;
    height: 2.15rem;
    flex-shrink: 0;
    place-items: center;
    border-radius: .7rem;
    background: rgba(75, 99, 255, .09);
    font-size: 1.15rem;
}

.entity-add-type-choice strong {
    display: block;
    color: inherit;
    font-size: .92rem;
}

.entity-add-type-choice small {
    display: block;
    margin-top: .08rem;
    color: #6b7892;
    font-size: .72rem;
}

.entity-add-location-card {
    padding: .8rem .88rem;
    border: 1px solid #dbeafe;
    border-radius: .9rem;
    background: linear-gradient(145deg, #f8fbff 0%, #eff6ff 100%);
}

.entity-add-label {
    display: block;
    color: #64748b;
    font-size: .7rem;
    font-weight: 700;
    letter-spacing: .08em;
    text-transform: uppercase;
}

.entity-add-location-card p {
    margin: .24rem 0 0;
    color: #1d4ed8;
    font-size: .92rem;
    font-weight: 600;
    word-break: break-word;
}

.entity-add-intro {
    margin: .9rem 0 1rem;
    color: #66758e;
    font-size: .87rem;
}

.entity-add-feedback {
    margin-bottom: .95rem;
}

.entity-add-field-grid {
    display: grid;
    grid-template-columns: minmax(0, 1fr) 9rem;
    gap: .9rem;
}

.entity-add-field {
    display: grid;
    align-content: start;
    gap: .38rem;
}

.entity-add-field-full {
    grid-column: 1 / -1;
}

.entity-add-field label {
    color: #314056;
    font-size: .84rem;
    font-weight: 600;
}

.entity-add-field[hidden] {
    display: none !important;
}

.entity-add-photo-card {
    margin-top: 1.1rem;
    padding: 1rem;
}

.entity-add-footer {
    gap: .65rem;
    justify-content: flex-end;
    padding: .95rem 1.45rem 1.15rem;
    border-top: 1px solid rgba(19, 37, 75, .08);
    background: #ffffff;
}

.entity-add-noscript {
    margin: .85rem 0 0;
    color: #6b7892;
    font-size: .82rem;
}

.entity-add-modal.is-busy .entity-add-header .btn-close,
.entity-add-modal.is-busy [data-entity-add-dismiss] {
    pointer-events: none;
    opacity: .45;
}

@media (prefers-reduced-motion: reduce) {
    .modal.fade .entity-add-dialog {
        transition: none;
    }
}

@media (max-width: 767.98px) {
    .entity-add-modal {
        --entity-add-width: 100%;
    }

    .entity-add-dialog {
        display: flex;
        align-items: flex-end;
        height: 100dvh;
        min-height: 100dvh;
        margin: 0;
    }

    .entity-add-modal .modal-content {
        height: min(94dvh, 860px);
        min-height: min(94dvh, 860px);
        border-radius: 1.25rem 1.25rem 0 0;
        box-shadow: 0 -1.2rem 3.25rem rgba(15, 23, 42, .17);
    }

    .modal.fade .entity-add-dialog {
        transform: translateY(2rem);
    }

    .modal.show .entity-add-dialog {
        transform: none;
    }

    .entity-add-header {
        padding: 1.05rem 1rem .86rem;
    }

    .entity-add-body {
        padding: .95rem 1rem 1.05rem;
    }

    .entity-add-type-switch,
    .entity-add-field-grid {
        grid-template-columns: 1fr;
    }

    .entity-add-footer {
        padding: .8rem 1rem calc(.8rem + env(safe-area-inset-bottom, 0px));
    }

        .entity-add-footer .btn {
            flex: 1;
        }
}