/**************************************************************
ROOT
**************************************************************/
:root{

    --primary:#0f172a;
    --primary-light:#1e293b;

    --blue:#2563eb;

    --success:#10b981;
    --warning:#f59e0b;
    --danger:#ef4444;

    --bg:#f8fafc;

    --card:#ffffff;

    --line:#e2e8f0;

    --text:#0f172a;

    --muted:#64748b;
}

/**************************************************************
COMMON
**************************************************************/
*{
    box-sizing:border-box;
}

body{
    background:var(--bg);
    color:var(--text);
}

img{
    max-width:100%;
}

section{
    width:100%;
}

/**************************************************************
HERO
**************************************************************/
.estimate-hero{

    position:relative;

    min-height:200px;
	
	padding:35px 20px;

    display:flex;
    align-items:center;
    justify-content:center;

    text-align:center;

    overflow:hidden;

    background:
    linear-gradient(
        135deg,
        rgba(15,23,42,.92),
        rgba(30,41,59,.88)
    ),
    url('/assets/images/estimate-hero_01.jpg')
    center/cover no-repeat;
}

.estimate-hero::before{

    content:'';

    position:absolute;

    width:700px;
    height:700px;

    top:-250px;
    right:-180px;

    border-radius:50%;

    background:
    radial-gradient(
        rgba(255,255,255,.08),
        transparent 70%
    );
}

.estimate-hero__inner{

    position:relative;
    z-index:2;

    max-width:900px;

    padding:20px;

    color:#fff;
}
.estimate-summary{

    display:grid;

    grid-template-columns:
    repeat(4,minmax(0,1fr));

    gap:20px;

    margin-top:20px;

    position:relative;
}
.estimate-kicker{

    display:inline-flex;

    padding:10px 20px;

    border-radius:999px;

    background:
    rgba(255,255,255,.12);

    backdrop-filter:blur(12px);

    font-size:12px;
    font-weight:800;
    letter-spacing:2px;

    margin-bottom:24px;
}

.estimate-hero__inner h1{

    margin:0 0 18px;

    font-size:
    clamp(34px,4vw,56px);

    line-height:1.15;

    letter-spacing:-2px;

    font-weight:900;


}

.estimate-hero__inner p{

    margin:0;

    font-size:18px;

    line-height:1.8;

    color:
    rgba(255,255,255,.82);
}

/**************************************************************
FEATURE
**************************************************************/
.estimate-hero-features{

    margin-top:28px;

    display:flex;
    justify-content:center;
    flex-wrap:wrap;

    gap:12px;
}

.estimate-hero-features span{

    padding:12px 18px;

    border-radius:999px;

    background:
    rgba(255,255,255,.12);

    border:
    1px solid rgba(255,255,255,.08);

    backdrop-filter:blur(10px);

    font-size:13px;
    font-weight:700;
}

/**************************************************************
SUMMARY
**************************************************************/
.estimate-summary-wrap{
	
	pointer-events:none;
	
	overflow:hidden;

    max-width:1200px;

    margin:0 auto;

    padding:0 20px;

    max-height:0;

    opacity:0;

    transform:translateY(-15px);

    transition:
        max-height .45s ease,
        opacity .35s ease,
        transform .35s ease,
        margin .35s ease;

    margin-top:0;
    margin-bottom:0;
}

.estimate-summary-wrap.is-show{
	
	pointer-events:auto;

    max-height:1000px;

    opacity:1;

    transform:translateY(0);

    margin-top:20px;
    margin-bottom:80px;
}
.recommend-project-name{
	display:block;
	font-size:45px;
	text-align:center;
	font-weight:900;
	margin:15px auto;
}
.summary-card{

    background:#fff;

    border-radius:24px;

    padding:22px;

    text-align:center;

    border:
    1px solid var(--line);

    box-shadow:
    0 20px 50px rgba(15,23,42,.08);
}

.summary-card strong{

    display:block;

    margin-bottom:10px;

    font-size:38px;
    font-weight:900;
}

.summary-card span{

    font-size:14px;
    font-weight:700;

    color:var(--muted);
}

.summary-card.available strong{
    color:var(--success);
}

.summary-card.reserved strong{
    color:var(--warning);
}

.summary-card.contracted strong{
    color:var(--blue);
}
.estimate-preview-meta{

    margin-top:10px;

    color:#64748b;

    font-size:14px;

    font-weight:600;

}
/**************************************************************
LAYOUT
**************************************************************/
.estimate-search{

    max-width:1200px;

    margin:25px auto 80px;

    padding:0 20px;
}

.estimate-card{

    background:#fff;

    border-radius:30px;

    padding:40px;

    border:
    1px solid var(--line);

    box-shadow:
    0 20px 50px rgba(15,23,42,.06);
}

/**************************************************************
CARD HEAD
**************************************************************/
.estimate-card-head{

    display:flex;

    align-items:flex-start;
    justify-content:space-between;

    gap:20px;

    margin-bottom:30px;
}

.estimate-card-head h2{

    margin:0 0 8px;

    font-size:28px;
    font-weight:900;
}

.estimate-card-head p{

    margin:0;

    color:var(--muted);
}

/**************************************************************
FORM
**************************************************************/
.estimate-form-row{

    display:grid;

    grid-template-columns:
    repeat(4,1fr);

    gap:16px;

    margin-bottom:24px;
}

.estimate-form-group label{

    display:block;

    margin-bottom:10px;

    font-size:13px;
    font-weight:800;

    color:#475569;
}

.estimate-form-group select{

    width:100%;

    height:64px;

    border-radius:18px;

    border:
    2px solid var(--line);

    background:#fff;

    padding:0 18px;

    font-size:15px;
    font-weight:700;

    transition:.25s;
}

.estimate-form-group select:focus{

    outline:none;

    border-color:var(--blue);

    box-shadow:
    0 0 0 5px rgba(37,99,235,.08);
}

/**************************************************************
PREVIEW
**************************************************************/
.estimate-preview{

    margin-bottom:24px;

    padding:24px;

    border-radius:22px;

    background:#f8fafc;

    border:
    1px solid var(--line);
}

.estimate-preview span{

    display:block;

    margin-bottom:8px;

    font-size:13px;
    font-weight:700;

    color:var(--muted);
}

.estimate-preview strong{

    display:block;

    font-size:22px;
    font-weight:900;
}

/**************************************************************
BUTTON
**************************************************************/
.estimate-btn{

    width:100%;

    height:64px;

    border:none;

    border-radius:18px;

    background:
    linear-gradient(
        135deg,
        #0f172a,
        #1e293b
    );

    color:#fff;

    font-size:16px;
    font-weight:900;

    cursor:pointer;

    transition:.25s;
}

.estimate-btn:hover{

    transform:translateY(-2px);

    box-shadow:
    0 15px 30px rgba(15,23,42,.18);
}

/**************************************************************
STATUS BUTTON
**************************************************************/
.estimate-status-btn{

    border:none;

    height:52px;

    padding:0 24px;

    border-radius:999px;

    background:#0f172a;

    color:#fff;

    font-size:14px;
    font-weight:800;

    cursor:pointer;
}
.estimate-status-btn-block{

	display: block;
    width: 200px;
    height: 60px;
    margin: 50px auto 0;
}
/**************************************************************
RECOMMEND
**************************************************************/
.estimate-recommend{

    max-width:1200px;

    margin:0 auto 0;

    padding:0 20px;

    max-height:0;

    overflow:hidden;

    opacity:0;

    transform:translateY(-15px);

    transition:
        max-height .45s ease,
        opacity .35s ease,
        transform .35s ease,
        margin .35s ease;
}

.estimate-recommend.is-show{

    max-height:1500px;

    opacity:1;

    transform:translateY(0);
	
	margin-top:80px;
	
    margin-bottom:80px;
}

.section-head{

    margin-bottom:24px;
}

.section-head h2{

    margin:0 0 8px;

    font-size:32px;
    font-weight:900;
}

.section-head p{

    margin:0;

    color:var(--muted);
}

.recommend-grid{

	display:grid;

    grid-template-columns:
        repeat(
            auto-fit,
            minmax(220px,1fr)
        );

    gap:18px;
}

.recommend-card{

    position:relative;

    background:#fff;

    padding:10px 15px 15px;

    border-radius:18px;
	
	background:#fff;
	
    box-shadow:
        0 4px 12px rgba(15,23,42,.04);

    border:1px solid #eef2f7;

    transition:.25s;
	    opacity:0;

    transform:
        translateY(30px)
        rotateX(10deg);

    transition:
        opacity .55s ease,
        transform .55s ease;
}

.recommend-card::after{

    content:'';

    position:absolute;

    top:0;
    left:0;

    width:100%;
    height:5px;

    border-radius:24px 24px 0 0;
}
.recommend-card:hover{

    transform:translateY(-6px);

    box-shadow:
        0 20px 40px
        rgba(15,23,42,.08);
}

.recommend-card.premium{
    border-top:5px solid #f59e0b;
}

.recommend-card.value{
    border-top:5px solid #10b981;
}

.recommend-card.popular{
    border-top:5px solid #3b82f6;
}

.recommend-card.today{
    border-top:5px solid #8b5cf6;
}

.recommend-badge{

    display:inline-flex;

    align-items:center;

    gap:8px;

    font-size:16px;

    font-weight:700;

    color:#64748b;
}

.recommend-card h3{

    margin:14px 0 8px;

    font-size:28px;

    font-weight:800;

    line-height:1.15;

    color:#0f172a;
}

.recommend-meta{

    margin-bottom:10px;

    color:#64748b;

    font-size:14px;
}

.recommend-area{

    margin-top:10px;

    font-size:16px;

    font-weight:700;
}

.recommend-price{

    margin-top:14px;

    font-size:20px;

    font-weight:800;

    line-height:1.3;

    color:#111827;
}
.recommend-price span{
	font-size:16px;
	color:#999;
}
.recommend-loading{

    display:none;

    min-height:260px;

    align-items:center;
    justify-content:center;

    flex-direction:column;

    gap:18px;

    background:#fff;

    border-radius:24px;

    border:1px solid #e2e8f0;
}

.recommend-loading.is-show{

    display:flex;
}

.recommend-spinner{

    width:52px;
    height:52px;

    border-radius:50%;

    border:4px solid #e2e8f0;

    border-top-color:#2563eb;

    animation:
        recommendSpin
        1s linear infinite;
}

@keyframes recommendSpin{

    from{
        transform:rotate(0deg);
    }

    to{
        transform:rotate(360deg);
    }
}

.recommend-loading strong{

    font-size:20px;

    font-weight:800;
}

.recommend-loading span{

    color:#64748b;
}

.recommend-card.is-visible{

    opacity:1;

    transform:
        translateY(0)
        rotateX(0deg);
}
.recommend-card::before{

    content:'';

    position:absolute;

    top:0;
    left:0;

    width:0;

    height:4px;

    transition:
        width .45s ease;
}

.recommend-card.is-visible::before{

    width:100%;
}
/**************************************************************
MOBILE
**************************************************************/
@media (max-width:768px){
	
	.estimate-search{
		padding:10px;
	}

    .estimate-hero{

        min-height:260px;
    }

    .estimate-hero__inner h1{

        font-size:24px;
    }
	
	.estimate-hero__inner p {
		font-size:15px;
	}

    .estimate-summary{

        grid-template-columns:
        repeat(2,1fr);

        gap:12px;

        margin-top:30px;
    }

    .summary-card strong{

        font-size:28px;
    }

    .estimate-card{

        padding:15px;
		border-radius:10px;
    }

    .estimate-card-head{

        flex-direction:column;
    }

    .estimate-form-row{

        grid-template-columns:1fr;
    }

    .recommend-grid{

        grid-template-columns:1fr;
    }

}

/**************************************************************
STATUS MODAL
**************************************************************/
.status-modal{

    position:fixed;
    inset:0;

    z-index:9999;

    display:none;

    align-items:center;
    justify-content:center;

    padding:20px;

    background:rgba(15,23,42,.72);

    backdrop-filter:blur(4px);
}

.status-modal.is-show{

    display:flex;
}

/**************************************************************
MODAL INNER
**************************************************************/
.status-modal-inner{

    width:min(1700px,95%);

    height:min(80%,1000px);

    background:#fff;

    border-radius:32px;

    overflow:hidden;

    display:flex;
    flex-direction:column;

    box-shadow:
        0 30px 80px rgba(15,23,42,.25);
}

/**************************************************************
HEADER
**************************************************************/
.status-modal-head{

    position:sticky;

    top:0;

    z-index:20;

    flex-shrink:0;

    background:#fff;

    border-bottom:1px solid #e2e8f0;
	
	display:flex;
	align-items:center;
	justify-content:space-between;
	padding:30px 20px;
	z-index:99999;
}

.status-modal-head h3{

    margin:0;

    font-size:32px;
    font-weight:900;

    color:#0f172a;
}
.status-modal-title{

    display:flex;

    flex-direction:column;

    gap:6px;
	
}

.status-modal-notice{

    margin:0;

    font-size:12px;

    font-weight:600;

    color:#ef4444;

    line-height:1;
}
.status-modal-notice01{

    margin:0;

    font-size:12px;

    font-weight:600;

    color:#777;

    line-height:1.4;
}


/**************************************************************
현황표 증별 구분스타일
**************************************************************/

.status-floor-wrap{

    flex:1;
	
	position:relative;
	
    overflow-y:auto;

    padding:24px 36px 36px;

    display:flex;
    flex-direction:column;

    gap:20px;
}

.status-floor-row{
    display:grid;
    grid-template-columns:80px 1fr;
    gap:20px;
    align-items:flex-start;
	border-bottom:1px solid #e2e8f0;
	padding-bottom: 20px;
}
.status-floor-row:last-child{
    border-bottom:none;
    padding-bottom:0;
}
.status-floor-label{

    position:sticky;

    top:12px;

    z-index:5;

    display:flex;
    align-items:center;
    justify-content:center;

    min-height:72px;

    border-radius:16px;

    background:#0f172a;

    color:#fff;

    font-size:18px;
    font-weight:800;
}

.status-floor-room-list{

    display:grid;

    grid-template-columns:
        repeat(auto-fill,minmax(190px,1fr));

    gap:10px;
}
/**************************************************************
CLOSE BUTTON
**************************************************************/
.status-modal-close{

    width:52px;
    height:52px;

    border:none;

    border-radius:50%;

    background:#0f172a;

    cursor:pointer;

    position:relative;

    transition:.2s;
	z-index:999999;
}

.status-modal-close:hover{

    transform:scale(1.05);
}

.status-modal-close::before,
.status-modal-close::after{

    content:'';

    position:absolute;

    top:50%;
    left:50%;

    width:20px;
    height:2px;

    background:#fff;

    border-radius:999px;
}

.status-modal-close::before{

    transform:
        translate(-50%,-50%)
        rotate(45deg);
}

.status-modal-close::after{

    transform:
        translate(-50%,-50%)
        rotate(-45deg);
}

/**************************************************************
ROOM LIST
**************************************************************/
.status-room-list{

    flex:1;

    overflow-y:auto;

    padding:28px 36px;

    display:grid;

    grid-template-columns:
        repeat(auto-fill,minmax(220px,1fr));

    gap:14px;
}

/**************************************************************
SCROLLBAR
**************************************************************/
.status-floor-wrap::-webkit-scrollbar{
    width:10px;
}

.status-floor-wrap::-webkit-scrollbar-track{
    background:#f1f5f9;
}

.status-floor-wrap::-webkit-scrollbar-thumb{
    background:#cbd5e1;
    border-radius:20px;
}

.status-floor-wrap::-webkit-scrollbar-thumb:hover{
    background:#94a3b8;
}

/**************************************************************
ROOM CARD
**************************************************************/
.status-room-item{

    min-height:78px;

    display:flex;

    flex-direction:column;

    justify-content:center;

    gap:6px;

    padding:10px;

    border-radius:16px;

    transition:.2s;
	
	cursor:pointer;
}

.status-room-item:hover{

    transform:translateY(-2px);
}

.status-room-item strong{

    font-size:24px;

    font-weight:900;

    color:#0f172a;
}

.status-room-item span{

    font-size:13px;

    font-weight:700;

    white-space:nowrap;
}

.status-room-main{

    display:flex;

    align-items:center;

    justify-content:space-between;

    width:100%;
}

.status-room-item small{

    display:block;

    width:100%;

    font-size:11px;

    color:#64748b;

    line-height:1.4;
}

/**************************************************************
STATUS COLORS
**************************************************************/
.status-room-item.status-available{

    border:1px solid rgba(16,185,129,.35);

    background:rgba(16,185,129,.06);
}

.status-room-item.status-available span{

    color:#059669;
}

.status-room-item.status-contracted{

    border:1px solid rgba(239,68,68,.28);

    background:rgba(239,68,68,.05);
}

.status-room-item.status-contracted span{

    color:#dc2626;
}

.status-room-item.status-reserved{

    border:1px solid rgba(245,158,11,.35);

    background:rgba(245,158,11,.06);
}

.status-room-item.status-reserved span{

    color:#d97706;
}

.status-room-item.status-hold{

    border:1px solid rgba(100,116,139,.35);

    background:rgba(100,116,139,.06);
}

.status-room-item.status-hold span{

    color:#475569;
}

.status-room-meta{
    margin-top:0px;

    display:grid;

    grid-template-columns:1fr auto;

    gap:4px;

    font-size:13px;

    color:#64748b;
}

.status-room-meta > div:nth-child(1){
    grid-column:1 / 3;
}

.status-room-meta > div:nth-child(2){
    grid-column:1;
}

.status-room-meta > div:nth-child(3){
    grid-column:2;
    grid-row:2;

    align-self:center;

    font-weight:700;

    color:#0f766e;
}
.transaction-type{
    padding:2px 8px;

    border-radius:999px;

    background:#fff;

    color:#059669;

    font-size:12px;

    font-weight:700;
	border:1px solid #000;
}
/**************************************************************
견적서 모달
**************************************************************/
.estimate-modal{

    position:fixed;

    inset:0;

    z-index:10000;

    display:none;

    align-items:center;

    justify-content:center;

    background:rgba(0,0,0,.7);

    padding:20px;
}

.estimate-modal.is-show{

    display:flex;
}

.estimate-modal-inner{

    width:min(1100px,100%);

    max-height:90vh;

    overflow-y:auto;

    background:#fff;

    border-radius:20px;

    position:relative;
}

.estimate-modal-close{

    position:absolute;

    top:15px;
    right:15px;

    width:42px;
    height:42px;

    border:0;

    border-radius:50%;

    cursor:pointer;
}

.estimate-modal-body{

    padding:40px;
}

/**************************************************************
로그인 하지않을때 현황표 출력스타일
**************************************************************/

.status-modal-inner{
    position:relative;
}

.status-floor-wrap.is-locked{
    filter:blur(2.5px);
    opacity:.35;
    pointer-events:none;
}

.status-floor-area{

    position:relative;

    flex:1;

    overflow:hidden;
}

.status-lock-overlay{

    position:absolute;

    inset:0;

    z-index:999;

    display:flex;

    align-items:center;

    justify-content:center;
}
.status-lock-box{

    width:100%;
    max-width:420px;

    padding:40px;

    border-radius:24px;

    background:#fff;

    text-align:center;

    box-shadow:
        0 20px 60px rgba(15,23,42,.15);
}

.status-lock-icon{

    font-size:52px;

    margin-bottom:16px;
}

.status-lock-box h4{

    margin:0 0 12px;

    font-size:24px;

    font-weight:800;
}

.status-lock-box p{

    margin:0 0 24px;

    color:#64748b;

    line-height:1.7;
}

.status-lock-btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    height:52px;

    padding:0 24px;

    border-radius:12px;

    background:#2563eb;

    color:#fff;

    text-decoration:none;

    font-weight:700;
}

/**************************************************************
LOGIN REQUIRED MODAL
**************************************************************/
#loginRequiredModal{

    position:fixed;
    inset:0;

    display:flex;
    align-items:center;
    justify-content:center;

    padding:20px;

    background:rgba(15,23,42,.75);

    backdrop-filter:blur(6px);

    z-index:99999;

    opacity:0;
    visibility:hidden;

    transition:.25s;
}

#loginRequiredModal.is-show{

    opacity:1;
    visibility:visible;
}

.login-required{

    position:relative;

    width:100%;
    max-width:700px;

    background:#fff;

    border-radius:32px;

    padding:60px;

    text-align:center;

    box-shadow:
        0 25px 60px rgba(0,0,0,.18);

    animation:modalUp .25s ease;
}

@keyframes modalUp{

    from{
        opacity:0;
        transform:translateY(20px);
    }

    to{
        opacity:1;
        transform:translateY(0);
    }
}

.login-modal-close{

    position:absolute;

    top:24px;
    right:24px;

    width:48px;
    height:48px;

    border:none;

    border-radius:50%;

    background:#f1f5f9;

    cursor:pointer;

    font-size:28px;

    color:#64748b;
}

.login-modal-close:hover{

    background:#e2e8f0;
}

.login-modal-icon{

    width:110px;
    height:110px;

    margin:0 auto 32px;

    border-radius:50%;

    background:
        linear-gradient(
            135deg,
            #eff6ff,
            #dbeafe
        );

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:52px;
}

.login-required h3{

    margin:0 0 16px;

    font-size:42px;
    font-weight:800;

    color:#0f172a;
}

.login-required p{

    margin:0;

    font-size:22px;

    color:#64748b;

    line-height:1.6;
}

.login-required-actions{

    display:grid;

    grid-template-columns:1fr 1fr;

    gap:18px;

    margin-top:50px;
}

.login-btn{

    height:72px;

    border-radius:18px;

    text-decoration:none;

    display:flex;
    align-items:center;
    justify-content:center;

    font-size:22px;
    font-weight:700;

    transition:.2s;
}

.login-btn.primary{

    background:
        linear-gradient(
            135deg,
            #2563eb,
            #1d4ed8
        );

    color:#fff;
}

.login-btn.primary:hover{

    transform:translateY(-2px);
}

.login-btn.secondary{

    border:2px solid #2563eb;

    color:#2563eb;

    background:#fff;
}

.login-btn.secondary:hover{

    background:#eff6ff;
}

.login-modal-info{

    margin-top:40px;

    padding-top:30px;

    border-top:1px solid #e5e7eb;

    color:#94a3b8;

    font-size:15px;

    line-height:1.8;
}
@media (max-width:768px){

    .login-required{

        padding:40px 24px;
        border-radius:24px;
    }

    .login-modal-icon{

        width:80px;
        height:80px;

        font-size:40px;
    }

    .login-required h3{

        font-size:28px;
    }

    .login-required p{

        font-size:16px;
    }

    .login-required-actions{

        grid-template-columns:1fr;
    }

    .login-btn{

        height:60px;
        font-size:18px;
    }
}

@media (max-width:768px){

	/**************************************************************
	MODAL
	**************************************************************/

	.status-floor-wrap{

		flex:1;

		overflow-y:auto;

		padding:10px;

		display:flex;
		flex-direction:column;

		gap:20px;
	}
	
	.status-floor-row{
		display:grid;
		grid-template-columns:50px 1fr;
		gap:10px;
		align-items:flex-start;
		border-bottom:1px solid #e2e8f0;
		padding-bottom: 20px;
	}
	.status-floor-row:last-child{
		border-bottom:none;
		padding-bottom:0;
	}
	.status-floor-label{

		position:sticky;
		top:12px;
		z-index:5;
		min-height:40px;
		width:40px;
		display:flex;
		align-items:center;
		justify-content:center;
		border-radius:5px;
		background:#0f172a;
		color:#fff;
		font-size:18px;
		font-weight:800;
	}

	.status-floor-room-list{

		display:grid;

		grid-template-columns:
			repeat(auto-fill,minmax(190px,1fr));

		gap:10px;
	}
	.status-room-item strong{

		font-size:20px;

	}

	.status-modal-inner{

		width:min(1700px,96vw);

		height:min(96vh,1000px);

		background:#fff;

		border-radius:10px;

		overflow:hidden;

		display:flex;
		flex-direction:column;

		box-shadow:
			0 30px 80px rgba(15,23,42,.25);
	}
	.status-modal-close {
		width: 30px;
		height: 30px;
		border: none;
		border-radius: 50%;
		background: #0f172a;
		cursor: pointer;
		position: absolute;
		transition: .2s;
		top: 10px;
		right: 10px;
	}
	.recommend-project-name{
		font-size:1.6em;
	}
	.estimate-recommend.is-show{
		margin-top:30px;
	}
	.section-head h2,
	.section-head p{
		text-align:center;
	}
	.status-lock-overlay{
		padding:20px;
	}
	.status-lock-box{
		padding:10px;
	}
	.status-modal {
		padding:0
	}
}

/**************************************************************
비 로그인시 회원가입유도 텍스트
**************************************************************/
.estimate-member-notice{

    display:flex;

    align-items:center;

    gap:14px;

    margin:20px 0;

    padding:18px 20px;

    border-radius:18px;

    border:1px solid rgba(250,204,21,.25);

    background:
        linear-gradient(
            135deg,
            rgba(250,204,21,.08),
            rgba(245,158,11,.04)
        );

}

.estimate-member-icon{

    flex-shrink:0;

    width:48px;

    height:48px;

    display:flex;

    align-items:center;

    justify-content:center;

    border-radius:50%;

    background:#facc15;

    font-size:22px;

}

.estimate-member-content{

    flex:1;

}

.estimate-member-content strong{

    display:block;

    color:#111827;

    font-size:16px;

    font-weight:700;

    margin-bottom:4px;

}

.estimate-member-content span{

    display:block;

    color:#6b7280;

    font-size:14px;

    line-height:1.6;

}
.selected-room-list{

    display:flex;

    flex-wrap:wrap;

    gap:12px;

    margin-top:14px;

}

.selected-room-card{

    display:flex;

    align-items:center;

    gap:12px;

    padding:12px 16px;

    border:1px solid #dbe3ef;

    border-radius:14px;

    background:#fff;

    box-shadow:
        0 4px 12px rgba(15,23,42,.05);

}

.selected-room-card strong{

    font-size:16px;

    font-weight:700;

    color:#0f172a;

}

.selected-room-card span{

    font-size:13px;

    color:#64748b;

}

.selected-room-card button{

    width:26px;

    height:26px;

    border:none;

    border-radius:50%;

    background:#ef4444;

    color:#fff;

    cursor:pointer;

    font-size:14px;

    font-weight:700;

    transition:.2s;

}

.selected-room-card button:hover{

    transform:scale(1.08);

    background:#dc2626;

}
.estimate-add-room-btn{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    gap:8px;

    margin-top:16px;

    padding:12px 18px;

    border:none;

    border-radius:12px;

    background:linear-gradient(
        135deg,
        #2563eb,
        #1d4ed8
    );

    color:#fff;

    font-size:15px;

    font-weight:700;

    cursor:pointer;

    transition:.25s;

}

.estimate-add-room-btn:hover{

    transform:translateY(-2px);

    box-shadow:
        0 10px 20px rgba(
            37,
            99,
            235,
            .25
        );

}
.selected-room-list{

    display:flex;

    flex-wrap:wrap;

    gap:12px;

    margin-top:16px;

}

.selected-room-card{

    display:flex;

    align-items:center;

    justify-content:space-between;

    min-width:180px;

    padding:14px 16px;

    border:1px solid #dbe3ef;

    border-radius:14px;

    background:#fff;

    box-shadow:
        0 4px 12px rgba(15,23,42,.06);

}

.selected-room-info{

    display:flex;

    flex-direction:column;

    gap:4px;

}

.selected-room-info strong{

    font-size:18px;

    font-weight:800;

    color:#0f172a;

}

.selected-room-info span{

    font-size:13px;

    color:#64748b;

}

.remove-room{

    width:28px;

    height:28px;

    border:none;

    border-radius:50%;

    background:#ef4444;

    color:#fff;

    font-size:14px;

    font-weight:700;

    cursor:pointer;

    transition:.2s;

}

.remove-room:hover{

    background:#dc2626;

    transform:scale(1.08);

}

.estimate-add-room-btn{

    margin-top:16px;

    padding:12px 18px;

    border:none;

    border-radius:12px;

    background:linear-gradient(
        135deg,
        #2563eb,
        #1d4ed8
    );

    color:#fff;

    font-size:15px;

    font-weight:700;

    cursor:pointer;

    transition:.25s;

}

.estimate-add-room-btn:hover{

    transform:translateY(-2px);

    box-shadow:
        0 10px 20px rgba(
            37,
            99,
            235,
            .25
        );

}
.selected-room-meta{

    display:flex;

    align-items:center;

    gap:8px;

    margin-top:4px;
}

.room-floor{

    color:#64748b;

    font-size:14px;

    font-weight:600;
}

.room-type{

    display:inline-flex;

    align-items:center;

    justify-content:center;

    padding:3px 8px;

    border-radius:999px;

    background:#eff6ff;

    color:#2563eb;

    font-size:12px;

    font-weight:700;
}