@charset "euc-kr";
html,body { font-family: 'Pretendard Variable', sans-serif; height: 100%; position: relative; color: var(--text); font-weight: 300; }
body { min-width: 940px; }
ul { margin: 0; padding: 0; }
li { list-style: none; }
a { text-decoration: none; color: inherit; display: block; box-sizing: border-box; }
strong { font-weight: 600 !important; }
label { cursor: pointer; } 
select { -webkit-appearance: none; cursor: pointer; -moz-appearance: none; appearance: none; filter: alpha(opacity=0); outline: none; font-family: 'Pretendard Variable', sans-serif; }
select::-ms-expand { display:none; }
select { height: 35px; border-radius: 5px; border: 1px solid var(--border); background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24"><path d="M17,9.17a1,1,0,0,0-1.41,0L12,12.71,8.46,9.17a1,1,0,0,0-1.41,0,1,1,0,0,0,0,1.42l4.24,4.24a1,1,0,0,0,1.42,0L17,10.59A1,1,0,0,0,17,9.17Z"></path></svg>') no-repeat 98% 50%; background-size: 18px; padding: 0 25px 0 10px; background-color: var(--w); color: var(--text2); font-size: 13.5px; color: var(--black); overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
select.focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); }
select[disabled] { background-color: var(--g01) !important; }

input { font-family: "Pretendard Variable", sans-serif; background-color: var(--w); outline: none; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; box-sizing: border-box; }
input::placeholder { color: var(--text2); }
input[disabled] { background-color: var(--g01) !important; }
input[type=checkbox] { cursor: pointer; margin:0; }
input[type="text"] { height: 35px; border-radius: 5px; border: 1px solid var(--border); padding: 0 10px; font-size: 13.5px; color: var(--black); }
input[type="file"] { height: 35px; line-height: 38px; border-radius: 5px; border: 1px solid var(--border); padding: 0 10px; font-size: 13.5px; color: var(--black); }
input[type="text"].focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); background-color: transparent; }
input[type="text"].active { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); background-color: transparent; }
input[type="number"] { width: 100px; height: 35px; border-radius: 5px; border: 1px solid var(--border); padding: 0 10px; font-size: 13.5px; position: relative; }
input[type="number"].focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); }
input[type="id"].focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); }
input[type="password"] { height: 35px; border-radius: 5px; border: 1px solid var(--border); padding: 0 10px; font-size: 13px; }
input[type="password"].focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); }
input[type="checkbox"].focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); }
input[type="radio"].focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); }
input[type="button"] { border: none; outline: none; cursor: pointer; }
input[disabled] { background-color: var(--g01) !important; }
input:-webkit-autofill,input:-webkit-autofill:focus { -webkit-text-fill-color: var(--black) !important; -webkit-box-shadow: 0 0 0px 1000px var(--blue01) inset !important; transition: background-color 5000s ease-in-out 0s !important; }

textarea { font-family: "Pretendard Variable", sans-serif; background-color: var(--w); outline: none; box-sizing: border-box; border-radius: 5px; border: 1px solid var(--border); line-height: 1.4; padding: 10px; font-size: 13px; resize: none; }
textarea.focus { border: 1px solid var(--blue) !important; box-shadow: 0 0 4px rgba(63,128,234,.7); background-color: transparent; }
textarea::placeholder { color: var(--text2); }
button { font-family: 'Pretendard Variable', sans-serif; border: none; box-sizing: border-box; cursor: pointer; background: none; outline: none; }

table { width: 100%; height: 100%; table-layout: fixed; position: relative; }
table th { height: 35px; padding: 5px 10px; text-align: center; vertical-align: middle; font-size: 13px; color: var(--text2); font-weight: 500; box-sizing: border-box; }
table th select { text-align: center; font-size: 13.5px; color: var(--blue); font-weight: 600; height: 28px; border: none; padding-left: 25px; background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%233182f6"><path d="M17,9.17a1,1,0,0,0-1.41,0L12,12.71,8.46,9.17a1,1,0,0,0-1.41,0,1,1,0,0,0,0,1.42l4.24,4.24a1,1,0,0,0,1.42,0L17,10.59A1,1,0,0,0,17,9.17Z"></path></svg>') no-repeat 95% 50%; background-size: 18px; }
table td { height: 40px; line-height: 1.4; padding: 5px 10px; text-align: center; vertical-align: middle; font-size: 13.5px; background-color: var(--w); box-sizing: border-box; }
table tbody tr:first-child td { border-top: none; }
table a { min-width: fit-content; display: inline-block; line-height: 1; font-size: 12px; background-color: var(--g02); color: var(--text2); padding: 6px 8px; border-radius: 4px; border: 1px solid var(--border); }
table a.href { display: inline-block; font-size: 13.5px; background: none; color: var(--blue); text-decoration: underline; padding: 0; border-radius: 0; border: none; }

/* 스크롤 숨기기 */
html:not(_) { scrollbar-width: thin; scrollbar-color: rgba(0,29,58,.18) transparent; }

.check-box { width: max-content; height: 20px; display: flex; align-items: center; justify-content: center; gap: 5px; font-size: 13.5px; font-weight: 500; position: relative; }
.check-box label { color: var(--text2); position: relative; line-height: 20px; left: -25px; padding-left: 25px; margin-right: -25px; }
.check-box input[type="radio"] { min-width: 18px !important; width: 18px !important; min-height: 18px !important; height: 18px !important; opacity: 0; margin: 0 !important; position: relative; z-index: 1; cursor: pointer; }
.check-box input[type="checkbox"] { min-width: 18px !important; width: 18px !important; min-height: 18px !important; height: 18px !important; opacity: 0; margin: 0 !important; position: relative; z-index: 1; cursor: pointer; }
.check-box::after { position: absolute; left: 1px; top: 1px; width: 18px; height: 18px; border: 1px solid var(--border2); border-radius: 4px; background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20" fill="%23fff0"><path d="m8.333 11.604 5.084-5.083q.229-.229.531-.229.302 0 .531.229.229.229.229.531 0 .302-.229.531l-5.625 5.625q-.229.23-.531.23-.302 0-.531-.23l-2.271-2.27q-.229-.23-.229-.532 0-.302.229-.531.229-.229.531-.229.302 0 .531.229Z"></path></svg>') no-repeat 50% 50%; background-color: var(--w); content: ''; box-sizing: border-box; }
.check-box:hover::after { background-color: var(--g01); transition: 0.2s; }
.check-box.on::after { border: 1px solid transparent; background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20" fill="%23fff"><path d="m8.333 11.604 5.084-5.083q.229-.229.531-.229.302 0 .531.229.229.229.229.531 0 .302-.229.531l-5.625 5.625q-.229.23-.531.23-.302 0-.531-.23l-2.271-2.27q-.229-.23-.229-.532 0-.302.229-.531.229-.229.531-.229.302 0 .531.229Z"></path></svg>') no-repeat 50% 50%; background-color: var(--blue) !important; }
.check-box.radio::after { border-radius: 100%; }

:root {
   --black: #000;
   --text: #333d4b;
   --text2: #6b7684;
   --w: #fff;
   --bg: #f6f7f9;
   --blue: #2272eb;
   --blue01: rgba(100,168,255,.1);
   --blue02: rgba(100,168,255,.2);
   --red: #f04452;
   --red01: rgba(255,126,137,.1);
   --g01: rgba(2,32,71,.05);
   --g02: rgba(2,32,71,.1);
   --border: rgba(2,32,71,.1);
   --border2: rgba(2,32,71,.2);
   --shadow: 0 0 0 1px rgba(2,32,71,0.05),0 10px 40px 0 rgba(2,32,71,.05),0 20px 50px 0 rgb(0,23,51,.2),2px 70px 80px 0 rgb(0,23,51,.02);
}

.t_red { color: var(--red) !important; }
.t_blue { color: var(--blue) !important; }

.btn { font-size: 13px; color: var(--text); font-weight: 500; padding: 8px; border-radius: 5px; background-color: var(--g01); }
.btn.sel { background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%236b7684"><path d="M17,9.17a1,1,0,0,0-1.41,0L12,12.71,8.46,9.17a1,1,0,0,0-1.41,0,1,1,0,0,0,0,1.42l4.24,4.24a1,1,0,0,0,1.42,0L17,10.59A1,1,0,0,0,17,9.17Z"></path></svg>') no-repeat 96% 48%; background-size: 20px; padding: 8px 28px 8px 8px; background-color: var(--g01); }
.btn:hover { background-color: var(--g02); }
.btn2 { font-size: 13px; color: var(--blue); font-weight: 500; padding: 10px; border-radius: 5px; background-color: var(--blue01); }
.btn2:hover { background-color: var(--blue02); }
.btn3 { font-size: 13px; color: var(--w); font-weight: 500; padding: 8px; border-radius: 5px; background-color: var(--blue); }
.none { display: none !important; }
.done { width: 100%; height: 700px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 10px; font-size: 14px; color: var(--text2); font-weight: 500; }
.alert { width: 100%; height: 700px; display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 15px; font-size: 15px; color: var(--text2); font-weight: 500; }

.list-area { width: 900px; margin: 0 auto; padding: 30px 0 30px 0; }
.list-title { display: flex; flex-direction: column; gap: 15px; }
.list-title h3 { font-size: 24px; font-weight: 600; }
.list-title > i { display: flex; align-items: center; justify-content: space-between; }
.list-title > i > span { display: flex; align-items: center; gap: 5px; font-size: 15px; color: var(--text2); }
.list-title > i > span button { width: 24px; height: 24px; background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" fill="%236b7684"><path d="M21,11a1,1,0,0,0-1,1,8.05,8.05,0,1,1-2.22-5.5h-2.4a1,1,0,0,0,0,2h4.53a1,1,0,0,0,1-1V3a1,1,0,0,0-2,0V4.77A10,10,0,1,0,22,12,1,1,0,0,0,21,11Z"></path></svg>') no-repeat 50% 50%; background-size: 16px; padding: 0; border-radius: 8px; }
.list-title > i > span button:hover { background-color: var(--g02); }

.list-filter { display: flex; flex-direction: column; gap: 10px; margin-bottom: 15px; padding-bottom: 15px; border-bottom: 1px solid var(--border); }
.list-filter i { display: flex; align-items: center; gap: 10px; }
.list-filter i > span { display: flex; align-items: center; gap: 10px; padding: 6px; border-radius: 5px; background-color: var(--g01); }
.list-filter i > span p { width: 1px; height: 18px; background-color: var(--border2); margin: 0 0 0 5px; }
.list-filter i > span input { width: 140px; height: 26px; }
.list-filter i > a { margin-left: -5px; }
.list-filter h4 { font-size: 14px; color: var(--text2); font-weight: 500; }

.select-box { height: 32px; display: flex; align-items: center; gap: 5px; font-size: 13px; color: var(--text); font-weight: 500; padding: 0 8px; border-radius: 5px; background-color: var(--g01); }
.select-box p { display: flex; align-items: center; gap: 5px; font-size: 13px; position: relative; }
.select-box p::after { display: block; content: ''; width: 5px; height: 5px; border-radius: 100%; background-color: var(--text); margin: 0 3px; transform: scale(0.5); }
.select-box select { font-size: 13px; border: none; background-color: transparent; padding-left: 0; }
.select-box select.focus { border: none !important; box-shadow: none !important; }

.grid-item-wrap i { display: flex; align-items: center; justify-content: space-between; margin-bottom: 12px; }
.grid-item-wrap i > span { display: flex; align-items: center; gap: 5px; font-size: 14px; color: var(--text2); }
.grid-item-wrap .list-filter { margin-bottom: 0; padding-bottom: 0; border-bottom: none; }
.grid-item { max-height: 795px; overflow-y: auto; overflow-x: hidden; }
.grid-item ul { display: grid; grid-auto-flow: dense; grid-template-columns: 55px 55px repeat(6, 1fr); border-radius: 8px; }
.grid-item ul.grid-header { border-bottom: none; position: sticky; top: 0; background-color: var(--w); border-radius: 0; z-index: 99; }
.grid-item ul.grid-header li { font-size: 13px; color: var(--text2); font-weight: 300; line-height: 45px; height: 45px; cursor: inherit; }
.grid-item ul li { padding: 0 10px; line-height: 50px; height: 50px; text-align: center; font-size: 13px; font-weight: 500; text-overflow: ellipsis; white-space: nowrap; overflow: hidden; box-sizing: border-box; }
.grid-item ul:nth-child(even) { background-color: var(--bg); }
.grid-item ul li:nth-child(1) { display: flex; align-items: center; justify-content: center; padding: 0; }
.grid-item ul li:nth-child(2) { padding: 0; }
.grid-item ul li:nth-child(3) { width: 180px; text-align: left; }
.grid-item ul li:nth-child(8) { border-right: none; font-weight: 600; color: var(--text); }
.grid-item ul li.hover { background-color: var(--blue01); }

.chart-wrap { display: flex; gap: 40px; margin: 0 0 20px 0; padding: 0 0 20px 0; border-bottom: 1px dashed var(--border); }
.pie-chart { width: 100%; display: flex; gap: 20px; position: relative; }
.pie-label { flex: 1; display: flex; flex-direction: column; gap: 20px; padding-top: 5px; }
.pie-label h3 { display: flex; align-items: center; justify-content: space-between; font-weight: 600; }
.pie-label i { display: flex; gap: 10px; }
.pie-label-item { flex: 1; display: flex; flex-direction: column; gap: 20px; border: 2px solid var(--border); padding: 15px; border-radius: 10px; }
.pie-label-item > span { display: block; width: fit-content; padding: 8px 10px; border-radius: 5px; background-color: var(--g02); font-size: 13px; font-weight: 600; color: var(--text2); }
.pie-label-item:nth-child(1) > span { background-color: var(--red01); color: var(--red); }
.pie-label-item:nth-child(3) > span { background-color: var(--blue01); color: var(--blue); }
.pie-label-item b { font-weight: 600; font-size: 24px; padding: 0 5px; }

.layer { min-width: 320px; position: absolute; background-color: var(--w); border: 1px solid var(--border); border-radius: 12px; box-shadow: var(--shadow); padding: 20px 20px 25px 20px; opacity: 0; visibility: hidden; z-index: 9999; }
.layer.on { opacity: 1; visibility: visible; }
.layer h3 { font-size: 15px; font-weight: 600; margin-bottom: 10px; }
.layer ul { display: flex; flex-direction: column; max-height: 300px; overflow-y: auto; }
.layer ul li { font-size: 15px; font-weight: 400; border-radius: 8px; padding: 15px 10px; cursor: pointer; transition: padding-left 0.2s; }
.layer ul li.this { color: var(--blue); background: url('data:image/svg+xml;charset=utf8,<svg xmlns="http://www.w3.org/2000/svg" height="20" width="20" fill="%232272eb"><path d="m8.333 11.604 5.084-5.083q.229-.229.531-.229.302 0 .531.229.229.229.229.531 0 .302-.229.531l-5.625 5.625q-.229.23-.531.23-.302 0-.531-.23l-2.271-2.27q-.229-.23-.229-.532 0-.302.229-.531.229-.229.531-.229.302 0 .531.229Z"></path></svg>') no-repeat 10px 50%; padding-left: 40px !important; }
.layer ul li:hover { background-color: var(--g01); padding-left: 20px; }
.layer ul input { width: 100%; height: 45px; font-size: 14px; margin-top: 5px; cursor: pointer; }
.layer dl { display: flex; flex-direction: column; gap: 10px; }
.layer dl dd { display: flex; align-items: center; gap: 20px; }
.layer dl dd span { font-size: 15px; font-weight: 400; }
.layer dl dd i { display: flex; align-items: center; gap: 5px; }
.layer dl dd i input { width: 50px; text-align: center; }
.layer-btn { display: flex; align-items: center; gap: 5px; justify-content: flex-end; margin-top: 15px; }
.layer-btn button { font-size: 13px; color: var(--text); font-weight: 400; padding: 8px 12px; border-radius: 8px; background-color: var(--g02); }
.layer-btn button:hover { background-color: var(--g01); }
.layer-btn .confirm { background-color: var(--blue) !important; color: var(--w); }