/* DOTSWORK — PC (www.dots.co.kr 톤: 화이트·블랙·얇은 라인·Pretendard·미니멀) */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css');
:root{
  --bg:#ffffff;--card:#fff;--line:#ececec;--soft:#f6f6f6;
  --ink:#111111;--muted:#8a8a8a;
  --brand:#111111;--brand-d:#000000;          /* 인라인 var(--brand) 호환: 블랙 계열 */
  --ok:#1f9d55;--warn:#c77700;--bad:#d23a3a;--info:#3b5bdb;
  --radius:14px;
}
*{box-sizing:border-box}
body{margin:0;font-family:'Pretendard Variable',Pretendard,-apple-system,BlinkMacSystemFont,"Apple SD Gothic Neo","Malgun Gothic",sans-serif;background:var(--bg);color:var(--ink);font-size:14px;font-weight:500;line-height:1.6;word-break:keep-all;-webkit-font-smoothing:antialiased}
a{color:var(--ink);text-decoration:none}
a:hover{text-decoration:underline}

/* ── 상단바 ── */
.topbar{background:#fff;position:sticky;top:0;z-index:50;border-bottom:1px solid var(--line)}
.topbar .wrap{max-width:none;min-width:1120px;margin:auto;display:flex;align-items:center;gap:18px;padding:0 40px;height:64px}
.brand,.brand:hover,.brand:focus{font-weight:500;font-size:22px;color:#000;letter-spacing:.5px;text-decoration:none !important}
.nav{display:flex;gap:6px;flex:1;flex-wrap:wrap}
.nav a{padding:8px 12px;border-radius:8px;color:var(--muted);font-weight:600;font-size:15px}
.nav a:hover{color:#000;text-decoration:none}
.nav a.active{color:#000}
.userbox{display:flex;align-items:center;gap:14px;white-space:nowrap}
.bell{position:relative;color:#111;display:inline-flex;align-items:center}
.bell:hover{color:#000;text-decoration:none}
.badge{position:absolute;top:-6px;right:-8px;background:var(--bad);color:#fff;border-radius:10px;font-size:10px;padding:1px 5px;font-weight:700}

/* ── 레이아웃 ── */
.container{max-width:none;min-width:1120px;margin:28px auto;padding:0 40px}
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:18px}
.card h2,.card h3{margin-top:0}
.grid{display:grid;gap:18px}
.grid.cols-2{grid-template-columns:1fr 1fr}
.grid.cols-3{grid-template-columns:repeat(3,1fr)}
h1{font-size:24px;font-weight:700;letter-spacing:-.4px;margin:0 0 20px}
h2{font-weight:700}h3{font-weight:700}

/* ── 버튼 (dots: 블랙/화이트) ── */
.btn{display:inline-block;border:1px solid #000;background:#000;color:#fff;padding:10px 18px;border-radius:12px;font-weight:600;cursor:pointer;font-size:14px;white-space:nowrap}
.btn:hover{background:#222;text-decoration:none}
.btn.lg{padding:14px 26px;font-size:16px}
.btn.ghost{background:#fff;color:#000;border-color:#000}
.btn.ghost:hover{background:var(--soft)}
.btn.ok{background:var(--ok);border-color:var(--ok);color:#fff}
.btn.ok:hover{background:#1b8a4a}
.btn.bad{background:var(--bad);border-color:var(--bad);color:#fff}
.btn.bad:hover{background:#bb3030}
.btn.gray{background:#fff;color:var(--muted);border-color:var(--line)}
.btn.gray:hover{background:var(--soft);color:#000}
.btn[disabled]{opacity:.4;cursor:not-allowed}

/* ── 폼 ── */
input,select,textarea{font:inherit;padding:10px 13px;border:1px solid var(--line);border-radius:12px;width:100%;background:#fff;color:#111}
input:focus,select:focus,textarea:focus{outline:none;border-color:#000}
label{display:block;font-weight:600;margin:14px 0 6px;font-size:13px}
.row{display:flex;gap:12px;flex-wrap:wrap}
.row>div{flex:1;min-width:140px}

/* ── 테이블 ── */
table{width:100%;border-collapse:collapse;font-size:13px}
th,td{text-align:left;padding:11px 12px;border-bottom:1px solid var(--line)}
th{background:#fafafa;font-weight:600;color:var(--muted);font-size:12px;letter-spacing:.2px}
tr:hover td{background:#fafafa}

/* ── 태그/배지 ── */
.tag{display:inline-block;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:600}
.tag.ok{background:#e7f6ec;color:#1f7a45}
.tag.warn{background:#fdf1de;color:#9a5b00}
.tag.bad{background:#fbe7e7;color:#a32525}
.tag.info{background:#e8edfb;color:#2c44ac}
.tag.gray{background:var(--soft);color:#666}

/* ── 기타 ── */
.muted{color:var(--muted)}
.flash{padding:13px 16px;border-radius:12px;margin-bottom:16px;font-weight:600;white-space:pre-line}
.flash.ok{background:#e7f6ec;color:#1f7a45}
.flash.err{background:#fbe7e7;color:#a32525}
.big-num{font-size:34px;font-weight:800;color:#000;letter-spacing:-1px}
.kpi{display:flex;justify-content:space-between;align-items:center}

/* ── 인증(로그인 등) ── */
.auth-wrap{max-width:400px;margin:9vh auto;padding:0 20px}
.auth-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:34px}
.auth-card .brand{font-size:30px;font-weight:500;color:#111;letter-spacing:1px;text-align:center;display:block;margin-bottom:6px;text-decoration:none}
.auth-card .muted{font-weight:500;letter-spacing:.2px}
.auth-card label{font-weight:600;letter-spacing:.2px}
.center{text-align:center}

/* ── 캘린더 ── */
.cal{width:100%;border-collapse:collapse;table-layout:fixed}
.cal th{text-align:center;padding:8px;background:#fff;color:var(--muted);font-size:12px}
.cal td{height:96px;vertical-align:top;border:1px solid var(--line);padding:5px;background:#fff}
.cal .day{font-size:12px;color:var(--muted)}
.cal .sun{color:var(--bad)}.cal .sat{color:var(--info)}
.cal td.hol,.cal td.sun-cell,.cal td.sat-cell{background:var(--soft)}
.cal .ev{display:block;background:var(--soft);color:#333;font-size:11px;border-radius:5px;padding:1px 5px;margin-top:3px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* ── 모달 ── */
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:100;align-items:center;justify-content:center}
.modal-bg.open{display:flex}
.modal{background:#fff;border-radius:18px;padding:28px;max-width:520px;width:92%;max-height:85vh;overflow:auto}
.check-list label{display:flex;align-items:center;gap:8px;font-weight:500;padding:9px 11px;border:1px solid var(--line);border-radius:12px;margin:6px 0}
.check-list input{width:auto}
.inline{display:inline}
small.hint{color:var(--muted);font-weight:400}
