/* Define styles for the BaseLayout component */
.base-layout {
    flex-direction: column;
    min-height: 100vh;
}

.base-layout .header {
    height: 60px;
}

.base-layout .body {
    flex-grow: 1;
    padding: 0 10px;
    padding-block-start: 40px;
}

.base-layout .body.wesog-body {
    display: flex;
    flex-direction: column;
    justify-content: center;
}

.base-layout .footer {
    width: 100vw;
    padding-block-start: 50px;
}

.body.details-view {
    padding: 10px 0 0 0;
}

.footer.details-view {
    padding-block-start: 0;
}

@media (width < 640px) {
    .base-layout > .body {
        width: 96vw;
    }

    .body.details-view {
        width: 100vw;
    }
}

[data-main-spinner] {
    display: flex;
}

[data-base-layout] {
    display: flex;
    opacity: 0;
}
