*{font-family:'Malgun Gothic','맑은 고딕',sans-serif;font-size:12px;box-sizing:border-box;margin:0;padding:0;}
body{background:#f0f0f0;min-width:1100px;overflow-x:auto;}
/* ── GNB ── */
#hd{background:#1a4a8a;position:sticky;top:0;z-index:1000;}
.gnb-inner{padding:0 20px;}
.menubar{display:flex;flex-wrap:nowrap;align-items:center;background:#2563a8;padding:0;min-height:36px;position:relative;z-index:200;overflow:visible;}
.menu-item{position:relative;flex-shrink:0;}
.menu-item>a{display:block;padding:0 14px;height:36px;line-height:36px;color:#cce4ff;text-decoration:none;white-space:nowrap;}
.menu-item>a:hover,.menu-item>a.active{background:#2563b0;color:#fff;}
.menu-item .submenu{display:none;position:absolute;top:36px;left:0;background:#1e3a6e;min-width:160px;z-index:2000;box-shadow:2px 4px 10px rgba(0,0,0,.4);}
.menu-item:hover .submenu{display:block;}
.menu-item .submenu a{display:block;padding:7px 14px;color:#cce4ff;text-decoration:none;white-space:nowrap;}
.menu-item .submenu a:hover,.menu-item .submenu a.active{background:#2563b0;color:#fff;}
.menubar-login{margin-left:auto;display:flex;align-items:center;gap:10px;color:#cce0ff;padding:0 14px;white-space:nowrap;}
.menubar-login .login-user{display:flex;align-items:center;gap:5px;font-size:12px;font-weight:bold;}
.menubar-login .login-user i{font-size:16px;color:#7fb8ff;}
.menubar-login .login-sep{color:#4a7ac0;font-size:13px;}
.menubar-login a{color:#cce0ff;text-decoration:none;font-size:12px;font-weight:bold;display:flex;align-items:center;gap:4px;padding:4px 8px;border-radius:3px;}
.menubar-login a:hover{background:#4fdfd0;color:#000;}
.menubar-login .btn-logout{color:#ffaaaa!important;}
.menubar-login .btn-logout:hover{background:#cc3333!important;color:#fff!important;}

/* ── 검색바 ── */
.search-wrap{background:#fff;border-bottom:2px solid #3366cc;}
.search-row{padding:5px 14px;display:flex;align-items:center;gap:0;flex-wrap:nowrap;overflow-x:auto;}
/* 그룹 컨테이너 */
.sg{display:flex;align-items:center;gap:4px;flex-shrink:0;padding:0 10px;border:1px solid #dce6f4;border-radius:4px;background:#f7faff;height:32px;}
.sg-label{font-size:11px;font-weight:600;color:#666;white-space:nowrap;margin-right:4px;flex-shrink:0;letter-spacing:.02em;}
/* 그룹 사이 구분 여백 */
.sg-sep{width:22px;flex-shrink:0;position:relative;}
.sg-sep::after{content:'';display:block;width:1px;height:20px;background:#d0d8e8;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);}
/* 그룹 내 공통 입력 스타일 */
.sg select,.sg input[type=date]{
  border:1px solid #c0ccdd;border-radius:3px;padding:1px 4px;height:24px;font-size:11px;background:#fff;flex-shrink:0;color:#333;}
.sg select:focus,.sg input[type=date]:focus{outline:none;border-color:#3366cc;}
/* 버튼류 */
.btn-search{background:#2563b0;color:#fff;border:none;border-radius:3px;padding:4px 14px;height:28px;cursor:pointer;font-size:12px;font-weight:bold;flex-shrink:0;margin-left:2px;}
.btn-search:hover{background:#1a4a8a;}
.btn-reset{background:#777;color:#fff;border:none;border-radius:3px;padding:4px 9px;height:28px;cursor:pointer;font-size:11px;flex-shrink:0;margin-left:4px;}
.btn-reset:hover{background:#555;}
.btn-excel{background:#1d7a3c;color:#fff;border:none;border-radius:3px;padding:3px 10px;height:26px;cursor:pointer;font-size:11px;flex-shrink:0;}
.btn-excel:hover{background:#145c2c;}
/* 기간 프리셋 */
.btn-period{height:24px;padding:0 8px;border:1px solid #c8d4e8;border-radius:3px;background:#f4f7fc;color:#3a5a8a;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;flex-shrink:0;}
.btn-period:hover{background:#dce8f8;}
.btn-period.active{background:#2563b0;color:#fff;border-color:#1a4a8a;}

/* 도움말 바 */
.search-help{display:flex;flex-direction:column;gap:3px;padding:5px 14px 6px;background:#f0f4ff;border-top:1px dashed #c8d8f0;font-size:10.5px;color:#556;line-height:1.6;}
.sh-row{display:flex;align-items:center;flex-wrap:wrap;gap:0;}
.sh-badge{display:inline-block;font-size:9.5px;font-weight:700;color:#fff;background:#7a9fd4;border-radius:3px;padding:0 5px;margin-right:6px;flex-shrink:0;line-height:16px;}
.sh-item{white-space:nowrap;}
.sh-item b{color:#1a4a9a;font-weight:700;margin-right:3px;}
.sh-sub{color:#888;font-size:10px;}
.sh-div{color:#ccd;margin:0 5px;font-size:11px;flex-shrink:0;}
.sh-badge-day{background:#2563b0;}
.sh-badge-period{background:#1d7a3c;}

/* ── 리스트 헤더바 ── */
.list-header{background:#eef3ff;border-bottom:1px solid #c8d8f0;padding:5px 20px;display:flex;align-items:center;gap:8px;}
.list-title{font-weight:bold;color:#1a4a8a;font-size:12px;}
.list-count{color:#e53e3e;font-weight:bold;}
.list-page-info{color:#666;font-size:11px;}

/* ── 테이블 래퍼 (여백 포함) ── */
.tbl-outer{padding:10px 16px 12px;background:#f0f2f5;}
.tbl-wrap{overflow-x:auto;overflow-y:auto;max-height:calc(100vh - 188px);border:1px solid #c8d4e4;border-radius:5px;box-shadow:0 1px 4px rgba(0,0,0,.07);}
.sl-table{border-collapse:collapse;font-size:11px;table-layout:fixed;white-space:nowrap;}
.sl-table th{
  background:#3366cc;color:#fff;padding:4px 8px;border:1px solid #2255aa;
  text-align:center;white-space:nowrap;position:sticky;top:0;z-index:10;cursor:pointer;font-size:11px;}
.sl-table th:hover{background:#4477dd;}
.sl-table th .sort-icon{font-size:9px;margin-left:2px;opacity:0.7;}
.sl-table td{padding:3px 8px;border:1px solid #ddd;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:0;}
.sl-table tr:hover td{background:#e8f4ff!important;}
.sl-table tr.selected td{background:#ccffcc!important;}
.sl-table tr:nth-child(even) td{background:#f8f8ff;}
.sl-table tr:nth-child(odd)  td{background:#fff;}
/* 상태 뱃지 */
.badge{display:inline-block;padding:1px 6px;border-radius:10px;font-size:10px;font-weight:bold;white-space:nowrap;}
.badge-청약{background:#fff3cd;color:#856404;}
.badge-개통{background:#d1ecf1;color:#0c5460;}
.badge-해지{background:#f8d7da;color:#721c24;}
.badge-취소{background:#e2e3e5;color:#383d41;}
.badge-임대{background:#d4edda;color:#155724;}
.badge-재약정{background:#cce5ff;color:#004085;}

/* ── 페이지네이션 ── */
.pagination{display:flex;align-items:center;justify-content:center;gap:3px;padding:7px;background:#fff;border-top:1px solid #ddd;}
.pagination button{min-width:28px;height:26px;border:1px solid #c8d0e0;border-radius:3px;background:#fff;color:#3366cc;cursor:pointer;font-size:11px;}
.pagination button:hover{background:#e8f0ff;}
.pagination button.active{background:#3366cc;color:#fff;border-color:#2255aa;font-weight:bold;}
.pagination button:disabled{opacity:0.4;cursor:not-allowed;}
.pg-info{font-size:11px;color:#666;margin:0 6px;}

/* 로딩 */
.loading-row td{text-align:center;padding:20px;color:#999;}
.empty-row td{text-align:center;padding:30px;color:#aaa;}

/* ── 컬럼 리사이즈 핸들 ── */
.sl-table th{position:relative;}
.col-resizer{position:absolute;right:0;top:0;width:5px;height:100%;cursor:col-resize;user-select:none;z-index:10;}
.col-resizer:hover,.col-resizer.dragging{background:rgba(255,255,255,0.5);}

/* ── 필드선택 버튼 ── */
.btn-field-select{background:#5a6fa8;color:#fff;border:none;border-radius:3px;padding:3px 10px;height:26px;cursor:pointer;font-size:11px;flex-shrink:0;}
.btn-field-select:hover{background:#3d5080;}

/* ── 필드선택 모달 ── */
.sl-field-modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:9000;display:flex;align-items:center;justify-content:center;}
.sl-field-modal-box{background:#fff;border-radius:6px;box-shadow:0 6px 32px rgba(0,0,0,.3);min-width:380px;max-width:520px;width:90%;display:flex;flex-direction:column;overflow:hidden;}
.sl-field-modal-header{background:#3366cc;color:#fff;padding:10px 14px;font-size:13px;font-weight:bold;display:flex;align-items:center;justify-content:space-between;}
.sl-field-modal-close{background:none;border:none;color:#fff;font-size:16px;cursor:pointer;line-height:1;padding:0 2px;}
.sl-field-modal-close:hover{color:#ffd;}
.sl-field-modal-body{padding:12px 14px;overflow-y:auto;max-height:400px;}
.sl-field-all-row{display:flex;gap:6px;margin-bottom:10px;padding-bottom:8px;border-bottom:1px solid #e0e6f0;}
.sl-field-btn-all{background:#eef3ff;border:1px solid #c0ccdd;border-radius:3px;padding:3px 10px;font-size:11px;cursor:pointer;color:#3366cc;}
.sl-field-btn-all:hover{background:#dce8f8;}
.sl-field-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:6px 10px;}
.sl-field-item{display:flex;align-items:center;gap:4px;font-size:12px;cursor:pointer;white-space:nowrap;padding:3px 2px;border-radius:3px;}
.sl-field-item:hover{background:#f0f6ff;}
.sl-field-item input[type=checkbox]{cursor:pointer;accent-color:#3366cc;}
.sl-field-modal-footer{padding:10px 14px;border-top:1px solid #e0e6f0;display:flex;gap:8px;justify-content:flex-end;background:#f7faff;}
.sl-field-btn-save{background:#2563b0;color:#fff;border:none;border-radius:3px;padding:5px 18px;font-size:12px;font-weight:bold;cursor:pointer;}
.sl-field-btn-save:hover{background:#1a4a8a;}
.sl-field-btn-cancel{background:#888;color:#fff;border:none;border-radius:3px;padding:5px 14px;font-size:12px;cursor:pointer;}
.sl-field-btn-cancel:hover{background:#555;}

/* ── cascade disabled select ── */
.sg select:disabled{background:#f0f0f0;color:#aaa;cursor:not-allowed;}

/* ── 커스텀 드롭다운 (매니저/파트너) ── */
/* face: .sg 안에 인라인으로 배치 */
.sl-cd{flex-shrink:0;}
.sl-cd-face{display:flex;align-items:center;gap:4px;height:24px;border:1px solid #c0ccdd;border-radius:3px;background:#fff;padding:0 6px;cursor:pointer;min-width:90px;max-width:120px;font-size:11px;color:#333;user-select:none;}
.sl-cd-face:hover{border-color:#3366cc;}
.sl-cd-label{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;}
.sl-cd-arrow{font-size:10px;color:#888;flex-shrink:0;}
/* panel: JS가 body에 position:fixed로 생성 — .sg/.search-row overflow 영향 없음 */
.sl-cd-panel{position:fixed;z-index:9100;background:#fff;border:1px solid #b0c0d8;border-radius:4px;box-shadow:0 4px 16px rgba(0,0,0,.18);min-width:160px;width:190px;}
.sl-cd-search{display:block;width:100%;box-sizing:border-box;border:none;border-bottom:1px solid #e0e6f0;padding:6px 8px;font-size:11px;outline:none;border-radius:4px 4px 0 0;background:#f7faff;}
.sl-cd-search::placeholder{color:#aab;}
.sl-cd-list{max-height:220px;overflow-y:auto;}
.sl-cd-item{padding:5px 10px;font-size:12px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.sl-cd-item:hover{background:#eef4ff;}
.sl-cd-item.selected{background:#dce8f8;font-weight:bold;color:#1a4a8a;}
.sl-cd-item.sl-cd-all{color:#555;border-bottom:1px solid #e8eef8;margin-bottom:2px;}
