/* ===============================
   FurniPlace Overlay
================================ */
#furniplace-modal {
    position: fixed;
    inset: 0;
    background: rgba(0, 0, 0, 0.75);
    z-index: 999999;
    display: none;
    display: flex;
    align-items: center;
    justify-content: center;
    /* safe margin */
}

/* ===============================
   Modal Container
================================ */
.furniplace-modal-content {
    background: #fff;
    width: 100%;
    height: 100%;
    overflow-y: auto;
    box-shadow: 0 25px 60px rgba(0, 0, 0, 0.35);
    position: relative;
    animation: furniPop 0.35s ease;
    padding-block: var(--block-spacing);
}

/* ===============================
   Scrollable Content Area
================================ */
.furniplace-modal-content-inner {
    padding: 24px 26px;
    overflow-y: auto;
    /* 🔥 internal scroll */
    flex: 1;
}

/* ===============================
   Close Button
================================ */


/* ===============================
   Title
================================ */
.furniplace-modal-content h3 {
    margin: 0 0 18px;
    font-size: 20px;
    font-weight: 600;
    color: #3b2a1a;
    text-align: center;
}

/* ===============================
   File Upload Styling
================================ */
#furniplace-room {
    width: 100%;
    padding: 10px;
    border: 2px dashed #c7b299;
    border-radius: 10px;
    background: #faf7f4;
    cursor: pointer;
    margin-bottom: 18px;
}

#furniplace-room::file-selector-button {
    padding: 8px 14px;
    border-radius: 6px;
    border: none;
    background: #8a5a3c;
    color: #fff;
    font-size: 13px;
    cursor: pointer;
}

#furniplace-room::file-selector-button:hover {
    background: #6e4228;
}

/* ===============================
   Generate Button (CTA)
================================ */
#furniplace-generate {
    width: 100%;
    padding: 14px;
    border-radius: 10px;
    border: none;
    background: linear-gradient(135deg, #8a5a3c, #5a341f);
    color: #fff;
    font-size: 15px;
    font-weight: 600;
    letter-spacing: .3px;
    cursor: pointer;
    transition: all .25s ease;
}

#furniplace-generate:hover {
    transform: translateY(-1px);
    box-shadow: 0 10px 25px rgba(0, 0, 0, 0.25);
}

/* ===============================
   Result Section
================================ */

#furniplace-result img {
    max-width: 100%;
    border-radius: 12px;
    box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25);
}

/* ===============================
   Animation
================================ */
@keyframes furniPop {
    from {
        opacity: 0;
        transform: scale(0.92);
    }

    to {
        opacity: 1;
        transform: scale(1);
    }
}

/* ===============================
   Mobile
================================ */

.instruction-section {
    margin-top: 15px;
}

.instruction-section label {
    display: block;
    font-size: 13px;
    font-weight: 600;
    margin-bottom: 6px;
    color: #3b2a1a;
}

#furniplace-instruction {
    width: 100%;
    min-height: 80px;
    padding: 10px;
    border-radius: 8px;
    border: 1px solid #c7b299;
    resize: vertical;
    font-size: 13px;
}


/* ===============================
   Loading State
================================ */
#furniplace-loading {
    margin-top: 20px;
    text-align: center;
    color: #3b2a1a;
    font-size: 14px;
    font-weight: 500;
}

.furniplace-spinner {
    width: 42px;
    height: 42px;
    margin: 0 auto 12px;
    border: 4px solid #e5d6c7;
    border-top: 4px solid #8a5a3c;
    border-radius: 50%;
    animation: furniSpin 1s linear infinite;
}

@keyframes furniSpin {
    to {
        transform: rotate(360deg);
    }
}




#furniplace-result {
    width: 100%;
    background-color: var(--clr-gray-200);
    margin: 0;
}

.furniplace-modal-content .Block-heading {
    margin: 0;
}

.furniplace-modal-content .furniplace-modal-header {
    display: flex;
    align-items: center;
    gap: 1rem;
    margin-block-end: 1.5rem;
    padding-block-end: 1.5rem;
    border-bottom: 1px solid var(--clr-gray-400);
    justify-content: space-between;
}

.furniplace-modal-content .Flex-root {
    align-items: center;
    --gap: 5rem;
}

.furniplace-modal-content {
    contain: paint;
}

.furniplace-modal-content #furniplace-loading {
    position: absolute;
    inset: 0;
    z-index: 2;
    display: grid;
    place-content: center;
    background-color: hsl(0, 0%, 100%, 70%);
    backdrop-filter: blur(0.5rem);
}


@media (max-width: 575.98px) {
    .furniplace-modal-header .Block-heading span {
        font-size: 1.15rem;
    }

    .furniplace-modal-header .Button-root {
        padding: 0.85rem;
        border-radius: 50%;
    }

    .furniplace-modal-header .Button-root span:not([class]) {
        display: none;
    }
}



#furniplace-history-tabs {
    margin-top: 3rem;
}

#furniplace-history-tabs tab-list::part(scroll-container) {
    flex-direction: column;
    gap: 1.5rem;
}

#furniplace-history-tabs {
    max-width: min(100%, 400px);
}

#furniplace-history-tabs tab-trigger {
    padding: 0;
    border-radius: 1rem;
}

#furniplace-history-tabs tab-trigger img {
    width: 100%;
    aspect-ratio: 16 / 9;
    object-fit: cover;
    object-position: center bottom;
}

.Block-productHistory {
    contain: paint;
}

.Block-productHistory .History-box {
    padding: 1.5rem;
    background-color: var(--clr-primary-light);
    border-radius: 1rem;
}

#furniplace-history-tabs tab-content {
    position: absolute;
    inset: 0;
    z-index: -2;
}

#furniplace-history-tabs tab-content :is(ui-transition, ui-transition img) {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-position: right;
}

#furniplace-history-tabs tab-content img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

#furniplace-history-tabs tab-trigger {
    outline: none;
}

#furniplace-history-tabs tab-trigger::before {
    content: "";
    position: absolute;
    inset: 0;
    box-shadow: inset 0 0 0 1rem transparent;
    transition: 300ms;
}

#furniplace-history-tabs tab-trigger[aria-selected="true"]::before {
    box-shadow: inset 0 0 0 1rem #fff;
}

.Block-productHistory {
    min-height: min(100vh, 1080px);
    min-height: min(100dvh, 1080px);
}

.Block-productHistory .Block-object>* {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    z-index: -3;
}
#furniplace-recent-wrapper {
    display: none;
}



.furniplace-left .Block-heading {
    display: flex;
    align-items: center;
    gap: 16px;
    cursor: pointer;
}
.furniplace-left .Block-heading iconify-icon {
    margin: 0;
    font-size: 24px;
}
.furniplace-modal-content {
    display: grid;
    padding: 0;
    grid-template-columns: 1fr 1.5fr;
}
.furniplace-modal-content .furniplace-left {
    padding: 50px;
}
.furniplace-modal-content .furniplace-right {
    contain: paint;
    min-width: 0;
}
#furniplace-result img {
    border-radius: 0;
    box-shadow: none;
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
}
#furniplace-recent-images {
    display: flex;
    gap: 16px;
    margin-block-end: 40px;
}
.furniplace-recent-title {
    margin-block-end: 16px;
}
#furniplace-recent-images > * {
    flex: 0 0 64px;
    cursor: pointer;
    aspect-ratio: 1;
    border-radius: 8px;
    contain: paint;
    box-shadow: 0 0 0 4px #f9f1ec;
}
#furniplace-recent-images img {
    width: 100%;
    object-fit: cover;
    height: 100%;
}
#furniplace-result {
    width: 100%;
    height: 100%;
    display: grid;
    align-items: end;
    padding: 50px;
}
#furniplace-download {
    width: 100%;
    max-width: 718px;
    margin-inline: auto;
	    background-image: url(https://dev1.softwaresenior.com/wp-content/uploads/2026/02/431b021…-scaled.jpg);
    background-size: 100%;
}

#furniplace-history-tabs tab-list::part(indicator) {
    display: none;
}

@media (max-width: 991.98px) {
	.furniplace-modal-content {
		grid-template-columns: 1fr;
		grid-template-rows: 1fr 1fr;
	}
	.furniplace-left {
		padding: 16px !important;
	}
}


.upload-trigger-box {
    display: grid;
}
.upload-trigger-box > * {
    grid-area: 1 / -1;
}
.upload-trigger-box #fp-trigger {
    z-index: 99;
    opacity: 0;
    cursor: pointer;
}

.fp-box {
    padding: 24px;
	overflow: auto;
	max-height: 95%;
}
.fp-box::-webkit-scrollbar {
	display: none;
}
.fp-box .fp-header {
    display: grid;
    grid-template-columns: auto 1fr;
    text-align: center;
    align-items: center;
    margin-bottom: 24px;
}

.upload-trigger-box {
    margin-bottom: 18px;
}

#furniplace-room {
    margin: 0 !important;
}
.fp-box .fp-header #fp-close {
    padding: 0;
    border: 0;
    background: unset;
    width: 24px;
    height: 24px;
	cursor: pointer;
    font-size: 16px;
}

#fp-select {
    width: 100%;
    padding: 10px;
    min-height: 201px;
    border: 2px dashed #c7b299;
    border-radius: 10px;
    background: #f9f1ec;
    cursor: pointer;
    margin-bottom: 18px;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 8px;
    text-align: center;
}
#fp-select .icon {
    width: 40px;
    height: 40px;
    background-color: var(--clr-primary-main);
    display: grid;
    place-content: center;
    color: var(--clr-primary-light);
    font-size: 24px;
    border-radius: 8px;
    margin-bottom: 8px;
}

.fp-uploads .fp-upload-inner {
    border: 1px solid #cccbcd;
    padding: 12px;
    border-radius: 12px;
    margin-block: 12px;
    display: grid;
    grid-template-columns: 62px 1fr auto;
    gap: 8px;
}
.fp-uploads .fp-upload-inner img {
    width: 100%;
    object-fit: cover;
    height: 100%;
    border: 1px solid #cccbcd;
    border-radius: 12px;
}
.fp-uploads .fp-upload-inner .info {
    display: grid;
    gap: 8px;
}
.fp-uploads .fp-upload-inner .name {
    color: #4d4b4e;
}
.fp-uploads .fp-upload-inner .size {
    color: #9a979b;
    font-size: 14px;
}
.fp-uploads .fp-upload-inner .remove {
    padding: 0;
    display: grid;
    align-self: center;
    width: 24px;
    height: 24px;
    font-size: 16px;
    display: grid;
    place-content: center;
    cursor: pointer;
    border: 0;
    color: #333234;
    background: unset;
}

.or {
    color: #b3b1b4;
    margin-block: 12px;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    gap: 1rem;
    align-items: center;
}
.or::before, .or::after {
    content: "";
    height: 1px;
    background-color: #b3b1b4;
}
#fp-camera {
    width: 100%;
}

.fp-simple-preview {
    margin-top: 12px;
}
#fp-simple-img {
    max-height: 345px;
    border: 4px solid #f9f1ec;
}
.fp-text {
    display: none;
}
#fp-done {
	width: 100%;
	margin-top: 24px;
}

.fp-download-box {
    max-height: 95%;
    overflow: auto;
}
.fp-download-box::-webkit-scrollbar {
    display: none;
}
.fp-header {
    display: grid;
    grid-template-columns: auto 1fr;
    text-align: center;
    font-size: 24px;
    margin-bottom: 24px;
    align-items: center;
}
#fp-download-close {
    padding: 0;
    cursor: pointer;
    border: 0;
    background: unset;
    width: 24px;
    height: 24px;
    font-size: 16px;
}
.form-control {
    display: grid;
    margin-bottom: 16px;
}
.form-control label {
    color: #4d4b4e;
    font-weight: 600;
    margin-block-end: 16px;
}

.form-control .wpcf7-list-item input {
    width: 18px;
    accent-color: var(--clr-primary-main);
    height: 18px;
}
.form-control .wpcf7-list-item {
    margin: 0;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 13px;
    color: var(--clr-primary-main);
}
.form-control .wpcf7-form-control:not(.wpcf7-checkbox) {
    width: 100%;
    border: 1px solid #cccbcd;
    height: 61px;
    padding: 16px;
    border-radius: 12px;
    font-size: 16px;
	font-family: var(--font-body);
}
.form-control .wpcf7-form-control:not(.wpcf7-checkbox)::placeholder {
    color: #9a979b; 
	font-family: var(--font-body);
}
.wpcf7-not-valid-tip {
    font-size: 14px;
}
.fp-download-form .Button-root {
    width: 100%;
}
#fp-select .info {
    color: #9a979b;
    font-weight: 500;
}

.furniplace-ai-btn {
    text-align: left;
    line-height: 1.25;
}

.fp-simple-box {
    display: grid;
    place-items: center;
}
.fp-simple-box > * {
    grid-area: 1 / -1;
}
#fp-simple-delete {
    background-color: var(--clr-primary-main);
    color: var(--clr-primary-light);
    border-radius: 8px;
    width: 40px;
    height: 40px;
    font-size: 24px;
}
#furniplace-generate[disabled] {
	background: gray !important;
} 