*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --navy:#1e3a6e;--navy-dark:#243872;--navy-mid:#2a4282;--navy-light:#3350a0;
  --sky:#29abe2;--sky-light:#4dbee8;--sky-pale:#e6f7fd;
  --white:#fff;--bg:#f3f4f7;--surface:#fff;--surface2:#f3f4f7;
  --border:#dde1ea;--border-light:#e8ebf2;
  --text:#1a2038;--text-mid:#3d4870;--text-muted:#6b748f;--text-hint:#9ba3be;
  --accent:#29abe2;--accent-hover:#1d90c4;--accent-light:#e6f7fd;
  --danger:#e03c3c;--danger-light:#fdf0f0;
  --success:#1a9e5c;--success-light:#edf8f3;
  --warning:#e07c1a;--warning-light:#fdf4e8;
  --info:#534ab7;--info-light:#eeedfe;
  --topbar-h:58px;--tabbar-h:0px;--subnav-w:280px;
  --radius:6px;--radius-lg:8px;--radius-sm:4px;
  --shadow:0 1px 2px rgba(26,36,86,.05);
  --shadow-md:0 4px 12px rgba(26,36,86,.08);--shadow-lg:0 10px 28px rgba(26,36,86,.12);
}

[data-theme="dark"]{
  /* 배경용 네이비: 다크 톤으로 낮춤 (히어로·탑바·헤더 눈부심 제거) */
  --navy:#1b2a47;--navy-dark:#16223a;--navy-mid:#243758;--navy-light:#324d7d;
  /* 글자용 네이비: 어두운 배경에서 읽히도록 밝게 */
  --navy-text:#92a9d6;
  /* 토스 스타일: 저채도 네이비-차콜, 한 단계 더 깊게 */
  --bg:#0d1119;--surface:#161c28;--surface2:#1d2433;--surface3:#232b3c;
  --border:#262f40;--border-light:#1f2736;
  --text:#e6eaf2;--text-mid:#aab3c5;--text-muted:#79859c;--text-hint:#586074;
  --accent:#3d9bf0;--accent-hover:#2f87d6;
  --sky-pale:#15293f;
  --accent-light:#16304a;
  --danger-light:#3a1f22;--success-light:#16302a;--warning-light:#33291a;--info-light:#222145;
  --shadow:0 1px 3px rgba(0,0,0,.35);
  --shadow-md:0 6px 20px rgba(0,0,0,.45);--shadow-lg:0 12px 32px rgba(0,0,0,.55);
}
/* 다크모드 — 네이비 글자색 보정 (인라인 style 포함) */
[data-theme="dark"] [style*="color:var(--navy)"]{color:var(--navy-text)!important}
[data-theme="dark"] .tooltip-box b,[data-theme="dark"] .tooltip-box li span,
[data-theme="dark"] .login-logo-name,[data-theme="dark"] .project-title,
[data-theme="dark"] .dash-stat-val,[data-theme="dark"] .dash-prep-date{color:var(--navy-text)}
[data-theme="dark"] .b-navy{background:rgba(146,169,214,.14);color:var(--navy-text)}
/* 다크모드 — 좌측 사이드바·탑바·드롭다운 (네이비 대신 다크 표면) */
[data-theme="dark"] .topbar{background:#11161f;box-shadow:0 2px 8px rgba(0,0,0,.4)}
[data-theme="dark"] .subnav{background:#11161f}
[data-theme="dark"] .top-dropdown{background:#1d2433}
/* 다크모드 — 하드코딩된 밝은 배경 보정 */
[data-theme="dark"] .main-ai-input-area,
[data-theme="dark"] .ai-input-area,
[data-theme="dark"] .login-field input{background:var(--surface2)}
[data-theme="dark"] .tab-item:hover{background:var(--surface2)}
[data-theme="dark"] .tab-item.active{background:var(--accent-light)}
[data-theme="dark"] .cal-cell.selected{background:var(--accent-light)}
/* ── 토스 톤 다크 조합 정리 (입력창·버튼·비전·캘린더 통일) ── */
[data-theme="dark"] .dash-vision{background:linear-gradient(105deg,#141f33,#1b2a47 60%,#152134);border:1px solid #26385a}
[data-theme="dark"] .dash-kpi-card{background:rgba(8,13,22,.5);border-color:#2a3f60}
[data-theme="dark"] .dash-stat-card{background:var(--surface2);border-color:var(--border)}
/* 입력창: 흰 배경 → 어두운 표면 */
[data-theme="dark"] .fi,
[data-theme="dark"] input:not([type=checkbox]):not([type=radio]):not([type=range]):not([type=color]),
[data-theme="dark"] select,
[data-theme="dark"] textarea{background:var(--surface2);border-color:var(--border);color:var(--text)}
[data-theme="dark"] .fi::placeholder,
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder{color:var(--text-hint)}
/* 버튼: 다크에서 hover는 더 밝게 (기존엔 거꾸로 어두워짐) */
[data-theme="dark"] .btn:hover{background:var(--surface3);border-color:#33405a}
/* 캘린더: 셀·주말색·태스크점을 다크 톤으로 */
[data-theme="dark"] .cal-cell{background:var(--surface);border-color:var(--border-light)}
[data-theme="dark"] .cal-cell:hover{background:var(--surface3);border-color:var(--accent)}
[data-theme="dark"] .cal-cell.today{background:var(--accent-light);border-color:var(--accent)}
[data-theme="dark"] .cal-cell.selected{background:#1c2c46;border-color:var(--accent)}
[data-theme="dark"] .cal-date.sun{color:#ef7a7a}
[data-theme="dark"] .cal-date.sat{color:#7fb0ee}
[data-theme="dark"] .cal-dot.priority-긴급{background:#3a1f22;color:#f0928f}
[data-theme="dark"] .cal-dot.priority-높음{background:#352713;color:#e3a866}
[data-theme="dark"] .cal-dot.priority-보통{background:#15273f;color:#7fb0ee}
[data-theme="dark"] .cal-dot.priority-낮음{background:#222b3c;color:#9aa4ba}
[data-theme="dark"] .cal-dot.repeat{background:#13301f;color:#73d39e}
[data-theme="dark"] .table-footer{background:var(--surface2)}
/* 다크모드 — JS가 인라인으로 찍는 파스텔 뱃지/라벨/막대 전역 보정 */
[data-theme="dark"] [style*="background:#fee2e2"]{background:#3a1f22!important;color:#f09a9a!important}
[data-theme="dark"] [style*="background:#ffedd5"]{background:#33291a!important;color:#e6ad6a!important}
[data-theme="dark"] [style*="background:#fef3c7"]{background:#332a10!important;color:#e0c068!important}
[data-theme="dark"] [style*="background:#fef9c3"]{background:#332a10!important;color:#e0c068!important}
[data-theme="dark"] [style*="background:#dcfce7"]{background:#14301f!important;color:#7fd6a8!important}
[data-theme="dark"] [style*="background:#f0fdf4"]{background:#14301f!important;color:#7fd6a8!important}
[data-theme="dark"] [style*="background:#e0f2fe"]{background:#10314a!important;color:#7fc4f0!important}
[data-theme="dark"] [style*="background:#dbeafe"]{background:#15293f!important;color:#8fb6e8!important}
[data-theme="dark"] [style*="background:#f0f7ff"]{background:#15293f!important;color:#8fb6e8!important}
[data-theme="dark"] [style*="background:#f1f5f9"]{background:#222b3c!important;color:#aeb6ca!important}
[data-theme="dark"] [style*="background:#f3f4f6"]{background:#222b3c!important;color:#aeb6ca!important}
[data-theme="dark"] #fb-code-suggest-box{background:#16263a!important;border-color:#2b3447!important}
/* 다크모드 — 상태 뱃지 (밝은 파스텔 → 어두운 톤) */
[data-theme="dark"] .proj-status-신청{background:#10314a;color:#7fc4f0}
[data-theme="dark"] .proj-status-진행중{background:#103024;color:#7fd6a8}
[data-theme="dark"] .proj-status-점검{background:#332a10;color:#e0c068}
[data-theme="dark"] .proj-status-완료{background:#222b3c;color:#aeb6ca}
[data-theme="dark"] .proj-status-중단{background:#3a1f22;color:#f09a9a}
[data-theme="dark"] .proj-status-보류{background:#262b36;color:#9ba3be}
[data-theme="dark"] .issue-score-high{background:#3a1f22;color:#f09a9a}
[data-theme="dark"] .issue-score-mid{background:#332a10;color:#e0c068}
[data-theme="dark"] .issue-score-low{background:#103024;color:#7fd6a8}
html,body{overflow-x:hidden}body{font-family:'Noto Sans KR',sans-serif;background:var(--bg);color:var(--text);font-size:13px;line-height:1.5;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}


/* ── 메인 페이지 ── */
.main-hero{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);border-radius:var(--radius-lg);padding:28px 32px;margin-bottom:20px;display:flex;align-items:center;justify-content:space-between;gap:16px}
.main-hero-left h2{font-size:20px;font-weight:700;color:#fff;letter-spacing:-.5px;margin-bottom:6px}
.main-hero-left p{font-size:13px;color:rgba(255,255,255,.6);line-height:1.6}
.main-hero-right{display:flex;align-items:center;gap:8px;flex-shrink:0}
.hero-stat{text-align:center;background:rgba(255,255,255,.1);border-radius:var(--radius);padding:10px 18px;min-width:80px}
.hero-stat-val{font-size:22px;font-weight:700;color:#fff;line-height:1}
.hero-stat-label{font-size:10px;color:rgba(255,255,255,.55);margin-top:3px;letter-spacing:.3px}
.main-grid{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:14px;margin-bottom:20px}
.main-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow);cursor:pointer;transition:all .2s}
.main-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:var(--accent)}
.main-card-icon{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-size:18px;margin-bottom:10px}
.mc-blue{background:var(--sky-pale)}.mc-green{background:var(--success-light)}.mc-amber{background:var(--warning-light)}.mc-navy{background:rgba(26,36,86,.08)}
.main-card-title{font-size:13px;font-weight:600;color:var(--text);margin-bottom:3px}
.main-card-desc{font-size:11.5px;color:var(--text-muted);line-height:1.5}
.main-card-count{font-size:22px;font-weight:700;color:var(--accent);margin-top:6px}
.main-row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:20px}
.main-section-title{font-size:12px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px;display:flex;align-items:center;justify-content:space-between}
.main-section-title a{font-size:11px;color:var(--accent);cursor:pointer;font-weight:500;text-transform:none;letter-spacing:0}
.main-section-title a:hover{text-decoration:underline}
.recent-table{width:100%;border-collapse:collapse}
.recent-table th{font-size:10.5px;font-weight:700;color:var(--text-hint);text-transform:uppercase;padding:6px 10px;border-bottom:1px solid var(--border);text-align:left}
.recent-table td{padding:8px 10px;border-bottom:1px solid var(--border-light);font-size:12.5px}
.recent-table tr:last-child td{border-bottom:none}
.recent-table tr:hover td{background:var(--sky-pale)}
/* AI 대화창 */
.main-ai-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;height:420px}
.main-ai-head{padding:14px 18px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;align-items:center;gap:8px}
.main-ai-head-title{font-size:14px;font-weight:700;color:#fff}
.main-ai-pdot{width:7px;height:7px;border-radius:50%;background:var(--sky-light);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
.main-ai-msgs{flex:1;overflow-y:auto;padding:14px;display:flex;flex-direction:column;gap:10px}
.main-ai-input-area{padding:10px 12px;border-top:1px solid var(--border);background:#fafbfd;border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.main-ai-input-wrap{display:flex;align-items:flex-end;gap:7px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:7px 10px;transition:all .15s}
.main-ai-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(41,171,226,.1)}
.main-ai-textarea{flex:1;border:none;outline:none;resize:none;font-size:13px;font-family:inherit;color:var(--text);background:transparent;min-height:20px;max-height:80px;line-height:1.5}
.main-ai-send{width:32px;height:32px;border-radius:8px;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;flex-shrink:0}
.main-ai-send:hover{background:var(--accent-hover)}
.main-ai-note{font-size:10px;color:var(--text-hint);text-align:center;margin-top:5px}
.quick-btns{display:flex;gap:6px;flex-wrap:wrap;padding:8px 14px;border-bottom:1px solid var(--border-light)}
.quick-btn{padding:4px 10px;border-radius:20px;border:1px solid var(--border);background:var(--bg);font-size:11.5px;color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:inherit}
.quick-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--sky-pale)}


/* ── 품목 등록 전용 스타일 ── */
.tooltip-wrap{position:relative;display:inline-flex;align-items:center;}
.tooltip-icon{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;background:transparent;border:1.5px solid #5b8dee;cursor:pointer;margin-left:5px;flex-shrink:0;line-height:1;}
.tooltip-box{display:none;position:absolute;top:calc(100% + 6px);left:0;width:429px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:0 4px 16px rgba(26,36,86,.15);padding:12px 14px;z-index:999;font-size:12px;line-height:1.7;color:var(--text);}
.tooltip-box::before{content:'';position:absolute;top:-6px;left:14px;width:10px;height:6px;background:var(--surface);clip-path:polygon(50% 0%,0% 100%,100% 100%);}
.tooltip-wrap:hover .tooltip-box{display:block;}
.tooltip-box b{display:block;font-size:12.5px;font-weight:700;color:var(--navy);margin-bottom:6px;}
.tooltip-box li{list-style:none;padding:1px 0;color:var(--text-muted);}
.tooltip-box li span{color:var(--navy);font-weight:600;}
.pw-resize{position:absolute;z-index:10;background:transparent;}
.pw-resize-n{top:0;left:8px;right:8px;height:5px;cursor:ns-resize;}
.pw-resize-s{bottom:0;left:8px;right:8px;height:5px;cursor:ns-resize;}
.pw-resize-w{left:0;top:8px;bottom:8px;width:5px;cursor:ew-resize;}
.pw-resize-e{right:0;top:8px;bottom:8px;width:5px;cursor:ew-resize;}
.pw-resize-nw{top:0;left:0;width:8px;height:8px;cursor:nw-resize;}
.pw-resize-ne{top:0;right:0;width:8px;height:8px;cursor:ne-resize;}
.pw-resize-sw{bottom:0;left:0;width:8px;height:8px;cursor:sw-resize;}
.pw-resize-se{bottom:0;right:0;width:8px;height:8px;cursor:se-resize;}
.pw-resize:hover{background:rgba(41,171,226,.2);}
.item-section-title{font-size:11px;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.5px;padding:7px 12px;background:var(--navy-mid);border-radius:var(--radius);margin-bottom:10px;display:flex;align-items:center;gap:6px}
.item-tab-wrap{display:flex;gap:0;margin-bottom:18px;border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}
.item-tab{flex:1;padding:10px;text-align:center;font-size:13px;font-weight:600;cursor:pointer;background:var(--bg);color:var(--text-muted);transition:all .15s;border:none}
.item-tab.active{background:var(--navy);color:#fff}
.item-tab:hover:not(.active){background:var(--border)}
.fg5{grid-template-columns:1fr 1fr 1fr 1fr 1fr}
.fg6{grid-template-columns:1fr 1fr 1fr 1fr 1fr 1fr}
.partner-search-wrap{display:flex;gap:6px;align-items:center}
.partner-search-wrap input{flex:1}
.item-list-table{width:100%}

/* ── 페이지 내 AI 대화창 ── */
.page-ai-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;flex-direction:column;height:280px;margin-top:20px}
.page-ai-head{padding:10px 16px;border-bottom:1px solid var(--border);background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0;display:flex;align-items:center;gap:7px}
.page-ai-head-title{font-size:13px;font-weight:600;color:#fff}
.page-ai-pdot{width:6px;height:6px;border-radius:50%;background:var(--sky-light);animation:pulse 2s ease-in-out infinite}
.page-ai-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.page-ai-input-area{padding:8px 10px;border-top:1px solid var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg)}
.page-ai-input-wrap{display:flex;align-items:center;gap:6px;background:var(--bg);border:1.5px solid var(--border);border-radius:8px;padding:6px 10px;transition:all .15s}
.page-ai-input-wrap:focus-within{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px rgba(41,171,226,.1)}
.page-ai-input{flex:1;border:none;outline:none;font-size:13px;font-family:inherit;color:var(--text);background:transparent}
.page-ai-send{width:28px;height:28px;border-radius:6px;border:none;background:var(--accent);color:#fff;cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.page-ai-send:hover{background:var(--accent-hover)}


/* ── 탑바 드롭다운 ── */
.top-menu{position:relative}
.top-dropdown{display:none;position:absolute;top:100%;left:0;background:#111a3e;border:1px solid rgba(255,255,255,.12);border-radius:0 0 6px 6px;z-index:200;box-shadow:0 6px 20px rgba(0,0,0,.3);padding:4px 0;white-space:nowrap;flex-direction:row;}
.top-menu:hover .top-dropdown{display:flex}
.top-dropdown:hover{display:flex}
.top-dd-item{display:block;padding:9px 20px;font-size:13px;color:rgba(255,255,255,.75);cursor:pointer;transition:all .15s;border-right:1px solid rgba(255,255,255,.08);user-select:none;}
.top-dd-item:last-child{border-right:none}
.top-dd-item:hover{background:rgba(255,255,255,.1);color:#fff}
/* ── 서브탭 ── */
.subtabbar{background:var(--surface);border-bottom:2px solid var(--border);display:flex;align-items:center;padding:0 16px;height:30px;position:sticky;top:var(--topbar-h);z-index:39;box-shadow:0 1px 4px rgba(0,0,0,.06)}
.subtabbar.hidden{display:none}
.subtab{padding:0 16px;height:100%;display:flex;align-items:center;font-size:13px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap}
.subtab:hover{color:var(--text)}
.subtab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}

/* ── 로그인 ── */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--navy-dark) 0%,var(--navy-mid) 100%)}
.login-box{background:var(--surface);border-radius:16px;padding:40px;width:380px;box-shadow:0 20px 60px rgba(0,0,0,.25)}
.login-logo{text-align:center;margin-bottom:28px}
.login-logo img{height:64px;margin-bottom:10px}
.login-logo-name{font-size:18px;font-weight:700;color:var(--navy);letter-spacing:-.5px}
.login-logo-sub{font-size:12px;color:var(--text-hint);margin-top:3px}
.login-field{margin-bottom:14px}
.login-field label{display:block;font-size:12px;font-weight:600;color:var(--text-muted);margin-bottom:5px}
.login-field input{width:100%;padding:10px 13px;border:1.5px solid var(--border);border-radius:var(--radius);font-size:13px;font-family:inherit;color:var(--text);background:#fafbfd;outline:none;transition:all .15s}
.login-field input:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px rgba(41,171,226,.12)}
.login-btn{width:100%;padding:11px;background:var(--navy);color:#fff;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;font-family:inherit;margin-top:6px;transition:all .15s}
.login-btn:hover{background:var(--navy-mid)}
.login-error{color:var(--danger);font-size:12px;margin-top:8px;text-align:center;min-height:18px}

/* ── 탑바 ── */
.topbar{position:fixed;top:0;left:0;right:0;height:var(--topbar-h);background:var(--navy);z-index:100;display:flex;align-items:center;box-shadow:0 2px 8px rgba(0,0,0,.2)}
.topbar-logo{width:236px;flex-shrink:0;display:flex;align-items:center;gap:8px;padding:0 14px;height:100%;overflow:hidden}
.logo-img{height:30px;width:30px;object-fit:contain;border-radius:5px;flex-shrink:0}
.logo-text{display:flex;flex-direction:column;line-height:1.2}
.logo-name{font-size:14px;font-weight:700;color:#fff;letter-spacing:-.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.logo-sub{font-size:11px;color:rgba(255,255,255,.6);letter-spacing:.2px;white-space:nowrap}
.topbar-nav{display:flex;align-items:stretch;height:100%;flex:1;padding:0 8px}
.top-menu{display:flex;align-items:center;justify-content:center;padding:0 14px;font-size:12.5px;font-weight:500;color:rgba(255,255,255,.85);cursor:pointer;transition:all .15s;border-bottom:2px solid transparent;white-space:nowrap}
.top-menu:hover{color:#fff;background:rgba(255,255,255,.06)}
.top-menu.active{color:#fff;border-bottom-color:var(--sky);background:rgba(255,255,255,.05)}
.topbar-right{display:flex;align-items:center;gap:4px;padding:0 14px;border-left:1px solid rgba(255,255,255,.1);height:100%}
.top-icon-btn{width:32px;height:32px;border-radius:var(--radius);border:none;background:rgba(255,255,255,.1);color:rgba(255,255,255,.85);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .15s}
.top-icon-btn:hover{background:rgba(255,255,255,.15);color:#fff}
.user-chip{display:flex;align-items:center;gap:7px;padding:4px 10px 4px 6px;border-radius:20px;background:rgba(255,255,255,.1);cursor:pointer;transition:all .15s;margin-left:4px}
.user-chip:hover{background:rgba(255,255,255,.16)}
.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--sky);display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;flex-shrink:0}
.user-chip-name{font-size:12px;font-weight:500;color:rgba(255,255,255,.9)}
.user-chip-role{font-size:10px;color:rgba(255,255,255,.65)}

/* ── 레이아웃 ── */
.layout{display:flex;padding-top:var(--topbar-h);min-height:100vh;align-items:flex-start;overflow-x:hidden;max-width:100vw}

/* ── 사이드바 ── */
.subnav{width:var(--subnav-w);flex-shrink:0;background:#243872;min-height:calc(100vh - var(--topbar-h));position:fixed;top:var(--topbar-h);left:0;bottom:0;overflow-y:auto;overflow-x:hidden;z-index:50;display:flex;flex-direction:column;transition:width .25s ease,background .2s}
.subnav.collapsed{width:0;overflow:hidden}
/* 사이드바 열고 닫을 때 내용물이 재배치(줄었다 늘었다)되지 않게 너비 고정 → 클리핑만 됨 */
.subnav>*{width:var(--subnav-w);box-sizing:border-box;flex-shrink:0}
.main{transition:margin-left .25s ease}
.subnav-section{padding:14px 0 6px}
.subnav-label{font-size:10px;font-weight:700;letter-spacing:.8px;color:rgba(255,255,255,.28);text-transform:uppercase;padding:0 16px;margin-bottom:3px}
.subnav-item{display:flex;align-items:center;gap:8px;padding:8px 18px;font-size:14px;color:rgba(255,255,255,.82);cursor:pointer;transition:all .15s;border-left:3px solid transparent}
.subnav-item:hover{color:#fff;background:rgba(255,255,255,.08)}
.subnav-item.active{color:#fff;background:rgba(41,171,226,.16);border-left-color:var(--sky);font-weight:500}
.subnav-dot{width:5px;height:5px;border-radius:50%;background:rgba(255,255,255,.45);flex-shrink:0;transition:all .15s}
.subnav-item.active .subnav-dot{background:var(--sky)}
.subnav-item:hover .subnav-dot{background:rgba(255,255,255,.7)}
.subnav-divider{display:none}
.subnav-bottom{margin-top:auto;padding:12px;border-top:1px solid rgba(255,255,255,.12)}
.add-page-btn{width:100%;padding:8px 12px;border-radius:var(--radius);border:1px dashed rgba(255,255,255,.2);background:transparent;color:rgba(255,255,255,.45);font-size:14px;font-weight:500;cursor:pointer;display:flex;align-items:center;gap:6px;font-family:inherit;transition:all .15s;margin-bottom:8px}
.add-page-btn:hover{border-color:var(--sky);color:var(--sky);background:rgba(41,171,226,.08)}
/* 사이드바 상단 컨트롤 */
.subnav-top-ctrl{display:flex;align-items:center;justify-content:space-between;padding:6px 14px 6px;border-bottom:1px solid rgba(255,255,255,.12);margin-bottom:0}
.subnav-top-label{font-size:14px;font-weight:600;letter-spacing:.3px;color:rgba(255,255,255,.7);text-transform:none}
.subnav-top-btns{display:flex;align-items:center;gap:3px}
.sctrl-btn{width:22px;height:22px;border-radius:4px;border:none;background:transparent;color:rgba(255,255,255,.65);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1;padding:0;position:relative}
.sctrl-btn:hover{background:rgba(41,171,226,.2);color:var(--sky)}
.sctrl-btn .sctrl-tip{position:absolute;left:50%;transform:translateX(-50%);top:calc(100% + 5px);background:var(--navy-mid);color:#fff;font-size:10px;white-space:nowrap;padding:3px 7px;border-radius:4px;pointer-events:none;opacity:0;transition:opacity .15s;z-index:999}
.sctrl-btn:hover .sctrl-tip{opacity:1}
/* 아코디언 그룹 헤더 */
.subnav-group-header{display:flex;align-items:center;justify-content:space-between;padding:11px 14px 5px;cursor:pointer;user-select:none}
.subnav-group-header:hover .subnav-group-label{color:rgba(255,255,255,.8)}
.subnav-group-label-wrap{display:flex;align-items:center;gap:6px}
.subnav-group-label{font-size:14px;font-weight:600;letter-spacing:.3px;color:rgba(255,255,255,.6);text-transform:none;transition:color .15s}
/* 표준 아코디언 화살표 = CSS 보더 셰브론(꼭지 sharp ❯). 펼치면 90도 회전(▼) */
.subnav-arrow{display:inline-block;width:7px;height:7px;border-right:1.6px solid rgba(255,255,255,.55);border-bottom:1.6px solid rgba(255,255,255,.55);border-radius:1px;transform:rotate(-45deg);transition:transform .2s,border-color .15s}
.nav-group.open .subnav-arrow{transform:rotate(45deg);border-color:rgba(255,255,255,.45)}
.subnav-group-header:hover .subnav-arrow{border-color:var(--sky)}
/* 아코디언 콘텐츠 */
.nav-items-wrap{position:relative;overflow:hidden;max-height:0;transition:max-height .28s ease}
.nav-group.open .nav-items-wrap{max-height:600px}
/* 사이드바 아코디언: 단일 연속 세로선(색 균일) + 활성 항목 점(•), 활성 배경 없음 */
.nav-items-wrap::before{content:'';position:absolute;left:17px;top:0;bottom:0;width:1px;background:rgba(255,255,255,.2)}
.nav-items-wrap .subnav-item{position:relative;padding-left:34px}
.nav-items-wrap .subnav-dot{display:none}
.nav-items-wrap .subnav-item.active{background:transparent;border-left-color:transparent}
.nav-items-wrap .subnav-item.active .subnav-dot{display:block;position:absolute;left:11px;top:50%;transform:translateY(-50%);width:8px;height:8px;border-radius:50%;background:var(--sky);margin:0}
.ai-trigger-btn{width:100%;padding:9px 12px;border-radius:var(--radius);background:linear-gradient(135deg,var(--sky) 0%,var(--navy-light) 100%);border:none;color:#fff;font-size:14px;font-weight:600;cursor:pointer;display:flex;align-items:center;gap:7px;font-family:inherit;transition:all .15s;box-shadow:0 2px 8px rgba(41,171,226,.3)}
.ai-trigger-btn:hover{opacity:.9;box-shadow:0 4px 14px rgba(41,171,226,.4)}
.ai-pulse{width:7px;height:7px;border-radius:50%;background:var(--surface);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.75)}}

/* ── 메인 ── */
.main{margin-left:calc(var(--subnav-w) + 20px);margin-right:48px;flex:1;min-width:0;overflow:hidden;display:flex;flex-direction:column;padding-top:0;margin-top:0;transition:margin-left .25s ease,margin-right .25s ease}

/* ── 탭바 ── */
.tabbar{display:none}
.tab-item{display:flex;align-items:center;gap:5px;padding:0 12px;height:100%;font-size:12px;color:var(--text-muted);cursor:pointer;border-bottom:2px solid transparent;transition:all .15s;white-space:nowrap;flex-shrink:0;position:relative;z-index:1}
.tab-item:hover{color:var(--text);background:#f5f7fc}
.tab-item.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600;background:#f5f9fd}
.tab-x{width:14px;height:14px;border-radius:3px;border:none;background:none;color:var(--text-hint);cursor:pointer;font-size:12px;padding:0;display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}
.tab-x:hover{background:var(--border);color:var(--text)}

/* ── 페이지 ── */
.page-wrap{padding:18px 24px}
.page-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:16px;flex-wrap:wrap;gap:12px}
.breadcrumb{font-size:11.5px;color:var(--text-muted);margin-bottom:4px}
.breadcrumb span{color:var(--text-hint);margin:0 4px}
.page-title{font-size:19px;font-weight:700;color:var(--text);letter-spacing:-.5px;display:flex;align-items:center;gap:8px}
.ai-badge{display:inline-flex;align-items:center;gap:4px;background:var(--sky-pale);color:var(--sky);font-size:10.5px;font-weight:700;padding:3px 8px;border-radius:20px;border:1px solid rgba(41,171,226,.2)}
.section{display:none}.section.active{display:block}
.tooltip-trigger{position:relative;display:inline-flex}
.tooltip-trigger:hover::after{content:attr(data-tip);position:absolute;bottom:calc(100% + 6px);left:50%;transform:translateX(-50%);background:var(--navy);color:#fff;font-size:11px;padding:8px 12px;border-radius:6px;white-space:pre;z-index:9999;pointer-events:none;min-width:220px;line-height:1.5;box-shadow:0 4px 12px rgba(0,0,0,0.2)}
.proj-card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:16px;margin-bottom:12px;transition:box-shadow .15s}
.proj-card:hover{box-shadow:0 2px 12px rgba(0,0,0,0.08)}
.proj-status-신청{background:#e0f2fe;color:#0369a1;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700}
.proj-status-진행중{background:#dcfce7;color:#15803d;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700}
.proj-status-점검{background:#fef9c3;color:#a16207;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700}
.proj-status-완료{background:#f1f5f9;color:#475569;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700}
.proj-status-중단{background:#fee2e2;color:#b91c1c;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700}
.proj-status-보류{background:#f3f4f6;color:#6b7280;border-radius:20px;padding:2px 10px;font-size:11px;font-weight:700}
.issue-radio-label{display:flex;align-items:center;gap:4px;font-size:12px;cursor:pointer;padding:4px 10px;border:1px solid var(--border);border-radius:6px;background:var(--surface)}
.issue-radio-label input{accent-color:var(--accent)}
.issue-score-high{background:#fee2e2;color:#b91c1c}
.issue-score-mid{background:#fef9c3;color:#a16207}
.issue-score-low{background:#dcfce7;color:#15803d}
.budget-bar{height:6px;background:var(--border-light);border-radius:3px;overflow:hidden;margin-top:4px}
.budget-bar-fill{height:100%;border-radius:3px;transition:width .3s}

/* ── 통계 ── */
.stats-row{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}
.stat-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:14px 18px;box-shadow:var(--shadow);transition:all .2s}
.stat-card:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}
.stat-card-top{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}
.stat-icon{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px}
.si-blue{background:var(--sky-pale)}.si-navy{background:rgba(26,36,86,.07)}.si-green{background:var(--success-light)}.si-orange{background:var(--warning-light)}
.stat-label{font-size:10.5px;font-weight:700;color:var(--text-muted);letter-spacing:.3px;text-transform:uppercase}
.stat-value{font-size:26px;font-weight:700;color:var(--text);letter-spacing:-1px;line-height:1.1}
.stat-sub{font-size:11px;color:var(--text-hint);margin-top:3px}
.stat-trend{font-size:10.5px;font-weight:600;padding:2px 6px;border-radius:4px}
.t-up{background:var(--success-light);color:var(--success)}.t-dn{background:var(--danger-light);color:var(--danger)}

/* ── 필터바 ── */
.filterbar{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:10px 16px;display:flex;align-items:center;gap:10px;flex-wrap:wrap;margin-bottom:14px;box-shadow:var(--shadow)}
.filter-label{font-size:11.5px;color:var(--text-muted);font-weight:600;white-space:nowrap}
.filter-sep{width:1px;height:18px;background:var(--border);flex-shrink:0}
.fi{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);font-size:12px;font-family:inherit;color:var(--text);background:var(--bg);outline:none;transition:all .15s}
input[list]::-webkit-calendar-picker-indicator{opacity:0.5;cursor:pointer}
.fi:focus{border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px rgba(41,171,226,.1)}

/* ── 툴바 ── */
.toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px;flex-wrap:wrap;gap:8px}
.toolbar-l,.toolbar-r{display:flex;align-items:center;gap:6px}

/* ── 버튼 ── */
.btn{display:inline-flex;align-items:center;gap:5px;padding:6px 12px;border-radius:var(--radius);font-size:12px;font-weight:500;cursor:pointer;transition:all .15s;border:1px solid var(--border);background:var(--surface);color:var(--text-mid);font-family:inherit;white-space:nowrap}
.btn:hover{background:var(--bg)}
.btn-primary{background:var(--accent);color:#fff;border-color:var(--accent)}
.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}
.btn-navy{background:var(--navy);color:#fff;border-color:var(--navy)}
.btn-navy:hover{background:var(--navy-mid)}
.btn-danger{color:var(--danger);border-color:rgba(224,60,60,.25)}
.btn-danger:hover{background:var(--danger-light)}
.btn-sm{padding:4px 9px;font-size:11.5px}
.btn-icon{width:26px;height:26px;padding:0;justify-content:center;font-size:13px}

/* ── 테이블 ── */
.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}
.table-scroll{overflow-x:auto;overflow-y:auto}
.data-table{width:max-content;min-width:100%;border-collapse:collapse}
#partner-body td:first-child{width:28px!important;min-width:28px!important;max-width:28px!important;padding:4px!important;text-align:center!important}
table.data-table th:first-child{width:28px!important;min-width:28px!important;max-width:28px!important;padding:4px!important;text-align:center!important}
.data-table thead th{background:var(--surface2);font-size:11px;font-weight:700;color:var(--text-muted);letter-spacing:.3px;text-transform:uppercase;padding:9px 12px;border-bottom:1px solid var(--border);text-align:left;white-space:nowrap;position:sticky;top:0;z-index:1}
.data-table tbody td{padding:9px 12px;border-bottom:1px solid var(--border-light);font-size:12.5px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:80px}
.data-table tbody tr:last-child td{border-bottom:none}
.data-table tbody tr:hover td{background:var(--sky-pale)}
.data-table tbody tr{cursor:pointer;transition:background .1s}
.table-footer{display:flex;align-items:center;justify-content:space-between;padding:10px 16px;border-top:1px solid var(--border);background:#fafbfd}
.table-info{font-size:11.5px;color:var(--text-muted)}
.pager{display:flex;align-items:center;gap:3px}
.pg-btn{width:26px;height:26px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);color:var(--text-muted);font-size:11.5px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .15s;font-family:inherit}
.pg-btn:hover{border-color:var(--accent);color:var(--accent)}
.pg-btn.active{background:var(--accent);color:#fff;border-color:var(--accent)}

/* ── 뱃지 ── */
.badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:20px;font-size:11px;font-weight:600;white-space:nowrap}
.b-ok{background:var(--success-light);color:var(--success)}
.b-low{background:var(--warning-light);color:var(--warning)}
.b-out{background:var(--danger-light);color:var(--danger)}
.b-blue{background:var(--sky-pale);color:var(--sky)}
.b-navy{background:rgba(26,36,86,.08);color:var(--navy)}
.b-admin{background:var(--sky-pale);color:var(--sky)}
.b-user{background:var(--bg);color:var(--text-muted)}

/* ── 견적서/품목 테이블 ── */
.items-table{width:100%;border-collapse:collapse}
.items-table th{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;padding:7px 8px;border-bottom:1px solid var(--border);text-align:left;background:#f4f6fb}
.items-table td{padding:4px 4px;vertical-align:middle;border-bottom:1px solid var(--border-light)}
.items-table td input{padding:6px 8px;font-size:12.5px;border:1px solid var(--border);border-radius:var(--radius);font-family:inherit;background:var(--surface);color:var(--text);width:100%;outline:none;transition:all .15s}
.items-table td input:focus{border-color:var(--accent);box-shadow:0 0 0 2px rgba(41,171,226,.1)}
.totals{text-align:right;padding:12px 0 4px;border-top:1px solid var(--border);margin-top:6px}
.total-line{font-size:12.5px;color:var(--text-muted);margin-bottom:4px}
.total-final{font-size:18px;font-weight:700;margin-top:8px;color:var(--text)}

/* ── 카드 ── */
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:12px 16px;margin-bottom:10px;box-shadow:var(--shadow)}
.card-title{font-size:11px;font-weight:700;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:14px;padding-bottom:8px;border-bottom:1px solid var(--border-light)}
.field-grid{display:grid;gap:12px;margin-bottom:12px}
.fg2{grid-template-columns:1fr 1fr}.fg3{grid-template-columns:1fr 1fr 1fr}.fg4{grid-template-columns:1fr 1fr 1fr 1fr}
.field{display:flex;flex-direction:column;gap:2px}
.field label{font-size:11px;font-weight:600;color:var(--text-muted)}
.task-item{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:var(--radius);border:1px solid var(--border-light);margin-bottom:7px;background:var(--bg);transition:all .15s;cursor:pointer}
.task-item:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(41,171,226,.1)}
.task-item.done{opacity:0.5}
.task-item.done .task-title{text-decoration:line-through}
.task-title{font-size:12.5px;font-weight:600;color:var(--text);flex:1;line-height:1.4}
.task-meta{font-size:11px;color:var(--text-muted);margin-top:2px}
.task-check{width:16px;height:16px;cursor:pointer;flex-shrink:0;margin-top:1px;accent-color:var(--accent)}
.priority-긴급{color:#ef4444;font-weight:700}
.priority-높음{color:#f97316}
.priority-보통{color:var(--accent)}
.priority-낮음{color:var(--text-muted)}
.task-filter-btn{background:var(--bg);border:1px solid var(--border);color:var(--text-muted);font-size:11px;padding:3px 10px}
.task-filter-btn.active{background:var(--accent);border-color:var(--accent);color:#fff}
.cal-cell{min-height:80px;border-radius:6px;border:1px solid var(--border-light);padding:4px;background:var(--bg);cursor:pointer;transition:all .15s;position:relative}
/* 대시보드 캘린더 위젯: 깔끔한 점 표시 (시안 스타일, 80px 칩셀은 전체화면용) */
.widget-card .cal-cell{min-height:40px;padding:4px 2px;border-radius:7px;border-color:transparent;background:transparent;display:flex;flex-direction:column;align-items:center;gap:3px}
.widget-card .cal-cell:hover{background:var(--surface2);border-color:transparent}
.widget-card .cal-cell.today{background:var(--accent);border-color:transparent}
.widget-card .cal-cell.today .cal-date{color:#fff;font-weight:700}
.widget-card .cal-cell.selected{background:var(--accent-light);border-color:transparent}
.widget-card .cal-date{font-size:11.5px;margin:0;line-height:1.2}
.cal-dots{display:flex;gap:3px;justify-content:center;flex-wrap:wrap;line-height:1;min-height:5px}
.cal-pt{width:5px;height:5px;border-radius:50%;display:inline-block}
.cal-pt.priority-긴급{background:#ef4444}
.cal-pt.priority-높음{background:#f59e0b}
.cal-pt.priority-보통{background:var(--accent)}
.cal-pt.priority-낮음{background:#94a3b8}
.cal-pt.repeat{background:#22c55e}
.cal-cell:hover{border-color:var(--accent);background:#f0f7ff}
.cal-cell.today{border-color:var(--accent);background:#e8f3fc}
.cal-cell.today .cal-date{color:var(--accent);font-weight:700}
.widget-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 20px;box-shadow:var(--shadow);overflow:hidden}
.widget-card.size-sm{min-height:160px}
.widget-card.size-md{min-height:260px}
.widget-card.size-lg{min-height:400px}
.widget-card{transition:box-shadow .15s;position:relative;cursor:grab;user-select:none}
.widget-card:active{cursor:grabbing}
.widget-card.dragging{opacity:0.35;box-shadow:0 8px 32px rgba(91,141,238,.25)}
.widget-card.drag-over{border:2px dashed var(--accent);background:#f0f7ff}
.wr{position:absolute;z-index:20;opacity:0;transition:opacity .15s}
.widget-card:hover .wr{opacity:1}
.wr-n{top:0;left:10px;right:10px;height:6px;cursor:n-resize}
.wr-s{bottom:0;left:10px;right:10px;height:6px;cursor:s-resize}
.wr-w{top:10px;left:0;bottom:10px;width:6px;cursor:w-resize}
.wr-e{top:10px;right:0;bottom:10px;width:6px;cursor:e-resize}
.wr-nw{top:0;left:0;width:12px;height:12px;cursor:nw-resize}
.wr-ne{top:0;right:0;width:12px;height:12px;cursor:ne-resize}
.wr-sw{bottom:0;left:0;width:12px;height:12px;cursor:sw-resize}
.wr-se{bottom:0;right:0;width:12px;height:12px;cursor:se-resize;background:rgba(91,141,238,0.3);border-radius:0 0 4px 0}
.wr-se::after{content:'';display:block;width:8px;height:8px;border-right:2px solid #5b8dee;border-bottom:2px solid #5b8dee;border-radius:0 0 3px 0;margin:2px}
.widget-drag-handle{cursor:grab;color:var(--text-muted);font-size:14px;margin-right:6px}
.widget-drag-handle:active{cursor:grabbing}
.widget-setting-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid var(--border-light);border-radius:var(--radius);margin-bottom:6px;background:var(--bg);cursor:grab}
.widget-setting-item:active{cursor:grabbing;opacity:0.7}
/* size-btn 제거 - 슬라이더로 대체 */
.cal-cell.other-month{opacity:0.35}
.cal-cell.selected{border-color:var(--navy);background:#eef2ff}
.cal-date{font-size:12px;font-weight:600;color:var(--text);margin-bottom:2px}
.cal-date.sun{color:#ef4444}
.cal-date.sat{color:#5b8dee}
.cal-dot{font-size:10px;line-height:1.4;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-radius:3px;padding:0 3px;margin-bottom:1px}
.cal-dot.priority-긴급{background:#fee2e2;color:#ef4444}
.cal-dot.priority-높음{background:#ffedd5;color:#f97316}
.cal-dot.priority-보통{background:#dbeafe;color:#2563eb}
.cal-dot.priority-낮음{background:#f1f5f9;color:#64748b}
.cal-dot.repeat{background:#f0fdf4;color:#16a34a}
.project-item{padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border-light);margin-bottom:8px;background:var(--bg);cursor:pointer;transition:all .15s}
.project-item:hover{border-color:var(--accent);box-shadow:0 2px 8px rgba(41,171,226,.1)}
.project-title{font-size:13px;font-weight:700;color:var(--navy);margin-bottom:4px}
.project-meta{font-size:11px;color:var(--text-muted);display:flex;gap:10px;align-items:center}
.status-badge{display:inline-block;padding:1px 8px;border-radius:20px;font-size:10.5px;font-weight:600}
.sb-대기{background:#f1f5f9;color:#64748b}
.sb-진행중{background:#dbeafe;color:#2563eb}
.sb-완료{background:#dcfce7;color:#16a34a}
.sb-보류{background:#fef3c7;color:#d97706}
.field input,.field select,.field textarea{padding:7px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:12.5px;font-family:inherit;color:var(--text);background:var(--surface);outline:none;transition:all .15s}
.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px rgba(41,171,226,.1);background:var(--surface)}
.field textarea{resize:vertical;min-height:68px}
.btn-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:10px}

/* ── 플로팅 창 (거래처) ── */
.floating-window{display:none;position:fixed;top:80px;right:40px;width:560px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:0 8px 32px rgba(26,36,86,.18);z-index:700}
.floating-window.open{display:block}
.floating-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;border-bottom:1px solid var(--border);cursor:move;user-select:none;background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}
.floating-title{font-size:14px;font-weight:700;color:#fff}
.floating-close{background:rgba(255,255,255,.12);border:none;color:rgba(255,255,255,.8);font-size:18px;cursor:pointer;padding:2px 8px;border-radius:var(--radius);transition:all .15s}
.floating-close:hover{background:rgba(255,255,255,.22);color:#fff}
.floating-body{padding:20px;max-height:70vh;overflow-y:auto}
.section-sep{font-size:10.5px;font-weight:700;color:var(--text-muted);letter-spacing:.5px;text-transform:uppercase;padding:3px 0;border-bottom:1px solid var(--border);margin:14px 0 10px}

/* ── 우측 고정 바 ── */
.right-bar{position:fixed;top:50%;right:0;transform:translateY(-50%);width:64px;background:var(--surface);border:1px solid var(--border);border-right:none;border-radius:10px 0 0 10px;box-shadow:-2px 0 12px rgba(26,36,86,.1);z-index:79;display:none;flex-direction:column;align-items:center;padding:8px 0;gap:2px;}
.right-bar-btn{width:56px;min-height:48px;border-radius:8px;border:none;background:transparent;color:var(--text-muted);cursor:pointer;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;font-size:14px;transition:all .15s;position:relative;padding:4px 2px;}
.right-bar-btn:hover{background:var(--sky-pale);color:var(--accent);}
.right-bar-btn.active{background:var(--sky-pale);color:var(--accent);}
.right-bar-divider{width:24px;height:1px;background:var(--border);margin:4px 0;}
.right-bar-add{width:56px;height:32px;border-radius:8px;border:1.5px dashed var(--border);background:transparent;color:var(--text-hint);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s;}
.right-bar-add:hover{border-color:var(--accent);color:var(--accent);background:var(--sky-pale);}
/* 즐겨찾기 팝업 */
.fav-popup{position:fixed;right:48px;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:0 4px 20px rgba(26,36,86,.15);z-index:200;min-width:180px;padding:8px 0;display:none;}
.fav-popup.open{display:block;}
.fav-popup-title{font-size:10px;font-weight:700;color:var(--text-hint);letter-spacing:.5px;text-transform:uppercase;padding:4px 14px 8px;}
.fav-item{display:flex;align-items:center;justify-content:space-between;padding:7px 14px;font-size:12.5px;color:var(--text);cursor:pointer;transition:all .15s;}
.fav-item:hover{background:var(--sky-pale);color:var(--accent);}
.fav-item-del{font-size:12px;color:var(--text-hint);border:none;background:none;cursor:pointer;padding:0 0 0 8px;line-height:1;}
.fav-item-del:hover{color:var(--danger);}
.fav-empty{padding:10px 14px;font-size:12px;color:var(--text-hint);}

/* ── AI 패널 ── */
/* ── 통합 AI 패널 (오른쪽 고정) ── */
.ai-panel{
  position:fixed;
  top:var(--topbar-h);
  right:0;bottom:0;
  width:480px;
  background:var(--surface);
  border-left:1px solid var(--border);
  z-index:80;
  display:none;flex-direction:column;
  box-shadow:-4px 0 20px rgba(26,36,86,.1);
  transition:none;
}
.ai-resize-left{position:absolute;left:0;top:0;bottom:0;width:5px;cursor:ew-resize;z-index:10;background:transparent;}
.ai-resize-left:hover,.ai-resize-left.dragging{background:rgba(41,171,226,.3);}
.ai-float-resize-n{position:absolute;top:0;left:8px;right:8px;height:5px;cursor:ns-resize;z-index:10;}
.ai-float-resize-s{position:absolute;bottom:0;left:8px;right:8px;height:5px;cursor:ns-resize;z-index:10;}
.ai-float-resize-w{position:absolute;left:0;top:8px;bottom:8px;width:5px;cursor:ew-resize;z-index:10;}
.ai-float-resize-e{position:absolute;right:0;top:8px;bottom:8px;width:5px;cursor:ew-resize;z-index:10;}
.ai-float-resize-nw{position:absolute;top:0;left:0;width:8px;height:8px;cursor:nw-resize;z-index:11;}
.ai-float-resize-ne{position:absolute;top:0;right:0;width:8px;height:8px;cursor:ne-resize;z-index:11;}
.ai-float-resize-sw{position:absolute;bottom:0;left:0;width:8px;height:8px;cursor:sw-resize;z-index:11;}
.ai-float-resize-se{position:absolute;bottom:0;right:0;width:8px;height:8px;cursor:se-resize;z-index:11;}
.ai-float-resize-n:hover,.ai-float-resize-s:hover,.ai-float-resize-w:hover,.ai-float-resize-e:hover,
.ai-float-resize-nw:hover,.ai-float-resize-ne:hover,.ai-float-resize-sw:hover,.ai-float-resize-se:hover{background:rgba(41,171,226,.2);}
.ai-panel.collapsed{width:48px}
.ai-panel.floating{
  position:fixed;
  right:auto;bottom:auto;
  top:calc(50vh - 300px);left:calc(50vw - 400px);
  width:800px;height:600px;
  border:1px solid var(--border);
  border-radius:10px;
  box-shadow:0 8px 32px rgba(26,36,86,.22);
  overflow:hidden;
  transition:none;
}
.ai-panel.floating .ai-panel-body{overflow:hidden}
.ai-panel-head{
  padding:0 12px;
  height:48px;
  border-bottom:1px solid var(--border);
  background:linear-gradient(135deg,var(--navy) 0%,var(--navy-mid) 100%);
  display:flex;align-items:center;justify-content:space-between;
  flex-shrink:0;cursor:pointer;
  user-select:none;
}
.ai-panel-head:hover{filter:brightness(1.08)}
.ai-panel-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;color:#fff;white-space:nowrap;overflow:hidden}
.ai-pdot{width:7px;height:7px;border-radius:50%;background:var(--sky-light);animation:pulse 2s ease-in-out infinite;flex-shrink:0}
.ai-toggle-btn{width:28px;height:28px;border-radius:var(--radius);border:none;background:rgba(255,255,255,.12);color:#fff;cursor:pointer;font-size:16px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}
.ai-toggle-btn:hover{background:rgba(255,255,255,.22)}
.ai-panel-body{flex:1;display:flex;flex-direction:column;overflow:hidden;transition:opacity .2s}
.ai-panel.collapsed .ai-panel-body{opacity:0;pointer-events:none}
.ai-panel.collapsed .ai-panel-title span:not(.ai-pdot){display:none}
/* 접혔을 때 세로 텍스트 */
.ai-panel.collapsed .ai-panel-head{justify-content:center;padding:0}
.ai-panel.collapsed .ai-toggle-btn{display:none}
.ai-panel-collapsed-label{
  display:none;writing-mode:vertical-rl;text-orientation:mixed;
  font-size:12px;font-weight:700;color:rgba(255,255,255,.8);
  letter-spacing:.5px;white-space:nowrap;
}
.ai-panel.collapsed .ai-panel-collapsed-label{display:flex;align-items:center;gap:6px}
.ai-quick-btns{display:flex;gap:5px;flex-wrap:wrap;padding:8px 12px;border-bottom:1px solid var(--border-light)}
.ai-quick-btn{padding:3px 9px;border-radius:20px;border:1px solid var(--border);background:var(--bg);font-size:11px;color:var(--text-muted);cursor:pointer;transition:all .15s;font-family:inherit;white-space:nowrap}
.ai-quick-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--sky-pale)}
.ai-msgs{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}
.ai-from{font-size:10.5px;color:var(--text-hint);margin-bottom:2px}
.ai-from-user{text-align:right}
.ai-bubble-ai{background:var(--sky-pale);border:1px solid rgba(41,171,226,.15);color:var(--text);border-radius:4px 12px 12px 12px;padding:9px 12px;font-size:12.5px;line-height:1.65;max-width:92%}
.ai-bubble-user{background:var(--navy);color:#fff;border-radius:12px 4px 12px 12px;padding:9px 12px;font-size:12.5px;line-height:1.65;max-width:92%;margin-left:auto}
.ai-input-area{padding:10px;border-top:1px solid var(--border);background:#fafbfd;flex-shrink:0}
.ai-input-wrap{display:flex;align-items:flex-end;gap:6px;background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:7px 10px;transition:all .15s}
.ai-input-wrap:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px rgba(41,171,226,.1)}
.ai-textarea{flex:1;border:none;outline:none;resize:none;font-size:12.5px;font-family:inherit;color:var(--text);background:transparent;min-height:20px;max-height:80px;line-height:1.5}
.ai-send-btn{width:30px;height:30px;border-radius:8px;border:none;background:var(--accent);color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:15px;transition:all .15s;flex-shrink:0}
.ai-send-btn:hover{background:var(--accent-hover)}
.ai-note{font-size:10px;color:var(--text-hint);text-align:center;margin-top:5px}
.ai-page-label{font-size:10.5px;font-weight:600;color:var(--sky);background:var(--sky-pale);padding:4px 12px;text-align:center;border-bottom:1px solid rgba(41,171,226,.15)}

/* ── 기타 ── */
.empty-state{text-align:center;padding:40px;color:var(--text-hint);font-size:13px}
.toolbar-sep{width:1px;height:18px;background:var(--border)}
input[type=checkbox]{width:14px;height:14px;accent-color:var(--accent);cursor:pointer}
.qty-ctrl{display:inline-flex;align-items:center;gap:7px}
.qty-btn{width:24px;height:24px;border-radius:var(--radius);border:1px solid var(--border);background:var(--surface);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;color:var(--text-muted);transition:all .15s}
.qty-btn:hover{background:var(--bg);border-color:var(--accent)}
.qty-num{min-width:26px;text-align:center;font-weight:600}
.toast{position:fixed;bottom:24px;right:24px;background:var(--navy);color:#fff;padding:11px 18px;border-radius:var(--radius-lg);font-size:12.5px;z-index:9999;opacity:0;transition:all .3s;pointer-events:none;box-shadow:0 4px 20px rgba(10,14,40,.25);transform:translateY(8px)}
.toast.show{opacity:1;transform:translateY(0)}

/* 드래그/아코디언 */
.nav-group{margin:0;transition:all .15s}
.nav-group.drag-over .subnav-section{background:rgba(41,171,226,.1);border-radius:var(--radius)}
.drag-handle{color:rgba(255,255,255,.35);font-size:13px;cursor:grab;padding:0 2px;line-height:1;transition:all .15s;user-select:none;letter-spacing:-1px}
.drag-handle:hover{color:rgba(255,255,255,.75)}
.nav-group:hover .drag-handle{color:rgba(255,255,255,.55)}
.nav-group[draggable=true]{cursor:default}
.nav-group.dragging{opacity:.4;border:1px dashed rgba(41,171,226,.5);border-radius:var(--radius)}
.drag-over-indicator{background:rgba(41,171,226,.15);border-left:3px solid var(--sky);border-radius:var(--radius)}
.nav-group.dragging{opacity:.4}
.admin-only{display:none}

@media print{
  .topbar,.subnav,.ai-panel,.btn-row,.toolbar,.no-print,.tabbar,.filterbar{display:none!important}
  .main{margin-left:0!important;padding:16px}
  .section{display:block!important}
  #sec-inventory,#sec-partners,#sec-users,#sec-mypage,#sec-po-list,#sec-po-write,#sec-dl-list,#sec-dl-write,#sec-fabric-list,#sec-product-list,#sec-etc-list,#sec-task-main,#sec-task-quick,#sec-task-proj-apply,#sec-task-proj-active,#sec-issue-list,#sec-task-today,#sec-task-week,#sec-task-all,#sec-task-repeat,#sec-task-projects,#sec-task-issues,#sec-task-timeboxing,#sec-task-cat{display:none!important}
  .card{box-shadow:none;border:1px solid #ccc;break-inside:avoid}
  body{background:var(--surface)}
  .print-header{display:block!important}
}
.print-header{display:none}

.licon{display:inline-block;vertical-align:-0.18em;flex-shrink:0}
.mst-label{display:inline-flex;align-items:center;gap:6px}
/* ── 메인 대시보드 위젯 (기획서 기준) ── */
.dash-vision{background:linear-gradient(135deg,#1a2456,#3a4ba0);border-radius:12px;padding:18px 22px;height:100%;box-sizing:border-box;color:#fff;display:flex;flex-direction:column;overflow:hidden}
.dash-vision-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}
.dash-vision-main{min-width:0}
.dash-vision-label{font-size:11px;font-weight:700;letter-spacing:1px;color:rgba(255,255,255,0.55);margin-bottom:4px}
.dash-vision-text{font-size:22px;font-weight:800;line-height:1.3}
.dash-vision-date{text-align:right;flex-shrink:0}
.dash-vd-day{font-size:30px;font-weight:800;line-height:1}
.dash-vd-ym{font-size:12px;color:rgba(255,255,255,0.7);margin-top:2px}
.dash-kpi-row{display:flex;gap:10px;margin-top:14px}
.dash-kpi-card{flex:1;background:rgba(255,255,255,0.12);border:1px solid rgba(255,255,255,0.18);border-radius:9px;padding:9px 12px;min-width:0}
.dash-kpi-name{font-size:11px;color:rgba(255,255,255,0.7);margin-bottom:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-kpi-val{font-size:17px;font-weight:800;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-kpi-tgt{font-size:10.5px;color:rgba(255,255,255,0.6);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-stat-row{display:flex;gap:10px}
.dash-stat-card{flex:1;display:flex;align-items:center;gap:10px;background:var(--bg);border:1px solid var(--border-light);border-radius:10px;padding:12px 14px}
.dash-stat-ic{font-size:24px;flex-shrink:0}
.dash-stat-body{min-width:0}
.dash-stat-val{font-size:20px;font-weight:800;color:var(--navy);line-height:1.1}
.dash-stat-lbl{font-size:11.5px;color:var(--text-muted);margin-top:2px}
.dash-stat-sub{font-size:10.5px;color:var(--accent);margin-top:1px}
.dash-task{display:flex;align-items:center;gap:8px;padding:7px 4px;border-bottom:1px solid var(--border-light);cursor:pointer;font-size:13px;transition:background .12s}
.dash-task:hover{background:var(--bg)}
.dash-task.done{opacity:0.5;text-decoration:line-through}
.dash-task-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-task-cat{font-size:10.5px;color:var(--text-muted);background:var(--bg);border-radius:5px;padding:1px 6px;flex-shrink:0}
.dash-prio{font-size:9px;flex-shrink:0}
.dash-date-badge{font-size:10.5px;font-weight:700;color:var(--text-muted);background:var(--bg);border-radius:5px;padding:2px 7px;flex-shrink:0;min-width:48px;text-align:center}
.dash-date-badge.today{background:var(--accent);color:#fff}
.dash-repeat-badge{font-size:10.5px;font-weight:600;color:var(--accent);flex-shrink:0}
.dash-ai-top3{background:linear-gradient(135deg,rgba(91,141,238,0.1),rgba(91,141,238,0.04));border-radius:9px;padding:2px 10px 6px;margin-bottom:8px}
.dash-ai-top3:empty{display:none}
.dash-ai-label{font-size:11px;font-weight:700;color:var(--accent);padding:7px 0 4px}
.dash-ai-item{display:flex;align-items:center;gap:8px;padding:5px 0;cursor:pointer;font-size:13px}
.dash-ai-rank{width:18px;height:18px;border-radius:50%;background:var(--accent);color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;flex-shrink:0}
.dash-ai-item .dash-task-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-prep-group{margin-bottom:10px}
.dash-prep-date{font-size:11.5px;font-weight:700;color:var(--navy);padding:4px 0;border-bottom:1.5px solid var(--border-light);margin-bottom:4px}
.dash-prep-date.today{color:var(--accent)}
.dash-prep-item{font-size:12.5px;padding:4px 6px;cursor:pointer;border-radius:5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.dash-prep-item:hover{background:var(--bg)}
.dash-empty{padding:18px;text-align:center;color:var(--text-muted);font-size:12.5px}

/* ===== 경영전략(.strat/.st-*) ===== */
    .strat,#strat-modal-bg{ --p:#534AB7; --teal:#0F6E56;--tl:#E1F5EE;--amber:#854F0B;--aml:#FAEEDA;--green:#3B6D11;--gl:#EAF3DE;--red:#A32D2D;--rl:#FCEBEB;--grl:#F1EFE8; --st-surface:#fff;--st-border:#e2ddd5;--st-text:#1a1917;--st-text2:#6b6860;--st-text3:#9c9a92;--st-radius:10px; }
    .strat{color:var(--st-text)}
    .strat *,#strat-modal *{box-sizing:border-box}
    .st-wrap{max-width:1400px}
    #sec-strategy-projects .st-wrap{max-width:1820px}
    .st-head{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}
    .st-title{font-size:22px;font-weight:700;letter-spacing:-.5px}
    .st-sub{font-size:13px;color:var(--st-text3);margin-top:4px}
    .st-btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:7px;font-size:13px;font-weight:500;cursor:pointer;border:none;transition:.15s;font-family:inherit}
    .st-btn-primary{background:var(--p);color:#fff}
    .st-btn-primary:hover{opacity:.88}
    .st-btn-outline{background:var(--st-surface);border:1px solid var(--st-border);color:var(--st-text2)}
    .st-btn-outline:hover{background:#f3f1ec}
    .st-btn-sm{padding:6px 12px;font-size:12px}
    .st-card{background:var(--st-surface);border:1px solid var(--st-border);border-radius:var(--st-radius);padding:18px;box-shadow:0 1px 4px rgba(0,0,0,.05)}
    .st-card+.st-card{margin-top:10px}
    .st-badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}
    .st-grid3{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}
    .st-vision{background:linear-gradient(135deg,#EEEDFE,#E1F5EE);border:1px solid #CECBF6;border-radius:14px;padding:28px;margin-bottom:24px}
    .st-vision-label{font-size:11px;font-weight:700;color:var(--p);letter-spacing:1px;margin-bottom:10px}
    .st-vision-text{font-size:26px;font-weight:800;color:#26215C;letter-spacing:-.8px;line-height:1.3}
    .st-vision-meta{font-size:12px;color:var(--p);margin-top:12px;opacity:.75}
    .st-sectitle{font-size:13px;font-weight:700;color:var(--st-text2);margin:0 0 12px;display:flex;align-items:center;gap:8px}
    .st-sectitle::after{content:'';flex:1;height:1px;background:var(--st-border)}
    .st-empty{text-align:center;padding:44px 20px;color:var(--st-text3)}
    .st-empty .i{font-size:32px;margin-bottom:10px}
    .stc-review{background:var(--aml);color:var(--amber)}
    .stc-active{background:var(--tl);color:var(--teal)}
    .stc-success{background:var(--gl);color:var(--green)}
    .stc-fail{background:var(--rl);color:var(--red)}
    .stc-hold{background:var(--grl);color:var(--st-text3)}
    .st-kpi-vals{display:flex;align-items:baseline;gap:8px;margin:6px 0 10px}
    .st-kpi-cur{font-size:22px;font-weight:700;color:var(--p)}
    .st-kpi-arrow{color:var(--st-text3)}
    .st-kpi-tgt{font-size:14px;color:var(--st-text3)}
    #strat-modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.4);z-index:5000;align-items:center;justify-content:center}
    #strat-modal-bg.open{display:flex}
    #strat-modal{background:var(--surface);border-radius:14px;padding:26px;width:460px;max-width:92vw;max-height:84vh;overflow-y:auto}
    .st-mtitle{font-size:16px;font-weight:700;margin-bottom:18px}
    .st-field{margin-bottom:14px}
    .st-field label{display:block;font-size:12px;font-weight:600;color:var(--st-text2);margin-bottom:6px}
    .st-field input,.st-field select,.st-field textarea{width:100%;padding:9px 12px;border:1px solid var(--st-border);border-radius:7px;font-size:13.5px;font-family:inherit;outline:none;background:var(--surface);color:var(--st-text)}
    .st-field input:focus,.st-field select:focus,.st-field textarea:focus{border-color:var(--p)}
    .st-field textarea{height:80px;resize:vertical}
    .st-mfoot{display:flex;gap:8px;justify-content:flex-end;margin-top:18px}
    /* 다크모드 — 경영전략 섹션(.strat/.st-*) 전체 토큰 보정 */
    [data-theme="dark"] .strat,[data-theme="dark"] #strat-modal-bg{
      --p:#8b82e0;
      --teal:#5fcda0;--tl:#16302a;--amber:#e0b070;--aml:#33291a;--green:#9ccf6a;--gl:#1c2e14;--red:#f09a9a;--rl:#3a1f22;--grl:#262b36;
      --st-surface:#19202e;--st-border:#2b3447;--st-text:#e3e7f0;--st-text2:#aeb6ca;--st-text3:#828ba3;
    }
    [data-theme="dark"] .st-card{box-shadow:0 1px 4px rgba(0,0,0,.35)}
    [data-theme="dark"] .st-vision{background:linear-gradient(135deg,#1e2442,#163029);border-color:#34406a}
    [data-theme="dark"] .st-vision-text{color:#cdd4ee}
    [data-theme="dark"] .st-btn-outline:hover{background:#222b3c}
    /* ── 비전·연간목표 합본 ── */
    .st-goals-section{margin-top:36px;padding-top:30px;border-top:2px solid var(--st-border)}
    .st-year-tabs{display:flex;align-items:center;gap:2px;border-bottom:1px solid var(--st-border);margin-bottom:18px;flex-wrap:wrap}
    .st-ytab{background:none;border:none;border-bottom:2px solid transparent;padding:8px 16px;font-size:14px;font-weight:600;color:var(--st-text3);cursor:pointer;font-family:inherit;margin-bottom:-1px;transition:.12s}
    .st-ytab:hover{color:var(--st-text)}
    .st-ytab.active{color:var(--p);border-bottom-color:var(--p)}
    .st-ytab-add{background:none;border:1px dashed var(--st-border);border-radius:6px;color:var(--st-text3);padding:5px 11px;font-size:13px;cursor:pointer;font-family:inherit;margin-left:8px;transition:.12s}
    .st-ytab-add:hover{color:var(--p);border-color:var(--p)}
    .st-goal-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(310px,1fr));gap:14px}
    .st-goal-head{display:flex;align-items:flex-start;justify-content:space-between;gap:8px;margin-bottom:14px}
    .st-goal-name{font-size:15px;font-weight:700;line-height:1.35}
    .st-goal-pctrow{display:flex;align-items:baseline;gap:8px;margin-bottom:2px}
    .st-goal-pct{font-size:26px;font-weight:800;color:var(--p);line-height:1}
    .st-goal-vals{font-size:12.5px;color:var(--st-text2)}
    .st-goal-bar{height:7px;border-radius:4px;background:var(--st-border);overflow:hidden;margin:10px 0 0}
    .st-goal-bar>div{height:100%;background:var(--p);border-radius:4px;transition:width .3s}
    .st-goal-projs{display:flex;flex-wrap:wrap;gap:6px;margin-top:14px}
    .st-goal-proj{display:inline-flex;align-items:center;gap:4px;background:var(--grl);color:var(--st-text2);border:1px solid var(--st-border);border-radius:6px;padding:3px 9px;font-size:12px;cursor:pointer;transition:.12s}
    .st-goal-proj:hover{border-color:var(--p);color:var(--p)}
    .st-goal-actions{display:flex;gap:6px;margin-top:14px}
    /* ── 노션식 DB 뷰 (경영전략 프로젝트) ── */
    .ndb-toolbar{display:flex;align-items:center;gap:4px;margin-bottom:16px;border-bottom:1px solid var(--st-border)}
    .ndb-views{display:flex;gap:2px}
    .ndb-vtab{background:none;border:none;border-bottom:2px solid transparent;padding:7px 13px;font-size:13px;font-weight:500;color:var(--st-text3);cursor:pointer;font-family:inherit;margin-bottom:-1px;transition:.12s;display:inline-flex;align-items:center;gap:5px}
    .ndb-vtab:hover{color:var(--st-text)}
    .ndb-vtab.active{color:var(--p);border-bottom-color:var(--p);font-weight:600}
    .ndb-table{width:100%;border-collapse:collapse;font-size:13px}
    /* ── 노션식 표 ── 헤더: 아이콘+라벨, 좌측정렬, 옅은 하단선만 */
    .ndb-table thead th{text-align:left;font-size:12px;font-weight:500;color:var(--st-text3);padding:7px 12px;border:0;border-bottom:1px solid var(--st-border);white-space:nowrap;vertical-align:middle}
    /* 프로젝트 표 헤더 상단 테두리 (>로 직접 자식만 — 펼침 안 할일 표 헤더 제외) */
    .ndb-table:not(.pt-table) > thead th{border-top:1px solid var(--st-border)}
    .ndb-table thead th .licon{vertical-align:-2px;margin-right:5px;opacity:.6}
    .ndb-th-x{width:40px}
    /* 본문 셀: 좌측정렬, 행 사이 옅은 가로 구분선만(세로 격자선 없음) */
    .ndb-table tbody td{padding:8px 12px;text-align:left;vertical-align:middle;border:0;border-bottom:1px solid var(--st-border);color:var(--st-text)}
    /* 프로젝트 행마다 상단+하단 테두리(행 단위 구분선) */
    .ndb-table tbody tr.ndb-row>td{border-top:1px solid var(--st-border);border-bottom:1px solid var(--st-border)}
    .ndb-table tr.ndb-xrow>td{border:0}
    .ndb-table tbody tr.ndb-row{cursor:pointer;transition:background .1s}
    .ndb-table tbody tr.ndb-row:hover{background:var(--surface2)}
    .ndb-table tbody tr.pt-trow{transition:background .1s}
    .ndb-table tbody tr.pt-trow:hover{background:var(--surface2)}
    .ndb-name{font-weight:500;color:var(--st-text)}
    .ndb-mut{color:var(--st-text3)}
    .ndb-empty{color:var(--st-text3);opacity:.45}
    .ndb-chip{display:inline-block;font-size:11.5px;line-height:1.6;padding:1px 9px;border-radius:6px;background:var(--surface2);color:var(--st-text2);border:1px solid var(--st-border)}
    .ndb-person{font-size:12.5px;color:var(--st-text2)}
    .ndb-count{display:inline-block;cursor:pointer;font-size:12px;color:var(--st-text3);padding:1px 8px;border-radius:5px;background:var(--surface2)}
    .ndb-count:hover{color:var(--p)}
    .ndb-prog{display:flex;align-items:center;gap:8px;min-width:120px}
    .ndb-prog-bar{flex:1;height:6px;border-radius:3px;background:var(--st-border);overflow:hidden}
    .ndb-prog-fill{height:100%;background:var(--p);border-radius:3px}
    /* 삭제(X): 실제 마지막 컬럼(액션 칸), 행 호버 시만 보임 → 사라지거나 어긋날 일 없음 */
    .ndb-actcell{width:40px;text-align:center;vertical-align:middle}
    .ndb-del{display:inline-flex;align-items:center;justify-content:center;opacity:0;border:none;background:none;color:var(--st-text3);cursor:pointer;padding:4px;border-radius:5px;line-height:0;font-family:inherit;transition:opacity .1s,background .1s,color .1s}
    .ndb-table tbody tr:hover .ndb-del{opacity:.6}
    .ndb-del:hover{opacity:1;background:var(--rl);color:var(--red)}
    .ndb-board{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;align-items:flex-start}
    .ndb-col{flex:0 0 262px;background:var(--surface2);border-radius:10px;padding:10px;min-height:90px}
    .ndb-col.drag-over{outline:2px dashed var(--p);outline-offset:-3px}
    .ndb-col-head{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;color:var(--st-text2);margin-bottom:10px;padding:2px 4px}
    .ndb-col-cnt{color:var(--st-text3);font-weight:500}
    .ndb-cardb{background:var(--st-surface);border:1px solid var(--st-border);border-radius:8px;padding:11px;margin-bottom:8px;cursor:grab;box-shadow:0 1px 2px rgba(0,0,0,.04)}
    .ndb-cardb:hover{border-color:var(--p)}
    .ndb-cardb:active{cursor:grabbing}
    .ndb-cardb.dragging{opacity:.4}
    .ndb-cardb-t{font-size:13px;font-weight:500;line-height:1.4;margin-bottom:8px}
    .ndb-cardb-m{font-size:11px;color:var(--st-text3);display:flex;flex-wrap:wrap;gap:6px;align-items:center}
    .ndb-add-card{width:100%;text-align:left;background:none;border:none;color:var(--st-text3);font-size:12px;padding:8px 6px;cursor:pointer;border-radius:6px;font-family:inherit}
    .ndb-add-card:hover{background:var(--st-border);color:var(--st-text)}
    .ndb-cal-bar{display:flex;align-items:center;gap:10px;margin-bottom:14px}
    .ndb-cal-bar b{font-size:15px;font-weight:700;min-width:120px}
    .ndb-cal-nav{border:1px solid var(--st-border);background:var(--st-surface);color:var(--st-text2);width:28px;height:28px;border-radius:6px;cursor:pointer;font-size:14px}
    .ndb-cal-nav:hover{border-color:var(--p);color:var(--p)}
    .ndb-cal-today{border:1px solid var(--st-border);background:var(--st-surface);color:var(--st-text2);height:28px;padding:0 10px;border-radius:6px;cursor:pointer;font-size:12px;font-family:inherit}
    .ndb-cal{display:grid;grid-template-columns:repeat(7,1fr);gap:1px;background:var(--st-border);border:1px solid var(--st-border);border-radius:8px;overflow:hidden}
    .ndb-cal-dow{background:var(--surface2);text-align:center;font-size:11px;font-weight:600;color:var(--st-text3);padding:7px 0}
    .ndb-cal-cell{background:var(--st-surface);min-height:94px;padding:6px}
    .ndb-cal-cell.other{background:var(--surface2);opacity:.55}
    .ndb-cal-d{font-size:11px;color:var(--st-text3);margin-bottom:4px;display:inline-block}
    .ndb-cal-cell.today .ndb-cal-d{color:#fff;background:var(--p);min-width:18px;height:18px;border-radius:50%;text-align:center;line-height:18px;font-weight:700}
    .ndb-cal-ev{background:var(--tl);color:var(--teal);border-radius:4px;padding:2px 5px;margin-bottom:3px;font-size:10.5px;cursor:pointer;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
    .ndb-cal-ev:hover{filter:brightness(.96)}
    /* ── 프로젝트 할일 아코디언 ── */
    .pt-acc{border:1px solid var(--st-border);border-radius:8px;margin-bottom:8px;overflow:hidden;background:var(--st-surface)}
    .pt-acc.open{border-color:var(--p)}
    .pt-head{display:flex;align-items:center;gap:9px;padding:11px 12px;cursor:pointer;user-select:none}
    .pt-head:hover{background:var(--surface2)}
    .pt-chev{color:var(--st-text3);font-size:11px;transition:transform .15s;flex-shrink:0}
    .pt-acc.open .pt-chev{transform:rotate(90deg)}
    .pt-htitle{flex:1;font-size:13px;font-weight:500;line-height:1.4}
    .pt-acc.done .pt-htitle{text-decoration:line-through;color:var(--st-text3)}
    .pt-hmeta{font-size:11px;color:var(--st-text3);white-space:nowrap}
    .pt-body{padding:4px 14px 14px;border-top:1px solid var(--st-border)}
    .pt-row{display:flex;gap:10px;margin-top:12px}
    .pt-row .st-field{flex:1;margin-bottom:0}
    .pt-files{margin-top:14px}
    .pt-files-lbl{font-size:12px;font-weight:600;color:var(--st-text2);margin-bottom:7px}
    .pt-file{display:flex;align-items:center;gap:8px;font-size:12px;padding:6px 9px;border:1px solid var(--st-border);border-radius:6px;margin-bottom:5px;background:var(--surface2)}
    .pt-file a{color:var(--p);text-decoration:none;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .pt-file a:hover{text-decoration:underline}
    .pt-file-del{border:none;background:none;color:var(--st-text3);cursor:pointer;font-size:13px;padding:0 4px}
    .pt-file-del:hover{color:var(--red)}
    .pt-upload{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--st-text2);cursor:pointer;padding:7px 11px;border:1px dashed var(--st-border);border-radius:6px;margin-top:4px}
    .pt-upload:hover{border-color:var(--p);color:var(--p)}
    .pt-upload input{display:none}
    .pt-bfoot{display:flex;justify-content:space-between;align-items:center;margin-top:16px}
    /* 아코디언 화살표 칸 */
    .ndb-table td.ndb-xcell{width:36px;text-align:center;cursor:pointer;color:var(--st-text3)}
    .ndb-table td.ndb-xcell:hover{color:var(--p)}
    .ndb-xchev{display:inline-block;width:7px;height:7px;border-right:1.6px solid currentColor;border-bottom:1.6px solid currentColor;border-radius:1px;transform:rotate(-45deg);transition:transform .2s;vertical-align:middle}
    .ndb-xchev.open{transform:rotate(45deg);color:var(--p)}
    /* 펼침 행 — 배경만, 테두리 없음 */
    .ndb-table tr.ndb-xrow:hover{background:transparent}
    .ndb-table tr.ndb-xrow>td{padding:0;background:transparent}
    .ndb-done{text-decoration:line-through;color:var(--st-text3)}
    /* 할일 인라인 편집 표 */
    .pt-table td{padding:5px 8px;vertical-align:middle}
    /* 입력창 박스 완전 제거 — 다크모드 전역 input 규칙보다 우선순위가 낮아 박스가
       보이던 문제를 !important로 강제. 셀이 일반 텍스트처럼 보이고, 마우스 올리면
       살짝 테두리만 떠서 편집 가능 표시. */
    .pt-inp,[data-theme="dark"] .pt-inp{width:100%;background:transparent!important;border:1px solid transparent!important;box-shadow:none!important;padding:5px 7px;border-radius:5px;font-size:13px;font-family:inherit;color:var(--st-text);box-sizing:border-box;text-align:left}
    .pt-inp:hover,[data-theme="dark"] .pt-inp:hover{border-color:var(--st-border)!important}
    .pt-inp:focus,[data-theme="dark"] .pt-inp:focus{border-color:var(--p)!important;outline:none}
    select.pt-inp{cursor:pointer}
    input.pt-done{text-decoration:line-through;color:var(--st-text3)}
    /* 상태/담당부서 드롭다운을 '상태 pill'(st-badge) 모양으로 — 화살표 없이 배지처럼 */
    select.tm-pill,[data-theme="dark"] select.tm-pill{ -webkit-appearance:none;-moz-appearance:none;appearance:none;
      border:0!important;outline:none!important;box-shadow:none!important;
      border-radius:20px;padding:3px 12px;font-size:11px;font-weight:600;font-family:inherit;
      cursor:pointer;text-align:center;text-align-last:center;width:auto;min-width:54px }
    select.tm-pill.tp-active{ background:var(--tl)!important;  color:var(--teal)!important }
    select.tm-pill.tp-success{background:var(--gl)!important;  color:var(--green)!important }
    select.tm-pill.tp-review{ background:var(--aml)!important; color:var(--amber)!important }
    select.tm-pill.tp-fail{   background:var(--rl)!important;  color:var(--red)!important }
    select.tm-pill.tp-hold{   background:var(--grl)!important; color:var(--st-text3)!important }
    select.tm-pill option{ color:var(--st-text);background:var(--st-surface);font-weight:500 }
    /* 날짜칸 캘린더 아이콘 톤다운(박스처럼 안 보이게) */
    .pt-inp[type=date]::-webkit-calendar-picker-indicator{opacity:.35;cursor:pointer}
    [data-theme="dark"] .pt-inp[type=date]::-webkit-calendar-picker-indicator{filter:invert(.7)}
    /* 컬럼 너비 드래그 리사이즈 그립 */
    .ndb-table th{position:relative}
    .col-grip{position:absolute;top:0;right:0;width:7px;height:100%;cursor:col-resize;user-select:none}
    .col-grip:hover{background:var(--p);opacity:.45}
    /* 표 전체 너비 드래그 조절 컨테이너 + 오른쪽 핸들 */
    .ndb-twrap{position:relative;width:100%;max-width:100%;padding-right:14px}
    .ndb-wgrip{position:absolute;top:0;right:-4px;width:9px;height:100%;cursor:ew-resize;z-index:2}
    .ndb-wgrip::before{content:'';position:absolute;top:50%;right:3px;transform:translateY(-50%);width:3px;height:42px;border-radius:2px;background:var(--st-border);transition:background .12s}
    .ndb-wgrip:hover::before{background:var(--p)}
    /* min-width 제거: %컬럼+fixed 레이아웃에서 첫칸이 100% 초과해 우측으로 삐져나오던 원인 */
    .pt-fcell{vertical-align:middle}
    .pt-fwrap{display:flex;flex-wrap:wrap;gap:4px;align-items:center;justify-content:flex-start;min-height:28px}
    .pt-chip{display:inline-flex;align-items:center;gap:4px;font-size:11px;background:var(--surface2);border:1px solid var(--st-border);border-radius:4px;padding:0 6px;min-height:24px;max-width:130px}
    .pt-chip a{color:var(--p);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
    .pt-chip a:hover{text-decoration:underline}
    .pt-chip button{border:none;background:none;color:var(--st-text3);cursor:pointer;font-size:11px;padding:0;line-height:1}
    .pt-chip button:hover{color:var(--red)}
    .pt-upbtn{display:inline-flex;align-items:center;justify-content:center;min-height:24px;border:1px dashed var(--st-border);background:none;color:var(--st-text3);border-radius:4px;cursor:pointer;font-size:12px;padding:0 9px;line-height:1}
    .pt-upbtn:hover{border-color:var(--p);color:var(--p)}
    /* 프로젝트 펼침 → 할일 표 패널(노션식 인셋 카드, 트리 연결선 제거) */
    .pt-wrap{padding:8px 14px 14px 46px;background:transparent}
    .pt-wrap .ndb-table{background:transparent;border:0}
    /* 할일 표 테두리(둥근 카드) — 아래 테두리 유지 */
    .pt-tablewrap{position:relative;border:1px solid var(--st-border);border-radius:8px;overflow:hidden}
    /* 마지막 할일 행의 하단 구분선만 제거(카드 아래 테두리는 유지) */
    .pt-table tbody tr:last-child>td{border-bottom:0}
    .pt-addbtn{display:flex;align-items:center;gap:6px;width:100%;text-align:left;background:none;border:none;color:var(--st-text3);font-size:12.5px;padding:9px 12px;cursor:pointer;font-family:inherit;margin-top:4px}
    .pt-addbtn:hover{color:var(--p)}
