*{box-sizing:border-box;margin:0}:root{--bg: #f5f5f7;--surface: #ffffff;--surface2: #f0f0f2;--border: rgba(0, 0, 0, .08);--text: #1d1d1f;--muted: #86868b;--accent: #6e45e2;--accent-soft: rgba(110, 69, 226, .1);--danger: #ff3b30;--warning: #c77700;--success: #1d9e58;--info: #0071e3;--glass: rgba(255, 255, 255, .72);--shadow: 0 1px 2px rgba(0, 0, 0, .04), 0 8px 30px rgba(0, 0, 0, .05);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .08), 0 24px 60px rgba(0, 0, 0, .12);--radius: 16px}[data-theme=dark]{--bg: #000000;--surface: #1c1c1e;--surface2: #2c2c2e;--border: rgba(255, 255, 255, .1);--text: #f5f5f7;--muted: #98989d;--accent: #9d7bff;--accent-soft: rgba(157, 123, 255, .14);--danger: #ff453a;--warning: #ffd60a;--success: #30d158;--info: #64b5ff;--glass: rgba(22, 22, 24, .72);--shadow: 0 1px 2px rgba(0, 0, 0, .4), 0 8px 30px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 16px rgba(0, 0, 0, .5), 0 24px 60px rgba(0, 0, 0, .6)}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,SF Pro Text,Segoe UI Variable Text,Segoe UI,Inter,system-ui,sans-serif;background:var(--bg);color:var(--text);font-size:14px;line-height:1.5;letter-spacing:-.006em;-webkit-font-smoothing:antialiased}a{color:var(--accent);text-decoration:none}h1{font-size:26px;font-weight:700;letter-spacing:-.022em}h2{font-size:17px;font-weight:600;letter-spacing:-.014em}h3{font-size:15px;font-weight:600;letter-spacing:-.01em}.app{display:flex;min-height:100vh}.sidebar{width:226px;flex-shrink:0;background:var(--glass);backdrop-filter:saturate(180%) blur(22px);-webkit-backdrop-filter:saturate(180%) blur(22px);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:18px 12px;position:sticky;top:0;height:100vh;z-index:40}.sidebar .brand{font-size:14.5px;font-weight:700;line-height:1.15;padding:4px 10px 18px;display:flex;gap:10px;align-items:center;letter-spacing:-.02em}.sidebar nav{display:flex;flex-direction:column;gap:2px;flex:1}.sidebar nav a{padding:9px 13px;border-radius:10px;color:var(--text);font-weight:500;display:flex;align-items:center;gap:11px;font-size:13.5px;transition:background .15s ease}.sidebar nav a:hover{background:var(--surface2)}.sidebar nav a.active{background:var(--accent-soft);color:var(--accent);font-weight:600}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{display:flex;align-items:center;gap:10px;padding:12px 28px;background:var(--glass);backdrop-filter:saturate(180%) blur(22px);-webkit-backdrop-filter:saturate(180%) blur(22px);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:30}.topbar .spacer{flex:1}.content{padding:32px 32px 48px;max-width:1280px;width:100%;margin:0 auto}.page-head{display:flex;align-items:center;gap:12px;margin-bottom:24px;flex-wrap:wrap}.page-head .spacer{flex:1}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card h2{margin-bottom:12px}.grid{display:grid;gap:16px}.grid.cols-2{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.grid.cols-4{grid-template-columns:repeat(auto-fit,minmax(170px,1fr))}.stat{display:flex;flex-direction:column;gap:2px}.stat .num{font-size:32px;font-weight:700;letter-spacing:-.03em}.stat .label{color:var(--muted);font-size:12.5px;font-weight:500}button,.btn{font:inherit;cursor:pointer;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:8px 18px;border-radius:980px;font-weight:500;font-size:13.5px;letter-spacing:-.006em;transition:background .15s ease,transform .1s ease,opacity .15s ease}button:hover,.btn:hover{background:var(--surface2)}button:active,.btn:active{transform:scale(.97)}button.primary{background:var(--accent);border-color:transparent;color:#fff;font-weight:600}button.primary:hover{background:var(--accent);opacity:.88}button.danger{color:var(--danger);border-color:transparent;background:#ff3b301a}button.small{padding:5px 13px;font-size:12.5px}button.icon{padding:7px 11px}button:disabled{opacity:.4;cursor:not-allowed}input,select,textarea{font:inherit;color:var(--text);background:var(--surface2);border:1px solid transparent;border-radius:12px;padding:9px 13px;width:100%;transition:border-color .15s ease,box-shadow .15s ease,background .15s ease}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 4px var(--accent-soft)}input::placeholder,textarea::placeholder{color:var(--muted)}label{font-size:12px;font-weight:600;color:var(--muted);display:block;margin-bottom:5px;letter-spacing:.01em}.field{margin-bottom:14px}.row{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.row>*{flex-shrink:0}table{width:100%;border-collapse:collapse}th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);font-weight:600;padding:10px 12px;border-bottom:1px solid var(--border)}td{padding:11px 12px;border-bottom:1px solid var(--border);vertical-align:middle}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface2)}.badge{display:inline-block;padding:3px 10px;border-radius:980px;font-size:11px;font-weight:600;white-space:nowrap;letter-spacing:0}.badge.gray{background:var(--surface2);color:var(--muted)}.badge.green{background:#30d15824;color:var(--success)}.badge.red{background:#ff453a24;color:var(--danger)}.badge.amber{background:#ff9f0a29;color:var(--warning)}.badge.blue{background:#0071e31f;color:var(--info)}.badge.accent{background:var(--accent-soft);color:var(--accent)}.avatar{width:30px;height:30px;border-radius:50%;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.tabs{display:flex;gap:4px;background:var(--surface2);padding:4px;border-radius:12px;margin-bottom:20px;flex-wrap:wrap;width:fit-content;max-width:100%}.tabs button{border:none;background:none;border-radius:9px;padding:7px 15px;font-weight:500;color:var(--muted);font-size:13px}.tabs button:hover{color:var(--text);background:none}.tabs button.active{color:var(--text);background:var(--surface);box-shadow:var(--shadow);font-weight:600}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:100;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:flex-start;justify-content:center;padding:6vh 16px}.modal{background:var(--surface);border-radius:20px;box-shadow:var(--shadow-lg);border:1px solid var(--border);width:100%;max-width:540px;max-height:86vh;overflow-y:auto;padding:26px}.modal h2{margin-bottom:16px;font-size:19px}.modal .actions{display:flex;justify-content:flex-end;gap:8px;margin-top:18px}.toast{position:fixed;bottom:24px;right:24px;z-index:200;background:var(--text);color:var(--bg);padding:12px 20px;border-radius:14px;box-shadow:var(--shadow-lg);font-weight:500;max-width:360px;font-size:13.5px}.toast.error{background:var(--danger);color:#fff}.empty{color:var(--muted);text-align:center;padding:30px 10px;font-size:13.5px}.notif-panel{position:absolute;right:0;top:46px;width:350px;max-height:440px;overflow-y:auto;background:var(--surface);border:1px solid var(--border);border-radius:18px;box-shadow:var(--shadow-lg);z-index:50}.notif-item{padding:11px 16px;border-bottom:1px solid var(--border)}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:var(--accent-soft)}.notif-item .time{font-size:11px;color:var(--muted)}.sched-grid{display:grid;grid-template-columns:170px repeat(7,minmax(118px,1fr));border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;background:var(--surface);box-shadow:var(--shadow)}.sched-grid .head,.sched-grid .cell,.sched-grid .rowhead{border-right:1px solid var(--border);border-bottom:1px solid var(--border);padding:6px;min-height:56px}.sched-grid .head{background:var(--surface2);font-weight:600;font-size:12px;text-align:center;min-height:0;color:var(--muted)}.sched-grid .rowhead{display:flex;gap:8px;align-items:center;font-weight:600;font-size:13px;background:var(--surface)}.sched-grid .cell{display:flex;flex-direction:column;gap:4px;transition:background .15s ease}.sched-grid .cell.droptarget{background:var(--accent-soft)}.shift-chip{border-radius:9px;padding:5px 8px;font-size:11.5px;font-weight:600;color:#fff;cursor:grab;line-height:1.3;transition:transform .1s ease,opacity .15s ease}.shift-chip:hover{transform:scale(1.02)}.shift-chip .sub{font-weight:400;opacity:.85;font-size:10.5px}.shift-chip.draft{outline:2px dashed rgba(255,255,255,.65);outline-offset:-2px;opacity:.82}.unavail{font-size:10.5px;color:var(--muted);font-style:italic}.kanban{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;align-items:start}.kanban .col{background:var(--surface2);border-radius:var(--radius);padding:12px}.kanban .col h3{padding:2px 6px 10px;color:var(--muted);font-size:12px;text-transform:uppercase;letter-spacing:.05em;font-weight:600}.task-card{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:12px 14px;margin-bottom:8px;cursor:pointer;box-shadow:var(--shadow);transition:transform .12s ease,box-shadow .12s ease}.task-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-lg)}.task-card .title{font-weight:600;margin-bottom:4px;letter-spacing:-.01em}.task-card .meta{display:flex;gap:6px;flex-wrap:wrap;align-items:center;font-size:11.5px;color:var(--muted)}.prio{width:8px;height:8px;border-radius:50%;display:inline-block}.prio.urgent{background:var(--danger)}.prio.high{background:#ff9f0a}.prio.medium{background:var(--info)}.prio.low{background:var(--muted)}.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;background:radial-gradient(ellipse 70% 50% at 50% -10%,var(--accent-soft),transparent),var(--bg)}.login-card{width:100%;max-width:400px;padding:34px 30px;border-radius:24px}.login-card .logo{text-align:center;margin-bottom:14px}.login-card h1{text-align:center;margin-bottom:24px;font-size:23px}.alert{padding:11px 15px;border-radius:12px;margin-bottom:14px;font-size:13px;font-weight:450}.alert.error{background:#ff453a1a;color:var(--danger)}.alert.info{background:#0071e314;color:var(--info)}.alert.warn{background:#ff9f0a1f;color:var(--warning)}.feed-item{display:flex;gap:10px;padding:9px 0;border-bottom:1px solid var(--border);font-size:13px;align-items:center}.feed-item:last-child{border-bottom:none}.feed-item .time{color:var(--muted);font-size:11.5px}.quiz-q{margin-bottom:20px}.quiz-q .opts{display:flex;flex-direction:column;gap:7px;margin-top:9px}.quiz-q .opts label{display:flex;gap:10px;align-items:center;font-size:13.5px;font-weight:450;color:var(--text);border:1px solid var(--border);padding:11px 14px;border-radius:12px;cursor:pointer;margin:0;transition:border-color .15s ease,background .15s ease}.quiz-q .opts label:hover{background:var(--surface2)}.quiz-q .opts label:has(input:checked){border-color:var(--accent);background:var(--accent-soft)}.quiz-q .opts input{width:auto;accent-color:var(--accent)}.progress-bar{height:6px;background:var(--surface2);border-radius:980px;overflow:hidden}.progress-bar>div{height:100%;background:var(--accent);border-radius:980px;transition:width .3s ease}.chat-layout{display:grid;grid-template-columns:300px 1fr;gap:16px;height:calc(100vh - 170px);min-height:420px}.chat-list{padding:10px;overflow-y:auto;display:flex;flex-direction:column;gap:3px}.chat-channel{display:flex;align-items:center;gap:11px;width:100%;text-align:left;border:none;background:none;padding:10px 11px;border-radius:12px;font-weight:500}.chat-channel.active{background:var(--accent-soft)}.chat-channel:hover{background:var(--surface2)}.chat-channel.active:hover{background:var(--accent-soft)}.chat-icon{width:36px;height:36px;border-radius:11px;background:var(--surface2);display:inline-flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.chat-channel-info{flex:1;min-width:0;display:flex;flex-direction:column}.chat-preview{font-size:11.5px;color:var(--muted);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.chat-thread{display:flex;flex-direction:column;padding:0;overflow:hidden}.chat-thread-head{padding:14px 18px;border-bottom:1px solid var(--border);display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.chat-messages{flex:1;overflow-y:auto;padding:16px 18px;display:flex;flex-direction:column;gap:6px}.msg-row{display:flex;gap:8px;align-items:flex-end}.msg-row.mine{justify-content:flex-end}.msg-bubble{background:var(--surface2);border-radius:18px 18px 18px 5px;padding:8px 13px;max-width:68%;font-size:13.5px}.msg-bubble.mine{background:var(--accent);color:#fff;border-radius:18px 18px 5px}.msg-author{font-size:11.5px;font-weight:600;color:var(--accent);margin-bottom:2px}.msg-bubble.mine .msg-time{color:#ffffffb3}.msg-time{font-size:10px;color:var(--muted);text-align:right;margin-top:2px}.chat-input{display:flex;gap:8px;padding:14px 18px;border-top:1px solid var(--border)}.chat-input input{border-radius:980px}@media (max-width: 900px){.chat-layout{grid-template-columns:1fr;height:auto}.chat-thread{min-height:60vh}.sidebar{position:fixed;left:-250px;transition:left .25s cubic-bezier(.4,0,.2,1);z-index:90}.sidebar.open{left:0}.kanban{grid-template-columns:1fr}.content{padding:16px}.menu-btn{display:inline-flex!important}}.menu-btn{display:none}
