*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Pretendard Variable,Pretendard,Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:#d1d5db;color:#1e293b}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}.app{display:flex;flex-direction:column;min-height:100vh}.header{background:#1e293b;color:#f1f5f9;height:44px;padding:0 20px;display:flex;align-items:center;justify-content:space-between;position:sticky;top:0;z-index:200;box-shadow:0 2px 8px #0006}.header-left{display:flex;align-items:center;gap:8px}.header-logo{background:#3b82f6;color:#fff;font-size:11px;font-weight:800;padding:2px 8px;border-radius:4px}.header-title{font-size:14px;font-weight:600}.header-version{font-size:10px;color:#94a3b8;font-weight:500;cursor:pointer;position:relative;padding:2px 5px;border-radius:4px}.header-version:hover{background:#f1f5f9;color:#475569}.version-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:99}.version-popup{position:absolute;top:28px;left:0;z-index:100;background:#fff;border:1px solid #E2E8F0;border-radius:10px;box-shadow:0 8px 24px #0000001f;padding:16px;min-width:240px;max-height:420px;overflow-y:auto}.version-popup-title{font-size:12px;font-weight:700;color:#475569;margin-bottom:12px}.version-entry{margin-bottom:12px}.version-entry:last-child{margin-bottom:0}.version-entry-header{display:flex;align-items:center;gap:8px;margin-bottom:6px}.version-badge{background:#3b82f6;color:#fff;font-size:11px;font-weight:700;padding:1px 7px;border-radius:20px}.version-date{font-size:11px;color:#94a3b8}.version-notes{margin:0;padding-left:16px}.version-notes li{font-size:12px;color:#475569;line-height:1.8}.header-center{display:flex;align-items:center;gap:12px}.month-label{font-size:17px;font-weight:800;min-width:130px;text-align:center}.nav-btn{background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;font-size:20px;width:32px;height:32px;border-radius:6px;display:flex;align-items:center;justify-content:center}.nav-btn:hover{background:#fff3}.header-right{display:flex;align-items:center;gap:8px}.presence{display:flex;align-items:center;gap:6px;font-size:12px;opacity:.75}.presence-dot{width:6px;height:6px;border-radius:50%;background:#22c55e;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.3}}.presence-count{white-space:nowrap}.avatar-stack{display:flex}.user-avatar{width:26px;height:26px;border-radius:50%;border:2px solid #1E293B;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;margin-left:-6px}.user-avatar:first-child{margin-left:0}.user-avatar.more{background:#475569}.me-btn{display:flex;align-items:center;gap:5px;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);color:#fff;padding:5px 10px;border-radius:16px;font-size:12px;font-weight:500}.me-btn:hover{background:#ffffff2e}.me-dot{width:7px;height:7px;border-radius:50;flex-shrink:0}.view-tabs{display:flex;gap:0;background:#f1f5f9;border-bottom:2px solid #CBD5E1;padding:0 16px}.view-tab{padding:8px 20px;font-size:13px;font-weight:600;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .15s,border-color .15s}.view-tab:hover{color:#1e293b}.view-tab.active{color:#2563eb;border-bottom-color:#2563eb;background:none}.mode-toggle{margin-left:auto;align-self:center;padding:4px 14px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;border:1.5px solid #CBD5E1;background:#f8fafc;color:#94a3b8;transition:all .2s;letter-spacing:-.2px;white-space:nowrap}.mode-toggle.edit{border-color:#2563eb;background:#eff6ff;color:#2563eb}.mode-toggle:hover{opacity:.8}.fill-btn{margin-left:8px;align-self:center;padding:5px 12px;font-size:12px;font-weight:600;border:1.5px solid #059669;border-radius:6px;background:#ecfdf5;color:#059669;cursor:pointer;white-space:nowrap}.fill-btn:hover{background:#d1fae5}.grid-wrapper{flex:1;padding:8px 12px;overflow:hidden}.grid-scroll{overflow:auto;max-height:calc(100vh - 100px);border-radius:6px;box-shadow:0 1px 6px #00000014;border:1px solid #E2E8F0}.cal-table{min-width:100%;width:max-content;border-collapse:collapse}.cal-table.personal-view{width:100%;table-layout:fixed}.cal-table.personal-view .th-date{width:40px}.cal-table.personal-view .th-dow{width:34px}.cal-table.personal-view .th-event{width:60px}.cal-table.personal-view .th-note{width:260px}.cal-table.personal-view .td-event{overflow:hidden}.cal-table.personal-view .event-name{overflow:hidden;text-overflow:ellipsis}.cal-table.personal-view .td-sch{min-width:0}.cal-table.personal-view .sch-pill{font-size:9px;padding:1px 5px}.cal-table.personal-view .sch-loc{font-size:10px}.cal-table thead{position:sticky;top:0;z-index:100;box-shadow:0 1px 4px #00000014}.thead-row th{background:#fff;color:#475569;padding:4px;text-align:center;border:none;border-bottom:2px solid #CBD5E1;border-right:1px solid #D1D5DB;font-size:11px;font-weight:600;white-space:nowrap}.th-date{width:36px;border-right:1.5px solid #CBD5E1!important}.th-dow{width:30px;border-right:2px solid #94A3B8!important}.th-event{width:100px;max-width:100px;border-right:2px solid #94A3B8!important}.th-staff{min-width:72px;width:80px;border-right:2px solid #94A3B8!important}.th-note{min-width:200px;width:240px;border-left:2px solid #94A3B8!important}.thead-row .th-date{position:sticky;left:0;z-index:110;background:#fff}.thead-row .th-dow{position:sticky;left:36px;z-index:110;background:#fff}.th-role{font-size:8px;color:#94a3b8;font-weight:500;line-height:1.2}.th-name{font-size:11px;font-weight:700;color:#1e293b;line-height:1.3}.day-row td{background:#fff;border:none;border-bottom:2px solid #B8BCC8;height:28px;line-height:1;vertical-align:middle;padding:0}.day-row.week-sep td{border-top:2.5px solid #94A3B8!important}.day-row.sunday td{border-bottom:2.5px solid #94A3B8!important}.day-row.saturday td,.day-row.sunday td,.day-row.holiday td{background:#fef7f7}.day-row.saturday .td-event,.day-row.saturday .td-note,.day-row.sunday .td-event,.day-row.sunday .td-note,.day-row.holiday .td-event,.day-row.holiday .td-note,.td-date,.td-dow{background:#fff!important}.day-row.saturday .td-date,.day-row.saturday .td-dow,.day-row.sunday .td-date,.day-row.sunday .td-dow,.day-row.holiday .td-date,.day-row.holiday .td-dow{background:#fddede!important}.cal-table.personal-view .day-row.saturday td:not(.td-sch),.cal-table.personal-view .day-row.sunday td:not(.td-sch),.cal-table.personal-view .day-row.holiday td:not(.td-sch){background:#fff!important}.cal-table.personal-view .day-row.saturday .td-sch.empty,.cal-table.personal-view .day-row.sunday .td-sch.empty,.cal-table.personal-view .day-row.holiday .td-sch.empty{background:#fff!important}.day-row:hover td{background:#eff6ff}.day-row:hover .td-date,.day-row:hover .td-dow{background:#dbeafe!important}.td-date{text-align:center;font-size:12px;font-weight:600;color:#374151;cursor:pointer;position:sticky;left:0;z-index:5;padding:0 4px;border-right:1.5px solid #CBD5E1!important}.td-date:hover{background:#dbeafe!important}.today-badge{display:inline-flex;align-items:center;justify-content:center;width:20px;height:20px;border-radius:50%;background:#2563eb;color:#fff;font-size:10px;font-weight:800}.red-text{color:#dc2626!important;font-weight:700}.day-row.sunday .td-date,.day-row.sunday .td-dow,.day-row.saturday .td-date,.day-row.saturday .td-dow,.day-row.holiday .td-date,.day-row.holiday .td-dow{color:#dc2626;font-weight:700}.td-dow{text-align:center;font-size:11px;color:#64748b;font-weight:500;position:sticky;left:36px;z-index:5;border-right:2px solid #CBD5E1!important}.td-event{padding:0 4px;text-align:center;border-right:2px solid #94A3B8!important;overflow:hidden}.td-event-admin{cursor:pointer}.td-event-admin:hover{background:#f0f9ff!important}.event-cell-wrap{width:108px;max-width:108px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:center;margin:0 auto}.event-name{font-size:11px;font-weight:600;color:#1e293b;white-space:nowrap;display:inline}.event-placeholder{font-size:16px;color:#e2e8f0;font-weight:300}.day-row.saturday .event-name,.day-row.sunday .event-name,.day-row.holiday .event-name{color:#dc2626}.td-note{border-left:2px solid #94A3B8!important;padding:0 10px;font-size:11.5px;color:#64748b;min-width:240px;vertical-align:middle;text-align:center}.td-note-admin{cursor:pointer}.td-note-admin:hover{background:#f8faff!important}.td-note-text{font-size:11.5px;color:#374151;white-space:nowrap;display:block}.td-note-placeholder{font-size:11px;color:#cbd5e1;font-style:italic}.non-admin .td-sch.empty,.non-admin .td-date{cursor:default!important}.td-sch{padding:0 4px!important;cursor:pointer;min-width:72px;position:relative;border-right:2px solid #94A3B8!important;-webkit-user-select:none;user-select:none;text-align:center;vertical-align:middle}.td-sch.empty{background:inherit!important}.td-sch.empty:hover{background:#eff6ff!important}.td-sch.filled:hover{filter:brightness(.93)}.sch-row{display:flex;flex-direction:row;align-items:center;justify-content:center;gap:3px;overflow:hidden;width:100%}.sch-code{flex-shrink:0;font-size:10px;font-weight:800;line-height:1;white-space:nowrap;letter-spacing:.2px}.sch-loc{font-size:10px;font-weight:600;color:inherit;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sch-dot{position:absolute;top:3px;right:3px;width:5px;height:5px;border-radius:50%;background:#00000040}.cell-selected:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#7c3aed33;border:2px solid #7C3AED;pointer-events:none;z-index:1}.app.dragging{-webkit-user-select:none;user-select:none}.bulk-summary{padding:10px 20px;background:#f8fafc;border-bottom:1px solid #E2E8F0;display:flex;flex-direction:column;gap:4px;max-height:120px;overflow-y:auto}.bulk-row{display:flex;align-items:center;gap:10px;font-size:12px}.bulk-name{font-weight:700;color:#1e293b;min-width:60px}.bulk-days{color:#64748b}.btn-bulk{background:#7c3aed!important}.btn-bulk:hover:not(:disabled){background:#6d28d9!important}.modal-picker-wrap{padding:10px 20px 4px;background:#f8fafc;border-bottom:1px solid #E2E8F0}.mf-label-sm{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.3px;margin-bottom:8px}.wcp-wrap{display:flex;flex-direction:column;gap:6px}.wcp-group{display:flex;align-items:center;gap:6px}.wcp-label{font-size:10px;font-weight:700;color:#94a3b8;min-width:52px;text-align:right;flex-shrink:0}.wcp-row{display:flex;flex-wrap:wrap;gap:4px}.wcp-btn{border:1.5px solid rgba(0,0,0,.12);border-radius:6px;padding:4px 8px;cursor:pointer;display:flex;flex-direction:column;align-items:center;min-width:44px;transition:filter .1s,box-shadow .1s}.wcp-btn:hover{filter:brightness(.93)}.wcp-code{font-size:12px;font-weight:800;line-height:1.3}.wcp-desc{font-size:9px;opacity:.7;line-height:1.2;white-space:nowrap}.wcp-selected{border-color:#2563eb!important}.undo-btn{background:#ffffff1f;border:1px solid rgba(255,255,255,.25);color:#fff;padding:5px 11px;border-radius:6px;font-size:12px;font-weight:600;cursor:pointer}.undo-btn:hover{background:#ffffff38}.undo-disabled{opacity:.35;cursor:not-allowed}.undo-disabled:hover{background:#ffffff1f}.toast{position:fixed;bottom:28px;left:50%;transform:translate(-50%);background:#1e293b;color:#fff;padding:10px 22px;border-radius:8px;font-size:13px;font-weight:600;box-shadow:0 4px 16px #0000004d;z-index:9999;animation:fadeInUp .2s ease}@keyframes fadeInUp{0%{opacity:0;transform:translate(-50%) translateY(8px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.loading{display:flex;align-items:center;justify-content:center;gap:12px;height:calc(100vh - 68px);color:#64748b;font-size:15px}.spinner{width:24px;height:24px;border:3px solid #E2E8F0;border-top-color:#3b82f6;border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000008c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px)}.modal{background:#fff;border-radius:14px;width:100%;max-width:760px;box-shadow:0 24px 64px #0000004d;overflow:hidden;animation:slideUp .16s ease}.modal-sm{max-width:420px}@keyframes slideUp{0%{opacity:0;transform:translateY(14px)}to{opacity:1;transform:translateY(0)}}.modal-head{background:#1e293b;color:#fff;padding:16px 20px;display:flex;align-items:flex-start;justify-content:space-between}.mh-name{font-size:19px;font-weight:800}.mh-date{font-size:12px;opacity:.65;margin-top:2px}.mh-close{background:none;border:none;color:#fff9;font-size:19px;padding:2px 5px;border-radius:4px}.mh-close:hover{background:#ffffff1f;color:#fff}.modal-info{display:flex;gap:10px;padding:12px 20px;background:#f8fafc;border-bottom:1px solid #E2E8F0;align-items:center}.modal-readonly-row{display:flex;align-items:center;gap:10px}.readonly-code{font-size:15px;font-weight:800;color:#1e293b;background:#e2e8f0;padding:4px 10px;border-radius:5px}.readonly-loc{font-size:13px;color:#475569}.readonly-empty{font-size:13px;color:#94a3b8;font-style:italic}.readonly-time-badge{display:inline-flex;align-items:center;font-size:12px;font-weight:700;color:#9a3412;background:#fff7ed;border:1.5px solid #FED7AA;padding:3px 9px;border-radius:5px;white-space:nowrap}.modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:14px;max-height:65vh;overflow-y:auto}.mf-group{display:flex;flex-direction:column;gap:5px}.mf-group.half{flex:1}.mf-group label{font-size:11px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.3px}.mf-group input,.mf-group select,.mf-group textarea{border:1.5px solid #E2E8F0;border-radius:7px;padding:8px 11px;font-size:13px;color:#1e293b;background:#fff;transition:border-color .15s;resize:vertical}.mf-group input:focus,.mf-group select:focus,.mf-group textarea:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.mf-group textarea{min-height:100px}.modal-err{margin:0 20px 12px;padding:9px 12px;background:#fee2e2;color:#991b1b;border-radius:7px;font-size:12px}.modal-foot{padding:12px 20px;border-top:1px solid #F1F5F9;display:flex;align-items:center;justify-content:space-between}.modal-meta{font-size:11px;color:#94a3b8}.modal-btns{display:flex;gap:8px}.hist-btn{font-size:11px;color:#64748b;background:none;border:1px solid #CBD5E1;border-radius:5px;padding:3px 8px;cursor:pointer}.hist-btn:hover{background:#f1f5f9}.hist-panel{border-top:1px solid #E2E8F0;padding:8px 16px;max-height:160px;overflow-y:auto;background:#f8fafc;flex-shrink:0}.hist-empty{font-size:12px;color:#94a3b8;text-align:center;padding:8px 0}.hist-row{display:flex;align-items:center;gap:8px;padding:4px 0;border-bottom:1px solid #E2E8F0;font-size:12px}.hist-row:last-child{border-bottom:none}.hist-who{font-weight:600;color:#1e293b;min-width:48px}.hist-when{color:#94a3b8;min-width:90px}.hist-diff{color:#475569;flex:1}.btn-cancel{background:#fff;border:1.5px solid #D1D5DB;color:#374151;padding:8px 18px;border-radius:7px;font-size:13px;font-weight:500}.btn-cancel:hover{background:#f9fafb}.btn-save{background:#2563eb;border:none;color:#fff;padding:8px 22px;border-radius:7px;font-size:13px;font-weight:700}.btn-save:hover:not(:disabled){background:#1d4ed8}.btn-save:disabled{opacity:.5;cursor:not-allowed}.modal-resize-handle{position:absolute;bottom:0;right:0;width:18px;height:18px;cursor:se-resize;border-bottom-right-radius:14px;background:linear-gradient(135deg,transparent 40%,#CBD5E1 40%,#94A3B8 100%);opacity:.5;transition:opacity .15s;z-index:10}.modal-resize-handle:hover{opacity:1}.login-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f172a,#1e3a5f);display:flex;align-items:center;justify-content:center;z-index:2000}.login-box{background:#fff;border-radius:18px;padding:40px 36px;width:100%;max-width:400px;box-shadow:0 32px 80px #00000073;text-align:center}.login-logo{display:inline-flex;align-items:center;justify-content:center;background:#2563eb;color:#fff;font-size:14px;font-weight:900;padding:4px 12px;border-radius:6px;margin-bottom:16px}.login-title{font-size:20px;font-weight:800;color:#0f172a;margin-bottom:6px}.login-sub{font-size:13px;color:#64748b;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:14px;text-align:left}.lf-group{display:flex;flex-direction:column;gap:5px}.lf-group label{font-size:12px;font-weight:700;color:#64748b}.lf-group input{border:1.5px solid #E2E8F0;border-radius:8px;padding:10px 13px;font-size:14px;color:#1e293b}.lf-group input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.login-err{background:#fee2e2;color:#991b1b;padding:9px 12px;border-radius:7px;font-size:12px;text-align:center}.login-btn{background:#2563eb;color:#fff;border:none;padding:13px;border-radius:9px;font-size:15px;font-weight:800;cursor:pointer;margin-top:4px}.login-btn:hover:not(:disabled){background:#1d4ed8}.login-btn:disabled{opacity:.5;cursor:not-allowed}.google-btn{display:flex;align-items:center;justify-content:center;gap:10px;background:#fff;color:#1a1a1a;border:1.5px solid #dadce0}.google-btn:hover:not(:disabled){background:#f8f9fa;border-color:#c6cacd}.google-icon{flex-shrink:0}.login-link{background:none;border:none;color:#2563eb;font-size:13px;cursor:pointer;text-align:center;padding:4px}.login-link:hover{text-decoration:underline}.login-reset-sent{text-align:center;padding:10px 0;display:flex;flex-direction:column;gap:12px;align-items:center}.reset-icon{font-size:36px}.reset-hint{font-size:12px;color:#94a3b8}.setup-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,#0f172a,#1e293b);display:flex;align-items:center;justify-content:center;z-index:2000}.setup-box{background:#fff;border-radius:16px;padding:32px;width:100%;max-width:430px;box-shadow:0 32px 80px #0006}.setup-title{font-size:22px;font-weight:800;color:#0f172a;margin-bottom:5px}.setup-sub{font-size:13px;color:#64748b;margin-bottom:20px}.setup-tabs{display:flex;gap:3px;background:#f1f5f9;padding:3px;border-radius:9px;margin-bottom:16px}.tab{flex:1;padding:7px;background:none;border:none;border-radius:7px;font-size:13px;font-weight:500;color:#64748b}.tab.active{background:#fff;color:#1e293b;font-weight:700;box-shadow:0 1px 3px #0000001a}.staff-grid{display:grid;grid-template-columns:1fr 1fr;gap:7px;margin-bottom:20px;max-height:260px;overflow-y:auto}.staff-pick{display:flex;align-items:center;gap:9px;padding:10px 12px;border:1.5px solid #E2E8F0;border-radius:9px;background:#fff;text-align:left}.staff-pick:hover{border-color:#93c5fd;background:#eff6ff}.staff-pick.selected{border-color:#2563eb}.pick-avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;flex-shrink:0}.pick-name{font-size:13px;font-weight:700;flex:1}.pick-role{font-size:10px;color:#94a3b8;white-space:nowrap}.setup-input{width:100%;border:1.5px solid #D1D5DB;border-radius:8px;padding:10px 13px;font-size:14px;margin-bottom:20px}.setup-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.setup-confirm{width:100%;background:#2563eb;color:#fff;border:none;padding:13px;border-radius:9px;font-size:15px;font-weight:800}.setup-confirm:hover:not(:disabled){background:#1d4ed8}.setup-confirm:disabled{opacity:.4;cursor:not-allowed}.td-memo{border-left:2px solid #E2E8F0!important;padding:0 10px;font-size:11.5px;color:#64748b;min-width:180px;vertical-align:middle;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none}.td-memo:hover{background:#f8faff!important}.memo-title{font-size:11.5px;color:#1e293b;font-weight:600;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.memo-placeholder{font-size:11px;color:#cbd5e1}.memo-expanded-row td{background:#f8fafc!important;border-bottom:2px solid #E2E8F0!important}.memo-expanded-cell{padding:10px 14px!important;font-size:12px;color:#374151;line-height:1.6}.memo-part{margin-bottom:8px}.memo-part:last-child{margin-bottom:0}.memo-part-label{display:inline-block;font-size:10px;font-weight:700;color:#64748b;text-transform:uppercase;letter-spacing:.3px;margin-right:8px;min-width:52px}.memo-part-text{color:#1e293b;white-space:pre-wrap}.hamburger-btn{display:flex;flex-direction:column;justify-content:center;gap:4px;padding:6px 8px;background:none;border:none;cursor:pointer;border-radius:6px;flex-shrink:0;margin-right:4px}.hamburger-btn span{display:block;width:18px;height:2px;background:#475569;border-radius:2px;transition:background .15s}.hamburger-btn:hover span{background:#1e293b}.hamburger-btn:hover{background:#f1f5f9}.side-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:300;background:#00000059;animation:fadeIn .15s ease}.side-menu{position:fixed;top:0;left:0;height:100dvh;width:260px;background:#fff;z-index:301;transform:translate(-100%);transition:transform .22s cubic-bezier(.4,0,.2,1);box-shadow:4px 0 24px #00000026;display:flex;flex-direction:column}.side-menu.open{transform:translate(0)}.side-menu-header{padding:20px 20px 14px;font-size:13px;font-weight:700;color:#94a3b8;letter-spacing:.5px;text-transform:uppercase;border-bottom:1px solid #F1F5F9}.side-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:13px 20px;background:none;border:none;border-radius:0;font-size:14px;color:#1e293b;cursor:pointer;text-align:left;transition:background .12s}.side-menu-item:hover{background:#f8fafc}.side-menu-item.active{background:#eff6ff;color:#2563eb;font-weight:600}.side-menu-item svg{flex-shrink:0;opacity:.7}.side-menu-item.active svg{opacity:1}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}:root.dark .hamburger-btn span{background:#94a3b8}:root.dark .hamburger-btn:hover{background:#1e293b}:root.dark .hamburger-btn:hover span{background:#cbd5e1}:root.dark .side-menu{background:#0f172a}:root.dark .side-menu-header{color:#475569;border-color:#1e293b}:root.dark .side-menu-item{color:#cbd5e1}:root.dark .side-menu-item:hover{background:#1e293b}:root.dark .side-menu-item.active{background:#1e3a5f;color:#60a5fa}.dag-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:500}.dag-popup{position:fixed;z-index:501;background:#1e293b;color:#fff;border-radius:10px;padding:8px 12px;display:flex;align-items:center;gap:8px;box-shadow:0 8px 28px #00000059;animation:fadeInUp .15s ease;white-space:nowrap}.dag-popup-mobile{bottom:80px;left:50%;transform:translate(-50%)}.dag-bar{position:fixed;bottom:calc(24px + env(safe-area-inset-bottom,0px));left:50%;transform:translate(-50%);border-radius:24px;padding:10px 20px;gap:12px;box-shadow:0 8px 32px #0006}.dag-count{font-size:12px;color:#94a3b8}.dag-edit-btn{background:#2563eb;color:#fff;border:none;border-radius:6px;padding:5px 14px;font-size:13px;font-weight:700;cursor:pointer}.dag-edit-btn:hover{background:#1d4ed8}.dag-close-btn{background:#ffffff1a;color:#94a3b8;border:none;border-radius:5px;padding:4px 8px;font-size:13px;cursor:pointer}.dag-close-btn:hover{background:#fff3;color:#fff}.app.dragging .td-sch{cursor:crosshair}.wcr-modal{min-width:320px}.wcr-table{width:100%;border-collapse:collapse;font-size:12.5px}.wcr-table thead th{background:#f1f5f9;color:#64748b;font-weight:700;font-size:11px;text-transform:uppercase;padding:6px 16px;text-align:left;border-bottom:1.5px solid #E2E8F0}.wcr-table tbody tr:hover td{background:#f8fafc}.wcr-table tbody td{padding:7px 16px;border-bottom:1px solid #F1F5F9;vertical-align:middle}.wcr-code-badge{display:inline-block;background:#e2e8f0;color:#1e293b;font-weight:800;font-size:12px;padding:2px 8px;border-radius:4px;white-space:nowrap}.wcr-desc{color:#374151;line-height:1.5}.wcr-code-input{width:60px;border:1.5px solid #E2E8F0;border-radius:5px;padding:3px 6px;font-size:12px;font-weight:700}.wcr-desc-input{width:100%;border:1.5px solid #E2E8F0;border-radius:5px;padding:3px 8px;font-size:12px}.profile-menu{position:absolute;top:calc(100% + 8px);right:0;background:#fff;border:1px solid #E2E8F0;border-radius:12px;box-shadow:0 8px 28px #00000024;padding:6px 0;min-width:200px;z-index:500;animation:fadeInUp .12s ease}.pm-header{display:flex;align-items:center;gap:10px;padding:10px 16px 8px}.pm-avatar{width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:800;color:#fff;flex-shrink:0}.pm-name{font-size:13px;font-weight:700;color:#1e293b}.pm-role{font-size:11px;color:#94a3b8}.pm-divider{height:1px;background:#f1f5f9;margin:4px 0}.pm-item{display:flex;align-items:center;gap:10px;width:100%;background:none;border:none;padding:9px 16px;font-size:13px;color:#374151;cursor:pointer;text-align:left}.pm-item:hover{background:#f8fafc}.pm-logout{color:#dc2626}.pm-logout:hover{background:#fef2f2}.month-label-btn{cursor:pointer;border-radius:6px;padding:2px 8px}.month-label-btn:hover{background:#ffffff26}.month-picker{position:absolute;top:calc(100% + 8px);left:50%;transform:translate(-50%);background:#fff;border:1px solid #E2E8F0;border-radius:12px;box-shadow:0 8px 28px #00000024;padding:12px;z-index:500;min-width:220px;animation:fadeInUp .12s ease}.mp-year-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.mp-year{font-size:15px;font-weight:800;color:#1e293b}.mp-arrow{background:none;border:1px solid #E2E8F0;border-radius:6px;width:28px;height:28px;font-size:16px;cursor:pointer;color:#475569;display:flex;align-items:center;justify-content:center}.mp-arrow:hover{background:#f1f5f9}.mp-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:4px}.mp-month{background:none;border:1px solid transparent;border-radius:7px;padding:7px 4px;font-size:13px;font-weight:500;color:#374151;cursor:pointer;text-align:center}.mp-month:hover{background:#eff6ff;border-color:#bfdbfe;color:#2563eb}.mp-active{background:#2563eb!important;color:#fff!important;border-color:#2563eb!important;font-weight:700}:root.dark{--bg: #0F172A;--surface: #1E293B;--surface2: #334155;--border: #334155;--text: #F1F5F9;--text2: #94A3B8}:root.dark body{background:#0f172a;color:#f1f5f9}:root.dark .header{background:#0f172a}:root.dark .grid-scroll{border-color:#334155}:root.dark .cal-table{background:#1e293b}:root.dark .day-row td{background:#1e293b;border-color:#3d4e68}:root.dark .day-row.saturday td,:root.dark .day-row.sunday td,:root.dark .day-row.holiday td{background:#1a2744}:root.dark .day-row.saturday .td-event,:root.dark .day-row.saturday .td-note,:root.dark .day-row.sunday .td-event,:root.dark .day-row.sunday .td-note,:root.dark .day-row.holiday .td-event,:root.dark .day-row.holiday .td-note{background:#1e293b!important}:root.dark .td-date,:root.dark .td-dow{background:#1e293b!important;color:#cbd5e1}:root.dark .td-note-text{color:#cbd5e1}:root.dark .memo-title{color:#e2e8f0}:root.dark .memo-part-text{color:#cbd5e1}:root.dark .day-row.saturday .td-date,:root.dark .day-row.saturday .td-dow,:root.dark .day-row.sunday .td-date,:root.dark .day-row.sunday .td-dow,:root.dark .day-row.holiday .td-date,:root.dark .day-row.holiday .td-dow{background:#1a2744!important}:root.dark .day-row:hover td{background:#1d3461}:root.dark .thead-row th{background:#0f172a;color:#94a3b8;border-color:#334155}:root.dark .th-name{color:#f1f5f9}:root.dark .th-role{color:#94a3b8!important}:root.dark .modal{background:#1e293b}:root.dark .modal-head{background:#0f172a}:root.dark .modal-info{background:#0f172a;border-color:#334155}:root.dark .modal-picker-wrap{background:#0f172a;border-color:#334155}:root.dark .modal-body{background:#1e293b}:root.dark .modal-foot{border-color:#334155}:root.dark .mf-group label{color:#94a3b8}:root.dark .mf-group input,:root.dark .mf-group textarea{background:#0f172a;border-color:#334155;color:#f1f5f9}:root.dark .btn-cancel{background:#1e293b;border-color:#475569;color:#cbd5e1}:root.dark .view-tabs{background:#0f172a;border-color:#334155}:root.dark .view-tab{color:#64748b}:root.dark .view-tab.active{color:#60a5fa;border-color:#60a5fa}:root.dark .profile-menu,:root.dark .month-picker{background:#1e293b;border-color:#334155}:root.dark .pm-name{color:#f1f5f9}:root.dark .pm-item{color:#cbd5e1}:root.dark .pm-item:hover{background:#334155}:root.dark .pm-divider{background:#334155}:root.dark .wcr-table thead th{background:#0f172a;color:#64748b;border-color:#334155}:root.dark .wcr-table tbody td{border-color:#334155}:root.dark .wcr-table tbody tr:hover td{background:#0f172a}:root.dark .wcr-code-badge{background:#334155;color:#f1f5f9}:root.dark .wcr-desc{color:#cbd5e1}:root.dark .hist-panel{background:#0f172a;border-color:#334155}:root.dark .hist-row{border-color:#334155}:root.dark .hist-who{color:#f1f5f9}:root.dark .hist-diff{color:#cbd5e1}:root.dark .hist-btn{color:#94a3b8;border-color:#475569}:root.dark .hist-btn:hover{background:#334155}:root.dark .mp-year{color:#f1f5f9}:root.dark .mp-month{color:#cbd5e1}:root.dark .mp-month:hover{background:#1d3461;border-color:#3b82f6;color:#60a5fa}:root.dark .readonly-code{background:#334155;color:#f1f5f9}.sch-board-t{position:absolute;bottom:2px;right:2px;background:#2563eb;color:#fff;font-size:8px;font-weight:800;padding:1px 3px;border-radius:2px;line-height:1;pointer-events:none}.td-sch.filled{position:relative}.side-board-new-badge{display:inline-block;background:#3b82f6;color:#fff;font-size:9px;font-weight:800;padding:0 4px;border-radius:4px;margin-left:5px;vertical-align:middle;line-height:14px}.side-board-item-wrap{display:flex;align-items:stretch;position:relative}.side-board-item-wrap .side-board-item{flex:1;min-width:0}.side-board-del-btn{flex-shrink:0;background:none;border:none;color:#cbd5e1;font-size:12px;padding:0 10px;cursor:pointer;display:flex;align-items:center;border-radius:0 6px 6px 0}.side-board-del-btn:hover{color:#ef4444;background:#fef2f2}.tb-badge-btn{display:inline-flex;align-items:center;background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;border:none;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:800;cursor:pointer;white-space:nowrap;transition:all .15s;box-shadow:0 2px 8px #2563eb73;letter-spacing:.2px}.tb-badge-btn:hover{background:linear-gradient(135deg,#1d4ed8,#6d28d9);box-shadow:0 4px 14px #2563eb8c;transform:translateY(-1px)}.tb-badge-btn:active{transform:translateY(0)}.side-menu-section-title{padding:10px 20px 4px;font-size:10px;font-weight:700;color:#94a3b8;letter-spacing:.5px;text-transform:uppercase;margin-top:4px}.side-menu-empty{padding:6px 20px;font-size:12px;color:#cbd5e1;font-style:italic}.side-archive-toggle{color:#64748b!important;font-size:13px}.side-archive-item{padding-left:30px!important}:root.dark .side-menu-section-title{color:#475569}:root.dark .side-menu-empty{color:#475569}.tb-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1200;padding:16px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.tb-modal{background:#fff;border-radius:16px;width:100%;max-width:1000px;height:85vh;max-height:800px;display:flex;flex-direction:column;box-shadow:0 28px 72px #00000059;animation:slideUp .16s ease;overflow:hidden}.tb-header{background:#0f172a;color:#f1f5f9;padding:14px 20px;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.tb-header-left{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.tb-title-badge{background:#2563eb;color:#fff;font-size:13px;font-weight:800;padding:3px 10px;border-radius:5px;white-space:nowrap}.tb-title-label{font-size:16px;font-weight:800;color:#f1f5f9}.tb-date-range{font-size:12px;color:#94a3b8;background:#ffffff14;padding:2px 8px;border-radius:4px}.tb-close-btn{background:none;border:none;color:#ffffff8c;font-size:19px;padding:2px 6px;border-radius:4px;cursor:pointer;flex-shrink:0}.tb-close-btn:hover{background:#ffffff1f;color:#fff}.tb-tabs{display:flex;background:#f1f5f9;border-bottom:2px solid #E2E8F0;flex-shrink:0}.tb-tab{padding:10px 22px;font-size:13px;font-weight:600;color:#64748b;background:none;border:none;border-bottom:2px solid transparent;margin-bottom:-2px;cursor:pointer;transition:color .14s,border-color .14s}.tb-tab:hover{color:#1e293b}.tb-tab.active{color:#2563eb;border-bottom-color:#2563eb}.tb-body{flex:1;overflow:hidden}.tb-notes-tab{display:flex;flex-direction:column;height:100%;padding:16px}.tb-note-input-row{display:flex;gap:10px;flex-shrink:0;margin-bottom:14px}.tb-note-input{flex:1;border:1.5px solid #E2E8F0;border-radius:8px;padding:9px 12px;font-size:13px;color:#1e293b;resize:none;font-family:inherit;transition:border-color .15s}.tb-note-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.tb-note-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:8px}.tb-note-item{background:#f8fafc;border:1px solid #E2E8F0;border-radius:8px;padding:10px 12px}.tb-note-meta{display:flex;align-items:center;gap:8px;margin-bottom:5px}.tb-note-author{font-size:12px;font-weight:700;color:#1e293b}.tb-note-time{font-size:11px;color:#94a3b8;flex:1}.tb-note-del{background:none;border:none;color:#94a3b8;font-size:13px;cursor:pointer;padding:0 2px}.tb-note-del:hover{color:#ef4444}.tb-note-content{font-size:13px;color:#374151;white-space:pre-wrap;line-height:1.55}.tb-mat-tab{display:flex;flex-direction:column;height:100%;overflow:hidden}.tb-mat-presets{padding:10px 14px 8px;border-bottom:1px solid #E2E8F0;flex-shrink:0;background:#f8fafc}.tb-mat-presets-label{font-size:10px;font-weight:700;color:#94a3b8;text-transform:uppercase;letter-spacing:.4px;margin-bottom:7px}.tb-mat-presets-row{display:flex;flex-wrap:wrap;gap:6px}.tb-preset-btn{padding:5px 12px;border-radius:20px;font-size:12px;font-weight:700;background:#eff6ff;border:1.5px solid #BFDBFE;color:#2563eb;cursor:pointer;transition:all .13s;white-space:nowrap}.tb-preset-btn:hover{background:#dbeafe;border-color:#93c5fd}.tb-preset-btn.preset-clear{background:#fef2f2;border-color:#fecaca;color:#dc2626}.tb-preset-btn.preset-clear:hover{background:#fee2e2;border-color:#fca5a5}.tb-mat-accordion-area{flex:1;overflow-y:auto;padding:8px 12px;min-height:0}.tb-acc-item{border:1px solid #E2E8F0;border-radius:8px;margin-bottom:6px;overflow:hidden}.tb-acc-header{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f8fafc;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .12s;border:none;width:100%;text-align:left}.tb-acc-header:hover{background:#f1f5f9}.tb-acc-arrow{font-size:10px;color:#94a3b8;transition:transform .18s;flex-shrink:0}.tb-acc-arrow.open{transform:rotate(180deg)}.tb-acc-cat-name{flex:1;font-size:13px;font-weight:700;color:#1e293b}.tb-acc-count{font-size:11px;color:#94a3b8;font-weight:500}.tb-acc-sel-all-btn{padding:2px 9px;border-radius:10px;font-size:10px;font-weight:700;background:#eff6ff;border:1px solid #BFDBFE;color:#2563eb;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .12s}.tb-acc-sel-all-btn:hover{background:#dbeafe}.tb-acc-body{padding:6px 10px 8px;display:flex;flex-direction:column;gap:3px}.tb-acc-mat-row{display:flex;align-items:center;gap:8px;padding:4px 6px;border-radius:5px;transition:background .1s;cursor:pointer}.tb-acc-mat-row:hover{background:#f1f5f9}.tb-acc-mat-row input[type=checkbox]{width:15px;height:15px;cursor:pointer;flex-shrink:0;accent-color:#2563EB}.tb-acc-mat-name{flex:1;font-size:12px;color:#374151}.tb-acc-mat-name.selected{color:#2563eb;font-weight:600}.tb-mat-selected-area{border-top:2px solid #E2E8F0;flex-shrink:0;max-height:42%;min-height:120px;display:flex;flex-direction:column;overflow:hidden}.tb-mat-selected-header{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#f8fafc;border-bottom:1px solid #E2E8F0;flex-shrink:0}.tb-mat-selected-title{font-size:12px;font-weight:700;color:#475569;flex:1}.tb-mat-count{font-size:12px;color:#94a3b8;font-weight:400}.tb-mat-selected-list{flex:1;overflow-y:auto;padding:8px 12px;display:flex;flex-direction:column;gap:5px}.tb-bmat-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:7px;border:1px solid #E2E8F0;margin-bottom:0;transition:background .1s}.tb-bmat-row.ready{background:#f0fdf4;border-color:#86efac}.tb-bmat-check{cursor:pointer;flex-shrink:0}.tb-bmat-name{flex:1;font-size:13px;color:#1e293b}.tb-bmat-name.done{color:#94a3b8;text-decoration:line-through}.tb-bmat-qty{width:68px;border:1px solid #E2E8F0;border-radius:5px;padding:3px 7px;font-size:12px;text-align:center;font-family:inherit}.tb-bmat-qty:focus{outline:none;border-color:#3b82f6}.tb-bmat-del{background:none;border:none;color:#cbd5e1;font-size:13px;cursor:pointer;padding:0 2px}.tb-bmat-del:hover{color:#ef4444}.tb-mat-add-master{border:1px dashed #CBD5E1;border-radius:8px;padding:8px 10px;display:flex;gap:6px;align-items:center;background:#f8fafc}.tb-mat-add-master .tb-input{flex:1;min-width:0}.tb-mat-add-master .tb-input-cat{width:90px;flex-shrink:0}.tb-mat-left,.tb-mat-right{display:none}.tb-mat-cat-tabs{display:flex;gap:4px;flex-wrap:nowrap;overflow-x:auto;padding:8px 12px;border-bottom:1px solid #E2E8F0;background:#f8fafc;flex-shrink:0;scrollbar-width:none}.tb-mat-cat-tabs::-webkit-scrollbar{display:none}.tb-mat-cat-tab{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;background:#fff;border:1.5px solid #E2E8F0;color:#64748b;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:all .13s}.tb-mat-cat-tab:hover{border-color:#93c5fd;color:#2563eb}.tb-mat-cat-tab.active{background:#2563eb;border-color:#2563eb;color:#fff}.tb-mat-checklist-area{flex:1;overflow-y:auto;padding:8px 12px;min-height:0}.tb-mat-check-row{display:flex;align-items:center;gap:9px;padding:7px 8px;border-radius:6px;cursor:pointer;transition:background .1s;border:1px solid transparent}.tb-mat-check-row:hover{background:#f1f5f9}.tb-mat-check-row.checked{background:#eff6ff;border-color:#bfdbfe}.tb-mat-check-row input[type=checkbox]{width:15px;height:15px;cursor:pointer;flex-shrink:0;accent-color:#2563EB}.tb-mat-check-name{flex:1;font-size:13px;color:#1e293b}.tb-mat-check-row.checked .tb-mat-check-name{color:#2563eb;font-weight:600}.tb-mat-check-cat{font-size:10px;color:#94a3b8;background:#f1f5f9;padding:1px 6px;border-radius:8px;white-space:nowrap}.tb-mat-check-row.focused{background:#eff6ff;outline:2px solid #3B82F6;outline-offset:-2px}.tb-mat-check-row.edit-mode{cursor:default}.tb-mat-manage-row{display:flex;justify-content:flex-end;padding:6px 12px 4px}.tb-mat-manage-btn{font-size:11px;font-weight:600;padding:3px 10px;border:1.5px solid #CBD5E1;border-radius:20px;background:#f8fafc;color:#64748b;cursor:pointer}.tb-mat-manage-btn:hover{border-color:#93c5fd;color:#2563eb}.tb-mat-manage-btn.active{background:#eff6ff;border-color:#3b82f6;color:#2563eb}.tb-master-del-btn{background:none;border:none;color:#cbd5e1;font-size:13px;padding:2px 6px;cursor:pointer;flex-shrink:0}.tb-master-del-btn:hover{color:#ef4444}.tb-preset-btn.preset-active{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8}.tb-mat-step1-footer{flex-shrink:0;padding:10px 12px;border-top:1px solid #E2E8F0;background:#fff}.tb-mat-view-list-btn{width:100%;padding:11px 0;border-radius:8px;background:#2563eb;color:#fff;font-size:14px;font-weight:700;border:none;cursor:pointer;transition:background .13s}.tb-mat-view-list-btn:hover:not(.disabled){background:#1d4ed8}.tb-mat-view-list-btn.disabled{background:#cbd5e1;color:#94a3b8;cursor:not-allowed}.tb-mat-step2-header{display:flex;align-items:center;gap:10px;padding:10px 14px;border-bottom:1px solid #E2E8F0;background:#f8fafc;flex-shrink:0}.tb-mat-back-btn{background:none;border:1.5px solid #CBD5E1;border-radius:6px;padding:5px 12px;font-size:12px;font-weight:700;color:#475569;cursor:pointer;white-space:nowrap;transition:all .12s}.tb-mat-back-btn:hover{background:#f1f5f9;border-color:#94a3b8}.tb-mat-progress{flex:1;text-align:center;font-size:13px;font-weight:700;color:#1e293b}.tb-mat-readylist-area{flex:1;overflow-y:auto;padding:10px 12px;display:flex;flex-direction:column;gap:5px;min-height:0}.tb-bmat-status-btn{background:none;border:none;padding:0;font-size:16px;cursor:pointer;flex-shrink:0;color:#94a3b8;line-height:1;width:20px;text-align:center;transition:color .12s}.tb-bmat-row.ready .tb-bmat-status-btn{color:#22c55e}.tb-slack-tab{display:flex;flex-direction:column;height:100%;padding:12px}.tb-slack-top{display:flex;align-items:center;gap:10px;margin-bottom:10px;flex-shrink:0}.tb-slack-ch-tabs{display:flex;gap:4px}.tb-slack-ch-tab{padding:5px 14px;border-radius:6px;font-size:12px;font-weight:700;background:#f1f5f9;border:1px solid #E2E8F0;color:#64748b;cursor:pointer}.tb-slack-ch-tab.active{background:#2563eb;color:#fff;border-color:#2563eb}.tb-slack-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.tb-slack-msg{display:block;padding:9px 12px;background:#f8fafc;border:1px solid #E2E8F0;border-radius:8px;text-decoration:none;color:inherit;transition:background .1s;cursor:pointer}.tb-slack-msg:hover{background:#eff6ff;border-color:#bfdbfe}.tb-slack-msg-meta{display:flex;align-items:center;gap:8px;margin-bottom:4px}.tb-slack-user{font-size:12px;font-weight:700;color:#1e293b}.tb-slack-ts{font-size:11px;color:#94a3b8}.tb-slack-text{font-size:12px;color:#374151;white-space:pre-wrap;line-height:1.5;word-break:break-word}.tb-files-tab{display:flex;flex-direction:column;height:100%;padding:16px}.tb-dropzone{border:2px dashed #CBD5E1;border-radius:10px;padding:24px;text-align:center;cursor:pointer;color:#94a3b8;font-size:13px;display:flex;flex-direction:column;align-items:center;gap:8px;transition:all .15s;flex-shrink:0;margin-bottom:14px}.tb-dropzone:hover,.tb-dropzone.drag-over{border-color:#3b82f6;background:#eff6ff;color:#2563eb}.tb-file-list{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:6px}.tb-file-row{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:8px;border:1px solid #E2E8F0;background:#f8fafc}.tb-file-icon{color:#64748b;flex-shrink:0}.tb-file-info{flex:1;min-width:0}.tb-file-name{background:none;border:none;padding:0;font-size:13px;font-weight:600;color:#2563eb;cursor:pointer;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:100%}.tb-file-name:hover{text-decoration:underline}.tb-file-meta{font-size:11px;color:#94a3b8;margin-top:2px}.tb-file-del{background:none;border:none;color:#cbd5e1;font-size:14px;cursor:pointer;padding:0 2px;flex-shrink:0}.tb-file-del:hover{color:#ef4444}.tb-section-title{font-size:12px;font-weight:700;color:#475569}.tb-empty{font-size:13px;color:#94a3b8;text-align:center;padding:16px 0}.tb-btn-primary{background:#2563eb;color:#fff;border:none;border-radius:7px;padding:8px 18px;font-size:13px;font-weight:700;cursor:pointer;white-space:nowrap;flex-shrink:0;transition:background .14s}.tb-btn-primary:hover:not(:disabled){background:#1d4ed8}.tb-btn-primary:disabled{opacity:.5;cursor:not-allowed}.tb-btn-secondary{background:#f1f5f9;color:#475569;border:1.5px solid #CBD5E1;border-radius:6px;padding:6px 14px;font-size:12px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background .12s}.tb-btn-secondary:hover:not(:disabled){background:#e2e8f0}.tb-btn-secondary:disabled{opacity:.5;cursor:not-allowed}.tb-input{width:100%;border:1.5px solid #E2E8F0;border-radius:6px;padding:7px 10px;font-size:12px;font-family:inherit;color:#1e293b}.tb-input:focus{outline:none;border-color:#3b82f6}:root.dark .tb-modal{background:#1e293b}:root.dark .tb-header{background:#0f172a}:root.dark .tb-tabs{background:#0f172a;border-color:#334155}:root.dark .tb-tab{color:#64748b}:root.dark .tb-tab.active{color:#60a5fa;border-color:#60a5fa}:root.dark .tb-note-input{background:#0f172a;border-color:#334155;color:#f1f5f9}:root.dark .tb-note-item{background:#0f172a;border-color:#334155}:root.dark .tb-note-author{color:#f1f5f9}:root.dark .tb-note-content{color:#cbd5e1}:root.dark .tb-mat-presets{background:#0f172a;border-color:#334155}:root.dark .tb-mat-presets-label{color:#475569}:root.dark .tb-preset-btn{background:#1d3461;border-color:#2563eb;color:#60a5fa}:root.dark .tb-preset-btn:hover{background:#1e3a5f}:root.dark .tb-preset-btn.preset-clear{background:#450a0a;border-color:#7f1d1d;color:#fca5a5}:root.dark .tb-preset-btn.preset-clear:hover{background:#7f1d1d}:root.dark .tb-acc-item{border-color:#334155}:root.dark .tb-acc-header{background:#0f172a}:root.dark .tb-acc-header:hover{background:#1e293b}:root.dark .tb-acc-cat-name{color:#f1f5f9}:root.dark .tb-acc-body{background:#1e293b}:root.dark .tb-acc-mat-row:hover{background:#0f172a}:root.dark .tb-acc-mat-name{color:#cbd5e1}:root.dark .tb-acc-mat-name.selected{color:#60a5fa}:root.dark .tb-acc-sel-all-btn{background:#1d3461;border-color:#2563eb;color:#60a5fa}:root.dark .tb-mat-selected-area{border-color:#334155}:root.dark .tb-mat-selected-header{background:#0f172a;border-color:#334155}:root.dark .tb-mat-selected-title{color:#94a3b8}:root.dark .tb-mat-add-master{background:#0f172a;border-color:#334155;border-style:dashed}:root.dark .tb-bmat-row{border-color:#334155;background:#0f172a}:root.dark .tb-bmat-row.ready{background:#052e16;border-color:#166534}:root.dark .tb-bmat-name{color:#e2e8f0}:root.dark .tb-bmat-qty{background:#0f172a;border-color:#334155;color:#f1f5f9}:root.dark .tb-slack-msg{background:#0f172a;border-color:#334155}:root.dark .tb-slack-msg:hover{background:#1d3461;border-color:#3b82f6}:root.dark .tb-slack-user{color:#f1f5f9}:root.dark .tb-slack-text{color:#cbd5e1}:root.dark .tb-dropzone{border-color:#334155;color:#64748b}:root.dark .tb-dropzone:hover,:root.dark .tb-dropzone.drag-over{border-color:#3b82f6;background:#1d3461;color:#60a5fa}:root.dark .tb-file-row{background:#0f172a;border-color:#334155}:root.dark .tb-file-meta{color:#64748b}:root.dark .tb-cat-btn{background:#334155;border-color:#475569;color:#94a3b8}:root.dark .tb-cat-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}:root.dark .tb-mat-cat-tabs{background:#0f172a;border-color:#334155}:root.dark .tb-mat-cat-tab{background:#1e293b;border-color:#334155;color:#94a3b8}:root.dark .tb-mat-cat-tab:hover{border-color:#3b82f6;color:#60a5fa}:root.dark .tb-mat-cat-tab.active{background:#2563eb;border-color:#2563eb;color:#fff}:root.dark .tb-mat-checklist-area{background:#1e293b}:root.dark .tb-mat-check-row:hover{background:#0f172a}:root.dark .tb-mat-check-row.checked{background:#1d3461;border-color:#2563eb}:root.dark .tb-mat-check-name{color:#e2e8f0}:root.dark .tb-mat-check-row.checked .tb-mat-check-name{color:#60a5fa}:root.dark .tb-mat-check-cat{background:#334155;color:#64748b}:root.dark .tb-mat-step1-footer{background:#1e293b;border-color:#334155}:root.dark .tb-mat-view-list-btn.disabled{background:#334155;color:#475569}:root.dark .tb-mat-step2-header{background:#0f172a;border-color:#334155}:root.dark .tb-mat-back-btn{background:#1e293b;border-color:#334155;color:#94a3b8}:root.dark .tb-mat-back-btn:hover{background:#334155}:root.dark .tb-mat-progress{color:#f1f5f9}:root.dark .tb-mat-readylist-area{background:#1e293b}:root.dark .tb-input{background:#0f172a;border-color:#334155;color:#f1f5f9}:root.dark .tb-btn-secondary{background:#334155;border-color:#475569;color:#cbd5e1}:root.dark .tb-btn-secondary:hover:not(:disabled){background:#475569}:root.dark .tb-section-title{color:#94a3b8}:root.dark .tb-empty{color:#475569}:root.dark .tb-slack-ch-tab{background:#334155;border-color:#475569;color:#94a3b8}@media (max-width: 768px){.tb-modal{height:92vh;max-height:none;border-radius:12px 12px 0 0;align-self:flex-end}.tb-overlay{align-items:flex-end;padding:0}.tb-mat-presets-row{gap:4px}.tb-preset-btn{font-size:11px;padding:4px 10px}.tb-mat-selected-area{max-height:45%}}@media (max-width: 768px){.grid-wrapper{padding:4px;overflow:visible}.grid-scroll{max-height:calc(100vh - 92px);overflow:auto}.header{padding:0 10px}.header-title{display:none}.month-label{font-size:15px;min-width:100px}.presence-count{display:none}}
