*{box-sizing:border-box;margin:0;padding:0}
body{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;background:#f8f8f6;color:#1a1a1a;font-size:14px}
.container{max-width:1100px;margin:0 auto;padding:24px}
.topbar{display:flex;align-items:center;gap:10px;margin-bottom:20px;flex-wrap:wrap}
.page-title{font-size:18px;font-weight:500}
.pilot-tag{font-size:11px;padding:2px 8px;border-radius:20px;background:#e6f1fb;color:#185fa5;font-weight:500}
.v-tag{font-size:11px;padding:2px 8px;border-radius:20px;background:#f2f2f0;color:#888;font-weight:400}
.filter-bar{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:20px;align-items:center}
select,input[type=text]{font-size:12px;padding:5px 9px;border-radius:7px;border:0.5px solid #ccc;background:#fff;color:#1a1a1a;cursor:pointer;outline:none}
.fdiv{width:1px;height:20px;background:#ddd;margin:0 2px}
.cal-wrap{position:relative;display:inline-block}
.date-btn{font-size:12px;padding:5px 10px;border-radius:7px;border:0.5px solid #ccc;background:#fff;cursor:pointer;display:flex;align-items:center;gap:5px}
.cal-popup{display:none;position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:0.5px solid #ccc;border-radius:10px;padding:14px;z-index:100;min-width:230px;box-shadow:0 4px 12px rgba(0,0,0,.1)}
.cal-popup.open{display:block}
.cal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.cal-nav{font-size:13px;padding:3px 9px;border:0.5px solid #ccc;border-radius:6px;background:none;cursor:pointer;color:#555}
.cal-month{font-size:13px;font-weight:500}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;text-align:center}
.cal-dow{font-size:10px;color:#999;padding:3px 0}
.cal-day{font-size:12px;padding:5px 2px;border-radius:6px;cursor:pointer;color:#1a1a1a}
.cal-day:hover{background:#f2f2f2}
.cal-day.sel{background:#1a1a1a;color:#fff;font-weight:500}
.cal-day.in-range{background:#e6f1fb;color:#185fa5}
.cal-day.empty{cursor:default}
.cal-footer{margin-top:10px;display:flex;justify-content:flex-end;gap:6px}
.cal-apply{font-size:12px;padding:4px 12px;border-radius:6px;border:1px solid #1a1a1a;background:#1a1a1a;color:#fff;cursor:pointer}
.cal-clear{font-size:12px;padding:4px 10px;border-radius:6px;border:0.5px solid #ccc;background:none;cursor:pointer;color:#555}
.main-tabs{display:flex;border-bottom:1px solid #e0e0e0;margin-bottom:24px}
.main-tab{font-size:13px;padding:9px 20px;cursor:pointer;color:#888;border-bottom:2px solid transparent;background:none;border-top:none;border-left:none;border-right:none;transition:all .15s;white-space:nowrap}
.main-tab.active{color:#1a1a1a;font-weight:500;border-bottom:2px solid #1a1a1a}
.main-tab:hover:not(.active){color:#1a1a1a}
.tab-content{display:none}
.tab-content.active{display:block}
.kpi-row{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:20px}
.kpi{background:#f2f2f0;border-radius:8px;padding:14px 16px}
.kpi-label{font-size:11px;color:#888;margin-bottom:6px}
.kpi-val{font-size:22px;font-weight:500;line-height:1}
.kpi-val-dual{font-size:16px;font-weight:500;line-height:1.3}
.kpi-sub{font-size:11px;margin-top:4px;color:#888}
.kpi-sub.danger{color:#a32d2d}
.kpi-sub.success{color:#3b6d11}
.stabs{display:flex;gap:5px;margin-bottom:14px;flex-wrap:wrap}
.stab{font-size:12px;padding:4px 13px;border-radius:20px;border:0.5px solid #ccc;background:#fff;color:#888;cursor:pointer;transition:all .12s}
.stab.active{background:#1a1a1a;color:#fff;border-color:#1a1a1a}
.stab .cnt{font-size:10px;margin-left:3px;opacity:.7}
.period-tabs{display:flex;gap:5px;margin-bottom:20px;flex-wrap:wrap}
.ptab{font-size:12px;padding:5px 14px;border-radius:20px;border:0.5px solid #ccc;background:#fff;color:#888;cursor:pointer}
.ptab.active{background:#1a1a1a;color:#fff;border-color:#1a1a1a}
.alarm-list{display:flex;flex-direction:column;gap:10px}
.alarm-card{background:#fff;border:0.5px solid #e0e0e0;border-radius:12px;padding:14px 16px;transition:border-color .15s}
.alarm-card:hover{border-color:#bbb}
.alarm-card.red{border-left:3px solid #e24b4a}
.alarm-card.yellow{border-left:3px solid #ef9f27}
.alarm-top{display:flex;align-items:flex-start;gap:12px}
.alarm-left{display:flex;flex-direction:column;gap:7px;align-items:center;flex-shrink:0;min-width:46px}
.badge{font-size:10px;font-weight:500;padding:2px 8px;border-radius:20px;white-space:nowrap}
.badge.red{background:#fcebeb;color:#a32d2d}
.badge.yellow{background:#faeeda;color:#854f0b}
.badge.done{background:#eaf3de;color:#3b6d11}
.badge.wip{background:#e6f1fb;color:#185fa5}
.badge.next{background:#f2f2f0;color:#595959}
.badge.safe{background:#f2f2f0;color:#999}
.badge.plan{background:#f3e8ff;color:#6b21a8}
.badge.pending{background:#f2f2f0;color:#bbb}
.score-box{display:flex;flex-direction:column;align-items:center;background:#f2f2f0;border-radius:7px;padding:6px 7px;width:46px;gap:1px}
.score-label{font-size:9px;color:#999}
.score-val{font-size:14px;font-weight:500;line-height:1.1}
.score-val.high{color:#3b6d11}
.score-val.mid{color:#854f0b}
.score-val.low{color:#a32d2d}
.score-divider{width:100%;height:0.5px;background:#ddd;margin:3px 0}
.sent-row{display:flex;justify-content:center;gap:2px}
.sent-dot{display:inline-block;width:5px;height:5px;border-radius:50%;background:#e4e4e1}
.sent-dot.lv2{background:#ef9f27}
.sent-dot.lv3{background:#e07530}
.sent-dot.lv4{background:#e24b4a}
.sent-val{font-size:8px;color:#bbb;margin-top:1px}
.sla-chip{font-size:10px;padding:1px 7px;border-radius:20px;white-space:nowrap;font-weight:500}
.sla-over{background:#fcebeb;color:#a32d2d}
.sla-warn{background:#faeeda;color:#854f0b}
.sla-ok{background:#eaf3de;color:#3b6d11}
.return-tags{display:flex;align-items:center;gap:5px;margin-top:5px;flex-wrap:wrap}
.return-label{font-size:10px;color:#c0bfbb;flex-shrink:0}
.rtag{font-size:10px;padding:1px 8px;border-radius:20px;background:#f2f2f0;color:#595959;border:0.5px solid #e4e4e1}
.alarm-body{flex:1;min-width:0}
.alarm-style{font-size:13px;font-weight:500;color:#1a1a1a}
.alarm-desc{font-size:12px;color:#595959;margin-top:3px;line-height:1.6}
.alarm-meta{font-size:11px;color:#999;margin-top:6px;display:flex;gap:6px;flex-wrap:wrap;align-items:center}
.chip{display:inline-flex;align-items:center;gap:3px;background:#f2f2f0;border-radius:20px;padding:2px 8px;font-size:11px;color:#595959}
.chip .dept{color:#999;font-size:10px}
.alarm-actions{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:0.5px solid #eee}
.act-btn{font-size:11px;padding:5px 11px;border-radius:7px;border:0.5px solid #ccc;background:#fff;color:#595959;cursor:pointer;transition:all .12s}
.act-btn:hover{background:#f2f2f0}
.act-btn.green{border-color:#3b6d11;color:#3b6d11}
.act-btn.green:hover{background:#eaf3de}
.act-btn.purple{border-color:#6b21a8;color:#6b21a8}
.act-btn.purple:hover{background:#f3e8ff}
.act-btn.ai{border-color:#185fa5;color:#185fa5;font-weight:500}
.act-btn.ai:hover{background:#e6f1fb}
.act-btn.ai:disabled{opacity:.5;cursor:not-allowed}
.memo-panel{margin-top:12px;padding:12px;background:#f8f8f6;border-radius:9px;display:none;flex-direction:column;gap:9px}
.memo-panel.open{display:flex}
.type-row{display:flex;gap:5px;flex-wrap:wrap}
.mtype{font-size:11px;padding:3px 10px;border-radius:20px;border:0.5px solid #ccc;background:#fff;color:#595959;cursor:pointer}
.mtype.sel{background:#1a1a1a;color:#fff;border-color:#1a1a1a}
.memo-ta{font-size:12px;padding:8px 10px;border-radius:7px;border:0.5px solid #ccc;background:#fff;color:#1a1a1a;resize:none;width:100%;line-height:1.5;font-family:inherit}
.memo-ta::placeholder{color:#bbb}
.memo-save{font-size:12px;padding:6px 14px;border-radius:7px;border:1px solid #3b6d11;background:none;color:#3b6d11;cursor:pointer;font-weight:500;align-self:flex-end}
.memo-save:hover{background:#eaf3de}
.done-record{margin-top:12px;padding:10px 12px;background:#f8f8f6;border-radius:9px;font-size:12px}
.card{background:#fff;border:0.5px solid #e0e0e0;border-radius:12px;padding:16px 18px}
.slabel{font-size:11px;font-weight:500;color:#888;text-transform:uppercase;letter-spacing:.05em;margin-bottom:12px}
.sc{background:#fff;border:0.5px solid #e0e0e0;border-radius:12px;padding:14px 16px;margin-bottom:10px}
.sc-cat{font-size:12px;font-weight:500;color:#1a1a1a;margin-bottom:7px;display:flex;align-items:center;gap:7px}
.sc-item{font-size:12px;color:#595959;padding:3px 0;display:flex;gap:7px}
.sc-item::before{content:"-->";color:#bbb;flex-shrink:0}
.ai-result-wrap{margin-top:14px;border-top:0.5px solid #eee;padding-top:14px}
.ai-sec{margin-bottom:16px;padding-bottom:16px;border-bottom:0.5px solid #f0f0f0}
.ai-sec:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.ai-sec-title{font-size:11px;font-weight:600;color:#888;text-transform:uppercase;letter-spacing:.5px;padding:4px 10px;background:#f0f1f5;border-radius:6px;display:inline-block;margin-bottom:8px}
.ai-hl{background:#fff8e1;border-left:3px solid #f9a825;padding:10px 14px;border-radius:0 8px 8px 0;font-size:13px;line-height:1.7;font-weight:500}
.ai-box{background:#fafafa;border:0.5px solid #e8e8e8;padding:12px 14px;border-radius:8px;font-size:13px;line-height:1.7;white-space:pre-wrap}
.ai-qt{background:#f3e5f5;border-left:3px solid #9c27b0;padding:8px 12px;border-radius:0 8px 8px 0;font-size:12px;font-style:italic;color:#4a148c;margin-top:6px}
.act-row{display:flex;gap:8px;align-items:center;padding:7px 0;border-bottom:0.5px solid #f0f0f0;font-size:12px}
.act-row:last-child{border-bottom:none}
.act-cat{font-size:10px;font-weight:500;background:#e3f2fd;color:#1565c0;padding:2px 8px;border-radius:20px;min-width:52px;text-align:center;flex-shrink:0}
.act-txt{flex:1;color:#1a1a1a}
.act-dept{color:#888;font-size:11px;flex-shrink:0}
.mi-card{background:#fff;border:0.5px solid #e0e0e0;border-radius:12px;padding:16px 18px;margin-bottom:12px}
.mi-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:12px;flex-wrap:wrap;gap:8px}
.mi-name{font-size:14px;font-weight:500;color:#1a1a1a}
.mi-meta{font-size:11px;color:#888;margin-top:3px}
.sc-grp{display:flex;gap:8px;align-items:center;flex-shrink:0}
.sc-chip{text-align:center;background:#f2f2f0;border-radius:8px;padding:6px 12px;min-width:60px}
.sc-chip .val{font-size:16px;font-weight:500;color:#1a1a1a}
.sc-chip .lbl{font-size:10px;color:#888;margin-top:1px}
.sc-chip .diff{font-size:11px;margin-top:2px}
.sc-chip .diff.up{color:#a32d2d}
.sc-chip .diff.dn{color:#3b6d11}
.kpi-mini{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.mkpi{background:#f8f8f6;border-radius:7px;padding:8px 10px}
.mkpi .lbl{font-size:10px;color:#888;margin-bottom:3px}
.mkpi .val{font-size:13px;font-weight:500;color:#1a1a1a}
.mkpi .val.danger{color:#a32d2d}
.mkpi .val.success{color:#3b6d11}
.mai-sec{margin-bottom:14px;padding-bottom:14px;border-bottom:0.5px solid #f0f0f0}
.mai-sec:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}
.mai-tag{font-size:10px;font-weight:600;padding:2px 9px;border-radius:20px;display:inline-block;margin-bottom:6px}
.t-yoy{background:#e6f1fb;color:#185fa5}
.t-rep{background:#faeeda;color:#854f0b}
.t-plan{background:#eaf3de;color:#3b6d11}
.t-act{background:#fce8e6;color:#a32d2d}
.t-keep{background:#f3e8ff;color:#6b21a8}
.mai-txt{font-size:13px;color:#595959;line-height:1.8;white-space:pre-wrap}
.mi-btns{display:flex;gap:6px;flex-wrap:wrap;margin-top:12px;padding-top:12px;border-top:0.5px solid #eee}
.pend-card{background:#fff;border:0.5px solid #e8e8e8;border-radius:12px;padding:14px 18px;margin-bottom:12px;opacity:.55}
.pend-inner{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:8px}
.pend-name{font-size:14px;font-weight:500;color:#1a1a1a}
.pend-meta{font-size:11px;color:#888;margin-top:3px}
/* 주간 탭 전용 */
.wk-search-bar{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.wk-search-bar input{width:200px;font-size:13px;padding:7px 12px;border-radius:8px;border:1px solid #ccc}
.wk-search-bar input:focus{border-color:#185fa5;outline:none}
.search-btn{font-size:12px;padding:7px 14px;border-radius:8px;border:1px solid #1a1a1a;background:#1a1a1a;color:#fff;cursor:pointer}
.search-btn:hover{background:#333}
.clear-btn{font-size:12px;padding:7px 12px;border-radius:8px;border:0.5px solid #ccc;background:#fff;color:#595959;cursor:pointer}
.result-info{font-size:12px;color:#888;margin-bottom:12px}
.wk-card{background:#fff;border:0.5px solid #e0e0e0;border-radius:12px;padding:14px 16px;margin-bottom:10px;transition:border-color .15s}
.wk-card:hover{border-color:#bbb}
.wk-card-hdr{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.wk-code{font-size:13px;font-weight:500;color:#1a1a1a}
.wk-item{font-size:11px;color:#888;margin-top:2px}
.wk-scores{display:flex;gap:8px;align-items:center;flex-wrap:wrap;flex-shrink:0}
.voc-chip{text-align:center;background:#f2f2f0;border-radius:7px;padding:5px 10px;min-width:54px}
.voc-chip .v{font-size:15px;font-weight:500}
.voc-chip .l{font-size:10px;color:#888;margin-top:1px}
.wk-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px}
.wk-stat{background:#f8f8f6;border-radius:6px;padding:6px 8px}
.wk-stat .l{font-size:10px;color:#aaa;margin-bottom:2px}
.wk-stat .v{font-size:12px;font-weight:500;color:#1a1a1a}
.neg-reviews{margin-top:8px;border-top:0.5px solid #f0f0f0;padding-top:10px}
.neg-cat-row{display:flex;gap:8px;margin-bottom:6px;align-items:flex-start}
.neg-cat-badge{font-size:10px;font-weight:500;padding:1px 8px;border-radius:20px;background:#fcebeb;color:#a32d2d;flex-shrink:0;margin-top:2px}
.neg-summ{font-size:11px;color:#595959;flex:1}
.neg-score-tiny{font-size:10px;color:#aaa;flex-shrink:0}
.ai-loading{display:flex;align-items:center;gap:8px;color:#185fa5;font-size:12px;padding:10px 0}
.ai-loading-dot{width:5px;height:5px;border-radius:50%;background:#185fa5;animation:pulse .8s ease-in-out infinite}
.ai-loading-dot:nth-child(2){animation-delay:.15s}
.ai-loading-dot:nth-child(3){animation-delay:.3s}
@keyframes pulse{0%,100%{opacity:.3;transform:scale(.8)}50%{opacity:1;transform:scale(1.2)}}
/* 월간 탭 전용 */
.mo-search-row{display:flex;gap:8px;margin-bottom:16px;align-items:center;flex-wrap:wrap}
.mo-search-row select{font-size:13px;padding:7px 12px;border-radius:8px;min-width:160px}
.mo-empty{text-align:center;padding:40px 0;color:#aaa;font-size:13px}
/* 시즌 탭 공통 */
.season-sub{display:none}
.season-sub.active{display:block}
