:root{--blue: #72b8e8;--purple: #9680cc;--pink: #d44a99;--bg-dark: #111118;--bg-card: rgba(22, 20, 34, .82);--bg-sidebar: #0e0d16;--text-primary: #eef0f6;--text-secondary: #8e97b2;--text-muted: #5a6280;--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, var(--blue) 0%, var(--purple) 50%, var(--pink) 100%);--gradient-purple: var(--gradient-logo);--gradient-purple-blue: linear-gradient(135deg, var(--purple) 0%, var(--blue) 100%);--border-color: rgba(150, 160, 200, .1);--success: #3db87a;--warning: #d4a020;--error: #e05050;--sidebar-width: 200px}*{box-sizing:border-box}body{margin:0;font-family:Pretendard,-apple-system,BlinkMacSystemFont,system-ui,sans-serif;background:var(--bg-dark);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}body:before{content:"";position:fixed;inset:0;background:radial-gradient(ellipse 70% 40% at 50% -10%,rgba(150,128,204,.1),transparent);pointer-events:none;z-index:0}#root{min-height:100vh;position:relative;z-index:1}a{color:var(--accent-purple-light);text-decoration:none}button{font-family:inherit;cursor:pointer;border:none}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(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-color);border-radius:12px}.layout{display:flex;min-height:100vh}.sidebar{width:200px;background:#12121a;border-right:1px solid rgba(255,255,255,.06);display:flex;flex-direction:column;flex-shrink:0;position:fixed;left:0;top:0;bottom:0;z-index:100}.logo{padding:20px 8px 16px;display:flex;flex-direction:column;align-items:center;gap:8px;border-bottom:1px solid rgba(255,255,255,.06)}.logo-img{height:56px;width:auto;object-fit:contain}.logo-text{font-size:.8rem;font-weight:700;color:var(--text-primary);white-space:nowrap}.nav{flex:1;padding:16px 12px;display:flex;flex-direction:column;align-items:stretch;gap:4px}.nav-item{display:flex;align-items:center;gap:12px;padding:12px 14px;border-radius:12px;color:var(--text-secondary);background:transparent!important;transition:all .2s;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:#7c3aed26}.nav-item.active{color:var(--text-primary);background:var(--accent-purple)!important}.nav-item.active svg{color:inherit}.main-content{flex:1;margin-left:200px;padding:24px;min-height:100vh}.sidebar-auth{padding:12px;display:flex;flex-direction:column;gap:8px;border-top:1px solid rgba(255,255,255,.06)}.sidebar-auth-btn{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:10px;border:none;cursor:pointer;font-size:.88rem;font-weight:600;font-family:inherit;transition:all .2s;width:100%}.sidebar-auth-btn.login{background:var(--accent-purple);color:#fff;box-shadow:0 2px 12px #7c3aed4d}.sidebar-auth-btn.login:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 16px #7c3aed73}.sidebar-auth-btn.register{background:#94a3b814;color:var(--text-secondary);border:1px solid rgba(255,255,255,.08)}.sidebar-auth-btn.register:hover{background:#94a3b824;color:var(--text-primary)}@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 rgba(255,255,255,.06)}.logo{display:none}.nav{flex-direction:row;flex:1;justify-content:space-around;padding:0}.nav-item{flex:1;justify-content:center}.nav-label{display:none}.main-content{margin-left:0;margin-bottom:70px;padding:16px}}.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 h3{font-size:1.1rem;margin-bottom:6px}.set-work-days-personal .desc{color:var(--text-secondary);font-size:.85rem;margin-bottom:20px}.member-row{display:flex;flex-direction:column;gap:14px}.member-avatar{width:40px;height:40px;border-radius:50%;background:var(--gradient-purple);display:flex;align-items:center;justify-content:center;font-size:.9rem;font-weight:600}.member-name{font-weight:500}.days-toggles{display:flex;gap:12px;flex-wrap:wrap}.day-cell{display:flex;flex-direction:column;align-items:center;gap:8px}.day-name{font-size:.7rem;color:var(--text-secondary)}.toggle{width:40px;height:22px;border-radius:11px;background:#94a3b84d;position:relative;transition:background .2s}.toggle:after{content:"";position:absolute;width:16px;height:16px;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)}.toggle.on:after{transform:translate(18px)}.time-row{display:flex;gap:20px;margin-top:20px}.time-field{display:flex;flex-direction:column;gap:6px}.time-field label{font-size:.8rem;color:var(--text-secondary)}.time-field input{padding:10px 14px;border-radius:8px;border:1px solid var(--border-color);background:#0f0f1a80;color:var(--text-primary);font-size:.95rem}.save-btn{margin-top:24px;padding:12px 32px;background:var(--gradient-purple);color:var(--text-primary);border-radius:10px;font-weight:600}.dashboard{max-width:1200px}.dashboard-grid{display:grid;grid-template-columns:1fr 1fr 1fr;grid-template-rows:auto auto;gap:20px}.clock-card{grid-column:1;grid-row:1;display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:260px}.clock-card-link{text-decoration:none;color:inherit;transition:transform .2s,box-shadow .2s}.clock-card-link:hover{transform:translateY(-2px);box-shadow:0 8px 24px #9680cc26}.clock-outer{width:170px;height:170px;position:relative;display:flex;align-items:center;justify-content:center}.clock-ring-svg{position:absolute;inset:0}.clock-inner{width:120px;height:120px;border-radius:50%;background:#0d0d14fa;display:flex;align-items:center;justify-content:center;position:relative;z-index:1}.clock-time{font-size:1.85rem;font-weight:700;color:var(--text-primary)}.clock-time-start{font-size:1.4rem;color:var(--success)}.clock-time-leave{font-size:1.4rem;color:var(--error)}.clock-label{margin-top:14px;color:var(--text-primary);font-size:.95rem}.card{padding:24px}.schedule-card h3,.chat-preview h3,.stats-card h3,.members-card h3{font-size:1rem;font-weight:600;margin-bottom:16px;color:var(--text-primary)}.schedule-card ul{list-style:none;padding:0;margin:0}.schedule-item{display:flex;gap:14px;align-items:flex-start;padding:12px 14px;border-radius:8px;margin-bottom:6px}.schedule-item.purple{background:#9680cc1f;border-left:3px solid var(--purple)}.schedule-item.blue{background:#72b8e81a;border-left:3px solid var(--blue)}.schedule-item.grey{background:#96a0c80d;border-left:3px solid var(--border-color)}.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:.82rem}.schedule-title{font-size:.95rem;color:var(--text-primary)}.chat-preview{grid-column:1;grid-row:2}.chat-preview ul{list-style:none;padding:0;margin:0}.chat-preview li{display:flex;gap:14px;padding:12px 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:8px}.chat-msg-content strong{margin-right:4px}.msg-text{flex:1;color:var(--text-secondary)}.ts{color:var(--text-muted);font-size:.8rem;margin-left:auto}.avatar{width:40px;height:40px;border-radius:50%;background:var(--purple);display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:600;color:#fff;flex-shrink:0}.view-all{display:block;margin-top:16px;text-align:center;color:var(--accent-purple-light);font-size:.9rem}.stats-card{grid-column:2;grid-row:2}.big-stat{font-size:2.5rem;font-weight:700;color:var(--text-primary)}.stats-card .big-stat{margin-bottom:12px}.stat-tabs{display:flex;gap:16px}.stat-tabs span{color:var(--text-secondary);font-size:.875rem}.stat-tabs span.active{color:var(--accent-purple-light);font-weight:600}.attendance-progress{margin-top:12px;height:5px;border-radius:3px;background:#96a0c81a;overflow:hidden}.attendance-progress:after{content:"";display:block;width:92%;height:100%;background:var(--purple);border-radius:3px}.members-card{grid-column:2;grid-row:2}.schedule-card{grid-column:2 / 4;grid-row:1}.members-card{grid-column:3;grid-row:2}.members-card .up{color:var(--success);font-size:.9rem;margin-left:4px}.members-card .increase{font-size:.85rem;color:var(--success);margin-left:2px}.members-card p{color:var(--text-secondary);font-size:.9rem;margin-top:4px}.members-card .total{color:var(--text-muted);font-size:.85rem}@media(max-width:900px){.dashboard-grid{grid-template-columns:1fr;grid-template-rows:auto}.schedule-card,.clock-card,.chat-preview,.stats-card,.members-card{grid-column:1;grid-row:auto}}.chat-page{display:flex;min-height:100vh;height:100vh;gap:0;margin:-24px}.chat-sidebar{width:280px;flex-shrink:0;overflow-y:auto;padding:20px;border-radius:0;border-right:1px solid var(--border-color)}.chat-sidebar h2{font-size:1.2rem;font-weight:600;margin-bottom:16px}.search-wrap{display:flex;align-items:center;gap:8px;padding:10px 12px;background:#0f0f1a80;border-radius:8px;margin-bottom:20px}.search-wrap input{flex:1;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{padding:12px;border-radius:8px;cursor:pointer;margin-bottom:4px}.channel-item.active{background:#7c3aed40;color:var(--accent-purple-light)}.channel-name{display:block;font-weight:500}.channel-last{display:block;font-size:.8rem;color:var(--text-secondary);margin-top:2px}.dm-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;cursor:pointer;margin-bottom:4px}.dm-item:hover{background:#94a3b814}.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{flex:1;font-size:.9rem}.dm-status{font-size:.75rem;color:var(--text-secondary)}.dm-status.online{color:var(--success)}.chat-main{flex:1;display:flex;flex-direction:column;min-width:0}.chat-header{padding:16px 24px;display:flex;align-items:center;justify-content:space-between;border-radius:0;border-bottom:1px solid var(--border-color)}.chat-header h3{font-size:1.1rem;margin:0 0 2px}.members-count{font-size:.85rem;color:var(--text-secondary)}.header-actions{display:flex;gap:8px}.header-actions button{padding:8px;color:var(--text-secondary)}.chat-messages{flex:1;overflow-y:auto;padding:24px}.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:#1e1b2d99;border-radius:12px}.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:#0000004d;padding:2px 6px;border-radius:4px;font-size:.9em}.msg-markdown pre{margin:.5em 0;padding:12px;background:#0000004d;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:#0000004d;padding:12px;border-radius:8px;font-family:monospace;font-size:.85rem;overflow-x:auto}.chat-input-area{padding:16px 24px;display:flex;flex-direction:column;gap:10px;border-radius:0;border-top:1px solid var(--border-color)}.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:#0f0f1a99;border:1px solid var(--border-color);border-radius:10px;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)}.format-toolbar button: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:#0f0f1a99;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:10px 20px;background:var(--gradient-purple);color:var(--text-primary);border-radius:10px;font-weight:500}@media(max-width:768px){.chat-page{flex-direction:column;height:auto}.chat-sidebar{width:100%;max-height:200px}.chat-main{min-height:400px}}.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);margin:-24px;background:var(--bg-dark)}.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-dark);--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:#12101c99;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-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:#373050f2;border:1px solid rgba(124,58,237,.35);border-radius:8px;box-shadow:0 4px 16px #0000004d;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:#191728fa!important;border:1px solid rgba(148,163,184,.2)!important;border-radius:10px;box-shadow:0 8px 24px #0006}.fc-popover .fc-popover-header,.fc .fc-popover-header{background:#1e1c28fa!important;border-bottom:1px solid rgba(148,163,184,.12);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:#191728fa!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:#1e1c28fa;border:1px solid rgba(255,255,255,.1);border-radius:12px;padding:20px;min-width:320px}.add-task-modal{min-width:360px}.add-task-modal .add-task-inline{margin-bottom:0}.add-task-modal-actions{margin-top:16px;padding-top:16px;border-top:1px solid rgba(255,255,255,.08)}.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 rgba(255,255,255,.1);background:#0f0d1a80;color:var(--text-primary);font-size:.9rem;margin-bottom:16px}.edit-task-actions{display:flex;gap:10px;justify-content:flex-end}.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:#12101cf2;border-left:1px solid rgba(148,163,184,.2)}.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 rgba(255,255,255,.1);background:#0f0d1a80;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 rgba(255,255,255,.1);background:#0f0d1a80;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}.event-detail-title{font-size:1.1rem;font-weight:600;margin-bottom:6px}.event-detail-meta{font-size:.9rem;color:var(--text-secondary)}.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}@media(max-width:900px){.calendar-page{flex-direction:column;height:auto}.tasks-sidebar{width:100%;border-left:none;border-top:1px solid rgba(255,255,255,.05)}}.attendance-page{max-width:1400px}.attendance-header{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:16px;margin-bottom:24px}.attendance-header h1{font-size:1.75rem;font-weight:700;margin:0}.header-actions{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.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)}.attendance-content{display:flex;flex-direction:column;gap:24px}.two-cards-row{display:grid;grid-template-columns:1fr 1.5fr;gap:24px}.two-cards-row.single{grid-template-columns:1fr;max-width:500px}.set-work-days-section,.records-section{padding:24px}.records-section h3{margin-bottom:16px;font-size:1rem}.records-table-wrap{overflow-x:auto}.records-table{width:100%;border-collapse:collapse}.records-table th,.records-table td{padding:12px 14px;text-align:left;border-bottom:1px solid var(--border-color)}.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)}.pagination button{padding:6px;color:var(--text-secondary)}.summary-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:20px}.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)}}.drive-page{max-width:1000px}.drive-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.drive-header h1{font-size:1.75rem;margin:0}.upload-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px}.drive-content{padding:24px}.breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:24px;font-size:.9rem;color:var(--text-secondary)}.breadcrumb button{background:none;color:var(--text-primary)}.breadcrumb button:hover{color:var(--accent-purple-light)}.folders-section,.recent-section{margin-bottom:32px}.folders-section h3,.recent-section h3{font-size:1rem;margin-bottom:16px}.folder-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:20px}.folder-card{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;border-radius:12px;cursor:pointer;transition:background .2s}.folder-card:hover{background:#7c3aed1a}.folder-icon{width:56px;height:56px;border-radius:12px;display:flex;align-items:center;justify-content:center}.file-list{display:flex;flex-direction:column;gap:8px}.file-row{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:8px}.file-row:hover{background:#94a3b814}.file-icon{color:var(--text-secondary)}.file-name{flex:1}.file-time{color:var(--text-secondary);font-size:.875rem}.delete-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;display:flex;align-items:center;transition:color .2s;margin-left:auto}.delete-btn:hover{color:#ef4444}.file-size{font-size:12px;color:var(--text-secondary);margin-left:auto}.empty-msg{color:var(--text-secondary);font-size:14px;padding:20px 0}.ai-chat-page{margin:-24px;min-height:100vh;display:flex;flex-direction:column}.ai-header{text-align:center;padding:16px 24px;flex-shrink:0}.ai-title{display:flex;align-items:center;justify-content:center;gap:12px}.ai-title h1{font-size:1.5rem;margin:0}.ai-desc{color:var(--text-secondary);font-size:.9rem;margin-top:8px}.ai-chat-area{padding:0 24px 24px;flex:1;display:flex;flex-direction:column;min-height:0}.messages{flex:1;overflow-y:auto;min-height:200px;margin-bottom:20px}.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-primary);padding:12px 18px;border-radius:16px}.msg-bubble.ai span{background:#94a3b826;padding:12px 18px;border-radius:16px}.msg-icon{color:var(--accent-purple-light);flex-shrink:0}.suggestions{margin-bottom: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:#7c3aed26;color:var(--accent-purple-light);border-radius:10px;font-size:.9rem}.suggestions button:hover{background:#7c3aed40}.input-area{display:flex;gap:12px}.input-area input{flex:1;padding:14px 18px;border-radius:12px;border:1px solid var(--border-color);background:#0f0f1a99;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-primary);border-radius:12px}@media(max-width:768px){.ai-chat-page{margin:-16px}}.members-page{max-width:1400px}.members-header{margin-bottom:24px}.members-header h1{font-size:1.75rem;margin:0;display:flex;align-items:center;gap:12px}.admin-badge{font-size:.75rem;padding:4px 10px;background:var(--error);border-radius:4px;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:1fr 320px;gap:24px}.table-section{padding:24px;overflow-x:auto}.table-section h3{margin-bottom:16px;font-size:1rem}.members-table{width:100%;border-collapse:collapse}.members-table th,.members-table td{padding:12px 16px;text-align:left;border-bottom:1px solid var(--border-color)}.members-table th{color:var(--text-secondary);font-size:.8rem;font-weight:600}.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{padding:4px 12px;border-radius:6px;font-size:.8rem}.team-tag.design{background:#3b82f633;color:var(--accent-blue)}.team-tag.dev{background:#22c55e33;color:var(--success)}.team-tag.marketing{background:#f9731633;color:#f97316}.team-tag.product{background:#ec489933;color:var(--accent-pink)}.role-tag{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;border-radius:6px;font-size:.8rem}.role-tag.leader{background:#eab30833;color:var(--warning)}.role-tag.team_lead{background:#7c3aed33;color:var(--accent-purple-light)}.role-tag.member{background:#94a3b833;color:var(--text-secondary)}.actions{display:flex;gap:8px}.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}.stats-sidebar{padding:24px;height:fit-content}.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}.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:#7c3aed33;color:var(--accent-purple-light)}.role-pill.leader{background:#eab30833;color:var(--warning)}.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}}.members-header{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}.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}.settings-page{display:flex;flex-direction:column;gap:24px}.settings-header h1{margin:0}.settings-layout{display:grid;grid-template-columns:200px 1fr;gap:20px;align-items:start}.settings-nav{display:flex;flex-direction:column;padding:12px;gap:4px;border-radius:12px}.settings-nav .nav-item{display:flex;align-items:center;gap:10px;padding:10px 14px;border:none;background:transparent;color:var(--text-secondary);border-radius:8px;cursor:pointer;font-size:14px;transition:all .2s;text-align:left}.settings-nav .nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.settings-nav .nav-item.active{background:#9680cc33;color:var(--purple)}.settings-content{border-radius:12px;padding:28px}.settings-section h3{font-size:18px;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:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--purple),var(--pink));display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.avatar-name{font-size:16px;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:#ffffff0d;border:1px solid var(--border-color);border-radius:8px;padding:10px 14px;color:var(--text-primary);font-size:14px;outline:none;transition:border-color .2s}.setting-input:focus{border-color:var(--purple)}.setting-input.disabled{opacity:.5;cursor:not-allowed}.save-btn{display:flex;align-items:center;gap:8px;padding:10px 20px;background:var(--purple);color:#fff;border:none;border-radius:8px;cursor:pointer;font-size:14px;font-weight:500;transition:opacity .2s}.save-btn:hover{opacity:.85}.setting-row{display:flex;justify-content:space-between;align-items:center;padding:16px 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:#ffffff26;border-radius:24px;cursor:pointer;transition:background .2s}.toggle-slider:before{content:"";position:absolute;width:18px;height:18px;left:3px;top:3px;background:#fff;border-radius:50%;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--purple)}.toggle-switch input:checked+.toggle-slider:before{transform:translate(20px)}.toggle-switch input:disabled+.toggle-slider{opacity:.6;cursor:not-allowed}.color-swatches{margin-top:24px}.color-swatches h4{font-size:14px;color:var(--text-secondary);margin-bottom:12px}.swatches-row{display:flex;gap:10px}.swatch{width:36px;height:36px;border-radius:50%;border:2px solid transparent;cursor:pointer;transition:transform .2s,border-color .2s}.swatch:hover{transform:scale(1.2);border-color:#fff}
