/**************************************************************
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:0px;
}
.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:0px;
}

.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,
.status-complete-btn{

    border:none;

    height:52px;

    padding:0 24px;

    border-radius:999px;

    background:#0f172a;

    color:#fff;

    font-size:35px;
    font-weight:800;

    cursor:pointer;
	
}
.estimate-status-btn{
    position:relative;

    overflow:hidden;

    background:
        linear-gradient(
            135deg,
            #0b1635,
            #123375
        );

    border:1px solid
        rgba(255,255,255,.08);

    color:#fff;
	
	z-index:1;

}
.estimate-status-btn::before{

    content:'';

    position:absolute;

    inset:0;

    background-image:
        linear-gradient(
            rgba(255,255,255,.06) 1px,
            transparent 1px
        ),
        linear-gradient(
            90deg,
            rgba(255,255,255,.06) 1px,
            transparent 1px
        );

    background-size:
        60px 28px;

    opacity:.5;

    pointer-events:none;
	z-index:0;

}
#completeRoomSelection.status-complete-btn{
	font-size:14px;
}
.estimate-status-btn-block{

	display: block;
    width: 100%;
    height: 150px;
    margin: 50px auto 0;

}
.estimate-status-btn strong{
	display:block;
	font-size:18px;
	color:#cfcfcf;
}
/**************************************************************
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%;
}


/**************************************************************
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:90%;

    height:90%;

    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-label .triangle{
	width:20px;
	height:20px;
	position:absolute;
	top:50%;
	margin-top:-10px;
	right:-20px;
	border-top:10px solid transparent;
	border-right:10px solid transparent;
	border-bottom:10px solid transparent;
	border-left:10px solid #000;
}
.status-floor-room-list{

    display:grid;

    grid-template-columns:
        repeat(auto-fill,minmax(140px,1fr));

    gap:10px;
}
.modal-btn-flex{
	display:flex;
	gap:10px;
}
.modal-btn-flex-block{
	display:none;
}

.floorplan-trigger{

    cursor:pointer;

    transition:.2s;

}

.floorplan-trigger:hover{

    transform:scale(1.05);

}
/**************************************************************
CLOSE BUTTON
**************************************************************/
.status-modal-close{

    width:52px;
    height:52px;

    border:none;

    border-radius:50%;

    background:#c70000;

    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{

    display:flex;

    flex-direction:column;

    justify-content:center;

    gap:6px;

    padding:10px;

    border-radius:0px;

    transition:.2s;
	
	cursor:pointer;
}

.status-room-item:hover{

    transform:translateY(-2px);
}

.status-room-item strong{

    font-size:16px;

    font-weight:900;

    color:#0f172a;
}

.status-room-item span{

    font-size:13px;

    font-weight:700;

    white-space:nowrap;
}

.status-room-main{

    display:flex;
	
	max-width:140px;
	
    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{
	
	max-width:140px;
	
    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-floor-label{
    cursor:pointer;
    position:relative;
    flex-direction:column;
    gap:4px;
    transition:all .2s ease;
}

.status-floor-label strong{
    font-size:24px;
    line-height:1;
}

.floorplan-hint{
    font-size:11px;
    font-weight:700;
    color:#ffffff;
    opacity:.85;
	text-align: center;
}

.status-floor-label:hover{
    transform:translateY(-2px);
    box-shadow:0 8px 18px rgba(15,23,42,.25);
}

.status-floor-label:hover .floorplan-hint{
    opacity:1;
    text-decoration:underline;
}

.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;
    }
}

/**************************************************************
비 로그인시 회원가입유도 텍스트
**************************************************************/
.estimate-member-notice{

    display:flex;
	
	max-width:1200px;
	
	width:100%;

    align-items:center;

    gap:14px;

    margin:20px auto;

    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-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:block;

    width:100%;
	
	max-width:400px;

    height:58px;

    margin:20px auto;

    border:0;

    border-radius:999px;

    background:#bd7403;

    color:#fff;

    font-size:16px;

    font-weight:800;

    cursor:pointer;

    transition:.2s;
}

.estimate-add-room-btn:hover{

    transform:translateY(-2px);

    background:#1d4ed8;
}
.empty-room{
	line-height:40px;
}

.selected-room-list{

    display:flex;

    flex-wrap:wrap;

    gap:12px;
	
	height:auto;
	
    margin:16px 0 0px;
	
	justify-content: center;

}
.selected-room-list.has-rooms{

    justify-content:flex-start;

}
.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);

}

.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;
}
.status-room-item.is-active{

    background:#dbeafe;

    border:2px solid #2563eb;

    box-shadow:0 0 0 3px rgba(37,99,235,.15);

}

.status-room-item.is-selected{

    background:#eff6ff;

    border:2px dashed #2563eb;

}

/**************************************************************
층별평면도 모달
**************************************************************/

.floorplan-modal{

    position:fixed;

    inset:0;

    background:rgba(0,0,0,.85);

    display:none;

    align-items:center;

    justify-content:center;

    z-index:999999;

}

.floorplan-modal.is-show{

    display:flex;

}

.floorplan-inner{

    position:relative;

    max-width:95vw;

    max-height:95vh;

}

.floorplan-inner img{

    max-width:95vw;

    max-height:95vh;

    display:block;

    background:#fff;

}

.floorplan-close{

    position:absolute;

    top:10px;

    right:10px;

    width:42px;

    height:42px;

    border:none;

    border-radius:50%;

    background:#ef4444;

    color:#fff;

    cursor:pointer;
	
	font-size:30px;

}

/**************************************************************
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;
    }

}

@media (max-width:768px){

	/**************************************************************
	MODAL
	**************************************************************/
	.status-modal-head {
		padding: 10px 20px ;
	}
    .status-modal{
        top:0px;
		padding:5px;;
    }
	.status-floor-wrap{

		flex:1;

		overflow-y:auto;

		padding:10px 10px 40px;

		display:flex;
		flex-direction:column;

		gap:20px;
	}
	
	.status-modal-title {
		
	}
	
	.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;
		padding: 5px;
	}
	.status-complete-btn{
	    position:absolute ;
	    top: 10px;
	    right: 50px;
	    padding: 2.5px 10px;
	    height: 30px;
	}

	.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{
		
		position:relative;

		width:min(1700px,100vw);

		height:calc( 100vh - 30px );

		background:#fff;

		border-radius:10px;

		overflow:hidden;
        
        padding-top: 30px;
        
		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-complete-btn{
		font-size:12px;
	}
	.status-modal-head h3 {
		font-size:18px;
		padding:5px 0;
	}

    .modal-btn-flex .status-complete-btn{

        display:none;

    }

    .modal-btn-flex-block{

        position:absolute;
        
        width: auto;
        height: 40px;
        
       top:140px;

        right:5px;

        padding:0px;

        display:flex;

        justify-content:flex-start;

        background:transparent;

        border-top:1px solid #e5e7eb;

        z-index:1000;

    }

	.modal-btn-flex-block .status-complete-btn{

		position:static;

		width:auto;

		background:rgba(0,0,0,0.5);

		height:40px;

		min-width:auto;

		transition:all .2s ease;

	}

	/* 1개 이상 선택 시 */
	.modal-btn-flex-block .status-complete-btn.is-active{

		background:#d10b0b;

		color:#fff;

		box-shadow:0 4px 12px rgba(0,0,0,.25);

	}

	/**************************************************************
	PREVIEW
	**************************************************************/
	.estimate-search {
		margin-bottom:25px;
	}
	.estimate-preview{

		padding:10px;
	}

	
	.empty-room{
		line-height:20px;
		font-size:13px;
	}
	
	.selected-room-list{
		
		justify-content: space-between;
		
		height:100%;
		
		max-height:250px;
		
		overflow:hidden;
		
		overflow-y: auto;
		
	}
	
	.selected-room-card{
		
		position:relative;

		display:flex;

		align-items:center;

		justify-content:space-between;

		min-width:auto;

		padding:10px 15px;

	}
	
	.selected-room-meta {
		gap:3px;
	}
	
	.selected-room-info strong {
		font-size:14px;
	}
	
	.estimate-preview span {
		margin-bottom:0;
	}
	
	.selected-room-card button {
		position:absolute;
		right:5px;
		top:5px;
		color: #000;
		height:auto;
		background:transparent;
	}
	
	.estimate-status-btn-block {
		height:80px;
	}
	
	.estimate-status-btn{
		font-size:18px;
	}
	.estimate-status-btn strong{
		font-size:12px;
	}

}

/**************************************************************
견적조회절차 출력 스타일
**************************************************************/
.estimate-guide{
	
	width:100%;
	
	max-width:1200px;

    display:flex;

    align-items:center;

    justify-content:center;

    gap:20px;

    margin:35px auto;

    padding:24px;

    border-radius:20px;

    background:
        linear-gradient(
            135deg,
            #eff6ff,
            #f8fafc
        );

    border:1px solid #dbeafe;

}

.guide-step{

    display:flex;

    align-items:center;

    gap:12px;

}

.guide-no{

    width:42px;
    height:42px;

    border-radius:50%;

    background:#2563eb;

    color:#fff;

    display:flex;

    align-items:center;

    justify-content:center;

    font-weight:800;

}

.guide-step strong{

    display:block;

    font-size:15px;

    font-weight:800;

}

.guide-step span{

    display:block;

    font-size:13px;

    color:#64748b;

}

.guide-arrow{

    font-size:24px;

    color:#94a3b8;

}
@media (max-width:768px){

    .estimate-guide{

        flex-direction:column;

        align-items:flex-start;

        gap:12px;

        padding:16px;

        margin:20px auto;

        border-radius:0px;
		
		border:none;

    }

    .guide-step{

        width:100%;

        align-items:center;

        gap:10px;

    }

    .guide-no{

        flex-shrink:0;

        width:34px;
        height:34px;

        font-size:13px;

    }

    .guide-step strong{

        font-size:14px;

        line-height:1.2;

    }

    .guide-step span{

        font-size:12px;

        line-height:1.4;

    }

    .guide-arrow{

        display:none;

    }

}

.empty-room{

	text-align:center;

	padding:30px 20px;

	color:#64748b;

}

.empty-room-status-btn{

	margin-top:15px;

	padding:12px 18px;

	border:0;

	border-radius:10px;

	background:#a30202;

	color:#fff;

	font-weight:700;

	cursor:pointer;

}

.empty-room-status-btn:hover{

	opacity:.9;

}