:root{--blue: #72b8e8;--purple: #8a72d8;--pink: #d44a99;--success: #25a46f;--warning: #d89b22;--error: #db5c63;--sidebar-width: 232px;--accent-purple: var(--purple);--accent-purple-light: #b09de0;--accent-purple-dark: #7056a8;--accent-blue: var(--blue);--accent-cyan: #60c8e0;--accent-pink: var(--pink);--gradient-logo: linear-gradient(135deg, #75b7ee 0%, #8b74d7 52%, #d64c9f 100%);--gradient-purple: linear-gradient(135deg, #7d67cb 0%, #aa79e5 100%);--gradient-purple-blue: linear-gradient(135deg, #8a72d8 0%, #72b8e8 100%);--bg-app: #0f1220;--bg-app-rgb: 15, 18, 32;--bg-card: rgba(20, 24, 41, .78);--bg-card-solid: #171b2f;--bg-elevated: rgba(26, 31, 51, .9);--bg-soft: rgba(255, 255, 255, .06);--bg-soft-strong: rgba(255, 255, 255, .1);--bg-input: rgba(10, 14, 28, .42);--bg-sidebar: rgba(11, 15, 28, .88);--bg-sidebar-solid: #101426;--bg-overlay: rgba(6, 10, 22, .62);--surface-tint: rgba(138, 114, 216, .12);--surface-tint-strong: rgba(138, 114, 216, .18);--border-color: rgba(164, 177, 214, .14);--border-strong: rgba(164, 177, 214, .24);--text-primary: #edf1ff;--text-secondary: #a8b4d3;--text-muted: #72809d;--text-on-accent: #f8f7ff;--shadow-soft: 0 20px 60px rgba(0, 0, 0, .24);--shadow-strong: 0 24px 80px rgba(0, 0, 0, .34);--ring-color: rgba(138, 114, 216, .28);--nav-hover: rgba(138, 114, 216, .12);--nav-active: rgba(138, 114, 216, .2);--bg-dark: var(--bg-app)}:root[data-theme=light]{--accent-purple-light: #6b4fc4;--accent-purple-dark: #5d44b0;--bg-app: #eef3fb;--bg-app-rgb: 238, 243, 251;--bg-card: rgba(255, 255, 255, .92);--bg-card-solid: #ffffff;--bg-elevated: rgba(255, 255, 255, .98);--bg-soft: rgba(77, 92, 132, .1);--bg-soft-strong: rgba(77, 92, 132, .18);--bg-input: rgba(244, 247, 253, .98);--bg-sidebar: rgba(248, 251, 255, .94);--bg-sidebar-solid: #f8fbff;--bg-overlay: rgba(73, 88, 126, .18);--surface-tint: rgba(107, 79, 196, .1);--surface-tint-strong: rgba(107, 79, 196, .16);--border-color: rgba(84, 102, 146, .22);--border-strong: rgba(84, 102, 146, .34);--text-primary: #19243d;--text-secondary: #4f5f7f;--text-muted: #6f7d99;--text-on-accent: #ffffff;--shadow-soft: 0 18px 40px rgba(97, 114, 150, .16);--shadow-strong: 0 24px 64px rgba(97, 114, 150, .24);--ring-color: rgba(107, 79, 196, .2);--nav-hover: rgba(107, 79, 196, .1);--nav-active: rgba(107, 79, 196, .16)}*{box-sizing:border-box}body{margin:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;background:radial-gradient(circle at top left,rgba(114,184,232,.16),transparent 28%),radial-gradient(circle at top right,rgba(212,74,153,.12),transparent 24%),linear-gradient(180deg,rgba(var(--bg-app-rgb),.98),rgba(var(--bg-app-rgb),1));color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;transition:background .3s ease,color .2s ease}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 70% 40% at 50% -10%,rgba(150,128,204,.12),transparent),linear-gradient(135deg,rgba(114,184,232,.04),transparent 32%,rgba(212,74,153,.05) 100%);pointer-events:none;z-index:0}:root[data-theme=light] body{background:radial-gradient(circle at top left,rgba(114,184,232,.22),transparent 26%),radial-gradient(circle at top right,rgba(212,74,153,.14),transparent 22%),linear-gradient(180deg,rgba(var(--bg-app-rgb),.98),rgba(var(--bg-app-rgb),1))}:root[data-theme=light] body:before{background:radial-gradient(ellipse 68% 42% at 50% -10%,rgba(107,79,196,.1),transparent),linear-gradient(135deg,rgba(114,184,232,.06),transparent 34%,rgba(212,74,153,.05) 100%)}#root{min-height:100vh;position:relative;z-index:1}a{color:var(--accent-purple-light);text-decoration:none;transition:color .2s ease}a:hover{color:var(--accent-purple)}button{font-family:inherit;cursor:pointer;border:none}input,select,textarea{font:inherit}button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:3px solid var(--ring-color);outline-offset:2px}svg,.lucide,[class*=lucide],.lucide-react{background:transparent!important}button,button svg,a svg,.nav-item svg,.nav-arrow svg,[class*=icon] svg{background:transparent!important}.glass{background:var(--bg-card);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid var(--border-color);box-shadow:var(--shadow-soft);border-radius:20px}.surface-card{background:var(--bg-elevated);border:1px solid var(--border-color);border-radius:20px;box-shadow:var(--shadow-soft)}:root[data-theme=light] .glass,:root[data-theme=light] .surface-card{box-shadow:0 16px 36px #6172961f}.section-heading{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.section-heading h1,.section-heading h2,.section-heading h3,.section-heading p{margin:0}@media(max-width:768px){:root{--sidebar-width: 100%}}.layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--bg-sidebar);backdrop-filter:blur(22px);-webkit-backdrop-filter:blur(22px);border-right:1px solid var(--border-color);display:flex;flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;bottom:0;z-index:100}.logo-panel{padding:18px 16px;display:flex;align-items:center;justify-content:space-between;gap:12px;border-bottom:1px solid var(--border-color)}.logo{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.logo-img{height:48px;width:auto;object-fit:contain;filter:drop-shadow(0 10px 16px rgba(86,96,164,.2))}.logo-copy{display:flex;align-items:center;min-width:0}.logo-copy strong{font-size:.98rem;color:var(--text-primary);line-height:1.1;word-break:keep-all;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.theme-toggle{width:42px;height:42px;border-radius:14px;background:var(--bg-soft);color:var(--text-primary);border:1px solid var(--border-color);display:inline-flex;align-items:center;justify-content:center;transition:transform .2s ease,background .2s ease,border-color .2s ease}.theme-toggle:hover{transform:translateY(-1px);background:var(--nav-hover);border-color:var(--border-strong)}.nav{flex:1;padding:20px 14px;display:flex;flex-direction:column;align-items:stretch;gap:6px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:14px;color:var(--text-secondary);background:transparent!important;border:1px solid transparent;transition:all .2s ease;text-decoration:none}.nav-label{font-size:.9rem;font-weight:500}.nav-item svg{background:transparent!important}.nav-item:hover{color:var(--text-primary);background:var(--nav-hover);border-color:#8a72d81f;transform:translate(2px)}.nav-item.active{color:var(--text-primary);background:var(--nav-active)!important;border-color:#8a72d847}.nav-item.active svg{color:var(--accent-purple-light)}.admin-nav-item{margin-top:8px;border-top:1px solid var(--border-color);padding-top:14px;color:var(--accent-purple-light)!important;opacity:.85}.admin-nav-item:hover{opacity:1;background:var(--nav-hover)!important;color:var(--accent-purple-light)!important}.admin-nav-item.active{opacity:1;background:var(--nav-active)!important;color:var(--text-primary)!important}.main-content{flex:1;margin-left:var(--sidebar-width);padding:24px 28px 28px;min-height:100vh;height:auto;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden}.content-topbar{display:flex;align-items:flex-end;justify-content:flex-start;gap:16px;margin-bottom:24px;padding:4px 4px 18px;border-bottom:1px solid var(--border-color)}.content-kicker{margin:0 0 6px;font-size:.76rem;letter-spacing:.08em;text-transform:uppercase;color:var(--text-muted)}.content-topbar h1{margin:0;font-size:1.75rem;line-height:1.1}.content-body{flex:1;min-height:0}.sidebar-bottom{padding:14px;border-top:1px solid var(--border-color);display:flex;flex-direction:column;gap:12px;background:linear-gradient(180deg,transparent 0%,rgba(138,114,216,.04) 100%)}.sidebar-user{display:flex;align-items:center;gap:10px;padding:12px;background:var(--bg-soft);border:1px solid rgba(138,114,216,.08);border-radius:18px}.sidebar-user-avatar{width:38px;height:38px;border-radius:14px;background:var(--gradient-purple);color:var(--text-on-accent);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:700;flex-shrink:0}.sidebar-user-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.sidebar-user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{font-size:.72rem;color:var(--text-secondary);white-space:nowrap}.sidebar-auth-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:12px 14px;border-radius:14px;cursor:pointer;font-size:.9rem;font-weight:700;transition:all .2s ease;width:100%}.logout-btn{background:#db5c631f!important;color:var(--error)!important;border:1px solid rgba(219,92,99,.24)!important}.logout-btn:hover{background:#db5c632e!important;transform:translateY(-1px)}@media(max-width:1024px){.main-content{padding:20px 20px 24px}.content-topbar{margin-bottom:20px}.logo-copy strong{font-size:.88rem}.logo-copy span{font-size:.72rem}}@media(max-width:768px){.sidebar{width:100%;height:auto;bottom:0;top:auto;flex-direction:row;justify-content:space-around;padding:8px 4px;border-right:none;border-top:1px solid var(--border-color);padding-bottom:calc(8px + env(safe-area-inset-bottom))}.logo-panel,.sidebar-bottom{display:none}.nav{flex-direction:row;flex:1;justify-content:flex-start;padding:0;overflow-x:auto;gap:4px;scrollbar-width:none}.nav::-webkit-scrollbar{display:none}.nav-item{flex:0 0 auto;min-width:52px;justify-content:center;padding:10px 12px}.nav-item:hover{transform:none}.nav-label{display:none}.main-content{margin-left:0;margin-bottom:82px;padding:16px 14px calc(24px + env(safe-area-inset-bottom));min-height:auto}.content-topbar{padding-inline:0;padding-bottom:14px;margin-bottom:16px}.content-topbar h1{font-size:1.45rem}}@media(max-width:480px){.main-content{padding:14px 12px calc(20px + env(safe-area-inset-bottom))}.content-topbar{padding-bottom:12px}.content-kicker{margin-bottom:4px;font-size:.72rem}.content-topbar h1{font-size:1.38rem}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}.login-page:after{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 80% 60% at 15% 15%,rgba(124,58,237,.25),transparent),radial-gradient(ellipse 55% 55% at 85% 85%,rgba(59,130,246,.18),transparent),radial-gradient(ellipse 40% 40% at 60% 10%,rgba(236,72,153,.1),transparent);pointer-events:none;z-index:0}.login-card{width:100%;max-width:420px;padding:48px 40px 44px;position:relative;z-index:1;box-shadow:0 0 0 1px #7c3aed2e,0 24px 48px #0006,0 4px 16px #7c3aed1f}.login-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:36px}.login-logo-img{height:52px;width:auto;object-fit:contain;filter:drop-shadow(0 0 12px rgba(124,58,237,.5))}.login-logo-title{font-size:1.6rem;font-weight:800;background:var(--gradient-purple);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;line-height:1}.login-logo-sub{font-size:.83rem;color:var(--text-muted);margin-top:2px;letter-spacing:.3px}.login-form{display:flex;flex-direction:column;gap:18px}.form-group{display:flex;flex-direction:column;gap:7px}.form-group label{font-size:.82rem;font-weight:600;color:var(--text-secondary);letter-spacing:.3px}.input-wrap{position:relative;display:flex;align-items:center}.input-icon{position:absolute;left:13px;color:var(--text-muted);pointer-events:none;flex-shrink:0;z-index:2}.form-input{width:100%;padding:11px 44px 11px 40px;background:#0a0816b3;border:1px solid rgba(148,163,184,.14);border-radius:10px;color:var(--text-primary);font-size:.93rem;font-family:inherit;transition:border-color .2s,box-shadow .2s,background .2s;outline:none;position:relative;z-index:1}.form-input::placeholder{color:var(--text-muted);font-size:.88rem}.form-input:focus{border-color:var(--accent-purple);background:#0f0a1ed9;box-shadow:0 0 0 3px #7c3aed2e}.form-input.error{border-color:var(--error);box-shadow:0 0 0 3px #ef44441f}.field-error{font-size:.78rem;color:var(--error);display:flex;align-items:center;gap:4px;padding-left:2px}.pw-toggle{position:absolute;right:10px;z-index:3;background:none;border:none;color:var(--text-muted);cursor:pointer;padding:6px;display:flex;align-items:center;border-radius:6px;transition:color .15s,background .15s;line-height:0}.pw-toggle:hover{color:var(--text-secondary);background:#94a3b814}.login-btn{width:100%;padding:12px;background:var(--gradient-purple-blue);color:#fff;font-size:.97rem;font-weight:700;border-radius:10px;border:none;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;margin-top:6px;letter-spacing:.3px;box-shadow:0 4px 20px #7c3aed4d}.login-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 24px #7c3aed73}.login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 2px 12px #7c3aed4d}.login-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.login-error{display:flex;align-items:center;gap:8px;padding:11px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.28);border-radius:8px;color:#fca5a5;font-size:.85rem;line-height:1.4}.login-btn-inner{display:flex;align-items:center;justify-content:center;gap:8px}.spinner{width:17px;height:17px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .65s linear infinite;flex-shrink:0}@keyframes spin{to{transform:rotate(360deg)}}.login-footer{margin-top:20px;text-align:center;font-size:.83rem;color:var(--text-muted)}.login-footer a{color:var(--accent-purple-light);font-weight:600;transition:color .15s}.login-footer a:hover{color:#c4b5fd}@media(max-width:480px){.login-card{padding:36px 22px 32px}}.register-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative}.register-page:after{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 72% 58% at 12% 18%,rgba(124,58,237,.24),transparent),radial-gradient(ellipse 55% 55% at 84% 82%,rgba(59,130,246,.16),transparent),radial-gradient(ellipse 40% 40% at 50% 8%,rgba(16,185,129,.1),transparent);pointer-events:none;z-index:0}.register-card{width:100%;max-width:460px;padding:42px 38px 38px;position:relative;z-index:1;box-shadow:0 0 0 1px #7c3aed2e,0 24px 48px #0006,0 4px 16px #7c3aed1f}.register-logo{display:flex;flex-direction:column;align-items:center;gap:10px;margin-bottom:28px}.register-logo-img{height:52px;width:auto;object-fit:contain;filter:drop-shadow(0 0 12px rgba(124,58,237,.5))}.register-logo-title{font-size:1.6rem;font-weight:800;background:var(--gradient-purple);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;letter-spacing:-.5px;line-height:1}.register-logo-sub{font-size:.83rem;color:var(--text-muted);margin-top:2px;letter-spacing:.3px}.register-form{display:flex;flex-direction:column;gap:16px}.form-select{appearance:none}.register-btn{width:100%;padding:12px;background:linear-gradient(135deg,#7c3aed,#2563eb);color:#fff;font-size:.97rem;font-weight:700;border-radius:10px;border:none;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;margin-top:6px;letter-spacing:.3px;box-shadow:0 4px 20px #2563eb47}.register-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px);box-shadow:0 6px 24px #2563eb66}.register-btn:active:not(:disabled){transform:translateY(0)}.register-btn:disabled{opacity:.5;cursor:not-allowed;box-shadow:none}.register-btn-inner{display:flex;align-items:center;justify-content:center;gap:8px}.register-error{display:flex;align-items:center;gap:8px;padding:11px 14px;background:#ef44441a;border:1px solid rgba(239,68,68,.28);border-radius:8px;color:#fca5a5;font-size:.85rem;line-height:1.4}.register-footer{margin-top:20px;text-align:center;font-size:.83rem;color:var(--text-muted)}.register-footer a{color:var(--accent-purple-light);font-weight:600;transition:color .15s}.register-footer a:hover{color:#c4b5fd}@media(max-width:480px){.register-card{padding:36px 22px 32px}}.clock-time-picker{display:flex;flex-direction:column;align-items:center;gap:12px}.clock-face{width:160px;height:160px;border-radius:50%;background:#0f0d1a99;border:2px solid rgba(148,163,184,.2);position:relative;flex-shrink:0}.clock-mark{position:absolute;left:50%;top:50%;width:24px;height:24px;margin-left:-12px;margin-top:-12px;display:flex;align-items:center;justify-content:center;font-size:.75rem;color:var(--text-secondary);transform-origin:12px 12px}.clock-hand{position:absolute;left:50%;top:50%;transform-origin:left center;cursor:grab;transition:transform .05s ease-out}.clock-hand:active,.clock-hand.active{cursor:grabbing}.hour-hand{width:35px;height:4px;margin-top:-2px;background:var(--text-primary);border-radius:2px;box-shadow:0 0 4px #0000004d}.minute-hand{width:50px;height:3px;margin-top:-1.5px;background:var(--accent-purple);border-radius:2px;box-shadow:0 0 4px #7c3aed66}.clock-center{position:absolute;left:50%;top:50%;width:10px;height:10px;margin-left:-5px;margin-top:-5px;border-radius:50%;background:var(--accent-purple)}.clock-display{font-size:.95rem;font-weight:600;color:var(--text-primary)}.clock-ampm-toggle{display:flex;gap:8px}.clock-ampm-toggle button{padding:6px 14px;border-radius:8px;font-size:.8rem;background:#94a3b81a;color:var(--text-secondary);border:1px solid rgba(148,163,184,.2)}.clock-ampm-toggle button.active{background:var(--accent-purple);color:var(--text-primary);border-color:var(--accent-purple)}.set-work-days-personal{display:flex;flex-direction:column;gap:20px}.schedule-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;flex-wrap:wrap}.set-work-days-personal h3{font-size:1.1rem;margin-bottom:4px}.set-work-days-personal .desc{color:var(--text-secondary);font-size:.85rem;line-height:1.6;margin:0}.member-info{display:flex;align-items:center;gap:8px;flex-shrink:0}.member-avatar{width:32px;height:32px;border-radius:50%;background:var(--gradient-purple);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:600;flex-shrink:0}.member-name{font-weight:500;font-size:.9rem}.schedule-loading{color:var(--text-secondary);font-size:.9rem;padding:12px 0}.schedule-summary{display:flex;align-items:center;justify-content:flex-start;gap:14px;flex-wrap:wrap;padding:16px 18px;border-radius:18px;background:var(--bg-soft);border:1px solid var(--border-color)}.schedule-summary p{margin:0;flex:1;min-width:0;color:var(--text-secondary);font-size:.83rem;line-height:1.6;overflow-wrap:anywhere}.summary-chip{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:var(--surface-tint);color:var(--text-primary);font-size:.82rem;font-weight:700}.day-schedule-grid{display:grid;grid-template-columns:repeat(7,minmax(170px,1fr));gap:14px;overflow-x:auto;padding-bottom:6px;scroll-snap-type:x proximity}.day-col{display:flex;flex-direction:column;gap:16px;padding:18px;border-radius:22px;background:var(--bg-soft);border:1px solid var(--border-color);transition:border-color .2s ease,background .2s ease,transform .2s ease;min-height:240px;min-width:170px;scroll-snap-align:start}.day-col.active{background:var(--surface-tint);border-color:#8a72d847;box-shadow:0 18px 36px #090c182e}.day-col:hover{transform:translateY(-1px)}.day-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.day-label{display:block;font-size:1rem;font-weight:700;color:var(--text-secondary)}.day-col.active .day-label{color:var(--text-primary)}.day-status{display:inline-flex;align-items:center;margin-top:8px;padding:6px 10px;border-radius:999px;font-size:.75rem;font-weight:700}.day-status.active{background:#25a46f29;color:var(--success)}.day-status.inactive{background:#94a3b824;color:var(--text-secondary)}.toggle{width:48px;height:28px;border-radius:999px;background:#94a3b84d;position:relative;border:1px solid transparent;transition:background .2s ease,border-color .2s ease;flex-shrink:0;cursor:pointer}.toggle:after{content:"";position:absolute;width:20px;height:20px;border-radius:50%;background:var(--text-primary);top:3px;left:3px;transition:transform .2s;box-shadow:0 1px 3px #0000004d}.toggle.on{background:var(--accent-purple);border-color:#8a72d857}.toggle.on:after{transform:translate(20px)}.day-times{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.time-field{display:flex;flex-direction:column;gap:6px}.time-field label{font-size:.76rem;font-weight:600;color:var(--text-secondary)}.time-field input{padding:10px 12px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:.88rem;width:100%;color-scheme:dark light;transition:border-color .2s ease,background .2s ease}.time-field input:focus{border-color:var(--accent-purple);outline:none;background:var(--bg-card-solid)}.day-off-label{display:flex;flex-direction:column;gap:6px;color:var(--text-secondary);margin-top:auto}.day-off-label strong{font-size:.86rem;color:var(--text-primary)}.day-off-label span{font-size:.8rem;line-height:1.5}.week-pattern-group{display:flex;flex-direction:column;gap:10px}.week-pattern-label{font-size:.78rem;font-weight:600;color:var(--text-secondary)}:root[data-theme=light] .time-field input{color-scheme:light}.week-pattern-options{display:flex;flex-wrap:wrap;gap:8px}.week-pattern-chip{padding:8px 12px;border-radius:999px;background:#ffffff0d;border:1px solid transparent;color:var(--text-secondary);font-size:.78rem;font-weight:600;transition:all .2s ease}.week-pattern-chip:hover{background:#8a72d81f;color:var(--text-primary)}.week-pattern-chip.active{background:var(--accent-purple);color:var(--text-on-accent);border-color:#8a72d861}.schedule-error{color:var(--error);font-size:.85rem}.schedule-save-btn{align-self:flex-start;display:inline-flex;align-items:center;justify-content:center;padding:12px 24px;background:var(--gradient-purple);color:var(--text-on-accent);border-radius:14px;font-weight:700;font-size:.92rem;box-shadow:var(--shadow-soft);transition:opacity .2s ease,transform .2s ease}.schedule-save-btn:disabled{opacity:.6;cursor:not-allowed}.schedule-save-btn:hover:not(:disabled){opacity:.92;transform:translateY(-1px)}@media(max-width:1400px){.day-schedule-grid{grid-template-columns:repeat(7,minmax(160px,1fr))}}@media(max-width:960px){.member-info{width:100%}.day-schedule-grid{grid-template-columns:repeat(7,minmax(150px,1fr))}}@media(max-width:640px){.schedule-summary{padding:14px 16px;align-items:flex-start}.day-schedule-grid{grid-template-columns:repeat(7,minmax(138px,1fr));gap:10px}.day-col{padding:16px;min-height:0;min-width:138px;border-radius:18px}.day-times{grid-template-columns:1fr}.week-pattern-options{gap:6px}.week-pattern-chip{padding:7px 10px;font-size:.76rem}.schedule-save-btn{width:100%;justify-content:center}}@media(max-width:480px){.set-work-days-personal h3{font-size:1rem}.set-work-days-personal .desc,.schedule-summary p,.day-off-label span{font-size:.8rem}.day-schedule-grid{grid-template-columns:repeat(7,minmax(132px,1fr))}.day-col{padding:14px;min-width:132px;gap:14px}.toggle{width:44px;height:26px}.toggle:after{width:18px;height:18px}.toggle.on:after{transform:translate(18px)}}.team-attendance-status{display:flex;flex-direction:column;gap:20px}.team-attend-header{display:flex;align-items:center;justify-content:space-between}.team-attend-header h3{font-size:1rem;font-weight:600}.attend-date{font-size:.82rem;color:var(--text-secondary)}.attend-summary{display:flex;gap:12px}.summary-item{flex:1;display:flex;flex-direction:column;align-items:center;padding:14px 0;border-radius:10px;gap:4px;border:2px solid transparent;cursor:pointer;transition:border-color .15s,transform .1s;background:none}.summary-item:hover{transform:translateY(-1px)}.summary-item.working{background:#22c55e1f}.summary-item.left{background:#64748b26}.summary-item.absent{background:#ef44441f}.summary-item.working.active{border-color:var(--success)}.summary-item.left.active{border-color:var(--text-secondary)}.summary-item.absent.active{border-color:var(--error)}.summary-count{font-size:1.6rem;font-weight:700}.summary-item.working .summary-count{color:var(--success)}.summary-item.left .summary-count{color:var(--text-secondary)}.summary-item.absent .summary-count{color:var(--error)}.summary-label{font-size:.75rem;color:var(--text-secondary)}.attend-member-grid{display:flex;flex-direction:column;gap:8px;max-height:420px;overflow-y:auto}.attend-member-card{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:10px;background:#ffffff08;border:1px solid transparent;transition:border-color .2s}.attend-member-card.working{border-color:#22c55e33}.attend-member-card.left{border-color:#64748b33}.attend-member-card.absent{border-color:#ef444426}.attend-member-avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-purple, var(--accent-purple));display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;color:#fff;flex-shrink:0}.attend-member-info{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.attend-member-name{font-size:.88rem;font-weight:600;color:var(--text-primary)}.attend-member-team{font-size:.72rem;color:var(--text-secondary)}.attend-member-right{display:flex;flex-direction:column;align-items:flex-end;gap:4px;flex-shrink:0}.attend-status-badge{font-size:.72rem;font-weight:600;padding:3px 10px;border-radius:20px}.attend-status-badge.working{background:#22c55e33;color:var(--success)}.attend-status-badge.left{background:#64748b33;color:var(--text-secondary)}.attend-status-badge.absent{background:#ef444426;color:var(--error)}.attend-time{font-size:.72rem;color:var(--text-secondary);font-variant-numeric:tabular-nums}.attend-empty{text-align:center;color:var(--text-secondary);font-size:.85rem;padding:32px 0}:root[data-theme=light] .summary-item.left{background:#5466921a}:root[data-theme=light] .attend-member-card{background:#5466920a}.team-work-schedule-panel{display:flex;flex-direction:column;gap:20px}.team-work-schedule-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px}.team-work-schedule-header h3{margin:0 0 8px;font-size:1.05rem}.team-work-schedule-header p{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.6}.team-work-schedule-count{padding:8px 12px;border-radius:999px;background:var(--surface-tint);color:var(--text-primary);font-size:.82rem;font-weight:700;white-space:nowrap}.team-work-schedule-list{display:flex;flex-direction:column;gap:14px}.team-work-schedule-card{display:grid;grid-template-columns:180px minmax(0,1fr);align-items:center;gap:18px;padding:18px;border-radius:20px;background:var(--bg-soft);border:1px solid var(--border-color)}.team-work-member-head{display:flex;align-items:center;gap:12px}.team-work-member-avatar{width:40px;height:40px;border-radius:14px;background:var(--gradient-purple);color:var(--text-on-accent);display:flex;align-items:center;justify-content:center;font-weight:700;flex-shrink:0}.team-work-member-copy{display:flex;flex-direction:column;gap:4px}.team-work-member-copy strong{font-size:.95rem}.team-work-member-copy span{color:var(--text-secondary);font-size:.8rem}.team-work-week-grid{display:grid;grid-template-columns:repeat(7,minmax(82px,1fr));gap:10px}.team-work-day-card{display:flex;flex-direction:column;gap:6px;min-width:0;padding:10px 12px;border-radius:16px;border:1px solid rgba(138,114,216,.16);background:#ffffff0a}.team-work-day-card.active{background:#7c3aed1f;border-color:#8a72d842}.team-work-day-card.off{background:#94a3b80f;border-color:#94a3b81f}.team-work-day{font-size:.76rem;font-weight:700;color:var(--accent-purple-light)}.team-work-time{font-size:.8rem;color:var(--text-primary);font-variant-numeric:tabular-nums;white-space:nowrap}.team-work-schedule-empty{margin:0;padding:28px 0;text-align:center;color:var(--text-secondary)}@media(max-width:1200px){.team-work-schedule-card{grid-template-columns:1fr}}@media(max-width:900px){.team-work-week-grid{grid-template-columns:repeat(3,minmax(0,1fr))}}@media(max-width:640px){.team-work-week-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}.toast{position:fixed;bottom:24px;right:24px;z-index:9999;display:flex;align-items:center;gap:10px;padding:12px 16px;border-radius:12px;background:var(--bg-card-solid);border:1px solid var(--border-color);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);box-shadow:var(--shadow-soft);min-width:240px;max-width:380px;animation:toast-in .25s ease}@keyframes toast-in{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.toast-message{flex:1;font-size:.9rem;line-height:1.4;color:var(--text-primary)}.toast-close{background:none;border:none;cursor:pointer;color:var(--text-secondary);padding:2px;display:flex;align-items:center;transition:color .15s}.toast-close:hover{color:var(--text-primary)}.toast-success{border-color:#3db87a59}.toast-success .toast-message:before{content:"✓ ";color:var(--success);font-weight:700}.toast-error{border-color:#ef444459}.toast-error .toast-message:before{content:"✕ ";color:var(--error);font-weight:700}.toast-info{border-color:#72b8e859}.dashboard{max-width:1200px;min-height:calc(100vh - 180px);height:auto;display:flex;flex-direction:column}.dashboard-grid{display:grid;grid-template-columns:240px 1fr 1fr;grid-template-rows:1fr 1fr;gap:20px;flex:1;min-height:0}.clock-card{grid-column:1;grid-row:1 / 3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px 24px;background:linear-gradient(180deg,var(--bg-card) 0%,var(--bg-elevated) 100%)}.clock-card-loading{opacity:.85}.clock-ring-btn{background:none;border:none;padding:0;cursor:default;display:flex;align-items:center;justify-content:center}.clock-ring-btn.clickable{cursor:pointer;transition:transform .2s}.clock-ring-btn.clickable:hover{transform:scale(1.03)}.clock-outer{width:160px;height:160px;position:relative;display:flex;align-items:center;justify-content:center}.clock-ring-svg{position:absolute;inset:0}.clock-inner{width:110px;height:110px;border-radius:50%;background:var(--bg-card-solid);display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.clock-time{font-size:1.6rem;font-weight:700;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:1px}.clock-time-start{font-size:1.2rem;color:var(--success)}.clock-time-elapsed{font-size:1.35rem;color:var(--text-primary);font-variant-numeric:tabular-nums;letter-spacing:1px}.clock-time-done{font-size:1.35rem;color:var(--text-secondary);font-variant-numeric:tabular-nums;letter-spacing:1px}.clock-time-loading{font-size:1.4rem;color:var(--text-secondary)}.clock-footer{display:flex;flex-direction:column;align-items:center;gap:10px;width:100%}.clock-hint{font-size:.78rem;color:var(--text-secondary)}.clock-checkin-time{font-size:.8rem;color:var(--text-secondary)}.clockout-btn{padding:8px 24px;background:#db5c6324;color:var(--error);border:1px solid rgba(219,92,99,.28);border-radius:20px;font-size:.88rem;font-weight:600;cursor:pointer;transition:background .2s,border-color .2s;width:100%}.clockout-btn:hover:not(:disabled){background:#db5c632e;border-color:#db5c636b}.clockout-btn:disabled{opacity:.5;cursor:not-allowed}.schedule-card{grid-column:2 / 4;grid-row:1;min-height:140px}.chat-preview{grid-column:2;grid-row:2;min-height:160px}.tasks-card{grid-column:3;grid-row:2;min-height:160px}.card{padding:22px 24px;border-radius:24px}.card h3{font-size:1rem;font-weight:700;margin-bottom:18px;color:var(--text-primary);display:flex;align-items:center;gap:8px}.empty-state{display:flex;flex-direction:column;gap:8px;padding:12px 0}.empty-state p{color:var(--text-secondary);font-size:.88rem;margin:0}.schedule-card ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:8px}.schedule-item{display:flex;gap:12px;align-items:flex-start;padding:12px 14px;border-radius:16px}.schedule-item.purple{background:var(--surface-tint);border:1px solid rgba(138,114,216,.18)}.schedule-icon{color:var(--text-secondary);flex-shrink:0;margin-top:2px}.schedule-item div{display:flex;flex-direction:column;gap:2px}.schedule-time{color:var(--text-secondary);font-size:.78rem}.schedule-title{font-size:.9rem;color:var(--text-primary)}.chat-preview ul{list-style:none;padding:0;margin:0}.chat-preview li{display:flex;gap:12px;padding:10px 0;border-bottom:1px solid var(--border-color);font-size:.9rem}.chat-preview li:last-of-type{border-bottom:none}.chat-msg-content{flex:1;display:flex;flex-wrap:wrap;align-items:baseline;gap:6px;min-width:0}.chat-msg-content strong{font-size:.88rem;flex-shrink:0}.msg-text{flex:1;color:var(--text-secondary);font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}.ts{color:var(--text-muted);font-size:.75rem;flex-shrink:0}.avatar{width:36px;height:36px;border-radius:12px;background:var(--gradient-purple);display:flex;align-items:center;justify-content:center;font-size:.82rem;font-weight:600;color:var(--text-on-accent);flex-shrink:0}.view-all{display:block;margin-top:14px;color:var(--accent-purple-light);font-size:.85rem;text-decoration:none;transition:color .2s}.view-all:hover{color:var(--accent-purple)}.tasks-list{display:flex;flex-direction:column;gap:10px;list-style:none;padding:0;margin:0}.task-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border-radius:16px;background:var(--bg-soft);border:1px solid transparent}.task-item.done{opacity:.72}.task-dot{width:10px;height:10px;border-radius:999px;flex-shrink:0}.task-title{flex:1;min-width:0}.task-done-badge{padding:4px 8px;border-radius:999px;font-size:.72rem;background:#25a46f24;color:var(--success)}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr 1fr;grid-template-rows:auto}.clock-card,.schedule-card,.chat-preview,.tasks-card{grid-column:auto;grid-row:auto;min-height:auto}}@media(max-width:640px){.dashboard{min-height:auto}.dashboard-grid{grid-template-columns:1fr;gap:16px}.clock-outer{width:144px;height:144px}.card{padding:18px;border-radius:20px}}.view-all:hover{color:var(--text-primary)}.tasks-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}.task-item{display:flex;align-items:center;gap:10px;font-size:.9rem;color:var(--text-primary)}.task-item.done .task-title{text-decoration:line-through;color:var(--text-secondary)}.task-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.task-title{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.task-done-badge{font-size:.72rem;color:var(--success);border:1px solid var(--success);border-radius:4px;padding:1px 6px;flex-shrink:0}@media(max-width:900px){.dashboard{height:auto;min-height:auto}.dashboard-grid{grid-template-columns:1fr;grid-template-rows:auto;flex:none}.clock-card,.schedule-card,.chat-preview,.tasks-card{grid-column:1;grid-row:auto}.clock-card{min-height:260px}}.chat-page{display:flex;min-height:0;height:clamp(620px,calc(100dvh - 180px),860px);max-height:calc(100dvh - 180px);gap:0;border-radius:28px;border:1px solid var(--border-color);background:var(--bg-card);box-shadow:var(--shadow-soft);overflow:hidden}.chat-page>*{min-width:0}.chat-sidebar{width:280px;flex-shrink:0;min-height:0;overflow-y:auto;padding:20px;background:var(--bg-elevated);border-right:1px solid var(--border-color)}.chat-sidebar h2{font-size:1.2rem;font-weight:600;margin-bottom:6px}.chat-list-head{margin-bottom:16px}.chat-list-head p{margin:0;color:var(--text-secondary);font-size:.84rem;line-height:1.5}.search-wrap{display:flex;align-items:center;gap:8px;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:14px;margin-bottom:20px}.search-wrap input{flex:1;min-width:0;background:none;border:none;color:var(--text-primary);font-size:.9rem}.chat-sidebar section{margin-bottom:24px}.chat-sidebar h4{font-size:.7rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:12px}.channel-item{min-width:0;padding:12px;border-radius:14px;cursor:pointer;margin-bottom:4px;transition:background .2s ease,transform .2s ease}.channel-item:hover{background:var(--nav-hover);transform:translate(2px)}.channel-item.active{background:var(--nav-active);color:var(--text-primary)}.channel-name{display:block;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.channel-last{display:block;font-size:.8rem;color:var(--text-secondary);margin-top:2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-item{display:flex;align-items:center;gap:10px;min-width:0;padding:10px 12px;border-radius:14px;cursor:pointer;margin-bottom:4px;transition:background .2s ease}.dm-item:hover{background:var(--nav-hover)}.dm-item.active{background:var(--nav-active)}.dm-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-purple);display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0}.dm-name{font-size:.9rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dm-copy{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.dm-room-hint{font-size:.75rem;color:var(--text-secondary)}.dm-status{font-size:.75rem;color:var(--text-secondary);flex-shrink:0}.dm-status.online{color:var(--success)}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0;height:100%;background:linear-gradient(180deg,rgba(255,255,255,.02) 0%,transparent 100%),var(--bg-card)}.chat-header{padding:18px 24px;display:flex;align-items:center;justify-content:space-between;gap:12px;min-width:0;background:var(--bg-elevated);border-bottom:1px solid var(--border-color);box-shadow:none}.chat-header h3{font-size:1.1rem;margin:0 0 2px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-room-meta{display:flex;align-items:center;gap:12px;min-width:0;flex:1}.chat-room-meta>div{min-width:0}.chat-back-btn{width:36px;height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-soft);color:var(--text-primary);border:1px solid var(--border-color)}.members-count{font-size:.85rem;color:var(--text-secondary);display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-header-actions{display:flex;gap:8px;flex-shrink:0}.chat-header-actions button{padding:8px;color:var(--text-secondary);border-radius:10px;background:transparent}.chat-header-actions button:hover{background:var(--nav-hover);color:var(--text-primary)}.chat-messages{flex:1;overflow-y:auto;padding:24px;background:linear-gradient(180deg,#ffffff03,#fff0),radial-gradient(circle at top right,rgba(212,74,153,.08),transparent 30%)}.chat-empty-room{display:flex;flex-direction:column;gap:10px;max-width:420px;margin:16px auto 0;padding:18px;border-radius:20px;background:var(--bg-soft);border:1px solid var(--border-color);text-align:center}.chat-empty-room strong,.chat-empty-room p{margin:0}.chat-empty-room p{color:var(--text-secondary);line-height:1.6}.chat-empty-search{padding:12px;border-radius:14px;background:var(--bg-soft);color:var(--text-secondary);font-size:.85rem}.msg{display:flex;gap:14px;margin-bottom:20px}.msg-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-purple);display:flex;align-items:center;justify-content:center;font-size:.85rem;flex-shrink:0}.msg.own{flex-direction:row-reverse}.msg.own .msg-content{background:#7c3aed40;margin-left:auto;margin-right:0}.msg.own .msg-avatar{background:var(--accent-purple)}.msg-content{max-width:75%;padding:12px 16px;background:var(--bg-soft);border:1px solid var(--border-color);border-radius:16px}.msg-meta{display:flex;align-items:center;gap:10px;margin-bottom:6px}.msg-time{font-size:.75rem;color:var(--text-secondary)}.msg-content p{margin:0;font-size:.95rem;line-height:1.5}.msg-markdown{font-size:.95rem;line-height:1.5;word-break:normal;overflow-wrap:break-word}.msg-markdown p{margin:0 0 .5em}.msg-markdown p:last-child{margin-bottom:0}.msg-markdown strong{font-weight:600}.msg-markdown em{font-style:italic}.msg-markdown del{text-decoration:line-through}.msg-markdown code{background:var(--bg-soft-strong);padding:2px 6px;border-radius:4px;font-size:.9em}.msg-markdown pre{margin:.5em 0;padding:12px;background:var(--bg-soft-strong);border:1px solid var(--border-color);border-radius:8px;overflow-x:auto}.msg-markdown pre code{background:none;padding:0}.msg-markdown ul,.msg-markdown ol{margin:.5em 0;padding-left:1.25em}.msg-markdown a{color:var(--accent-purple-light);text-decoration:underline}.msg-markdown a:hover{color:var(--accent-purple)}.msg-reactions{font-size:.8rem;color:var(--text-secondary);margin-top:8px}.file-attachment{display:flex;align-items:center;gap:10px;padding:8px 0}.file-icon{font-size:1.5rem}.code-block{background:var(--bg-soft-strong);border:1px solid var(--border-color);padding:12px;border-radius:8px;font-family:monospace;font-size:.85rem;overflow-x:auto}.chat-input-area{padding:18px 24px 22px;display:flex;flex-direction:column;gap:10px;flex-shrink:0;background:var(--bg-card-solid);border-top:1px solid var(--border-color);box-shadow:none}.input-preview{margin-bottom:4px}.input-preview-content{max-width:70%}.input-row{display:flex;gap:12px;align-items:center}.chat-input-area .chat-input{flex:1;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:14px;color:var(--text-primary);font-size:.95rem;resize:none;min-height:44px;max-height:120px;font-family:inherit}.chat-input-area .chat-input::placeholder{color:var(--text-secondary)}.format-toolbar{display:flex;gap:4px}.format-toolbar button{padding:6px 8px;color:var(--text-secondary);border-radius:10px;background:transparent}.format-toolbar button:hover{background:var(--nav-hover);color:var(--text-primary)}.format-toolbar button{position:relative}.emoji-picker{position:absolute;bottom:100%;left:0;margin-bottom:8px;padding:12px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;display:grid;grid-template-columns:repeat(8,1fr);gap:4px;z-index:100;box-shadow:0 8px 24px #0000004d}.emoji-picker button{padding:6px;font-size:1.2rem;background:transparent;border:none;border-radius:6px;cursor:pointer}.emoji-picker button:hover{background:#7c3aed33}.attach-label{padding:6px 8px;color:var(--text-secondary);cursor:pointer}.attach-label:hover{color:var(--text-primary)}.attachments-preview{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:8px}.attach-tag{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;background:#7c3aed33;border-radius:8px;font-size:.85rem;color:var(--text-primary)}.attach-tag button{padding:2px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;display:flex}.attach-tag button:hover{color:var(--text-primary)}.attach-thumb{width:32px;height:32px;object-fit:cover;border-radius:4px}.file-preview-img{max-width:120px;max-height:120px;border-radius:8px;object-fit:cover}.link-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.link-modal{padding:24px;min-width:320px;border-radius:12px}.link-modal h4{margin:0 0 16px;font-size:1rem}.link-modal input{width:100%;padding:12px 16px;margin-bottom:16px;background:var(--bg-input);border:1px solid var(--border-color);border-radius:10px;color:var(--text-primary);font-size:.95rem}.link-modal-actions{display:flex;gap:12px;justify-content:flex-end}.link-modal-actions button{padding:10px 20px;border-radius:10px;background:#94a3b826;color:var(--text-primary);border:1px solid var(--border-color)}.link-modal-actions button.primary{background:var(--gradient-purple);border:none}.send-btn{display:flex;align-items:center;gap:8px;padding:12px 18px;background:var(--gradient-purple);color:var(--text-on-accent);border-radius:14px;font-weight:700}:root[data-theme=light] .chat-main{background:radial-gradient(circle at top right,rgba(107,79,196,.08),transparent 28%),linear-gradient(180deg,#ffffffd1,#f4f7fdf5)}:root[data-theme=light] .msg.own .msg-content{background:#6b4fc429;border-color:#6b4fc433}@media(max-width:768px){.chat-page{display:block;min-height:calc(100vh - 164px);height:auto;max-height:none;border-radius:20px}.chat-sidebar{width:100%;max-height:none;padding:16px;border-right:none}.chat-main{min-height:60vh}.chat-page.list-open-mobile .chat-main,.chat-page.room-open-mobile .chat-sidebar{display:none}.chat-header{padding:16px;align-items:center}.chat-header-actions{width:auto;flex-direction:row;align-items:center}.chat-room-meta{min-width:0}.chat-messages{padding:16px}.msg-content{max-width:100%}.chat-input-area{padding:14px 16px 18px}.input-row{flex-wrap:wrap;align-items:stretch}.format-toolbar{width:100%;overflow-x:auto;scrollbar-width:none}.format-toolbar::-webkit-scrollbar{display:none}.chat-input-area .chat-input{width:100%}.send-btn{flex:0 0 auto;justify-content:center}.emoji-picker{grid-template-columns:repeat(6,1fr)}.link-modal{min-width:0;width:calc(100vw - 32px);max-width:420px;padding:18px}}@media(max-width:480px){.chat-page{border-radius:18px}.search-wrap,.chat-header,.chat-input-area .chat-input{border-radius:12px}.chat-sidebar,.chat-messages,.chat-input-area{padding-inline:14px}.chat-header{padding:14px;flex-wrap:nowrap}.chat-header h3{font-size:1rem}.chat-header-actions button,.chat-back-btn{width:34px;height:34px;padding:0}.members-count{font-size:.8rem}.msg{gap:10px;margin-bottom:16px}.msg-avatar{width:34px;height:34px;font-size:.78rem}.input-row{flex-direction:column}.send-btn{width:100%}}.time-input{display:flex;align-items:center;gap:4px}.time-input-group{display:flex;align-items:center;background:#0f0d1a80;border:1px solid rgba(255,255,255,.1);border-radius:8px;overflow:hidden}.time-input-field{width:44px;padding:10px 8px 10px 12px;font-size:1rem;font-weight:600;color:var(--text-primary);background:transparent;border:none;text-align:center}.time-input-field:focus{outline:none}.time-input-arrows{display:flex;flex-direction:column;padding-right:4px}.time-input-arrows button{padding:2px;color:var(--text-secondary);background:transparent}.time-input-arrows button:hover{color:var(--text-primary)}.time-input-sep{font-size:1.2rem;font-weight:600;color:var(--text-secondary)}.calendar-page{display:flex;gap:0;height:calc(100vh - 48px);max-height:calc(100vh - 48px);margin:-24px;background:linear-gradient(180deg,var(--bg-card) 0%,rgba(var(--bg-app-rgb),.72) 100%);overflow:hidden}.calendar-main{flex:1;padding:36px 40px 48px;position:relative;overflow:auto}.fullcalendar-wrapper{max-width:85%;margin:0 auto;position:relative}.fullcalendar-wrapper.fc-transitioning{animation:fc-wrapper-transition .35s ease-out}.fullcalendar-wrapper.fc-transitioning .fc-view-harness,.fullcalendar-wrapper.fc-transitioning .fc-scrollgrid{animation-duration:.35s;animation-timing-function:ease-out}.fullcalendar-wrapper.fc-transitioning.fc-direction-next .fc-view-harness,.fullcalendar-wrapper.fc-transitioning.fc-direction-next .fc-scrollgrid{animation-name:fc-month-transition-next}.fullcalendar-wrapper.fc-transitioning.fc-direction-prev .fc-view-harness,.fullcalendar-wrapper.fc-transitioning.fc-direction-prev .fc-scrollgrid{animation-name:fc-month-transition-prev}@keyframes fc-wrapper-transition{0%{opacity:.85}to{opacity:1}}@keyframes fc-month-transition-next{0%{opacity:.6;transform:translate(-12px)}to{opacity:1;transform:translate(0)}}@keyframes fc-month-transition-prev{0%{opacity:.6;transform:translate(12px)}to{opacity:1;transform:translate(0)}}.fullcalendar-wrapper .fc{--fc-border-color: rgba(148, 163, 184, .12);--fc-button-bg-color: rgba(124, 58, 237, .3);--fc-button-border-color: rgba(124, 58, 237, .5);--fc-button-hover-bg-color: rgba(124, 58, 237, .5);--fc-button-hover-border-color: rgba(124, 58, 237, .7);--fc-button-active-bg-color: var(--accent-purple);--fc-today-bg-color: rgba(124, 58, 237, .08);--fc-page-bg-color: transparent;--fc-neutral-bg-color: var(--bg-card-solid);--fc-list-event-hover-bg-color: rgba(124, 58, 237, .15)}.fullcalendar-wrapper .fc-theme-standard td,.fullcalendar-wrapper .fc-theme-standard th,.fullcalendar-wrapper .fc-scrollgrid{border-color:var(--fc-border-color)}.fullcalendar-wrapper .fc-col-header-cell{background:var(--bg-soft);color:var(--text-secondary);font-size:.8rem}.fullcalendar-wrapper .fc-daygrid-day-number{color:var(--text-secondary);font-size:.9rem}.fullcalendar-wrapper .fc-daygrid-day.fc-day-today{background:#7c3aed0f}.fullcalendar-wrapper .fc-daygrid-day.fc-day-today .fc-daygrid-day-number{color:var(--error);font-weight:600}.fullcalendar-wrapper .fc-event{background:#ec489959;border-color:#ec489980}.fullcalendar-wrapper .fc-event{transition:transform .2s ease,box-shadow .2s ease,background .2s ease}.fullcalendar-wrapper .fc-event:hover{background:#ec489980;transform:translateY(-1px);box-shadow:0 2px 8px #ec489940}.fullcalendar-wrapper .fc-event-task{border-width:1px}.fullcalendar-wrapper .fc-event-task.fc-event-priority-high{background:#ef444459;border-color:#ef444480}.fullcalendar-wrapper .fc-event-task.fc-event-priority-high:hover{background:#ef444480;box-shadow:0 2px 8px #ef444440}.fullcalendar-wrapper .fc-event-task.fc-event-priority-medium{background:#eab30859;border-color:#eab30880}.fullcalendar-wrapper .fc-event-task.fc-event-priority-medium:hover{background:#eab30880;box-shadow:0 2px 8px #eab30840}.fullcalendar-wrapper .fc-event-task.fc-event-priority-low{background:#22c55e59;border-color:#22c55e80}.fullcalendar-wrapper .fc-event-task.fc-event-priority-low:hover{background:#22c55e80;box-shadow:0 2px 8px #22c55e40}.fullcalendar-wrapper .fc-event-team-task.fc-event-priority-high{background:#a78bfa59;border-color:#a78bfa99}.fullcalendar-wrapper .fc-event-team-task.fc-event-priority-high:hover{background:#a78bfa80}.fullcalendar-wrapper .fc-event-team-task.fc-event-priority-medium{background:#6366f159;border-color:#6366f199}.fullcalendar-wrapper .fc-event-team-task.fc-event-priority-medium:hover{background:#6366f180}.fullcalendar-wrapper .fc-event-team-task.fc-event-priority-low{background:#8b5cf64d;border-color:#8b5cf680}.fullcalendar-wrapper .fc-event-team-task.fc-event-priority-low:hover{background:#8b5cf673}.fullcalendar-wrapper .fc-daygrid-day{transition:background .2s ease}.fullcalendar-wrapper .fc-daygrid-day:hover{background:#7c3aed0a}.fullcalendar-wrapper .fc-toolbar .fc-button{transition:background .2s ease,transform .15s ease}.fullcalendar-wrapper .fc-toolbar .fc-button:hover{transform:scale(1.02)}.fullcalendar-wrapper .fc-toolbar .fc-button:active{transform:scale(.98)}.fullcalendar-wrapper .fc-button{color:var(--text-primary);text-transform:none}.fullcalendar-wrapper .fc-toolbar-title{font-size:1.25rem;color:var(--text-primary)}.event-popup{position:absolute;top:100%;left:50%;transform:translate(-50%);margin-top:6px;padding:10px 14px;min-width:180px;background:var(--bg-card-solid);border:1px solid var(--border-color);border-radius:8px;box-shadow:var(--shadow-soft);z-index:10}.event-popup .event-title{font-weight:600;margin-bottom:6px;font-size:.9rem}.event-links{display:flex;gap:12px;font-size:.78rem;color:var(--text-secondary)}.event-links span,.event-links a{display:flex;align-items:center;gap:4px}.event-links a{color:var(--accent-purple-light);text-decoration:none}.event-popup-item{margin-bottom:8px}.event-popup-item:last-child{margin-bottom:0}.fc-popover,.fc .fc-popover,.fc-more-popover{background:var(--bg-card-solid)!important;border:1px solid var(--border-color)!important;border-radius:10px;box-shadow:var(--shadow-soft)}.fc-popover .fc-popover-header,.fc .fc-popover-header{background:var(--bg-elevated)!important;border-bottom:1px solid var(--border-color);padding:10px 14px}.fc-popover .fc-popover-title,.fc .fc-popover-title{color:var(--text-primary)!important}.fc-popover .fc-popover-close,.fc .fc-popover-close{color:var(--text-secondary)!important}.fc-popover .fc-popover-body,.fc .fc-popover-body{background:var(--bg-card-solid)!important;color:var(--text-primary)!important;padding:12px}.fc-popover .fc-event,.fc-popover .fc-event-main{color:var(--text-primary)!important}.edit-task-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200}.edit-task-modal{background:var(--bg-card-solid);border:1px solid var(--border-color);border-radius:12px;padding:20px;width:min(480px,calc(100vw - 32px));max-width:calc(100vw - 32px);min-width:0;box-shadow:var(--shadow-strong)}.add-task-modal{width:min(520px,calc(100vw - 32px))}.add-task-modal .add-task-inline{margin-bottom:0}.add-task-modal-actions{margin-top:16px;padding-top:16px;border-top:1px solid var(--border-color)}.context-menu-modal{min-width:280px}.context-menu-options{display:flex;flex-direction:column;gap:8px}.context-menu-option{display:flex;align-items:center;gap:14px;padding:14px 16px;background:#7c3aed1a;border:1px solid rgba(124,58,237,.25);border-radius:10px;color:var(--text-primary);font-size:.95rem;font-weight:500;cursor:pointer;transition:background .2s,border-color .2s}.context-menu-option:hover{background:#7c3aed33;border-color:#7c3aed66}.context-menu-option svg{color:var(--accent-purple-light);flex-shrink:0}.add-event-datetime{display:flex;gap:10px;align-items:center}.add-event-datetime .add-task-date{flex:0 0 140px}.add-event-datetime .add-task-date+*{flex:1;min-width:0}.edit-task-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.edit-task-header-title{display:flex;align-items:center;gap:10px}.edit-task-header h4{margin:0;font-size:1rem}.task-type-badge{font-size:.72rem;font-weight:500;padding:3px 8px;border-radius:6px}.task-type-badge.my{background:#7c3aed33;color:var(--accent-purple-light)}.task-type-badge.team{background:#3b82f633;color:var(--accent-blue)}.edit-task-close{padding:4px;color:var(--text-secondary)}.edit-task-title{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:.9rem;margin-bottom:16px}.edit-task-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap}.edit-task-actions button{min-width:88px;white-space:nowrap}.edit-task-actions .cancel-btn{padding:8px 18px;background:#94a3b81f;color:var(--text-secondary);border-radius:8px}.edit-task-actions .add-btn{padding:8px 20px;background:var(--accent-purple);color:var(--text-primary);border-radius:8px;font-weight:600}.empty-hint{font-size:.85rem;color:var(--text-muted);margin:0;padding:8px 0}.tasks-sidebar{width:340px;padding:24px;overflow-y:auto;flex-shrink:0;background:var(--bg-elevated);border-left:1px solid var(--border-color)}.tasks-tabs{display:flex;gap:20px;margin-bottom:24px;font-size:.95rem}.tasks-tabs span{color:var(--text-secondary);cursor:pointer}.tasks-tabs span.active{color:var(--accent-purple-light);font-weight:600;padding-bottom:4px;border-bottom:2px solid var(--accent-purple)}.add-task-inline{display:flex;flex-direction:column;gap:10px;margin-bottom:20px}.add-task-vertical .add-task-row{display:flex;flex-direction:column;gap:4px}.add-task-vertical .add-task-row label{font-size:.8rem;color:var(--text-secondary)}.add-task-vertical .add-task-row input,.add-task-vertical .add-task-row select{width:100%}.add-task-vertical .add-task-inline-btn{width:100%;padding:12px 16px;display:flex;align-items:center;justify-content:center;gap:8px}.add-task-title{width:100%;padding:10px 14px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:.9rem}.add-task-title::placeholder{color:var(--text-muted)}.add-task-date,.add-task-time,.add-task-priority,.add-task-assignee{min-width:0;padding:8px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:.8rem}.add-task-time::-webkit-calendar-picker-indicator,.add-task-date::-webkit-calendar-picker-indicator{filter:invert(1);opacity:.7}.add-task-priority,.add-task-assignee{cursor:pointer}.add-task-inline-btn{padding:12px 16px;background:var(--accent-purple);color:var(--text-primary);border-radius:10px;font-weight:600;font-size:.9rem;flex-shrink:0;display:flex;align-items:center;justify-content:center;gap:8px}.add-task-inline-btn:hover{background:var(--accent-purple-dark)}.today-tasks h4,.upcoming-tasks h4{font-size:.82rem;margin-bottom:14px;color:var(--text-secondary);font-weight:500}.task-item{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid rgba(148,163,184,.1);max-height:120px;transition:max-height .32s ease-out,opacity .28s ease-out,padding .32s ease-out,margin .32s ease-out,transform .32s ease-out,border-color .2s;overflow:hidden}.task-item.deleting{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin-top:-14px;margin-bottom:0;border-bottom-color:transparent;transform:scaleY(.6) translateY(-12px);transform-origin:top center;pointer-events:none}.task-item.done .task-title{text-decoration:line-through;color:var(--text-muted)}.task-checkbox{width:20px;height:20px;border:2px solid rgba(148,163,184,.4);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:.75rem;flex-shrink:0;cursor:pointer;margin-top:2px}.task-item.done .task-checkbox{background:var(--success);border-color:var(--success);color:var(--text-primary)}.task-info{flex:1;min-width:0}.task-title{display:block;font-size:.92rem;font-weight:500}.task-meta{font-size:.8rem;color:var(--text-secondary);margin-top:2px}.priority-dot.high{color:var(--error)}.priority-dot.medium{color:var(--warning)}.priority-dot.low,.priority-dot.done{color:var(--success)}.task-actions{display:flex;gap:4px}.task-actions button{padding:4px;color:var(--text-secondary);background:transparent!important}.task-actions button svg{background:transparent!important}.task-actions button:hover{color:var(--text-primary)}.assignee{color:var(--text-secondary)}.assignee svg{background:transparent!important}.add-task-btn{width:100%;padding:12px;background:var(--accent-purple);color:var(--text-primary);border-radius:10px;font-weight:600;font-size:.9rem;margin-top:14px}.event-item{display:flex;align-items:flex-start;gap:12px;padding:14px 0;border-bottom:1px solid rgba(148,163,184,.1);cursor:pointer;max-height:120px;transition:max-height .32s ease-out,opacity .28s ease-out,padding .32s ease-out,margin .32s ease-out,transform .32s ease-out,border-color .2s;overflow:hidden}.event-item.deleting{max-height:0;opacity:0;padding-top:0;padding-bottom:0;margin-top:-14px;margin-bottom:0;border-bottom-color:transparent;transform:scaleY(.6) translateY(-12px);transform-origin:top center;pointer-events:none}.event-item:hover{background:#7c3aed0f}.event-item-info{flex:1;min-width:0}.event-item-title{display:block;font-weight:500;font-size:.92rem}.event-item-meta{display:block;font-size:.8rem;color:var(--text-secondary);margin-top:2px}.event-item-delete{padding:4px;color:var(--text-secondary);background:transparent!important;flex-shrink:0}.event-item-delete:hover{color:var(--error)}.event-detail-view{padding:12px 0;display:flex;flex-direction:column;gap:8px}.event-detail-title{font-size:1.1rem;font-weight:600;margin-bottom:6px}.event-detail-meta{font-size:.9rem;color:var(--text-secondary)}.member-select-area{display:flex;flex-wrap:wrap;gap:6px;align-items:center}.member-tag{display:inline-flex;align-items:center;gap:4px;background:#8b5cf633;border:1px solid rgba(139,92,246,.4);border-radius:20px;padding:2px 8px 2px 10px;font-size:.8rem;color:var(--text-primary)}.member-tag button{background:none;border:none;color:var(--text-secondary);cursor:pointer;font-size:1rem;line-height:1;padding:0;display:flex;align-items:center;transition:color .15s}.member-tag button:hover{color:#ef4444}.event-detail-creator{font-size:.82rem;color:var(--text-secondary);margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color)}.event-detail-actions{display:grid;grid-template-columns:repeat(auto-fit,minmax(92px,1fr));justify-content:stretch}.event-detail-actions .cancel-btn,.event-detail-actions .add-btn{width:100%}.add-task-modal-actions .delete-btn{color:var(--error)}.add-task-modal-actions .delete-btn:hover{background:#ef444433;color:var(--error)}.upcoming-group{margin-bottom:20px}.upcoming-date{font-size:.85rem;color:var(--text-secondary);margin-bottom:10px;font-weight:500}:root[data-theme=light] .calendar-page{background:linear-gradient(180deg,#ffffffd1,#eef3fbf5)}:root[data-theme=light] .fullcalendar-wrapper .fc{--fc-border-color: rgba(84, 102, 146, .14);--fc-today-bg-color: rgba(107, 79, 196, .08)}:root[data-theme=light] .fullcalendar-wrapper .fc-col-header-cell{background:#54669214}:root[data-theme=light] .fullcalendar-wrapper .fc-daygrid-day:hover{background:#6b4fc40a}:root[data-theme=light] .add-task-time::-webkit-calendar-picker-indicator,:root[data-theme=light] .add-task-date::-webkit-calendar-picker-indicator{filter:none;opacity:.8}:root[data-theme=light] .task-item:hover,:root[data-theme=light] .event-item:hover{background:#6b4fc40d}@media(max-width:900px){.calendar-page{flex-direction:column;height:auto;max-height:none;margin:-16px}.calendar-main{padding:18px 16px 24px}.fullcalendar-wrapper{max-width:100%}.fullcalendar-wrapper .fc-toolbar{flex-direction:column;align-items:stretch;gap:10px}.fullcalendar-wrapper .fc-toolbar-title{font-size:1.05rem;text-align:center}.fullcalendar-wrapper .fc-header-toolbar{margin-bottom:1rem}.tasks-sidebar{width:100%;border-left:none;border-top:1px solid var(--border-color);padding:18px 16px 24px}}@media(max-width:640px){.calendar-page{margin:-14px}.edit-task-modal,.add-task-modal,.context-menu-modal{min-width:0;width:calc(100vw - 24px);max-width:420px}.add-event-datetime{flex-direction:column;align-items:stretch}.add-event-datetime .add-task-date{flex:1 1 auto}.tasks-tabs{gap:12px;font-size:.88rem;overflow-x:auto;scrollbar-width:none}.tasks-tabs::-webkit-scrollbar{display:none}.event-detail-actions{grid-template-columns:1fr}}.leave-section{padding:24px}.leave-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.leave-header h3{font-size:1.1rem;font-weight:600;color:var(--text-primary);margin:0}.leave-add-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.85rem;font-weight:500;cursor:pointer;transition:opacity .2s}.leave-add-btn:hover{opacity:.85}.leave-form{background:var(--bg-secondary);border-radius:12px;padding:20px;margin-bottom:24px;display:flex;flex-direction:column;gap:14px}.leave-form-row{display:flex;align-items:center;gap:12px}.leave-form-row label{min-width:48px;font-size:.85rem;color:var(--text-secondary)}.leave-form-row select,.leave-form-row input[type=date],.leave-form-row input[type=text]{flex:1;background:var(--bg-tertiary, var(--bg-card));border:1px solid var(--border);border-radius:8px;padding:8px 12px;color:var(--text-primary);font-size:.9rem;outline:none;transition:border-color .2s}.leave-form-row select:focus,.leave-form-row input:focus{border-color:var(--accent)}.leave-submit-btn{align-self:flex-end;padding:10px 24px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:.9rem;font-weight:500;cursor:pointer;transition:opacity .2s}.leave-submit-btn:hover:not(:disabled){opacity:.85}.leave-submit-btn:disabled{opacity:.5;cursor:not-allowed}.leave-list,.leave-admin-list{margin-bottom:28px}.leave-list h4,.leave-admin-list h4{font-size:.95rem;font-weight:600;color:var(--text-secondary);margin:0 0 14px;text-transform:uppercase;letter-spacing:.05em}.leave-empty{color:var(--text-secondary);font-size:.9rem;text-align:center;padding:20px 0}.leave-table{width:100%;border-collapse:collapse;font-size:.88rem}.leave-table th{text-align:left;padding:10px 12px;color:var(--text-secondary);font-weight:500;border-bottom:1px solid var(--border)}.leave-table td{padding:10px 12px;color:var(--text-primary);border-bottom:1px solid var(--border)}.leave-table tr:hover td{background:var(--bg-hover, rgba(255,255,255,.03))}.leave-status-badge{display:inline-block;padding:3px 10px;border-radius:20px;font-size:.78rem;font-weight:500}.leave-status-badge.pending{background:#facc1526;color:#facc15}.leave-status-badge.approved{background:#4ade8026;color:#4ade80}.leave-status-badge.rejected{background:#f8717126;color:#f87171}.leave-actions{display:flex;gap:6px}.leave-approve-btn,.leave-reject-btn{padding:4px 12px;border:none;border-radius:6px;font-size:.8rem;cursor:pointer;transition:opacity .2s}.leave-approve-btn{background:#4ade8033;color:#4ade80}.leave-approve-btn:hover{opacity:.75}.leave-reject-btn{background:#f8717133;color:#f87171}.leave-reject-btn:hover{opacity:.75}@media(max-width:768px){.leave-table th:nth-child(3),.leave-table td:nth-child(3){display:none}}.attendance-page{max-width:1400px;width:100%}.attendance-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.attendance-header-copy{min-width:0;flex:1}.attendance-header-copy p{margin:0;color:var(--text-secondary);line-height:1.6;max-width:560px}.header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.custom-date-filter{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.date-input{min-height:40px;padding:9px 12px;border-radius:12px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:.9rem}.filter-apply-btn{min-height:40px;padding:10px 16px;border-radius:12px;background:#7c3aed2e;border:1px solid rgba(138,114,216,.22);color:var(--text-primary);font-size:.88rem;font-weight:600}.export-btn{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;background:var(--gradient-purple);color:var(--text-primary);font-weight:500}.date-range{padding:10px 16px;font-size:.9rem;color:var(--text-secondary)}.filter-tabs button{padding:8px 16px;border-radius:8px;background:#94a3b81a;color:var(--text-secondary);font-size:.875rem}.filter-tabs button.active{background:#7c3aed4d;color:var(--accent-purple-light)}.team-status-section,.team-schedule-section{padding:20px 24px;border-radius:14px;min-width:0;overflow:hidden}.attendance-content{display:flex;flex-direction:column;gap:24px;min-width:0}.two-cards-row{display:grid;grid-template-columns:1fr 1.5fr;gap:24px;min-width:0}.two-cards-row.single,.two-cards-row.admin-wide{grid-template-columns:1fr}.two-cards-row>*{min-width:0;width:100%}.set-work-days-section,.records-section{padding:24px;min-width:0;overflow:hidden}.records-section h3{margin-bottom:16px;font-size:1rem}.records-table-wrap{overflow-x:auto;max-width:100%;width:100%;padding-bottom:6px;scrollbar-width:thin}.records-table{width:100%;border-collapse:collapse;min-width:720px}.set-work-days-section .set-work-days-personal{min-width:0}.set-work-days-section .day-schedule-grid{max-width:100%}.records-table th,.records-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border-color);white-space:nowrap}.records-table th{color:var(--text-secondary);font-size:.75rem;font-weight:600}.records-table tr.late{background:#eab3081f}.record-avatar{width:28px;height:28px;border-radius:50%;background:var(--gradient-purple);display:inline-flex;align-items:center;justify-content:center;font-size:.75rem;margin-right:10px;vertical-align:middle}.dot{display:inline-block;width:10px;height:10px;border-radius:50%;background:#94a3b840;margin-right:4px}.dot.on{background:var(--accent-purple)}.status-badge{padding:4px 12px;border-radius:20px;font-size:.8rem}.status-badge.present{background:#22c55e33;color:var(--success)}.status-badge.late{background:#eab30840;color:var(--warning)}.status-badge.absent{background:#ef444433;color:var(--error)}.pagination{display:flex;align-items:center;justify-content:flex-end;gap:12px;margin-top:16px;font-size:.875rem;color:var(--text-secondary);min-width:0}.pagination button{padding:6px;color:var(--text-secondary)}.summary-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;min-width:0}.stat-card{padding:20px;text-align:center}.stat-card .label{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.stat-card .value{font-size:1.75rem;font-weight:700}.stat-card .value.green{color:var(--success)}.stat-card .value.yellow{color:var(--warning)}.stat-card .value.red{color:var(--error)}@media(max-width:1100px){.two-cards-row{grid-template-columns:1fr}}@media(max-width:900px){.summary-stats{grid-template-columns:repeat(2,1fr)}.team-status-section,.team-schedule-section,.set-work-days-section,.records-section,.my-history-section,.leave-section-wrap{padding:20px}}@media(max-width:720px){.attendance-header{margin-bottom:20px}.header-actions{width:100%;align-items:stretch}.export-btn,.date-range,.custom-date-filter,.filter-tabs{width:100%}.export-btn,.date-range{justify-content:center}.filter-tabs{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px}.filter-tabs button,.date-input,.filter-apply-btn{width:100%}.custom-date-filter{flex-direction:column;align-items:stretch}.team-status-section,.team-schedule-section,.set-work-days-section,.records-section,.my-history-section,.leave-section-wrap{padding:18px}.pagination{justify-content:center;flex-wrap:wrap}}@media(max-width:560px){.attendance-header-copy p{font-size:.92rem}.team-status-section,.team-schedule-section,.set-work-days-section,.records-section,.my-history-section,.leave-section-wrap,.stat-card{padding:16px}.records-table{min-width:620px}.records-table th,.records-table td{padding:10px 12px}.record-avatar{width:24px;height:24px;margin-right:8px;font-size:.72rem}.summary-stats{grid-template-columns:1fr}}.drive-page{max-width:1180px;display:flex;flex-direction:column;gap:24px}.drive-header{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:flex-end;gap:18px}.drive-header-copy{max-width:700px}.drive-kicker{margin:0 0 10px;color:var(--text-muted);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.drive-subtitle{margin:0;color:var(--text-secondary);line-height:1.6;font-size:1rem}.drive-header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}.drive-access-badge{display:inline-flex;align-items:center;padding:8px 12px;border-radius:999px;background:#6366f11f;border:1px solid rgba(129,140,248,.24);color:var(--accent-purple-light);font-size:.82rem;font-weight:600}.upload-btn{display:flex;align-items:center;gap:8px;padding:12px 18px;border-radius:14px;background:var(--gradient-purple);color:#fff;font-weight:700;box-shadow:0 18px 40px #7056a847}.upload-btn:disabled{opacity:.7;cursor:wait}.drive-overview{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px}.drive-stat-card{display:flex;align-items:center;gap:14px;padding:18px 20px}.drive-stat-icon{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:#7c3aed24;color:var(--accent-purple-light)}.drive-stat-label{display:block;margin-bottom:6px;font-size:.82rem;color:var(--text-secondary)}.drive-stat-card strong{font-size:1.2rem}.drive-layout{display:grid;grid-template-columns:320px minmax(0,1fr);gap:20px}.drive-side-panel{display:flex;flex-direction:column;gap:20px;padding:24px}.drive-panel-head h3{margin:12px 0 10px;font-size:1.15rem}.drive-panel-head p{margin:0;color:var(--text-secondary);line-height:1.6}.drive-panel-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border-radius:999px;background:#7c3aed1f;color:var(--accent-purple-light);font-size:.8rem}.upload-cta{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 16px;border-radius:16px;background:#7c3aed29;color:var(--text-primary);font-weight:700;border:1px solid rgba(124,58,237,.24)}.drive-access-note{padding:16px;border-radius:18px;background:#6366f114;border:1px solid rgba(129,140,248,.16)}.drive-access-note span{display:block;margin-bottom:8px;color:var(--text-secondary);font-size:.8rem}.drive-access-note strong{display:block;margin-bottom:8px;font-size:1rem}.drive-access-note p{margin:0;color:var(--text-secondary);line-height:1.6}.drive-side-stats{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.drive-side-stats div{padding:14px;border-radius:16px;background:#ffffff0a}.drive-side-stats span{display:block;font-size:.8rem;color:var(--text-secondary);margin-bottom:8px}.drive-side-stats strong{font-size:1rem}.drive-content{padding:24px}.drive-section-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.drive-section-head h3{margin:0 0 8px;font-size:1.05rem}.drive-section-head p{margin:0;color:var(--text-secondary);line-height:1.5}.file-list{display:flex;flex-direction:column;gap:12px}.file-row{display:flex;align-items:center;justify-content:space-between;gap:14px;padding:16px 18px;border-radius:18px;background:#ffffff08;border:1px solid transparent;transition:transform .2s ease,border-color .2s ease,background .2s ease}.file-row:hover{transform:translateY(-1px);background:#94a3b814;border-color:#b0a3ff29}.file-main{display:flex;align-items:center;gap:14px;min-width:0}.file-copy{min-width:0}.file-icon{color:var(--text-secondary);width:44px;height:44px;border-radius:14px;background:#7c3aed24;display:inline-flex;align-items:center;justify-content:center}.file-name{display:block;margin-bottom:6px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.file-meta-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.file-meta{font-size:.82rem;color:var(--text-secondary)}.file-divider{width:4px;height:4px;border-radius:999px;background:var(--text-muted)}.file-side{display:flex;align-items:center;gap:16px;flex-shrink:0}.download-btn,.delete-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;justify-content:center;width:34px;height:34px;transition:color .2s ease,background .2s ease}.download-btn:hover{color:var(--accent-purple-light);background:#7c3aed24}.delete-btn:hover{color:#ef4444;background:#ef44441a}.file-size{font-size:.82rem;color:var(--text-secondary);min-width:58px;text-align:right}.file-actions{display:flex;align-items:center;gap:6px}.drive-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;min-height:240px;text-align:center;color:var(--text-secondary)}.drive-empty-state p{margin:0;max-width:320px;line-height:1.6}@media(max-width:1024px){.drive-layout{grid-template-columns:1fr}.drive-side-panel{order:-1}}@media(max-width:720px){.drive-overview{grid-template-columns:1fr}.drive-header{align-items:stretch}.drive-header-actions{width:100%;justify-content:flex-start}.upload-btn{width:100%;justify-content:center}.file-row{flex-direction:column;align-items:stretch}.file-side{justify-content:space-between}}@media(max-width:480px){.drive-page{gap:18px}.drive-side-panel,.drive-content{padding:18px}.drive-side-stats{grid-template-columns:1fr}.drive-access-badge{width:100%;justify-content:center}}.ai-chat-page{min-height:100%;height:100%;display:flex;flex-direction:column;gap:18px}.ai-header{text-align:center;padding:6px 12px 0;flex-shrink:0}.ai-title{display:flex;align-items:center;justify-content:center;gap:12px}.ai-title p{font-size:1rem;margin:0;color:var(--text-secondary);line-height:1.6;max-width:420px}.ai-chat-area{padding:24px;flex:1;display:flex;flex-direction:column;min-height:0;border-radius:28px}.messages{flex:1;overflow-y:auto;min-height:200px;margin-bottom:20px;padding:4px 4px 0}.msg-bubble{display:flex;gap:12px;max-width:85%;margin-bottom:16px}.msg-bubble.user{align-self:flex-end;flex-direction:row-reverse}.msg-bubble.user span{background:var(--accent-purple);color:var(--text-on-accent);padding:12px 18px;border-radius:18px}.msg-bubble.ai span{background:var(--bg-soft);border:1px solid var(--border-color);padding:12px 18px;border-radius:18px}.msg-icon{color:var(--accent-purple-light);flex-shrink:0}.suggestions{margin-bottom:20px;padding:16px 18px;background:var(--bg-soft);border:1px solid var(--border-color);border-radius:20px}.suggestions p{font-size:.8rem;color:var(--text-secondary);margin-bottom:12px}.suggestions button{display:block;width:100%;padding:12px 16px;margin-bottom:8px;text-align:left;background:#8a72d81a;color:var(--text-primary);border:1px solid transparent;border-radius:14px;font-size:.9rem;transition:all .2s ease}.suggestions button:hover{background:#8a72d82e;border-color:#8a72d838}.input-area{display:flex;gap:12px;padding-top:4px}.input-area input{flex:1;padding:14px 18px;border-radius:16px;border:1px solid var(--border-color);background:var(--bg-input);color:var(--text-primary);font-size:1rem}.input-area input::placeholder{color:var(--text-secondary)}.input-area .send-btn{padding:14px 20px;background:var(--gradient-purple);color:var(--text-on-accent);border-radius:16px}@media(max-width:768px){.ai-chat-area{padding:18px}.msg-bubble{max-width:100%}.input-area{flex-direction:column}.input-area .send-btn{width:100%;justify-content:center}}@media(max-width:480px){.ai-title{align-items:flex-start;text-align:left;justify-content:flex-start}.ai-title p{font-size:.92rem}.ai-header{text-align:left;padding-inline:0}.ai-chat-area{padding:14px;border-radius:20px}.suggestions{padding:14px}.input-area input,.input-area .send-btn{padding:12px 14px}}.members-page{max-width:1400px;width:100%}.members-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:20px}.members-header-copy{display:flex;flex-direction:column;align-items:flex-start;gap:10px;min-width:0}.members-header-copy p{margin:0;color:var(--text-secondary);line-height:1.6;max-width:540px}.admin-badge{font-size:.75rem;padding:6px 10px;background:#db5c631f;color:var(--error);border-radius:999px;font-weight:600}.no-access{padding:40px;text-align:center;color:var(--text-secondary)}.filters-row{margin-bottom:24px}.search-wrap{display:flex;align-items:center;gap:10px;padding:10px 14px;max-width:320px;margin-bottom:16px}.search-wrap input{flex:1;background:none;border:none;color:var(--text-primary)}.search-wrap input::placeholder{color:var(--text-secondary)}.filter-group{margin-bottom:12px}.filter-label{font-size:.85rem;color:var(--text-secondary);margin-right:12px;display:inline-block;margin-bottom:8px}.filter-btns{display:flex;flex-wrap:wrap;gap:8px}.filter-btns button{padding:6px 14px;border-radius:8px;background:#94a3b81a;color:var(--text-secondary);font-size:.85rem}.filter-btns button.active{background:#7c3aed4d;color:var(--accent-purple-light)}.total-members{margin-top:16px;padding:12px 16px;display:inline-block;font-weight:600}.members-content{display:grid;grid-template-columns:minmax(0,1fr) 320px;gap:24px;align-items:start}.table-section{padding:24px;overflow:hidden;overflow-y:hidden;min-width:0}.table-section h3{margin-bottom:16px;font-size:1rem}.members-table-wrap{overflow-x:auto;padding-bottom:6px;min-width:0;scrollbar-width:thin}.members-table{width:100%;border-collapse:collapse;min-width:760px}.members-table th,.members-table td{padding:12px 16px;text-align:left;border-bottom:1px solid rgba(255,255,255,.06);vertical-align:middle;white-space:nowrap}.members-table th{color:var(--text-secondary);font-size:.8rem;font-weight:600}.members-table tbody tr:last-child td{border-bottom:none}.members-table tbody tr:hover td{background:#ffffff05}.members-table td:first-child{min-width:180px}.members-table td:last-child,.members-table th:last-child{min-width:190px}.members-table .avatar{width:36px;height:36px;border-radius:50%;background:var(--gradient-purple);display:inline-flex;align-items:center;justify-content:center;font-size:.85rem;margin-right:12px;vertical-align:middle}.team-tag{display:inline-flex;align-items:center;max-width:140px;padding:4px 12px;border-radius:999px;font-size:.8rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:color-mix(in srgb,var(--accent-purple) 14%,transparent);color:var(--text-primary);border:1px solid color-mix(in srgb,var(--accent-purple) 18%,transparent)}.role-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:6px;font-size:.8rem}.role-tag.ADMIN{background:#7c3aed33;color:var(--accent-purple-light)}.role-tag.TEAM_LEAD{background:#3b82f633;color:var(--accent-blue)}.role-tag.MEMBER{background:#94a3b833;color:var(--text-secondary)}.actions{display:flex;gap:8px}.actions-cell{display:flex;align-items:center;gap:8px;flex-wrap:wrap;justify-content:flex-start}.action-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;font-size:.8rem;background:#7c3aed26;color:var(--accent-purple-light);border-radius:6px}.member-status-cell{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.member-status-tag{display:inline-flex;align-items:center;justify-content:center;min-width:64px;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700}.member-status-tag.ACTIVE{background:#22c55e29;color:#86efac}.member-status-tag.INACTIVE{background:#94a3b829;color:var(--text-secondary)}.action-btn.activate-btn{background:#22c55e1f;color:#86efac}.action-btn.mute-btn{background:#eab30824;color:#facc15}.action-btn.deactivate-btn{background:#ef444424;color:#fca5a5}.stats-sidebar{padding:24px;height:fit-content;min-width:0}.stats-sidebar h3{font-size:.9rem;margin-bottom:16px}.bar-chart{display:flex;align-items:flex-end;gap:12px;height:140px;margin-bottom:24px}.bar{flex:1;background:var(--gradient-purple);border-radius:8px 8px 0 0;display:flex;flex-direction:column;align-items:center;justify-content:flex-start;padding-top:8px;font-size:.7rem;text-align:center;min-width:0}.bar span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pie-legend span{display:flex;align-items:center;gap:8px;margin-bottom:10px;font-size:.85rem}.pie-legend i{width:12px;height:12px;border-radius:4px}.team-composition{margin-top:16px;font-size:.85rem;color:var(--text-secondary)}.modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.change-role-modal{padding:28px;max-width:420px;width:90%}.change-role-modal h3{margin-bottom:20px;font-size:1.1rem}.role-options{display:flex;flex-direction:column;gap:12px;margin-bottom:24px}.role-option p{margin:6px 0 0;font-size:.85rem;color:var(--text-secondary)}.role-option.selected .role-pill{border-color:var(--accent-purple)}.role-pill{display:inline-flex;align-items:center;gap:6px;padding:6px 14px;border-radius:8px;border:2px solid transparent}.role-pill.MEMBER{background:#94a3b833;color:var(--text-secondary)}.role-pill.TEAM_LEAD{background:#3b82f633;color:var(--accent-blue)}.role-pill.ADMIN{background:#7c3aed33;color:var(--accent-purple-light)}.modal-actions{display:flex;gap:12px;justify-content:flex-end}.cancel-btn{padding:10px 20px;background:#94a3b833;color:var(--text-secondary);border-radius:8px}.confirm-btn{padding:10px 24px;background:var(--gradient-purple);color:var(--text-primary);border-radius:8px;font-weight:600}@media(max-width:1100px){.members-content{grid-template-columns:1fr}}.invite-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;border:none;color:var(--purple, #9680cc);border-radius:8px;cursor:pointer;font-size:14px;white-space:nowrap}.invite-modal{padding:28px;border-radius:16px;min-width:360px;max-width:480px}.modal-header-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px}.close-btn:hover{color:var(--text-primary)}.setting-field{margin-bottom:16px}.setting-field label{display:block;font-size:13px;color:var(--text-secondary);margin-bottom:6px}.setting-input{width:100%;background:#ffffff0d;border:1px solid var(--border-color);border-radius:8px;padding:10px 14px;color:var(--text-primary);font-size:14px;outline:none;box-sizing:border-box}.setting-input:focus{border-color:var(--purple, #9680cc)}.role-btns{display:flex;gap:8px}.role-btn{padding:6px 14px;border:1px solid var(--border-color);border-radius:6px;background:transparent;color:var(--text-secondary);cursor:pointer;font-size:13px;transition:all .2s}.role-btn.active{border-color:var(--purple, #9680cc);color:var(--purple, #9680cc);background:#9680cc26}:root[data-theme=light] .members-table th,:root[data-theme=light] .members-table td{border-bottom-color:#54669224}:root[data-theme=light] .members-table tbody tr:hover td{background:#5466920d}:root[data-theme=light] .members-table-wrap{scrollbar-color:rgba(84,102,146,.32) transparent}@media(max-width:900px){.members-header{align-items:flex-start;flex-direction:column}.invite-btn{width:100%;justify-content:center}.members-page .search-wrap{max-width:none}.table-section,.stats-sidebar{padding:18px}.filter-btns{overflow-x:auto;flex-wrap:nowrap;padding-bottom:2px;scrollbar-width:none}.filter-btns::-webkit-scrollbar{display:none}.filter-btns button{flex:0 0 auto;white-space:nowrap}}@media(max-width:640px){.members-header-copy p{font-size:.92rem}.members-table th,.members-table td{white-space:nowrap;padding:10px 12px}.table-section,.stats-sidebar{padding:16px}.invite-modal,.change-role-modal{width:calc(100vw - 24px);min-width:0;padding:20px 18px}.role-btns,.modal-actions{flex-wrap:wrap}.modal-actions .cancel-btn,.modal-actions .confirm-btn{width:100%;justify-content:center}}.settings-page{display:flex;flex-direction:column;gap:24px;max-width:1160px}.settings-header{display:grid;grid-template-columns:minmax(0,1fr) minmax(280px,380px);align-items:end;gap:20px}.settings-header-copy{max-width:620px}.settings-kicker{margin:0 0 10px;color:var(--text-muted);font-size:.78rem;letter-spacing:.08em;text-transform:uppercase}.settings-subtitle{margin:0;color:var(--text-secondary);line-height:1.6;font-size:1rem}.settings-summary-card{display:flex;align-items:center;gap:14px;padding:16px 18px;justify-self:end;width:100%}.settings-summary-icon{width:40px;height:40px;border-radius:14px;background:var(--surface-tint);color:var(--accent-purple-light);display:flex;align-items:center;justify-content:center}.settings-summary-card strong,.settings-summary-card span{display:block}.settings-summary-card strong{margin-bottom:4px}.settings-summary-card span{color:var(--text-secondary);font-size:.9rem;line-height:1.5}.settings-layout{display:grid;grid-template-columns:220px minmax(0,1fr);gap:24px;align-items:start}.settings-nav{display:flex;flex-direction:column;padding:14px;gap:6px;border-radius:20px;position:sticky;top:16px}.settings-nav-item{display:flex;align-items:center;gap:10px;padding:12px 14px;border:none;background:transparent;color:var(--text-secondary);border-radius:14px;cursor:pointer;font-size:14px;transition:all .2s ease;text-align:left;width:100%}.settings-nav-item:hover{background:var(--nav-hover);color:var(--text-primary)}.settings-nav-item.active{background:var(--nav-active);color:var(--text-primary)}.settings-content{border-radius:24px;padding:30px;min-width:0}.settings-section h3{font-size:20px;margin-bottom:24px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.profile-avatar-row{display:flex;align-items:center;gap:16px;margin-bottom:24px}.big-avatar{width:72px;height:72px;border-radius:22px;background:var(--gradient-logo);display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.avatar-name{font-size:18px;font-weight:600;margin:0 0 4px}.avatar-role{font-size:13px;color:var(--text-secondary);margin:0;text-transform:capitalize}.setting-field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.setting-field label{font-size:13px;color:var(--text-secondary)}.setting-input{background:var(--bg-input);border:1px solid var(--border-color);border-radius:14px;padding:12px 14px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s ease,background .2s ease}.setting-input:focus{border-color:var(--accent-purple);background:var(--bg-card-solid)}.setting-input.disabled{opacity:.5;cursor:not-allowed}.save-btn{display:flex;align-items:center;gap:8px;justify-content:center;padding:12px 20px;background:var(--gradient-purple);color:var(--text-on-accent);border:none;border-radius:14px;cursor:pointer;font-size:14px;font-weight:700;transition:transform .2s ease,opacity .2s ease,box-shadow .2s ease;box-shadow:var(--shadow-soft)}.save-btn:hover{opacity:.94;transform:translateY(-1px)}.password-error{color:var(--error);font-size:13px;margin:-4px 0 8px}.danger-zone{margin-top:32px;padding:20px;border-radius:20px;border:1px solid rgba(239,68,68,.2);background:#ef44440f}.danger-zone-head{display:flex;gap:14px;align-items:flex-start;margin-bottom:16px}.danger-zone-icon{width:36px;height:36px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;color:#fca5a5;background:#ef44441f;flex-shrink:0}.danger-zone h4{margin:0 0 6px;font-size:1rem}.danger-zone p{margin:0;color:var(--text-secondary);line-height:1.6}.danger-btn,.danger-confirm-btn,.danger-cancel-btn{border:none;border-radius:14px;padding:11px 16px;font-weight:700}.danger-btn,.danger-confirm-btn{background:#ef44442e;color:#fecaca}.danger-cancel-btn{background:#94a3b81f;color:var(--text-primary)}.danger-confirm-box{margin-top:16px;padding-top:16px;border-top:1px solid rgba(239,68,68,.14)}.danger-confirm-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:14px}.setting-row{display:flex;justify-content:space-between;align-items:center;gap:16px;padding:18px 0;border-bottom:1px solid var(--border-color)}.setting-row:last-child{border-bottom:none}.setting-row-label{display:block;font-size:14px;font-weight:500;margin-bottom:4px}.setting-row-desc{display:block;font-size:12px;color:var(--text-secondary)}.toggle-switch{position:relative;display:inline-block;width:44px;height:24px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;inset:0;background:var(--bg-soft-strong);border-radius:24px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:var(--bg-card-solid);border-radius:50%;transition:transform .2s;box-shadow:0 3px 8px #00000024}.toggle-switch input:checked+.toggle-slider{background:var(--accent-purple)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch input:disabled+.toggle-slider{opacity:.6;cursor:not-allowed}.theme-options-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}.theme-option-card{display:flex;flex-direction:column;gap:16px;padding:18px;border-radius:20px;border:1px solid var(--border-color);background:var(--bg-soft);color:inherit;text-align:left;transition:transform .2s ease,border-color .2s ease,background .2s ease}.theme-option-card:hover{transform:translateY(-2px);border-color:var(--border-strong);background:var(--surface-tint)}.theme-option-card.active{border-color:#8a72d85c;background:var(--surface-tint);box-shadow:var(--shadow-soft)}.theme-option-header{display:flex;align-items:center;gap:12px}.theme-option-icon{width:42px;height:42px;border-radius:14px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-card-solid);color:var(--accent-purple-light);border:1px solid var(--border-color)}.theme-option-header strong,.theme-option-header p{display:block;margin:0}.theme-option-header p{margin-top:4px;color:var(--text-secondary);font-size:.9rem}.theme-preview{display:grid;grid-template-columns:28px 1fr;gap:10px 12px;align-items:center;padding:16px;border-radius:16px;border:1px solid var(--border-color)}.theme-preview-light{background:linear-gradient(180deg,#fff,#edf2fb)}.theme-preview-dark{background:linear-gradient(180deg,#161b2f,#0f1220)}.theme-preview-chip{width:28px;height:28px;border-radius:10px;background:var(--gradient-purple-blue);grid-row:span 3}.theme-preview-line{height:10px;border-radius:999px;background:#8291b447}.theme-preview-line.short{width:64%}.theme-preview-line.muted{opacity:.55}.appearance-note{margin-top:18px;padding:18px;border-radius:18px;background:var(--bg-soft);border:1px solid var(--border-color)}.appearance-note h4,.appearance-note p{margin:0}.appearance-note h4{margin-bottom:8px;font-size:.95rem}.appearance-note p{color:var(--text-secondary);line-height:1.6}@media(max-width:1080px){.settings-header{grid-template-columns:1fr}.settings-summary-card{justify-self:stretch}.settings-layout{grid-template-columns:1fr}.settings-nav{position:static;flex-direction:row;flex-wrap:wrap}.settings-nav-item{width:auto}}@media(max-width:720px){.theme-options-grid{grid-template-columns:1fr}.settings-content{padding:22px}.danger-confirm-actions{flex-direction:column}}@media(max-width:900px){.settings-header{grid-template-columns:1fr;align-items:stretch}.settings-summary-card{justify-self:stretch}.settings-layout{grid-template-columns:1fr}.settings-nav{flex-direction:row;overflow-x:auto}.theme-options-grid{grid-template-columns:1fr}}@media(max-width:640px){.settings-page{gap:18px}.settings-content{padding:22px 18px}.profile-avatar-row{flex-direction:column;align-items:flex-start}.settings-nav{flex-wrap:nowrap;overflow-x:auto;scrollbar-width:none}.settings-nav::-webkit-scrollbar{display:none}.settings-nav-item{flex:0 0 auto;white-space:nowrap}.setting-row{flex-direction:column;align-items:flex-start}.settings-content .save-btn,.danger-zone .danger-btn,.danger-zone .danger-confirm-btn,.danger-zone .danger-cancel-btn{width:100%;justify-content:center}.danger-zone-head{flex-direction:column}}.admin-page{max-width:1200px;margin:0 auto;display:flex;flex-direction:column;gap:24px}.admin-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:12px}.admin-title-row{display:flex;align-items:flex-start;gap:10px;min-width:0}.admin-title-row p{margin:0;color:var(--text-secondary);line-height:1.6;max-width:520px}.admin-crown-icon{color:var(--accent-purple)}.admin-header-actions{display:flex;align-items:center;gap:10px}.admin-export-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:transparent;color:var(--text-secondary);font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.admin-export-btn:hover{color:var(--text-primary);border-color:#fff3;background:#ffffff0d}.admin-tabs{display:flex;gap:4px;background:#ffffff0a;border-radius:12px;padding:4px;width:fit-content}.admin-tab-btn{padding:9px 24px;border-radius:9px;border:none;background:transparent;color:var(--text-secondary);font-size:.9rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.admin-tab-btn:hover{color:var(--text-primary);background:#ffffff0d}.admin-tab-btn.active{background:var(--accent-purple);color:#fff}.admin-tab-content{border-radius:16px;padding:24px;border:1px solid rgba(255,255,255,.06)}.admin-section-title{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:18px}.admin-members-table{width:100%;border-collapse:collapse;min-width:760px}.admin-table-wrap{overflow-x:auto;padding-bottom:6px;scrollbar-width:thin}.admin-members-table th{text-align:left;font-size:.78rem;font-weight:600;color:var(--text-secondary);padding:10px 14px;border-bottom:1px solid rgba(255,255,255,.06)}.admin-members-table td{padding:12px 14px;font-size:.88rem;color:var(--text-primary);border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.admin-members-table tr:last-child td{border-bottom:none}.admin-members-table tr:hover td{background:#ffffff05}:root[data-theme=light] .admin-members-table th{border-bottom-color:#54669224}:root[data-theme=light] .admin-members-table td{border-bottom-color:#5466921a}:root[data-theme=light] .admin-members-table tr:hover td{background:#5466920d}.admin-avatar{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;border-radius:50%;background:var(--accent-purple);color:#fff;font-size:.78rem;font-weight:700;margin-right:10px;flex-shrink:0}.admin-team-tag{display:inline-flex;align-items:center;max-width:150px;font-size:.75rem;font-weight:600;padding:5px 12px;border-radius:999px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;background:color-mix(in srgb,var(--accent-purple) 14%,transparent);color:var(--text-primary);border:1px solid color-mix(in srgb,var(--accent-purple) 18%,transparent)}.admin-team-manager-head{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap;margin-bottom:18px}.admin-team-manager-copy{margin:10px 0 0;color:var(--text-secondary)}.admin-team-create{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.admin-team-create input{min-width:220px;padding:11px 14px;border-radius:12px;border:1px solid var(--border-color);background:var(--surface-muted);color:var(--text-primary)}.admin-create-team-btn,.admin-team-delete-btn{display:inline-flex;align-items:center;gap:8px;padding:11px 14px;border-radius:12px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer;font-weight:600}.admin-create-team-btn{background:var(--accent-purple);color:#fff;border-color:transparent}.admin-team-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:16px}.admin-team-card{padding:18px;border-radius:18px;border:1px solid var(--border-color);background:color-mix(in srgb,var(--surface-muted) 72%,transparent);display:flex;flex-direction:column;gap:14px}.admin-team-card-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.admin-team-card-body{display:flex;flex-direction:column;gap:10px}.admin-team-card-body p{margin:0;color:var(--text-secondary);line-height:1.5}.admin-team-count{display:inline-flex;align-items:center;gap:8px;color:var(--text-primary);font-weight:600}.admin-team-delete-btn{color:#f87171;border-color:#ef444433}.admin-role-tag{display:inline-flex;align-items:center;gap:4px;font-size:.75rem;font-weight:600;padding:3px 10px;border-radius:20px}.admin-role-tag.ADMIN{background:#7c3aed40;color:#c4b5fd}.admin-role-tag.TEAM_LEAD{background:#3b82f633;color:#93c5fd}.admin-role-tag.MEMBER{background:#64748b33;color:var(--text-secondary)}.admin-actions-cell{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.admin-status-cell{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.admin-status-tag{display:inline-flex;align-items:center;justify-content:center;min-width:64px;padding:4px 10px;border-radius:999px;font-size:.75rem;font-weight:700}.admin-status-tag.ACTIVE{background:#22c55e29;color:#86efac}.admin-status-tag.INACTIVE{background:#94a3b829;color:var(--text-secondary)}.admin-action-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border-radius:8px;border:1px solid rgba(255,255,255,.1);background:#ffffff0a;color:var(--text-secondary);font-size:.78rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.admin-action-btn:hover{background:#ffffff14;color:var(--text-primary)}.admin-action-btn.deactivate-btn{color:#f87171;border-color:#ef444433}.admin-action-btn.deactivate-btn:hover{background:#ef44441a}.admin-action-btn.activate-btn{color:#4ade80;border-color:#22c55e33}.admin-action-btn.activate-btn:hover{background:#22c55e1a}.admin-action-btn.mute-btn{color:#fbbf24;border-color:#eab30833}.admin-action-btn.mute-btn:hover{background:#eab3081a}.admin-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.admin-modal{background:var(--bg-card-solid);border:1px solid var(--border-color);border-radius:16px;padding:28px;width:360px;max-width:90vw;display:flex;flex-direction:column;gap:20px}.admin-modal h3{font-size:1rem;font-weight:600}.admin-role-options{display:flex;flex-direction:column;gap:8px}.admin-role-option{display:flex;align-items:center;padding:12px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.07);cursor:pointer;transition:all .2s}.admin-role-option:hover{background:#ffffff0a}.admin-role-option.selected{border-color:var(--accent-purple);background:#7c3aed1f}.admin-role-pill{display:inline-flex;align-items:center;gap:5px;font-size:.85rem;font-weight:600}.admin-role-pill.ADMIN{color:#c4b5fd}.admin-role-pill.TEAM_LEAD{color:#93c5fd}.admin-role-pill.MEMBER{color:var(--text-secondary)}.admin-modal-actions{display:flex;gap:10px;justify-content:flex-end}.cancel-btn,.confirm-btn{padding:9px 20px;border-radius:10px;border:none;font-size:.85rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.cancel-btn{background:#ffffff0f;color:var(--text-secondary)}.cancel-btn:hover{background:#ffffff1a;color:var(--text-primary)}.confirm-btn{background:var(--accent-purple);color:#fff}.confirm-btn:hover:not(:disabled){opacity:.9}.confirm-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:768px){.admin-page{gap:20px}.admin-header{align-items:flex-start}.admin-header-actions,.admin-export-btn{width:100%}.admin-export-btn{justify-content:center}.admin-tabs{width:100%;overflow-x:auto;flex-wrap:nowrap;scrollbar-width:none}.admin-tabs::-webkit-scrollbar{display:none}.admin-tab-btn{flex:0 0 auto;white-space:nowrap}.admin-tab-content{padding:18px}.admin-team-create,.admin-team-create input,.admin-create-team-btn{width:100%}.admin-members-table th:nth-child(2),.admin-members-table td:nth-child(2){display:none}.admin-members-table th,.admin-members-table td{white-space:nowrap}.admin-actions-cell{flex-direction:column;gap:4px}.admin-status-cell{flex-direction:column;align-items:flex-start}}@media(max-width:480px){.admin-tab-content{padding:16px;border-radius:20px}.admin-modal{padding:22px 18px}.admin-modal-actions{flex-direction:column}}.team-management-page{display:flex;flex-direction:column;gap:20px}.team-management-header{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.team-management-copy p{margin:0;color:var(--text-secondary)}.team-management-summary{display:inline-flex;align-items:center;gap:10px;padding:12px 16px;border-radius:16px}.team-management-panel{display:flex;flex-direction:column;gap:16px;padding:24px;border-radius:24px}.team-management-toolbar{display:flex;align-items:center;justify-content:space-between;gap:16px;flex-wrap:wrap}.team-management-search{width:min(320px,100%)}.team-management-search input{width:100%;padding:12px 14px;border-radius:14px;border:1px solid var(--border-color);background:var(--surface-muted);color:var(--text-primary)}.team-management-caption{margin:0;color:var(--text-secondary);font-size:.94rem}.team-management-table-wrap{overflow-x:auto}.team-management-table{width:100%;min-width:760px;border-collapse:collapse}.team-management-table th,.team-management-table td{padding:16px 12px;border-bottom:1px solid var(--border-color);text-align:left;vertical-align:middle}.team-member-cell{display:inline-flex;align-items:center;gap:10px}.team-member-avatar{width:34px;height:34px;border-radius:999px;display:inline-flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--accent-purple),var(--accent-pink));color:#fff;font-weight:700}.team-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;background:var(--surface-muted)}.team-change-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 14px;border:1px solid var(--border-color);border-radius:12px;background:transparent;color:var(--text-primary);cursor:pointer}.team-management-empty{text-align:center;color:var(--text-secondary)}.team-management-modal-overlay{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:20px;background:#0a0e2075;z-index:1200}.team-management-modal{width:min(520px,100%);padding:24px;border-radius:24px;display:flex;flex-direction:column;gap:18px}.team-management-modal h3,.team-management-modal p{margin:0}.team-management-modal p{color:var(--text-secondary)}.team-select-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:10px}.team-select-option{padding:12px;border-radius:14px;border:1px solid var(--border-color);background:transparent;color:var(--text-primary);cursor:pointer}.team-select-option.selected{border-color:var(--accent-purple);background:color-mix(in srgb,var(--accent-purple) 16%,transparent)}.team-management-modal-actions{display:flex;justify-content:flex-end;gap:10px}.team-cancel-btn,.team-confirm-btn{padding:10px 16px;border-radius:12px;border:1px solid var(--border-color);cursor:pointer}.team-cancel-btn{background:transparent;color:var(--text-primary)}.team-confirm-btn{background:var(--accent-purple);color:#fff;border-color:transparent}@media(max-width:768px){.team-management-panel{padding:18px}.team-management-modal{padding:20px}.team-management-table{min-width:680px}}
