/* ============================================================
   대륙마루 ERP — 관리자 웹 디자인 시스템 (PC 퍼스트)
   ============================================================ */
:root{
  --green:#2B3A2E;--green-2:#3D4F42;--green-soft:#E8EDE9;
  --gold:#C8A35B;--gold-soft:#F3EBDA;
  --bg:#F1F2EF;--card:#FFFFFF;--line:#E3E4DF;
  --ink:#1A1A1A;--ink-2:#5C5C57;--ink-3:#9A998F;
  --info:#3A7BD5;--ok:#2E9E5B;--warn:#E0A100;--danger:#D9534F;
  --info-bg:#E8F0FB;--ok-bg:#E6F4EC;--warn-bg:#FBF3DC;--danger-bg:#FBE9E8;
  --r:10px;--sh:0 1px 3px rgba(30,40,32,.06);--side-w:230px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Pretendard',-apple-system,'Apple SD Gothic Neo','Noto Sans KR',system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button,input,select,textarea{font-family:inherit;font-size:inherit}
img{display:block;max-width:100%}

/* 레이아웃 */
.layout{display:flex;min-height:100vh}
.sidebar{width:var(--side-w);background:var(--green);color:#fff;flex-shrink:0;position:fixed;inset:0 auto 0 0;display:flex;flex-direction:column;z-index:30}
.sidebar .brand{height:58px;display:flex;align-items:center;padding:0 18px;border-bottom:1px solid rgba(255,255,255,.1)}
.sidebar .brand img{height:38px}
.sidebar nav{flex:1;padding:10px;overflow-y:auto;scrollbar-width:thin;scrollbar-color:rgba(200,163,91,.35) transparent}
.sidebar nav::-webkit-scrollbar{width:8px}
.sidebar nav::-webkit-scrollbar-track{background:transparent;margin:6px 0}
.sidebar nav::-webkit-scrollbar-thumb{background:rgba(255,255,255,.14);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
.sidebar nav::-webkit-scrollbar-thumb:hover{background:rgba(200,163,91,.55);background-clip:padding-box}
.sidebar nav a{display:flex;align-items:center;gap:11px;padding:11px 13px;border-radius:8px;color:rgba(255,255,255,.78);font-weight:600;font-size:13.5px;margin-bottom:2px}
.sidebar nav a .ic{width:19px;height:19px;display:inline-flex;align-items:center;justify-content:center;font-size:19px;flex-shrink:0}
/* ---------- SVG 아이콘 ---------- */
.ic-svg{width:1em;height:1em;display:inline-block;vertical-align:-.14em;flex-shrink:0}
.ic{display:inline-flex;align-items:center;justify-content:center;line-height:1}
.topbar .who .ic{font-size:16px;vertical-align:-.2em;margin-right:2px}
.menu-toggle .ic{font-size:22px}
.drawer .dh .x .ic-svg{font-size:16px}
.stars{display:inline-flex;align-items:center;gap:1px;font-size:13px;vertical-align:middle}
.stars .ic-svg.st-on{color:var(--gold)}
.stars .ic-svg.st-off{color:var(--line)}
.rate-n{font-size:12.5px;font-weight:700;color:var(--ink-2);margin-left:4px}
.thumb-doc .ic-svg{font-size:20px}
.sidebar nav a:hover{background:rgba(255,255,255,.08);color:#fff}
.sidebar nav a.on{background:var(--gold);color:#fff}
.sidebar nav .grp{font-size:11px;color:rgba(255,255,255,.4);padding:14px 13px 6px;font-weight:700;letter-spacing:.5px}
.sidebar .foot{padding:14px;border-top:1px solid rgba(255,255,255,.1);font-size:12px;color:rgba(255,255,255,.6)}

.main{flex:1;margin-left:var(--side-w);min-width:0}
.topbar{height:58px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 24px;gap:16px;position:sticky;top:0;z-index:20}
.topbar h1{font-size:18px;font-weight:800;flex:1}
.topbar .who{font-size:13px;color:var(--ink-2)}
.topbar .who b{color:var(--green)}
.content{padding:24px}

/* 카드 */
.card{background:var(--card);border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:18px;margin-bottom:16px}
/* 규격화된 카드 헤더: 좌우 카드 헤더 높이 일치 + 모듈 구분선 */
.card-h{font-size:15px;font-weight:800;margin:-2px 0 16px;padding-bottom:13px;
  border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;
  gap:10px;min-height:30px}
.card-h .ic-svg{color:var(--green)}
.card-h .btn{margin:-4px 0}

/* ---------- SVG 아이콘 공통 ---------- */
.ic-svg{width:1.15em;height:1.15em;display:inline-block;vertical-align:-.18em;flex-shrink:0}
.sidebar nav a .ic{display:inline-flex;align-items:center;justify-content:center}
.sidebar nav a .ic .ic-svg{width:18px;height:18px;vertical-align:middle}
.topbar .menu-toggle .ic-svg{width:22px;height:22px;vertical-align:-.3em}
.topbar .who .ic-svg{width:15px;height:15px;opacity:.7;vertical-align:-.2em}
.thumb-doc .ic-svg{width:22px;height:22px;color:var(--green)}
.notice-line .ic-svg{color:var(--green)}

/* 별점 */
.stars{display:inline-flex;gap:1px;vertical-align:-.18em}
.stars .ic-svg{width:14px;height:14px}
.stars .st-on{color:var(--gold)}
.stars .st-off{color:#D9D7CF}
.rate-n{margin-left:5px;font-weight:700;font-variant-numeric:tabular-nums}
.rate{display:inline-flex;align-items:center;gap:4px;font-variant-numeric:tabular-nums}
.rate .ic-svg{width:14px;height:14px;color:var(--gold)}

/* 인라인 아이콘+텍스트 (카드헤더 타이틀, 안내문) */
.hd{display:inline-flex;align-items:center;gap:8px}
.lead-ic{display:inline-flex;align-items:center;gap:7px}
.lead-ic .ic-svg{width:16px;height:16px;flex-shrink:0}
.grid{display:grid;gap:16px}
.g-2{grid-template-columns:1fr 1fr}.g-3{grid-template-columns:repeat(3,1fr)}.g-4{grid-template-columns:repeat(4,1fr)}

/* KPI */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.kpi{background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:18px;box-shadow:var(--sh)}
.kpi .l{font-size:12.5px;color:var(--ink-2);font-weight:600}
.kpi .n{font-size:30px;font-weight:800;color:var(--green);margin-top:6px;line-height:1}
.kpi .s{font-size:12px;color:var(--ink-3);margin-top:6px}
.kpi.alert .n{color:var(--danger)}
.kpi.warn .n{color:var(--warn)}

/* 테이블 */
.tbl{width:100%;border-collapse:collapse;background:#fff;border-radius:var(--r);overflow:hidden}
.tbl th{background:#FAFAF8;text-align:left;padding:12px 14px;font-size:12.5px;color:var(--ink-2);font-weight:700;border-bottom:1px solid var(--line);white-space:nowrap}
.tbl td{padding:12px 14px;border-bottom:1px solid var(--line);font-size:13.5px;vertical-align:middle}
.tbl tr:last-child td{border-bottom:none}
.tbl tr:hover td{background:#FBFBF9}
.tbl .num{text-align:right;font-variant-numeric:tabular-nums}

/* 뱃지 */
.badge{display:inline-flex;align-items:center;gap:4px;padding:3px 9px;border-radius:999px;font-size:11.5px;font-weight:700}
.badge.info{background:var(--info-bg);color:var(--info)}
.badge.ok{background:var(--ok-bg);color:var(--ok)}
.badge.warn{background:var(--warn-bg);color:var(--warn)}
.badge.danger{background:var(--danger-bg);color:var(--danger)}
.badge.gray{background:#EDEDE8;color:var(--ink-2)}

/* 버튼 */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;height:38px;padding:0 16px;border:0;border-radius:8px;font-size:13.5px;font-weight:700;cursor:pointer;transition:.12s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--green);color:#fff}
.btn-gold{background:var(--gold);color:#fff}
.btn-line{background:#fff;color:var(--green);border:1.5px solid var(--green)}
.btn-ghost{background:var(--green-soft);color:var(--green)}
.btn-danger{background:var(--danger);color:#fff}
.btn-gray{background:#EDEDE8;color:var(--ink-2)}
.btn-sm{height:30px;padding:0 11px;font-size:12.5px}
.btn-row{display:flex;gap:8px}

/* 폼 */
.field{margin-bottom:14px}
.field>label{display:block;font-size:12.5px;font-weight:600;color:var(--ink-2);margin-bottom:6px}
.req{color:var(--danger)}
.input,.select,.textarea{width:100%;height:40px;padding:0 12px;border:1.5px solid var(--line);border-radius:8px;font-size:14px;background:#fff}
.textarea{height:auto;padding:10px 12px;min-height:80px;resize:vertical}
.input:focus,.select:focus,.textarea:focus{outline:0;border-color:var(--green);box-shadow:0 0 0 3px rgba(43,58,46,.08)}
.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%235C5C57' stroke-width='1.8' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}
.form-row{display:flex;gap:12px;flex-wrap:wrap;align-items:flex-end}
.filterbar{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:16px;background:#fff;border:1px solid var(--line);border-radius:var(--r);padding:14px}
.filterbar .input,.filterbar .select{width:auto;min-width:130px;height:36px}

/* kv (상세) */
.kv{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px dashed var(--line);font-size:13.5px}
.kv:last-child{border:none}
.kv .k{color:var(--ink-2)}.kv .v{font-weight:600}
.kv.total{border-top:2px solid var(--ink);border-bottom:none;margin-top:6px;padding-top:12px;font-size:15px}
.kv.total .v{color:var(--green);font-weight:800;font-size:18px}
.minus{color:var(--danger)}

/* 모달/드로어 */
.drawer-bg{position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:40;display:none}
.drawer-bg.open{display:block}
.drawer{position:fixed;top:0;right:0;bottom:0;width:980px;max-width:96vw;background:var(--bg);z-index:41;transform:translateX(100%);transition:.25s;overflow-y:auto;box-shadow:-8px 0 24px rgba(0,0,0,.12)}
.drawer .db table{width:100%}
.drawer .db .tbl td,.drawer .db .tbl th{white-space:nowrap}
.drawer.open{transform:none}
.drawer .dh{background:var(--green);color:#fff;padding:16px 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:2}
.drawer .dh h2{font-size:16px}
.drawer .dh .x{background:rgba(255,255,255,.15);border:0;color:#fff;width:30px;height:30px;border-radius:7px;cursor:pointer;font-size:16px}
.drawer .db{padding:20px}

/* 유틸 */
.muted{color:var(--ink-3)}.small{font-size:12px}
.row{display:flex;align-items:center;justify-content:space-between;gap:10px}
.tabs{display:flex;gap:6px;margin-bottom:16px;border-bottom:1px solid var(--line)}
.tabs button{background:none;border:0;padding:10px 14px;font-weight:700;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent;font-size:13.5px}
.tabs button.on{color:var(--green);border-bottom-color:var(--green)}
.chips{display:flex;flex-wrap:wrap;gap:6px}
.chip{padding:6px 11px;border:1.5px solid var(--line);border-radius:999px;background:#fff;font-size:12.5px;font-weight:600;cursor:pointer;color:var(--ink-2)}
.chip.on{background:var(--green);color:#fff;border-color:var(--green)}
.thumb-doc{width:46px;height:46px;border-radius:6px;background:var(--green-soft);display:flex;align-items:center;justify-content:center;font-size:20px}
.kpi .s{min-height:1em}
hr.div{border:0;border-top:1px solid var(--line);margin:14px 0}
.toast{position:fixed;right:24px;bottom:24px;background:rgba(26,26,26,.92);color:#fff;padding:12px 20px;border-radius:10px;z-index:100;opacity:0;transition:.25s;font-size:14px;pointer-events:none}
.toast.show{opacity:1}

/* 차트(간이 바) */
.bars{display:flex;gap:10px;align-items:stretch;height:150px;padding-top:22px;margin-bottom:26px}
.bars .bar{flex:1;height:100%;background:var(--green-soft);border-radius:6px;position:relative;display:flex;flex-direction:column;justify-content:flex-end;overflow:visible}
.bars .bar i{background:linear-gradient(180deg,var(--green-2),var(--green));border-radius:6px;display:block;width:100%;min-height:4px;transition:height .5s ease}
.bars .bar.hl i{background:linear-gradient(180deg,#d9b873,var(--gold))}
.bars .bar span{position:absolute;bottom:-22px;left:0;right:0;text-align:center;font-size:11px;color:var(--ink-3);font-weight:600}
.bars .bar .barval{position:absolute;top:-18px;left:0;right:0;text-align:center;font-size:10.5px;font-weight:700;color:var(--ink-2);font-variant-numeric:tabular-nums}
.bars .bar.hl .barval{color:#9a7b34}
.bars .bar:hover i{filter:brightness(1.08)}

@media(max-width:1000px){
  .sidebar{transform:translateX(-100%);transition:.25s;box-shadow:8px 0 24px rgba(0,0,0,.18)}
  .sidebar.open{transform:none}
  .main{margin-left:0}
  .kpi-grid{grid-template-columns:1fr 1fr}
  .g-2,.g-3,.g-4{grid-template-columns:1fr}
  .menu-toggle{display:inline-flex!important}
  .content{padding:16px}
  .topbar{padding:0 14px}
  .topbar h1{font-size:16px}
  .topbar .who{display:none}                 /* 좁은 화면에서 우측 정보 숨김 */
  /* 넓은 테이블은 카드 안에서 가로 스크롤 */
  .card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  .tbl{min-width:560px}
  .filterbar{padding:12px}
  .filterbar .input,.filterbar .select{min-width:110px}
  .drawer{width:100%;max-width:100%}        /* 드로어 전체폭 */
}
@media(max-width:560px){
  .kpi-grid{grid-template-columns:1fr 1fr;gap:10px}
  .kpi .n{font-size:24px}
  .tabs{overflow-x:auto;white-space:nowrap}
}
.menu-toggle{display:none;background:none;border:0;font-size:22px;cursor:pointer}
/* 모바일에서 사이드바 오버레이 배경 */
.side-scrim{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:25}
.side-scrim.open{display:block}

/* ============================================================
   관리자 시각화 컴포넌트 (무외부의존: conic-gradient + CSS)
   ============================================================ */
/* 요약 스탯 스트립 */
.stat-strip{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-bottom:16px}
.stat{background:#fff;border:1px solid var(--line);border-radius:10px;padding:14px 16px;box-shadow:var(--sh);border-left:3px solid var(--line)}
.stat .l{font-size:12px;color:var(--ink-2);font-weight:600}
.stat .n{font-size:21px;font-weight:800;margin-top:5px;line-height:1}
.stat .sub{font-size:11.5px;color:var(--ink-3);margin-top:4px}
.stat.green{border-left-color:var(--green)} .stat.green .n{color:var(--green)}
.stat.gold{border-left-color:var(--gold)} .stat.gold .n{color:#9a7b34}
.stat.info{border-left-color:var(--info)} .stat.info .n{color:var(--info)}
.stat.warn{border-left-color:var(--warn)} .stat.warn .n{color:var(--warn)}
.stat.danger{border-left-color:var(--danger)} .stat.danger .n{color:var(--danger)}

/* 도넛 차트 */
.donut-wrap{display:flex;align-items:center;gap:24px;flex-wrap:wrap}
.donut{width:148px;height:148px;border-radius:50%;position:relative;flex-shrink:0}
.donut::after{content:'';position:absolute;inset:24%;background:#fff;border-radius:50%}
.donut .center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:1}
.donut .center .n{font-size:24px;font-weight:800;color:var(--green)}
.donut .center .l{font-size:11px;color:var(--ink-3);margin-top:2px}
.legend{display:flex;flex-direction:column;gap:9px;flex:1;min-width:160px}
.legend .it{display:flex;align-items:center;gap:9px;font-size:13px}
.legend .dot{width:11px;height:11px;border-radius:3px;flex-shrink:0}
.legend .it .v{margin-left:auto;font-weight:700;font-variant-numeric:tabular-nums}
.legend .it .pct{color:var(--ink-3);font-size:11.5px;width:38px;text-align:right}

/* 랭킹 바 (기사 실적/지역 분포) */
.rank{display:flex;flex-direction:column;gap:12px}
.rank .r{display:grid;grid-template-columns:18px 1fr;gap:10px;align-items:center}
.rank .r .idx{font-weight:800;color:var(--ink-3);font-size:12px;text-align:center}
.rank .r .body{min-width:0}
.rank .r .top{display:flex;justify-content:space-between;font-size:13px;margin-bottom:5px}
.rank .r .top b{font-weight:700}
.rank .r .top .v{font-weight:700;font-variant-numeric:tabular-nums;color:var(--green)}
.rank .bar{height:8px;background:var(--green-soft);border-radius:4px;overflow:hidden}
.rank .bar i{display:block;height:100%;background:linear-gradient(90deg,var(--green),var(--green-2));border-radius:4px}
.rank .r:first-child .bar i{background:linear-gradient(90deg,var(--gold),#b48a3f)}

/* 재고 게이지 */
.gauge{height:8px;background:#EEEDE7;border-radius:4px;overflow:hidden;width:100%;min-width:90px}
.gauge i{display:block;height:100%;border-radius:4px;transition:width .4s}
.gauge.ok i{background:var(--ok)} .gauge.warn i{background:var(--warn)} .gauge.danger i{background:var(--danger)}
.gauge-cell{display:flex;align-items:center;gap:10px;min-width:160px}
.gauge-cell .lab{font-variant-numeric:tabular-nums;font-size:12.5px;white-space:nowrap;color:var(--ink-2)}

/* 평점 별 */
.stars-row{display:inline-flex;align-items:center;gap:1px;vertical-align:-.2em}
.stars-row .ic-svg{width:13px;height:13px}
.stars-row .on{color:var(--gold)} .stars-row .off{color:#D9D7CF}

/* 월간 캘린더 */
.calbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}
.calbar h2{font-size:17px;font-weight:800}
.calbar .nav{display:flex;gap:6px}
.viewtoggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}
.viewtoggle button{border:0;background:#fff;padding:8px 16px;font-size:13px;font-weight:700;cursor:pointer;color:var(--ink-2)}
.viewtoggle button.on{background:var(--green);color:#fff}
.cal2{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}
.cal2 .dow{text-align:center;font-size:11px;color:var(--ink-3);font-weight:700;padding:6px 0}
.cal2 .cell{min-height:92px;border:1px solid var(--line);border-radius:8px;padding:6px;background:#fff;display:flex;flex-direction:column;gap:3px}
.cal2 .cell.empty{background:transparent;border:none}
.cal2 .cell .d{font-weight:700;color:var(--ink-2);font-size:12px}
.cal2 .cell.today{border-color:var(--green);box-shadow:0 0 0 2px rgba(43,58,46,.12)}
.cal2 .cell.today .d{color:var(--green)}
.cal2 .ev{font-size:10.5px;padding:3px 6px;border-radius:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer;font-weight:600}
.cal2 .ev.s-tech_assigned{background:var(--warn-bg);color:#8a6d00}
.cal2 .ev.s-scheduled{background:var(--warn-bg);color:#8a6d00}
.cal2 .ev.s-completed{background:var(--ok-bg);color:var(--ok)}
.cal2 .ev.s-material_order,.cal2 .ev.s-reserved{background:var(--info-bg);color:var(--info)}
.cal2 .more{font-size:10px;color:var(--ink-3)}
@media(max-width:760px){.cal2 .cell{min-height:62px}.cal2 .ev{font-size:9px}}

/* ============================================================
   상단 사용자 드롭다운
   ============================================================ */
.usermenu{position:relative}
.um-trigger{display:flex;align-items:center;gap:8px;background:none;border:1px solid var(--line);border-radius:999px;padding:5px 8px 5px 5px;cursor:pointer;color:var(--ink);transition:.12s}
.um-trigger:hover{background:#FAFAF8;border-color:var(--green)}
.um-avatar{width:30px;height:30px;border-radius:50%;background:var(--green-soft);display:inline-flex;align-items:center;justify-content:center;color:var(--green)}
.um-avatar .ic-svg{width:17px;height:17px}
.um-name{font-size:13px;color:var(--ink-2)}
.um-name b{color:var(--green)}
.um-chev{display:inline-flex;color:var(--ink-3);transition:transform .15s}
.um-chev .ic-svg{width:15px;height:15px}
.usermenu.open .um-chev{transform:rotate(180deg)}

.um-pop{position:absolute;top:calc(100% + 8px);right:0;min-width:220px;background:#fff;border:1px solid var(--line);
  border-radius:12px;box-shadow:0 12px 32px rgba(30,40,32,.16);padding:6px;z-index:60;
  opacity:0;visibility:hidden;transform:translateY(-6px);transition:.16s}
.usermenu.open .um-pop{opacity:1;visibility:visible;transform:none}
.um-head{padding:10px 12px 12px;border-bottom:1px solid var(--line);margin-bottom:6px}
.um-head b{display:block;font-size:14px}
.um-head span{font-size:11.5px;color:var(--ink-3)}
.um-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;font-size:13.5px;font-weight:600;color:var(--ink);cursor:pointer}
.um-item:hover{background:var(--green-soft)}
.um-item .ic-svg{width:17px;height:17px;color:var(--ink-3)}
.um-item.danger{color:var(--danger)}
.um-item.danger .ic-svg{color:var(--danger)}
.um-item.danger:hover{background:var(--danger-bg)}
.um-pop hr{border:0;border-top:1px solid var(--line);margin:6px 4px}
@media(max-width:560px){.um-name{display:none}}

/* 테이블 정렬 인디케이터 */
.tbl th.sort-asc::after{content:'▲';font-size:8px;color:var(--green);margin-left:5px}
.tbl th.sort-desc::after{content:'▼';font-size:8px;color:var(--green);margin-left:5px}
.tbl th[style*="cursor"]:hover{color:var(--green)}
/* 일괄 선택 */
.bulkbar{display:none;align-items:center;gap:12px;background:var(--green-soft);border:1px solid var(--green);border-radius:8px;padding:10px 14px;margin-bottom:12px;font-size:13.5px}
.bulkbar.on{display:flex}
.bulkbar b{color:var(--green)}
.tbl td .rowchk,.tbl th .allchk{width:16px;height:16px;accent-color:var(--green);cursor:pointer}
/* 인라인 편집 입력 */
.inline-edit{width:110px;height:32px;padding:0 8px;border:1.5px solid var(--green);border-radius:6px;font-size:13px;text-align:right;font-variant-numeric:tabular-nums}

/* ============================================================
   필터 영역 — 카운트 칩 + 기간 프리셋 (한눈에 분포 파악)
   ============================================================ */
.filters{background:#fff;border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--sh);padding:14px 16px;margin-bottom:16px;display:flex;flex-direction:column;gap:12px}
.filters .frow{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.filters .flabel{font-size:11px;color:var(--ink-3);font-weight:800;letter-spacing:.3px;min-width:42px}
.filters .spacer{flex:1}
.filters .input{height:36px;width:auto;min-width:200px}

.fchips{display:flex;gap:7px;flex-wrap:wrap}
.fchip{display:inline-flex;align-items:center;gap:7px;padding:7px 13px;border:1.5px solid var(--line);border-radius:999px;background:#fff;font-size:13px;font-weight:700;color:var(--ink-2);cursor:pointer;transition:.12s;white-space:nowrap}
.fchip:hover{border-color:var(--green);color:var(--green)}
.fchip.on{background:var(--green);color:#fff;border-color:var(--green)}
.fchip .cnt{font-size:11px;font-weight:800;background:var(--green-soft);color:var(--green);border-radius:999px;padding:1px 7px;min-width:20px;text-align:center;line-height:1.5}
.fchip.on .cnt{background:rgba(255,255,255,.24);color:#fff}
.fchip.dot::before{content:'';width:8px;height:8px;border-radius:50%;background:currentColor;opacity:.7}
.fchip.c-info{--c:var(--info)} .fchip.c-warn{--c:var(--warn)} .fchip.c-ok{--c:var(--ok)} .fchip.c-danger{--c:var(--danger)} .fchip.c-gray{--c:var(--ink-3)}
.fchip[class*="c-"]:not(.on){color:var(--c)} .fchip[class*="c-"]:not(.on) .cnt{background:color-mix(in srgb,var(--c) 14%,#fff);color:var(--c)}
.fchip[class*="c-"].on{background:var(--c);border-color:var(--c)}

.dpreset{display:inline-flex;border:1.5px solid var(--line);border-radius:8px;overflow:hidden}
.dpreset button{border:0;background:#fff;padding:7px 13px;font-size:12.5px;font-weight:700;color:var(--ink-2);cursor:pointer;border-right:1px solid var(--line)}
.dpreset button:last-child{border-right:0}
.dpreset button:hover{background:#FAFAF8}
.dpreset button.on{background:var(--green);color:#fff}

/* ============================================================
   §8 3분할 작업 콘솔 (목록 | 상세 | 폼)
   ============================================================ */
.ws{display:flex;height:calc(100vh - 58px - 48px);min-height:520px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff;box-shadow:var(--sh)}
.ws-pane{display:flex;flex-direction:column;min-width:0;overflow:hidden}
.ws-list{width:330px;flex-shrink:0;background:#FAFAF8}
.ws-detail{flex:1;min-width:260px}
.ws-form{width:380px;flex-shrink:0;background:#FAFAF8}
.ws-resizer{width:6px;cursor:col-resize;flex-shrink:0;background:var(--line);position:relative;transition:.1s}
.ws-resizer:hover,.ws-resizer.drag{background:var(--green)}
.ws-resizer::after{content:'';position:absolute;inset:0 -4px}
.ws-head{padding:12px 14px;border-bottom:1px solid var(--line);font-weight:800;font-size:13.5px;display:flex;align-items:center;justify-content:space-between;gap:8px;background:#fff;flex-shrink:0;min-height:46px}
.ws-head .sub{font-size:11px;color:var(--ink-3);font-weight:600}
.ws-body{flex:1;overflow-y:auto;padding:12px}
.ws-filter{padding:10px 12px;border-bottom:1px solid var(--line);background:#fff;display:flex;flex-direction:column;gap:8px}
.ws-filter .input{height:34px}
.ws-filter .fchips{gap:5px}
.ws-filter .fchip{padding:5px 10px;font-size:11.5px}
.ws-card{background:#fff;border:1px solid var(--line);border-radius:9px;padding:11px 12px;margin-bottom:8px;cursor:pointer;transition:.1s}
.ws-card:hover{border-color:var(--green)}
.ws-card.on{border-color:var(--green);box-shadow:0 0 0 2px rgba(43,58,46,.13)}
.ws-card .ct{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}
.ws-card .ct b{font-size:13px;font-weight:700;line-height:1.35}
.ws-card .cm{font-size:11.5px;color:var(--ink-3);margin-top:4px}
.ws-card.overdue{border-left:3px solid var(--danger)}
.ws-empty{padding:48px 20px;text-align:center;color:var(--ink-3);font-size:13px}
.ws-detail .ws-body .kv{padding:8px 0}
.ws-tabs{display:flex;border-bottom:1px solid var(--line);background:#fff}
.ws-tabs button{flex:1;border:0;background:none;padding:11px 4px;font-size:12.5px;font-weight:700;color:var(--ink-3);cursor:pointer;border-bottom:2px solid transparent}
.ws-tabs button.on{color:var(--green);border-bottom-color:var(--green)}
.ws-section{font-size:12px;font-weight:800;color:var(--ink-2);margin:16px 0 8px}
.ws-section:first-child{margin-top:0}
.overdue-badge{background:var(--danger-bg);color:var(--danger);font-weight:700;font-size:11.5px;padding:2px 9px;border-radius:999px}
/* 단계 진행 버튼 */
.stage-flow{display:flex;flex-direction:column;gap:6px}
.stage-flow button{display:flex;align-items:center;gap:9px;text-align:left;border:1.5px solid var(--line);background:#fff;border-radius:8px;padding:9px 12px;font-size:12.5px;font-weight:600;cursor:pointer;color:var(--ink-2)}
.stage-flow button .dot{width:9px;height:9px;border-radius:50%;background:var(--line);flex-shrink:0}
.stage-flow button.done{color:var(--green);border-color:var(--green-soft)}
.stage-flow button.done .dot{background:var(--green)}
.stage-flow button.cur{border-color:var(--green);background:var(--green-soft);color:var(--green)}
.stage-flow button.cur .dot{background:var(--gold)}
.stage-flow button.next:hover{border-color:var(--green);background:var(--green-soft)}
.stage-flow button:disabled{opacity:.45;cursor:not-allowed}
@media(max-width:1100px){
  .ws{height:auto;flex-direction:column}
  .ws-list,.ws-form{width:auto;border:0;border-bottom:1px solid var(--line)}
  .ws-resizer{display:none}
  .ws-list .ws-body{max-height:300px}
}

/* 진행 타임라인 (작업 콘솔 상세) */
.steps{position:relative;padding-left:6px}
.steps .step{position:relative;padding:0 0 14px 22px;border-left:2px solid var(--line)}
.steps .step:last-child{border-left-color:transparent;padding-bottom:0}
.steps .step::before{content:'';position:absolute;left:-6px;top:1px;width:11px;height:11px;border-radius:50%;background:#fff;border:2px solid var(--line)}
.steps .step.done::before{background:var(--green);border-color:var(--green)}
.steps .step.now::before{background:var(--gold);border-color:var(--gold);box-shadow:0 0 0 3px var(--gold-soft)}
.steps .step.now{border-left-color:var(--green)}
.steps .step .s-title{font-size:12.5px;font-weight:700}
.steps .step.muted .s-title{color:var(--ink-3);font-weight:600}

/* 캘린더 주/일/리스트 뷰 */
.cal2.v-week .cell{min-height:300px;align-items:stretch}
.cal2.v-day,.cal2.v-list{display:block}
.cal-dayhead{font-size:14px;font-weight:800;padding:6px 2px 12px;color:var(--green)}
.cal-evcard{display:flex;gap:10px;align-items:center;border:1px solid var(--line);border-left:4px solid var(--line);border-radius:8px;padding:11px 13px;margin-bottom:8px;cursor:pointer;background:#fff;transition:.1s}
.cal-evcard:hover{background:#FAFAF8;border-color:var(--green)}
.cal-evcard .ec-t{font-weight:700;font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.cal-evcard .ec-m{font-size:12px;color:var(--ink-3);margin-top:3px}
.cal-list-day{font-weight:800;font-size:13px;color:var(--green);margin:16px 0 8px;padding-bottom:5px;border-bottom:1px solid var(--line)}
.cal-empty{padding:44px 20px;text-align:center;color:var(--ink-3);font-size:13px}
@media(max-width:760px){.cal2.v-week{grid-template-columns:1fr}.cal2.v-week .cell{min-height:auto}.cal2.v-week .dow{display:none}}
