/* ======================================
   PREMIUM LAYOUT IMAGE FRAME
   (Auto-size, all layouts supported)
====================================== */

.layout-plan-section {
    padding-bottom: 120px;
}

/* Frame that grows with image */
.layout-frame {
    position: relative;
    display: inline-block;      /* KEY: container wraps image */
    max-width: 100%;
    margin: 0 auto;
    padding: 18px;              /* breathing space */
    border-radius: 24px;
    background: linear-gradient(
        135deg,
        rgba(195,164,100,0.35),
        rgba(255,255,255,0.95),
        rgba(195,164,100,0.35)
    );
    box-shadow:
        0 30px 80px rgba(0,0,0,0.35),
        inset 0 0 0 1px rgba(195,164,100,0.45);
}

/* Gold inner border */
.layout-frame::before {
    content: "";
    position: absolute;
    inset: 10px;
    border-radius: 18px;
    border: 1px solid rgba(195,164,100,0.55);
    pointer-events: none;
}

/* Image itself */
.layout-frame img {
    display: block;
    max-width: 100%;
    height: auto;              /* KEY: natural height */
    border-radius: 14px;
    background: #fff;
}

/* Soft vignette for luxury feel */
.layout-frame::after {
    content: "";
    position: absolute;
    inset: 0;
    border-radius: 24px;
    background: radial-gradient(
        ellipse at center,
        rgba(0,0,0,0) 60%,
        rgba(0,0,0,0.25) 100%
    );
    pointer-events: none;
}

/* Mobile spacing */
@media (max-width: 767px) {
    .layout-frame {
        padding: 12px;
    }
}
/* ===============================
   ZOOM CONTROLS
================================ */

.layout-wrapper {
    text-align: center;
}

.layout-frame img {
    transition: transform 0.4s ease;
    transform-origin: center center;
}

/* Controls container */
.layout-zoom-controls {
    margin-top: 20px;
    display: inline-flex;
    gap: 12px;
}

/* Buttons */
.layout-zoom-controls button {
    background: #142C14;
    color: #C9B26B;
    border: 1px solid rgba(201,178,107,0.6);
    padding: 10px 18px;
    border-radius: 999px;
    font-size: 15px;
    cursor: pointer;
    transition: all 0.25s ease;
}

.layout-zoom-controls button:hover {
    background: #2D5B28;
    box-shadow: 0 0 15px rgba(201,178,107,0.4);
}

/* Mobile */
@media (max-width: 767px) {
    .layout-zoom-controls button {
        padding: 8px 14px;
        font-size: 14px;
    }
}
