:root{--bg:#f5f7fa;--panel:#fff;--line:#e8ebf1;--line-strong:#d7dce5;--text:#1a2230;--muted:#6b7585;--faint:#9aa3b2;--brand:#2f55d4;--brand-dark:#243d8f;--brand-soft:#eef2fd;--ok:#0f9d58;--warn:#e0850b;--danger:#e0413f;--radius:10px;--radius-lg:14px;--shadow-card:0 1px 2px rgba(16,24,40,.05);--shadow-pop:0 12px 32px rgba(16,24,40,.14);--sb:#1b2130;--sb-hover:#262e40;--sb-text:#c3cbd9;--sb-label:#69748c;--sb-line:#2a3346}*{box-sizing:border-box}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Apple SD Gothic Neo,Malgun Gothic,sans-serif;background:var(--bg);color:var(--text);font-size:14px}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:218px;background:var(--sb);color:var(--sb-text);flex-shrink:0;display:flex;flex-direction:column;height:100vh;transition:width .18s ease}.logo{display:flex;flex-direction:column;align-items:flex-start;gap:5px;padding:16px 16px 14px;cursor:pointer;flex-shrink:0;border-bottom:1px solid var(--sb-line)}.logo:hover{background:var(--sb-hover)}.logo-imgwrap{display:flex;align-items:center}.logo-imgwrap img{width:auto}.logo-full{display:block;height:34px}.logo-symbol{display:none;height:34px}.logo-sub{font-weight:700;font-size:12px;color:#8b97ab;letter-spacing:-.2px;white-space:nowrap;padding-left:2px}.nav{padding:8px 10px;flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.nav::-webkit-scrollbar{width:0;height:0;display:none}.nav button,.nav a.navext{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;color:var(--sb-text);text-align:left;padding:9px 12px;border-radius:8px;cursor:pointer;font-size:13.5px;margin-bottom:1px;position:relative;white-space:nowrap;text-decoration:none;box-sizing:border-box}.nav button:hover,.nav a.navext:hover{background:var(--sb-hover);color:#fff}.nav a.navext .nav-label{flex:1}.nav a.navext .navext-ext{font-size:10px;opacity:.5;flex-shrink:0}.nav button.active{background:var(--brand);color:#fff;font-weight:600}.nav .ico{width:20px;text-align:center;flex-shrink:0;font-size:17.5px;line-height:1;color:#9aa6bc}.nav button.active .ico{color:#fff}.nav button:hover .ico{color:#dfe5ef}.nav .nav-badge{position:absolute;right:9px;top:50%;transform:translateY(-50%);background:#ef4444;color:#fff;font-size:10px;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px}.sidebar.collapsed .nav .nav-badge{right:5px;top:5px;transform:none}.nav-div{height:1px;background:var(--sb-line);margin:9px 12px 8px}.sidebar.collapsed .nav-div{margin:8px 10px}.nav-group{font-size:10.5px;font-weight:700;color:var(--sb-label);letter-spacing:.5px;padding:13px 14px 5px;text-transform:uppercase;white-space:nowrap}.sidebar.collapsed .nav-group{display:none}.sidebar.collapsed .nav-group-line{height:1px;background:var(--sb-line);margin:9px 10px 8px}.sidebar.collapsed{width:60px}.sidebar.collapsed .logo{align-items:center;padding:15px 0}.sidebar.collapsed .logo-sub,.sidebar.collapsed .logo-full{display:none}.sidebar.collapsed .logo-symbol{display:block}.sidebar.collapsed .nav{padding:8px 6px}.sidebar.collapsed .nav button,.sidebar.collapsed .nav a.navext{justify-content:center;padding:11px 0;gap:0}.sidebar.collapsed .nav a.navext .navext-ext,.sidebar.collapsed .nav-label{display:none}.sidebar.collapsed .nav .badge{position:absolute;top:3px;right:7px;margin:0;padding:0 4px;font-size:9px;line-height:14px;min-width:14px;text-align:center}.sidebar.collapsed .sb-foot{display:none}.nav .badge{margin-left:auto;background:#e5484d;color:#fff;border-radius:10px;font-size:11px;padding:1px 7px;font-weight:700}.sb-profile{display:flex;align-items:center;gap:10px;padding:11px 14px;border-top:1px solid var(--sb-line);flex-shrink:0}.sb-profile .pa{width:32px;height:32px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;letter-spacing:-.5px}.sb-profile .pmeta{min-width:0;line-height:1.3}.sb-profile .pn{font-size:12.5px;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sb-profile .pr2{font-size:10.5px;color:var(--sb-label);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar.collapsed .sb-profile{justify-content:center;padding:11px 0}.sidebar.collapsed .sb-profile .pmeta{display:none}.sb-foot{padding:11px 16px;font-size:10.5px;color:var(--sb-label);border-top:1px solid var(--sb-line);flex-shrink:0}.sb-foot-link{background:none;border:none;padding:0;margin-bottom:4px;color:var(--sb-label);font-size:11px;cursor:pointer;text-decoration:underline;text-underline-offset:2px}.sb-foot-link:hover{color:#fff}.main{flex:1;display:flex;flex-direction:column;min-width:0;height:100vh}.topbar{height:58px;flex-shrink:0;background:var(--panel);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 22px;gap:16px;position:relative}.topbar-center{position:absolute;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:10px;z-index:1}.topbar h1{font-size:16px;margin:0;font-weight:700}.topbar .spacer{flex:1}.role-switch{display:flex;align-items:center;gap:8px}.role-switch label{font-size:12px;color:var(--muted)}.role-switch select{padding:7px 10px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fff}.content{padding:22px;overflow:auto;flex:1;min-height:0}.panel{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);margin-bottom:16px;overflow:hidden;box-shadow:var(--shadow-card)}.panel-h{padding:14px 16px;border-bottom:1px solid var(--line);font-weight:700;font-size:14px;display:flex;align-items:center;gap:8px}.panel-h .pi{color:var(--brand);font-size:17px;line-height:1}.panel-h .sub{font-weight:400;color:var(--muted);font-size:12px}.panel-h .right{margin-left:auto;font-weight:400}.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:16px}.stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:16px 18px;box-shadow:var(--shadow-card)}.stat .n{font-size:28px;font-weight:800;line-height:1.1}.stat .l{color:var(--muted);font-size:12.5px;margin-top:4px}.stat.warn .n{color:#e5484d}.stat.ok .n{color:#1f9d55}.statpill{display:inline-block;border:1px solid var(--line);border-radius:22px;padding:8px 16px;font-size:13px;margin:0 8px 9px 0;background:#fff;color:#33415c}.statpill b{font-weight:800;font-size:15px;margin:0 2px}.statpill.alert{border-color:#e5484d}.footer-note{color:var(--muted);font-size:12px;line-height:1.7;padding:6px 4px 0}table{width:100%;border-collapse:collapse}th,td{text-align:left;padding:10px 14px;border-bottom:1px solid var(--line);vertical-align:top;word-break:keep-all}th{font-size:12px;color:var(--muted);font-weight:600;background:#fafbfd;position:sticky;top:0}tr:last-child td{border-bottom:none}tr.row:hover{background:#f7f9fc;cursor:pointer}td .kw{font-weight:600}td .kwbadges{display:flex;gap:5px;flex-wrap:wrap;margin-bottom:5px}td .desc{color:#445;font-size:13px}td .meta{color:var(--muted);font-size:11.5px;margin-top:3px}.rtbl{table-layout:fixed}.rtbl th{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rtbl td{overflow:hidden}.rtbl td .kw,.rtbl td .desc,.rtbl td .meta{white-space:normal;word-break:break-word}.rtbl th .sort-ind{font-size:10px;color:var(--faint)}.rtbl th:hover .sort-ind{color:var(--muted)}.rcards{display:flex;flex-direction:column;gap:8px}.rcard{border:1px solid var(--line);border-radius:10px;padding:11px 13px;cursor:pointer;background:#fff}.rcard:active{background:#f3f6fb}.rc-top{display:flex;justify-content:space-between;align-items:flex-start;gap:8px}.rc-kw{font-weight:700;font-size:14px;color:#1f2733;line-height:1.4;flex:1;min-width:0;word-break:break-word}.rc-desc{font-size:12.5px;color:#5a6678;margin-top:5px;line-height:1.55;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.rc-meta{display:flex;flex-wrap:wrap;gap:7px;align-items:center;margin-top:9px;font-size:11.5px;color:var(--muted)}.hide-mobile{display:inline}.badge-s{display:inline-block;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:700;white-space:nowrap}.s-계획{background:#ede9fe;color:#6d28d9}.s-진행중{background:#dbeafe;color:#1d4ed8}.s-완료{background:#d1fae5;color:#047857}.s-보류{background:#ffedd5;color:#c2410c}.s-지연{background:#fee2e2;color:#b91c1c}.s-이관{background:#e5e7eb;color:#4b5563}.pill{display:inline-block;padding:2px 7px;border-radius:6px;font-size:11px;font-weight:600}.pill-due{background:#fee2e2;color:#b91c1c}.pill-today{background:#ffedd5;color:#c2410e}.pill-soon{background:#fef3c7;color:#92400e}.pill-star{background:#fff7d6;color:#a16207}.pill-appr{background:#e0f2fe;color:#0369a1}.pill-rel{background:#eef2ff;color:#4338ca}.pill-collab{background:#dcfce7;color:#15803d}.pcards{display:grid;grid-template-columns:repeat(auto-fill,minmax(335px,1fr));gap:14px}.pcard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:16px;display:flex;flex-direction:column}.pcard h3{margin:0 0 4px;font-size:15px;cursor:pointer}.pcard .pdesc{color:#445;font-size:13px;margin:6px 0 12px;flex:1}.avatars{display:flex;gap:6px;flex-wrap:wrap;margin-bottom:8px}.av{display:inline-flex;align-items:center;gap:6px;background:#f1f5f9;border-radius:16px;padding:3px 10px 3px 3px;font-size:12px}.av i{width:20px;height:20px;border-radius:50%;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:10px;font-style:normal;font-weight:700}.av.fol i{background:#94a3b8}.lbl{font-size:11px;color:var(--muted);margin-bottom:5px;font-weight:600}.pcard-foot{display:flex;align-items:center;gap:8px;margin-top:10px;padding-top:12px;border-top:1px solid var(--line)}.pcard-foot .sp{flex:1;font-size:12px;color:var(--muted)}.scope{display:flex;gap:8px;margin-bottom:16px}.seg{display:inline-flex;background:#eef0f4;border-radius:10px;padding:4px;margin-bottom:16px;gap:4px}.seg button{border:none;background:none;padding:8px 18px;border-radius:8px;cursor:pointer;font-size:13.5px;font-weight:600;color:#5a6678}.seg button.active{background:#fff;color:var(--brand);box-shadow:0 1px 3px #0000001a}.seg .sgs{font-weight:500;font-size:11px;color:var(--muted);margin-left:5px}.seg button.active .sgs{color:var(--brand)}.chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.chip{padding:7px 14px;border:1px solid var(--line);background:#fff;border-radius:20px;cursor:pointer;font-size:13px;color:#445}.chip.active{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}.chip.chip-late{border-color:#fca5a5;color:#b91c1c;background:#fef2f2}.chip.chip-late.active{background:#dc2626;border-color:#dc2626;color:#fff}.chip.chip-today{border-color:#fdba74;color:#c2410e;background:#fff7ed}.chip.chip-today.active{background:#ea580c;border-color:#ea580c;color:#fff}.chip .c{margin-left:6px;opacity:.7;font-size:11px}.btn,.btn-primary,.btn-ok,.btn-warn,.btn-danger{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--text);cursor:pointer;font-size:13px;font-weight:600;line-height:1.2;white-space:nowrap;transition:background .12s,border-color .12s,box-shadow .12s,transform .04s;font-family:inherit}.btn:hover{background:#f3f5f9;border-color:var(--line-strong)}.btn:active,.btn-primary:active,.btn-ok:active,.btn-warn:active,.btn-danger:active{transform:translateY(.5px)}.btn:disabled,.btn-primary:disabled,.btn-ok:disabled,.btn-warn:disabled,.btn-danger:disabled{opacity:.5;cursor:not-allowed}.btn .ti,.btn-primary .ti,.btn-ok .ti,.btn-warn .ti,.btn-danger .ti{font-size:15px}.btn-primary{background:var(--brand);border-color:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark);border-color:var(--brand-dark)}.btn-ok{background:var(--ok);border-color:var(--ok);color:#fff}.btn-ok:hover{filter:brightness(.95);background:var(--ok)}.btn-warn{background:var(--warn);border-color:var(--warn);color:#fff}.btn-warn:hover{filter:brightness(.95);background:var(--warn)}.btn-danger{background:var(--danger);border-color:var(--danger);color:#fff}.btn-danger:hover{filter:brightness(.95);background:var(--danger)}.btn-sm{padding:5px 11px;font-size:12px;border-radius:8px}input[type=file]{font-size:13px;color:var(--muted);max-width:100%}input[type=file]::file-selector-button{margin-right:10px;padding:7px 14px;border-radius:9px;border:1px solid var(--line);background:#fff;color:var(--text);font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:background .12s,border-color .12s}input[type=file]::file-selector-button:hover{background:#f3f5f9;border-color:var(--line-strong)}.form{max-width:760px}.form .field{margin-bottom:15px}.form label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:#33415c}.form input,.form textarea,.form select{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:9px;font-size:13.5px;font-family:inherit;background:#fff;color:var(--text);transition:border-color .12s,box-shadow .12s}.form input:focus,.form textarea:focus,.form select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2f55d41f}.form textarea{min-height:64px;resize:vertical}.form .row2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.form.wide{max-width:1440px;margin:0 auto}.write-grid{display:grid;grid-template-columns:minmax(0,1.55fr) minmax(0,1fr);gap:24px;align-items:start;margin-top:4px}.write-grid .field{margin-bottom:14px}.side-card{background:#fbfcfe;border:1px solid var(--line);border-radius:12px;padding:14px 16px;margin-bottom:16px}.side-h{display:flex;align-items:center;gap:6px;font-weight:700;font-size:13px;color:#33415c;margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid var(--line)}.side-card .field{margin-bottom:12px}.side-card .field:last-child{margin-bottom:0}@media (max-width:1000px){.form.wide{max-width:100%}.write-grid{grid-template-columns:1fr;gap:0}}.form .check{display:flex;align-items:center;gap:8px;font-size:13px}.form .check input{width:auto}.hint{font-size:11.5px;color:var(--muted);margin-top:4px}.drawer-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#141c2a73;display:flex;justify-content:flex-end;z-index:50}.drawer{width:520px;max-width:92vw;background:#fff;height:100%;overflow:auto;box-shadow:-8px 0 30px #00000026}.drawer.wide{width:min(1080px,94vw)}.detail-grid{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(0,1fr);gap:24px;align-items:start}.dg-side .panel-lite{background:#f8fafc;border:1px solid var(--line);border-radius:10px;padding:12px 14px;margin-bottom:14px}.dsec{border:1px solid var(--line);border-radius:10px;padding:14px 16px;margin-bottom:14px;background:#fff}.dsec-h{font-size:11.5px;font-weight:800;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin-bottom:9px;display:flex;align-items:center;gap:6px}.dsec-h .ic{color:var(--brand);font-size:14px}.dg-side .dsec{background:#fbfcfe}.attach-chip{display:flex;align-items:center;gap:8px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:13px}.attach-chip .fi{width:26px;height:26px;border-radius:6px;background:#fef3c7;color:#b45309;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dv-card{border:1px solid var(--line);border-radius:10px;padding:12px 13px;margin-bottom:10px;background:#fff}.dv-ver{display:flex;align-items:center;gap:8px;padding:6px 0;border-top:1px solid #f1f3f7;font-size:12.5px}.dv-fb{font-size:12.5px;padding:6px 0;border-top:1px solid #f1f3f7}.dv-fb .who{font-weight:700;margin-right:5px}@media (max-width:900px){.detail-grid{grid-template-columns:1fr;gap:0}}.drawer-h{padding:18px 22px;border-bottom:1px solid var(--line);display:flex;align-items:flex-start;gap:12px}.drawer-h h2{margin:0;font-size:18px}.drawer-h .x{cursor:pointer;font-size:24px;width:38px;height:38px;flex-shrink:0;color:var(--muted);line-height:1;border:1px solid var(--line);background:#fff;border-radius:9px;display:flex;align-items:center;justify-content:center;margin-left:6px}.drawer-h .x:hover{background:#f3f5f9;color:var(--text);border-color:var(--line-strong)}.drawer-b{padding:18px 22px}.kv{display:grid;grid-template-columns:90px 1fr;gap:8px 12px;font-size:13px;margin-bottom:16px}.kv .k{color:var(--muted)}.sec-t{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.4px;margin:18px 0 8px}.rtext{white-space:pre-wrap;word-break:break-word;line-height:1.75;font-size:13.5px;color:#1f2733}.md{font-size:13.5px;line-height:1.75;color:#1f2733;word-break:break-word}.md>*:first-child{margin-top:0}.md>*:last-child{margin-bottom:0}.md p{margin:0 0 8px}.md ul,.md ol{margin:4px 0 8px;padding-left:22px}.md li{margin:2px 0}.md table{border-collapse:collapse;margin:6px 0;font-size:12.5px;max-width:100%}.md th,.md td{border:1px solid var(--line);padding:5px 9px;text-align:left}.md th{background:#f3f5f9;font-weight:700}.md code{background:#f3f5f9;padding:1px 5px;border-radius:4px;font-size:12px}.md pre{background:#f3f5f9;padding:10px;border-radius:8px;overflow-x:auto}.md pre code{background:none;padding:0}.md blockquote{border-left:3px solid var(--line);margin:6px 0;padding:2px 12px;color:#5a6678}.md h1,.md h2,.md h3,.md h4{font-size:14.5px;margin:10px 0 6px;font-weight:700}.md a{color:var(--brand)}.md hr{border:none;border-top:1px solid var(--line);margin:10px 0}.rt-wrap{border:1px solid var(--line);border-radius:8px;background:#fff;position:relative}.rt-tb{border-top-left-radius:8px;border-top-right-radius:8px}.mention-item.on{background:#eef2ff}.rt-tb{display:flex;flex-wrap:wrap;align-items:center;gap:3px;padding:6px 8px;background:#f7f9fc;border-bottom:1px solid var(--line)}.rt-btn{border:1px solid transparent;background:none;border-radius:6px;padding:4px 8px;font-size:12.5px;cursor:pointer;color:#33415c;line-height:1.2}.rt-btn:hover{background:#e7edf5;border-color:var(--line)}.rt-sep{width:1px;height:16px;background:var(--line);margin:0 3px}.rt-colors{position:absolute;top:100%;left:0;margin-top:4px;background:#fff;border:1px solid var(--line);border-radius:8px;padding:6px;display:flex;gap:5px;box-shadow:0 6px 18px #00000024;z-index:20}.rt-sw{width:18px;height:18px;border-radius:4px;cursor:pointer;border:1px solid rgba(0,0,0,.15)}.rt-ed{padding:10px 12px;outline:none;font-size:13.5px;line-height:1.75;overflow-y:auto;max-height:340px}.rt-ed:empty:before{content:attr(data-ph);color:var(--muted)}.rt-ed:focus{box-shadow:inset 0 0 0 2px #2563eb1f}.timeline .ev{border-left:2px solid var(--line);padding:0 0 14px 14px;position:relative}.timeline .ev:before{content:"";position:absolute;left:-5px;top:3px;width:8px;height:8px;border-radius:50%;background:var(--brand)}.timeline .ev .t{font-size:11px;color:var(--muted)}.timeline .ev .c{font-size:13px;margin-top:2px}.empty{padding:40px;text-align:center;color:var(--muted)}.tiles{display:grid;grid-template-columns:repeat(5,1fr);gap:12px;margin-bottom:16px}.tile{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius-lg);padding:14px;display:flex;align-items:center;gap:12px;cursor:pointer;box-shadow:var(--shadow-card);transition:border-color .12s,background .12s}.tile:hover{border-color:#cdd9f7;background:#fcfdff}.tile-ic{width:38px;height:38px;border-radius:10px;background:var(--brand-soft);color:var(--brand);display:flex;align-items:center;justify-content:center;font-size:20px;flex-shrink:0}.tile .tn{font-size:23px;font-weight:800;line-height:1.05}.tile .tl{font-size:11.5px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chart-row{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-bottom:18px}.chart-card{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px;display:flex;flex-direction:column}.chart-card .ct{font-weight:700;font-size:13.5px;margin-bottom:10px}.chart-body{display:flex;align-items:center;gap:12px}.clickable{cursor:pointer;transition:box-shadow .12s,border-color .12s}.clickable:hover{box-shadow:var(--shadow-pop);border-color:var(--brand)}.legend{font-size:12px;flex:1;min-width:0}.legend .lg{display:flex;align-items:center;gap:6px;margin-bottom:5px;white-space:nowrap}.legend .dot{width:10px;height:10px;border-radius:3px;flex-shrink:0}.legend .lv{margin-left:auto;font-weight:700}.wgrid{display:grid;grid-template-columns:repeat(3,1fr);gap:14px}.wgrid.w4{grid-template-columns:repeat(4,1fr)}.nlist .ni{display:flex;gap:8px;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px;cursor:pointer}.nlist .ni:last-child{border-bottom:none}.nlist .ni:hover .nt{color:var(--brand)}.nlist .nt{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nlist .nd{color:var(--muted);font-size:11.5px;white-space:nowrap}.tag{display:inline-block;background:#eef2ff;color:#4338ca;border-radius:5px;font-size:10.5px;padding:1px 6px;margin-right:5px;font-weight:600}.tag.imp{background:#fee2e2;color:#b91c1c}.chat{display:flex;height:calc(100vh - 140px);border:1px solid var(--line);border-radius:12px;overflow:hidden;background:#fff}.chat-list{width:230px;border-right:1px solid var(--line);overflow:auto;flex-shrink:0}.chat-list .ci{padding:12px 14px;border-bottom:1px solid var(--line);cursor:pointer;display:flex;gap:10px;align-items:center}.chat-list .ci.active{background:#eef2ff}.chat-list .ci:hover{background:#f7f9fc}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}.chat-head{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:700}.chat-body{flex:1;overflow:auto;padding:16px;background:#f4f6f9;display:flex;flex-direction:column;gap:10px}.bubble{max-width:70%;padding:9px 13px;border-radius:14px;font-size:13.5px;line-height:1.4}.bubble .bn{font-size:11px;color:var(--muted);margin-bottom:3px}.bubble.them{background:#fff;border:1px solid var(--line);align-self:flex-start;border-top-left-radius:4px}.bubble.me{background:var(--brand);color:#fff;align-self:flex-end;border-top-right-radius:4px}.bubble .bt{font-size:10px;opacity:.6;margin-top:3px;text-align:right}.chat-input{display:flex;gap:8px;padding:12px;border-top:1px solid var(--line)}.chat-input input{flex:1;padding:10px 12px;border:1px solid var(--line);border-radius:20px;font-size:13.5px}.tg-banner{background:#e7f3ff;border:1px solid #b6dcff;border-radius:10px;padding:12px 16px;margin-bottom:14px;font-size:13px;color:#0b5cab}.tg-card{display:flex;gap:10px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-radius:10px;padding:11px 13px;margin-top:8px;font-size:13px}.tg-card .tgi{width:30px;height:30px;border-radius:7px;background:#2aabee;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;flex-shrink:0}.cal-layout{display:grid;grid-template-columns:minmax(0,1fr) 380px;gap:16px;align-items:start}@media (max-width:1000px){.cal-layout{grid-template-columns:1fr}}.cal-grid{display:grid;grid-template-columns:.85fr 1.3fr 1.3fr 1.3fr 1.3fr 1.3fr .85fr;gap:7px}.cal-grid .cdow{text-align:center;font-size:13px;color:var(--muted);font-weight:700;padding:6px 0}.cal-grid .cdow.wknd{color:#b0b7c3}.cal-cell{min-height:118px;min-width:0;overflow:hidden;border:1px solid var(--line);border-radius:9px;padding:7px 8px;font-size:12.5px}.cal-cell.wknd{background:#f7f9fc;min-height:118px}.cal-cell.out{background:#fafbfd;color:#cbd2dd}.cal-cell.today{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand) inset;background:#f5f8ff}.cal-cell .cd{font-weight:700;margin-bottom:5px;font-size:13.5px}.cal-cell.wknd .cd{font-size:12px;color:var(--muted)}.cal-ev{font-size:11px;border-radius:5px;padding:2px 6px;margin-bottom:3px;color:#1f2937;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.5;cursor:pointer}.ev-list .ei{display:flex;gap:9px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}.ev-list .ei:last-child{border-bottom:none}.ev-list .ec{width:9px;height:9px;border-radius:50%;flex-shrink:0}.drive .di{display:flex;gap:9px;align-items:center;padding:9px 0;border-bottom:1px solid var(--line);font-size:13px}.drive a.di{text-decoration:none;color:inherit;cursor:pointer}.drive a.di:hover{background:#f7f9fc}.drive a.di:hover span:nth-child(2){color:var(--brand)}.drive .di:last-child{border-bottom:none}.drive .dico{width:26px;height:26px;border-radius:6px;background:#fef3c7;display:flex;align-items:center;justify-content:center;flex-shrink:0}.todo{display:flex;align-items:center;gap:11px;padding:11px 2px;border-bottom:1px solid var(--line)}.todo:last-child{border-bottom:none}.todo input[type=checkbox]{width:17px;height:17px;flex-shrink:0;cursor:pointer}.todo .tx{flex:1;font-size:13.5px}.todo.done .tx{text-decoration:line-through;color:var(--muted)}.todo .x{border:none;background:none;color:#cbd2dd;cursor:pointer;font-size:17px;line-height:1}.todo .x:hover{color:#e5484d}.pr{font-size:11px;font-weight:700;border-radius:5px;padding:2px 8px;flex-shrink:0}.pr-상{background:#fee2e2;color:#b91c1c}.pr-중{background:#fef3c7;color:#92400e}.pr-하{background:#e5e7eb;color:#4b5563}.gantt{min-width:900px}.gantt-head{display:flex;border-bottom:2px solid var(--line);padding-bottom:6px;margin-bottom:8px}.gantt-author{width:82px;flex-shrink:0;font-size:12.5px;padding-right:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gantt-row .gantt-author{font-weight:600;color:#33415c}.gantt-head .gantt-author{color:var(--muted)}.gantt-label{width:220px;flex-shrink:0;font-size:12.5px;padding-right:10px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gantt-axis{flex:1;display:flex;position:relative}.gantt-axis .gax{flex:1;font-size:11px;color:var(--muted);border-left:1px solid var(--line);padding-left:5px}.gantt-row{display:flex;align-items:center;height:36px}.gantt-row:hover{background:#f7f9fc}.gantt-label .gl-kw{font-weight:600;cursor:pointer}.gantt-track{flex:1;position:relative;height:24px}.gantt-track .grid{position:absolute;top:0;bottom:0;border-left:1px solid #f0f2f6}.gantt-bar{position:absolute;height:22px;border-radius:5px;top:1px;font-size:10.5px;color:#fff;font-weight:600;padding:0 7px;display:flex;align-items:center;overflow:hidden;white-space:nowrap;cursor:pointer;box-shadow:0 1px 2px #0000001f}.gantt-bar-lbl{position:absolute;top:1px;height:22px;display:flex;align-items:center;font-size:10.5px;font-weight:700;white-space:nowrap;cursor:pointer;pointer-events:auto}.gantt-today{position:absolute;top:-4px;bottom:-4px;width:2px;background:#dc2626;z-index:3}.gantt-today .gt-lbl{position:absolute;top:-18px;left:-14px;font-size:10px;color:#dc2626;font-weight:700;white-space:nowrap}.gantt-today-head{position:absolute;top:0;font-size:10px;color:#dc2626;font-weight:700;white-space:nowrap;transform:translate(-50%)}body.meeting{font-size:15px}body.meeting .content{padding:24px 28px}body.meeting td .desc{font-size:14.5px}body.meeting td .kw{font-size:15.5px}body.meeting .panel-h{font-size:17px}.toggle{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted);cursor:pointer}.btn-meeting{display:inline-flex;align-items:center;gap:7px;font-weight:700;font-size:13px;border:1.5px solid var(--brand);color:var(--brand);background:#fff;padding:7px 14px;border-radius:20px;cursor:pointer;white-space:nowrap}.btn-meeting:hover{background:#eef2ff}.btn-meeting.on{background:var(--brand);color:#fff;box-shadow:0 2px 8px #2f55d44d}.btn-meeting.on:hover{background:var(--brand-dark)}.btn-meeting .sw{font-size:10.5px;font-weight:700;padding:1px 7px;border-radius:10px;background:#eef2ff;color:var(--brand)}.btn-meeting.on .sw{background:#ffffff40;color:#fff}.kanban{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;align-items:flex-start}.kcol{background:#f1f3f7;border-radius:12px;min-width:210px;width:210px;flex-shrink:0;display:flex;flex-direction:column;max-height:calc(100vh - 220px)}.kcol-h{padding:11px 14px;font-weight:700;font-size:13.5px;display:flex;align-items:center;gap:7px;border-bottom:2px solid transparent}.kcol-h .cnt{margin-left:auto;background:#fff;border-radius:10px;font-size:11px;padding:1px 8px;color:var(--muted);font-weight:700}.kcol-body{padding:8px;overflow-y:auto;flex:1;min-height:60px}.kcol.drag-over{outline:2px dashed var(--brand);outline-offset:-3px}.kcard{background:#fff;border:1px solid var(--line);border-radius:9px;padding:10px 11px;margin-bottom:8px;cursor:grab;box-shadow:0 1px 2px #0000000d}.kcard:active{cursor:grabbing}.kcard .kk{font-weight:600;font-size:13px;margin:4px 0 5px}.kcard .km{color:var(--muted);font-size:11.5px;display:flex;gap:7px;flex-wrap:wrap;align-items:center}.kcard-badges{display:flex;gap:4px;flex-wrap:wrap}.org-exec{display:flex;justify-content:center;margin-bottom:8px}.org-line{height:18px;width:2px;background:var(--line);margin:0 auto}.org-branch{margin-bottom:52px}.org-branch-h{font-weight:800;font-size:15.5px;color:var(--text);margin:2px 0 14px;padding-left:11px;border-left:4px solid var(--brand);display:flex;align-items:center;gap:8px}.org-row{display:flex;justify-content:center;gap:14px;flex-wrap:wrap;margin-bottom:2px}.org-mid{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:28px}.org-ph{padding:14px;color:var(--muted);font-size:12.5px;text-align:center}.org-depts{display:grid;grid-template-columns:repeat(4,1fr);gap:14px}.org-deptcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;overflow:hidden}.org-deptcard .odh{padding:11px 14px;color:#fff;font-weight:700;font-size:14px}.org-deptcard.compact{width:66.67%;margin:0 auto}.org-deptcard.compact.start{margin:0}.org-deptcard.compact.end{margin-left:auto;margin-right:0}.org-deptcard.compact.ceo{width:44.45%}.org-tier{display:flex;justify-content:center;gap:14px;margin-bottom:28px;flex-wrap:wrap}.org-slot{flex:0 0 calc((100% - 42px)*.225)}.org-slot>.org-deptcard:not(.compact){width:100%}.person{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid var(--line);cursor:pointer}.person:last-child{border-bottom:none}.person:hover{background:#f7f9fc}.person .pav{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12.5px;letter-spacing:-.5px;flex-shrink:0}.person.lead .pav{background:var(--brand)}.person.leave{opacity:.45}.badge-leave{display:inline-block;background:#f3f4f6;color:#6b7280;font-size:10px;font-weight:700;border-radius:5px;padding:1px 5px;margin-left:5px;vertical-align:middle}.person .pinfo{flex:1;min-width:0}.person .pname{font-weight:600;font-size:13.5px}.person .ptitle{color:var(--muted);font-size:11.5px}.org-hpeople{display:flex}.org-hpeople>*{flex:1;min-width:0;border-bottom:none;border-right:1px solid var(--line)}.org-hpeople>*:last-child{border-right:none}.formcard{background:var(--panel);border:1px solid var(--line);border-radius:12px;padding:16px 18px;margin-bottom:12px;cursor:pointer}.formcard:hover{border-color:var(--brand)}.formcard h3{margin:0 0 4px;font-size:15px}.qbar-row{display:flex;align-items:center;gap:10px;margin-bottom:7px;font-size:13px}.qbar-label{width:120px;flex-shrink:0;text-align:right;color:#445;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.qbar-track{flex:1;background:#eef0f4;border-radius:6px;height:22px;position:relative;overflow:hidden}.qbar-fill{height:100%;background:var(--brand);border-radius:6px;min-width:2px}.qbar-cnt{width:54px;font-size:12px;color:var(--muted)}.stars{color:#f5a623;font-size:16px;letter-spacing:1px}.access-pill{font-size:11px;font-weight:700;border-radius:6px;padding:2px 8px}.acc-공개{background:#dcfce7;color:#15803d}.acc-승인제{background:#fef3c7;color:#92400e}.acc-제한{background:#fee2e2;color:#b91c1c}.toast-host{position:fixed;top:18px;left:50%;transform:translate(-50%);z-index:220;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{pointer-events:auto;background:#1f2733;color:#fff;padding:12px 18px;border-radius:10px;font-size:13.5px;font-weight:500;line-height:1.55;box-shadow:0 8px 28px #0000003d;max-width:560px;word-break:keep-all;cursor:pointer;animation:toastIn .18s ease}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.mention-pop{position:absolute;left:0;top:100%;z-index:80;background:#fff;border:1px solid var(--line);border-radius:8px;box-shadow:0 8px 24px #00000029;min-width:170px;max-height:210px;overflow-y:auto;margin-top:2px}.mention-item{padding:7px 11px;font-size:13px;cursor:pointer;display:flex;gap:6px;align-items:center;white-space:nowrap}.mention-item:hover{background:#eef2ff}.guide-acc{border:1px solid var(--line);border-radius:10px;margin-bottom:8px;overflow:hidden;background:#fff}.guide-q{display:flex;align-items:center;gap:8px;padding:13px 15px;cursor:pointer;font-weight:600;font-size:14px}.guide-q:hover{background:#f7f9fc}.guide-a{padding:6px 16px 14px;border-top:1px solid var(--line)}.help-btn{background:#eef2ff;color:#3730a3;border:1px solid #c7d2fe;border-radius:7px;padding:3px 9px;font-size:12px;cursor:pointer;font-weight:600;white-space:nowrap}.help-btn:hover{background:#e0e7ff}.gs-group{margin:6px 6px 10px;border:1px solid var(--line);border-radius:10px;overflow:hidden;background:#fff}.gs-head{position:sticky;top:0;z-index:1;display:flex;align-items:center;gap:8px;padding:7px 13px;background:#f1f5fb;border-bottom:1px solid var(--line)}.gs-head-label{font-size:12px;font-weight:800;color:#334155;letter-spacing:.2px}.gs-head-cnt{margin-left:auto;font-size:11px;font-weight:700;color:#475569;background:#e2e8f0;border-radius:999px;padding:1px 9px;min-width:18px;text-align:center}.gs-item{padding:9px 14px;font-size:13.5px;cursor:pointer;color:#1f2733;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;border-top:1px solid #f1f3f7}.gs-item:first-of-type{border-top:none}.gs-item:hover{background:#eef2ff}.btn-search{background:none;border:1px solid var(--line);border-radius:8px;padding:6px 12px;cursor:pointer;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:6px}.btn-search:hover{background:#f1f5f9}.bell-wrap{position:relative}.btn-bell{position:relative;width:38px;height:38px;border-radius:20px;border:1.5px solid var(--line);background:#fff;font-size:17px;cursor:pointer;line-height:1}.btn-bell:hover{background:#f1f5f9}.bell-badge{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;border-radius:9px;background:#dc2626;color:#fff;font-size:11px;font-weight:700;display:flex;align-items:center;justify-content:center;border:2px solid #fff}.noti-pop{position:absolute;top:46px;right:0;width:360px;max-width:88vw;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 36px #00000029;z-index:50;overflow:hidden}.noti-h{display:flex;align-items:center;gap:8px;padding:12px 14px;border-bottom:1px solid var(--line)}.noti-list{max-height:420px;overflow:auto}.noti-item{display:flex;gap:10px;align-items:flex-start;padding:11px 14px;border-bottom:1px solid var(--line);cursor:pointer}.noti-item:hover{background:#f7f9fc}.noti-item.read{opacity:.55}.noti-ic{font-size:16px;line-height:1.3}.noti-t{font-size:13px;font-weight:600;color:#1e293b;word-break:keep-all}.noti-s{font-size:11.5px;color:var(--muted);margin-top:2px}.noti-dot{width:8px;height:8px;border-radius:50%;background:#2f55d4;flex-shrink:0;margin-top:5px}.hamburger{display:none;width:38px;height:38px;flex-shrink:0;border:1.5px solid var(--line);background:#fff;border-radius:9px;font-size:18px;line-height:1;cursor:pointer;color:#33415c}.hamburger:hover{background:#f1f5f9}.nav-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f162673;z-index:110}.lvcal-bar{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-wrap:wrap}.lvcal-head,.lvcal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:6px}.lvcal-head{margin-bottom:6px}.lvcal-head .d{text-align:center;font-size:12px;font-weight:700;color:var(--muted);padding:4px 0}.lvcal-head .d.sun{color:#dc2626}.lvcal-head .d.sat{color:#2563eb}.lvcal-cell{min-height:94px;border:1px solid var(--line);border-radius:8px;padding:5px 6px;cursor:pointer;overflow:hidden;background:#fff}.lvcal-cell:hover{background:#f7f9fc}.lvcal-cell.other{background:#fafbfd;color:#cbd2dd}.lvcal-cell.today{border-color:var(--brand);box-shadow:0 0 0 1px var(--brand) inset}.lvcal-cell.holiday{background:#fef2f2}.lvcal-cell .dt{font-size:12.5px;font-weight:700;margin-bottom:3px}.lvcal-cell .dt.sun{color:#dc2626}.lvcal-cell .dt.sat{color:#2563eb}.lvcal-ev{font-size:10.5px;color:#fff;border-radius:4px;padding:1px 5px;margin-bottom:2px;white-space:normal;word-break:keep-all;overflow-wrap:break-word;line-height:1.35}.lvcal-ev.pending{border:1.5px dashed rgba(255,255,255,.95)}.lvcal-hol{font-size:10px;color:#dc2626;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.lvcal-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;font-size:12px;color:#445}.lvcal-legend .lg{display:flex;align-items:center;gap:5px}.lvcal-legend .dot{width:10px;height:10px;border-radius:3px}.lv-calc{background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;padding:9px 12px;font-size:13.5px;color:#1e40af;margin-bottom:14px}.lv-mini{font-size:13px;color:#5a6678;white-space:nowrap}.lv-mini b{font-size:17px;font-weight:800;color:#1f2733;margin:0 3px}.lv-lead{background:#fffbeb;border:1px solid #fde68a;border-radius:8px;padding:9px 12px;font-size:12.5px;color:#92400e;margin-bottom:14px}.dash-grid{display:grid;grid-template-columns:minmax(0,1.7fr) minmax(0,1fr);gap:16px;align-items:start;margin-bottom:16px}.dash-side{display:flex;flex-direction:column}.dash-side .panel,.dash-side .chart-card{margin-bottom:14px}.dash-cards4{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:16px;margin-bottom:16px;align-items:stretch}.dash-cards4 .chart-card .chart-body{flex:1}.chart-fill{flex:1;display:flex;flex-direction:column;justify-content:center}.dash-col4{display:flex;flex-direction:column;gap:14px}.dash-cards4>.panel{margin:0}.dash-col4 .panel{margin:0}@media (max-width:1000px){.dash-cards4{grid-template-columns:1fr 1fr}}@media (max-width:600px){.dash-cards4{grid-template-columns:1fr}}.dash.present .dash-cards4,.dash.present .tiles{display:none}.dash.present .panel-h{font-size:17px}.dash.present .rtbl{font-size:15.5px}.dash.present .rtbl th{font-size:13px;padding:10px 12px}.dash.present .rtbl td{padding:12px}.dash.present .badge-s{font-size:13px;padding:3px 10px}.btn-new{display:inline-flex;align-items:center;gap:6px;background:var(--brand);color:#fff;border:none;border-radius:9px;padding:8px 14px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap}.btn-new:hover{background:var(--brand-dark)}.btn-new .ti{font-size:15px}.role-preview{display:inline-flex;align-items:center;gap:5px;font-size:12px;color:var(--muted);flex-shrink:0}.role-preview .ti{font-size:15px}.role-preview select{border:1px solid var(--line);border-radius:8px;padding:5px 7px;font-size:12px;background:#fff;color:var(--text);cursor:pointer;max-width:130px}.role-preview select.on{border-color:#f59e0b;background:#fffbeb;color:#b45309;font-weight:700}.role-preview .rp-exit{border:none;background:#fde68a;color:#92400e;border-radius:6px;width:20px;height:20px;font-size:11px;cursor:pointer;line-height:1}.preview-banner{display:flex;align-items:center;gap:7px;background:#fffbeb;border-bottom:1px solid #fcd34d;color:#92400e;font-size:12.5px;padding:7px 18px;flex-shrink:0}.preview-banner .ti{font-size:15px}.preview-banner button{margin-left:auto;border:1px solid #fcd34d;background:#fff;color:#b45309;border-radius:7px;padding:4px 10px;font-size:12px;font-weight:600;cursor:pointer}.preview-banner button:hover{background:#fef3c7}.topbar .ava{width:32px;height:32px;border-radius:50%;background:var(--brand);color:#fff;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex-shrink:0;letter-spacing:-.5px}.topbar-search{display:flex;align-items:center;gap:7px;background:#f1f3f7;border:1px solid var(--line);border-radius:9px;padding:7px 13px;width:320px;color:var(--muted);font-size:12.5px;cursor:pointer}.topbar-search:hover{background:#eaeef4;border-color:var(--line-strong)}.topbar-search .ti{font-size:15px}.topbar-search .kbd{margin-left:auto;font-size:10px;background:#fff;border:1px solid var(--line-strong);border-radius:4px;padding:0 5px;color:var(--faint)}@media (max-width:820px){.dash-grid{grid-template-columns:1fr}.topbar-search{width:auto;padding:7px 9px}.topbar-center{position:static;transform:none;order:5;flex-basis:100%;justify-content:flex-start;gap:8px}.sidebar{position:fixed;left:0;top:0;z-index:120;height:100vh;width:230px;transform:translate(-100%);transition:transform .2s ease;box-shadow:2px 0 18px #00000040}.sidebar.nav-open{transform:translate(0)}.sidebar.collapsed{width:230px}.sidebar.collapsed .logo{align-items:flex-start;padding:15px 16px 13px}.sidebar.collapsed .logo-full{display:block}.sidebar.collapsed .logo-symbol{display:none}.sidebar.collapsed .logo-sub{display:block}.sidebar.collapsed .nav{padding:8px 10px}.sidebar.collapsed .nav button,.sidebar.collapsed .nav a.navext{justify-content:flex-start;padding:10px 12px;gap:9px}.sidebar.collapsed .nav a.navext .navext-ext,.sidebar.collapsed .nav-label{display:inline}.sidebar.collapsed .nav .badge{position:static;margin-left:auto;font-size:11px;line-height:1.4;min-width:0;padding:1px 7px}.sidebar.collapsed .sb-foot{display:block}.hamburger{display:inline-flex;align-items:center;justify-content:center}.hide-mobile{display:none}.noti-pop{position:fixed;top:64px;left:8px;right:8px;width:auto;max-width:none}.noti-list{max-height:70vh}.topbar{height:auto;min-height:54px;padding:8px 12px;gap:8px;flex-wrap:wrap}.topbar h1{font-size:15px}.role-switch label{display:none}.role-switch select{padding:6px 8px;font-size:12.5px}.btn-meeting{padding:6px 10px;font-size:12px}.content{padding:14px 12px}.stats{grid-template-columns:repeat(2,1fr);gap:10px}.tiles{grid-template-columns:repeat(5,1fr);gap:6px}.tile{flex-direction:column;align-items:center;text-align:center;padding:9px 3px;gap:2px}.tile-ic{width:26px;height:26px;font-size:15px;border-radius:7px}.tile .tl{font-size:9px;line-height:1.15;margin-top:1px;word-break:keep-all}.chart-row,.wgrid,.wgrid.w4,.org-depts{grid-template-columns:1fr}.org-slot{flex-basis:100%}.org-slot:empty{display:none}.pcards,.form .row2{grid-template-columns:1fr}.form{max-width:100%}.stat .n{font-size:24px}.tile .tn{font-size:15px}.panel{overflow-x:auto}.panel>table,.panel-h+table,.content>table{min-width:600px}.drawer{width:100%;max-width:100%}.kv{grid-template-columns:80px 1fr}.seg{display:flex;overflow-x:auto;max-width:100%}.seg button{white-space:nowrap;flex-shrink:0}}@media (max-width:480px){.stats{grid-template-columns:1fr 1fr}.tiles{grid-template-columns:repeat(5,1fr)}.topbar h1{font-size:14px}.content{padding:12px 10px}}.muted{color:var(--muted)}.sm{font-size:13px}.xs{font-size:11.5px}.row:not(tr){display:flex;align-items:center;gap:12px}.center{min-height:100vh;display:flex;align-items:center;justify-content:center;flex-direction:column}.inp{padding:8px 12px;border:1px solid var(--line);border-radius:9px;font-size:13px;background:#fff;font-family:inherit;color:var(--text);transition:border-color .12s,box-shadow .12s}.inp:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px #2f55d41f}.btn-ghost{display:inline-flex;align-items:center;gap:5px;padding:7px 13px;border:1px solid var(--line);border-radius:9px;background:#fff;font-size:13px;cursor:pointer;font-weight:600;color:var(--text);transition:background .12s,border-color .12s}.btn-ghost:hover{background:#f3f5f9;border-color:var(--line-strong)}.btn-ghost:disabled{opacity:.45;cursor:not-allowed}.warn{background:#fff7ed;color:#c2410e;border:1px solid #fed7aa;border-radius:8px;padding:10px 12px;font-size:12.5px;line-height:1.6}code{background:#eef1f7;padding:1px 5px;border-radius:4px;font-size:12px}.card{background:#fff;border:1px solid var(--line);border-radius:14px;padding:30px 28px;box-shadow:0 4px 24px #141e3c0f}.login{width:340px;text-align:center;display:flex;flex-direction:column;gap:12px}.login-logo{width:190px;height:auto;align-self:center;margin:4px 0 0}.login-sub{color:var(--muted);font-size:13.5px;letter-spacing:1px;margin-bottom:6px}.brand{font-size:20px;font-weight:800;color:var(--brand)}.btn-google{margin-top:8px;padding:12px 16px;border:1px solid var(--line);border-radius:10px;background:#fff;font-size:14px;font-weight:600;cursor:pointer}.btn-google:hover:not(:disabled){background:#f0f3ff;border-color:var(--brand)}.btn-google:disabled{opacity:.5;cursor:not-allowed}.checklist{list-style:none;padding:0;display:flex;flex-direction:column;gap:8px;max-width:620px}.checklist li{background:#fff;border:1px solid var(--line);border-radius:8px;padding:10px 14px;font-size:14px}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#141c2a73;display:flex;justify-content:flex-end;z-index:50}.drawer-body{padding:18px 22px 60px}.hist{display:flex;align-items:center;gap:8px;padding:7px 0;border-bottom:1px solid #f1f5f9;font-size:13px}.deliv{border:1px solid var(--line);border-radius:8px;padding:10px 12px;margin-bottom:8px}.fld{display:flex;flex-direction:column;gap:5px;margin-bottom:12px}.fld>label{font-size:12px;font-weight:600;color:#33415c}.req{color:#e11d48}.fld2{display:grid;grid-template-columns:1fr 1fr;gap:12px}.chk{display:flex;align-items:center;gap:7px;font-size:13.5px;cursor:pointer;padding:9px 0}.chk input{width:16px;height:16px}.stat-cards{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}@media (max-width:760px){.stat-cards{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.stats3{grid-template-columns:1fr!important}}.sc{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;text-align:center}.sc-n{font-size:23px;font-weight:800}.sc-l{font-size:11.5px;color:var(--muted);margin-top:3px}.bar-wrap{position:relative;background:#eef0f4;border-radius:6px;height:18px;min-width:90px;overflow:hidden}.bar{position:absolute;left:0;top:0;bottom:0;background:#16a34a;border-radius:6px}.bar-t{position:relative;font-size:11px;line-height:18px;padding-left:7px;color:#1f2937;font-weight:600}.tab{padding:7px 14px;border:1px solid var(--line);background:#fff;border-radius:8px;font-size:13px;cursor:pointer;color:#445}.tab.on{background:var(--brand);border-color:var(--brand);color:#fff;font-weight:600}.list-item{padding:12px 16px;border-bottom:1px solid #f1f5f9;font-size:13.5px}.list-item:last-child{border-bottom:none}.cards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.ccard{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;cursor:pointer}.ccard:hover{border-color:var(--brand);box-shadow:0 2px 10px #141e3c0f}.crumbs{margin-bottom:12px;font-size:13.5px}.crumb{color:var(--brand);cursor:pointer}.crumb:hover{text-decoration:underline}.lv-summary{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;max-width:560px}.lv-card{background:#fff;border:1px solid var(--line);border-radius:12px;padding:14px;text-align:center}.lv-n{font-size:24px;font-weight:800}.lv-l{font-size:12px;color:var(--muted);margin-top:3px}.rtbl th{position:static}.btx-load{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:9999;background:radial-gradient(120% 120% at 50% 0%,#3a93f2,#1e63c7 45%,#0b2e66)}.btx-load-inner{display:flex;flex-direction:column;align-items:center;animation:btxFade .5s ease}.btx-load-logo{height:50px;animation:btxPulse 1.9s ease-in-out infinite}.btx-load-logo img{height:100%;width:auto;display:block;filter:drop-shadow(0 4px 16px rgba(0,0,0,.25))}.btx-load-title{margin-top:16px;color:#fff;font-size:15px;font-weight:300;letter-spacing:7px;padding-left:7px;opacity:.92}.btx-load-bar{margin-top:26px;width:170px;height:3px;border-radius:3px;background:#ffffff38;overflow:hidden;position:relative}.btx-load-bar span{position:absolute;top:0;left:0;height:100%;width:42%;border-radius:3px;background:linear-gradient(90deg,#fff3,#fff);animation:btxSlide 1.25s cubic-bezier(.4,0,.2,1) infinite}.btx-load-text{margin-top:14px;color:#ffffffb3;font-size:12.5px;letter-spacing:.5px}@keyframes btxPulse{0%,to{opacity:.85;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}@keyframes btxSlide{0%{transform:translate(-130%)}to{transform:translate(320%)}}@keyframes btxFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}.drive-list{width:100%}.drive-row{display:flex;align-items:center;padding:10px 16px;border-bottom:1px solid var(--line)}.drive-row:last-child{border-bottom:none}.drive-head{font-size:11.5px;font-weight:700;color:var(--muted);background:#f8fafc}.drive-head .sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.drive-head .sortable:hover{color:var(--text)}.drive-head .sort-ind{font-size:9.5px;color:var(--faint);margin-left:2px}.drive-head .sortable:hover .sort-ind{color:var(--muted)}.drive-row.body:hover{background:#f7f9fc}.drive-name{flex:1 1 auto;min-width:160px;display:flex;align-items:flex-start;gap:9px;cursor:pointer;padding-right:18px}.drive-head .drive-name{cursor:default;align-items:center}.drive-name .di{flex-shrink:0;line-height:1.4}.drive-name .dnm{word-break:break-all;line-height:1.4;font-size:13.5px;color:var(--text)}.drive-name .dnm.folder{font-weight:700}.drive-row .dc{flex:0 0 auto;font-size:12.5px;color:var(--muted);white-space:nowrap;padding-right:14px}.dc-date{width:124px}.dc-user{width:104px;overflow:hidden;text-overflow:ellipsis}.dc-size{width:60px;text-align:right;padding-right:18px}.dc-dl{flex:0 0 auto;width:108px;text-align:right}.btn-dl{display:inline-flex;align-items:center;gap:5px;padding:5px 11px;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--brand);font-size:12.5px;font-weight:600;text-decoration:none;white-space:nowrap;cursor:pointer}.btn-dl:hover{background:#f0f3ff;border-color:var(--brand)}.mtg-rec{display:flex;gap:16px;align-items:stretch}.mtg-side{width:280px;flex-shrink:0;display:flex;flex-direction:column;gap:12px}.mtg-main{flex:1;display:flex;flex-direction:column;min-width:0}.mtg-dot{width:6px;height:6px;border-radius:50%;background:#b91c1c;animation:btxPulse 1s infinite}@media (max-width:820px){.mtg-rec{flex-direction:column}.mtg-side{width:100%}}.rec-pill{display:inline-flex;align-items:center;gap:6px;margin-left:12px;background:#fee2e2;color:#b91c1c;border:1px solid #fca5a5;border-radius:20px;padding:5px 12px;font-size:12px;font-weight:800;cursor:pointer;font-variant-numeric:tabular-nums;letter-spacing:.3px}.rec-pill:hover{background:#fecaca}.tpl-chip{display:inline-flex;align-items:center;gap:6px;background:#eef2ff;border:1px solid #d6e0fb;border-radius:16px;padding:4px 10px;font-size:12.5px;color:#33415c}.tpl-chip .tpl-ic{font-size:13px;color:var(--muted);cursor:pointer}.tpl-chip .tpl-ic:hover{color:var(--brand)}.todo-drag{display:inline-flex;align-items:center;color:#c0c5d0;cursor:grab;padding:2px;flex-shrink:0}.todo-drag:active{cursor:grabbing}.todo-drag:hover{color:var(--muted)}.field label{display:block;font-size:12.5px;font-weight:600;margin-bottom:6px;color:#33415c}.toast-host{position:fixed;top:64px;left:50%;transform:translate(-50%);z-index:300;display:flex;flex-direction:column;gap:8px;align-items:center;pointer-events:none}.toast{pointer-events:auto;display:inline-flex;align-items:center;gap:8px;color:#fff;padding:10px 16px;border-radius:10px;font-size:13.5px;font-weight:600;box-shadow:0 8px 24px #0003;cursor:pointer;max-width:90vw;animation:toastIn .18s ease}.toast i{font-size:16px}.toast-success{background:#0f7a4d}.toast-error{background:#b91c1c}.toast-info{background:#1b2333}@keyframes toastIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:none}}
