@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@400;500;600;700&family=DM+Sans:ital,wght@0,400;0,500;0,600;0,700&display=swap";:root{--bg-deep: #0c0f14;--bg-surface: #141820;--bg-elevated: #1a1f2b;--bg-hover: #222836;--border: #2a3042;--border-focus: #4a7cff;--text-primary: #e8eaf0;--text-secondary: #8b92a8;--text-muted: #555d75;--accent: #4a7cff;--accent-hover: #6190ff;--accent-glow: rgba(74, 124, 255, .15);--danger: #ff5c5c;--danger-glow: rgba(255, 92, 92, .12);--success: #34d399;--warning: #fbbf24;--current-week: #ff5c5c;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--mono: "JetBrains Mono", monospace;--sans: "DM Sans", sans-serif;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .5);--transition: .15s cubic-bezier(.25, .1, .25, 1)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--sans);background:var(--bg-deep);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg-deep);position:relative;overflow:hidden}.login-page:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 20% 50%,rgba(74,124,255,.06) 0%,transparent 50%),radial-gradient(ellipse at 80% 20%,rgba(255,92,92,.04) 0%,transparent 50%);animation:loginBgShift 20s ease-in-out infinite alternate}@keyframes loginBgShift{0%{transform:translate(0)}to{transform:translate(-5%,3%)}}.login-card{background:var(--bg-surface);border:1px solid var(--border);padding:2.5rem;border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:380px;position:relative;z-index:1;animation:loginCardIn .5s cubic-bezier(.16,1,.3,1) both}@keyframes loginCardIn{0%{opacity:0;transform:translateY(16px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.login-card h1{text-align:center;margin-bottom:.4rem;font-family:var(--mono);font-size:1.1rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.login-subtitle{text-align:center;font-size:.78rem;color:var(--text-muted);margin-bottom:2rem;font-family:var(--mono);text-transform:uppercase;letter-spacing:.08em}.form-group{margin-bottom:1.1rem}.form-group label{display:block;margin-bottom:.4rem;font-size:.75rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.06em;font-family:var(--mono)}.form-group input{width:100%;padding:.65rem .85rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.9rem;font-family:var(--sans);background:var(--bg-elevated);color:var(--text-primary);transition:border-color var(--transition),box-shadow var(--transition)}.form-group input:focus{outline:none;border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow)}.form-group input::placeholder{color:var(--text-muted)}.error-message{color:var(--danger);font-size:.8rem;margin-bottom:.5rem;font-family:var(--mono);padding:.5rem .7rem;background:var(--danger-glow);border-radius:var(--radius-sm);border:1px solid rgba(255,92,92,.2)}button{padding:.6rem 1.2rem;border:1px solid transparent;border-radius:var(--radius-sm);font-size:.85rem;font-family:var(--sans);font-weight:600;cursor:pointer;background:var(--accent);color:#fff;transition:all var(--transition);letter-spacing:.01em}button:hover{background:var(--accent-hover);box-shadow:0 0 16px var(--accent-glow)}button:active{transform:scale(.97)}button:disabled{opacity:.4;cursor:not-allowed;box-shadow:none}.login-card button[type=submit]{width:100%;margin-top:.6rem;padding:.75rem;font-family:var(--mono);font-size:.8rem;text-transform:uppercase;letter-spacing:.1em}.app-header{display:flex;justify-content:space-between;align-items:center;padding:0 1.5rem;height:52px;background:var(--bg-surface);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:50}.app-header h1{font-family:var(--mono);font-size:.85rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.app-header h1 .header-dot{color:var(--accent)}.header-actions{display:flex;align-items:center;gap:.6rem}.user-info{font-family:var(--mono);font-size:.72rem;color:var(--text-muted);padding:.3rem .6rem;background:var(--bg-elevated);border-radius:var(--radius-sm);border:1px solid var(--border)}.user-role{color:var(--accent);font-weight:600}.btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);padding:.35rem .75rem;font-size:.75rem;font-family:var(--mono);border:1px solid var(--border)}.btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-muted);box-shadow:none}.btn-secondary.active{background:var(--accent-glow);color:var(--accent);border-color:var(--accent)}.toolbar{display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.5rem;background:var(--bg-surface);border-bottom:1px solid var(--border)}.year-selector{display:flex;align-items:center;gap:.5rem}.year-selector button{width:30px;height:30px;padding:0;border-radius:var(--radius-sm);background:var(--bg-elevated);color:var(--text-secondary);font-weight:600;font-size:.85rem;display:flex;align-items:center;justify-content:center;border:1px solid var(--border)}.year-selector button:hover{background:var(--bg-hover);color:var(--text-primary);box-shadow:none}.year-display{font-family:var(--mono);font-size:1.4rem;font-weight:700;min-width:70px;text-align:center;color:var(--text-primary);letter-spacing:-.03em}.agent-legend{display:flex;gap:.8rem;flex-wrap:wrap;align-items:center}.legend-item{display:flex;align-items:center;gap:.35rem;font-size:.72rem;font-family:var(--mono);color:var(--text-secondary)}.legend-color{width:10px;height:10px;border-radius:2px;display:inline-block;box-shadow:0 0 6px #ffffff0d}.main-content{display:flex;flex-direction:column;gap:1rem;padding:1rem 1.5rem;min-height:calc(100vh - 104px)}.agent-manager{background:var(--bg-surface);border-radius:var(--radius-md);padding:.8rem 1rem;border:1px solid var(--border)}.agent-manager h3{display:none}.agent-list{display:flex;flex-wrap:wrap;gap:.35rem;margin-bottom:0}.agent-row{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;border-radius:var(--radius-sm);background:var(--bg-elevated);border:1px solid transparent;transition:all var(--transition)}.agent-row:hover{border-color:var(--border)}.agent-row.editing{flex-wrap:wrap;padding:.5rem .6rem;border-color:var(--accent);background:var(--accent-glow);gap:.4rem}.agent-edit-fields{display:flex;align-items:center;gap:.4rem;width:100%}.agent-edit-fields input:not([type=color]){flex:1}.agent-edit-actions{display:flex;gap:.35rem;width:100%}.agent-edit-actions .btn-save{flex:1;background:var(--accent);color:#fff;border-color:var(--accent)}.agent-edit-actions .btn-save:hover{background:var(--accent-hover)}.agent-edit-actions .btn-small:not(.btn-save){flex:1}.agent-row input[type=text],.agent-row input:not([type]){flex:1;padding:.3rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.8rem;font-family:var(--sans);background:var(--bg-deep);color:var(--text-primary)}.agent-row input[type=text]:focus,.agent-row input:not([type]):focus{outline:none;border-color:var(--border-focus)}.agent-row input[type=color]{width:24px;height:24px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:transparent;padding:1px}.agent-color{width:12px;height:12px;border-radius:2px;display:inline-block;flex-shrink:0}.agent-drag-handle{display:flex;align-items:center;gap:.5rem;flex:1;cursor:grab;padding:.1rem 0;border-radius:var(--radius-sm);transition:background var(--transition)}.agent-drag-handle:hover{background:var(--bg-hover)}.agent-drag-handle:active{cursor:grabbing}.agent-name{flex:1;font-size:.82rem;font-weight:500}.btn-small{padding:.2rem .5rem;font-size:.7rem;font-family:var(--mono);background:transparent;color:var(--text-muted);border:1px solid var(--border)}.btn-small:hover{background:var(--bg-hover);color:var(--text-primary);box-shadow:none}.btn-danger{color:var(--danger);border-color:transparent}.btn-danger:hover{background:var(--danger-glow);color:var(--danger);border-color:#ff5c5c4d}.agent-add{display:flex;gap:.4rem;align-items:center;padding-top:.5rem;margin-top:.5rem;border-top:1px solid var(--border)}.agent-add input[type=text],.agent-add input:not([type]){flex:1;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;font-family:var(--sans);background:var(--bg-elevated);color:var(--text-primary)}.agent-add input[type=text]:focus,.agent-add input:not([type]):focus{outline:none;border-color:var(--border-focus)}.agent-add input[type=color]{width:30px;height:30px;border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;background:transparent;padding:1px}.agent-add button{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;padding:.45rem .8rem}.year-calendar{flex:1}.month-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.month-block{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden}.month-block-header{padding:.5rem .75rem;font-family:var(--mono);font-weight:700;font-size:.72rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.1em;background:var(--bg-elevated);border-bottom:1px solid var(--border)}.month-block-weeks{display:flex;flex-direction:column}.week-row{display:flex;align-items:center;padding:.4rem .75rem;background:var(--bg-surface);border-top:1px solid var(--border);transition:background var(--transition);cursor:default;gap:.75rem}.month-block-weeks .week-row:first-child{border-top:none}.week-row:hover{background:var(--bg-elevated)}.week-row.current-week{background:#ff5c5c0f;box-shadow:inset 3px 0 0 var(--current-week)}.week-row.current-week .week-number{color:var(--current-week)}.week-row.drop-over{background:var(--accent-glow);box-shadow:inset 0 0 0 1px var(--accent)}.week-row.dragging{opacity:.3}.week-info{display:flex;align-items:center;gap:.5rem;min-width:140px}.week-number{font-family:var(--mono);font-size:.68rem;color:var(--text-muted);font-weight:600;letter-spacing:.02em;-webkit-user-select:none;user-select:none;min-width:28px}.week-dates{font-family:var(--mono);font-size:.62rem;color:var(--text-muted);opacity:.6;-webkit-user-select:none;user-select:none;white-space:nowrap}.week-agent{display:flex;align-items:center;gap:.5rem;flex:1}.week-agent-drag{cursor:grab}.week-agent-drag:active{cursor:grabbing}.btn-unassign{width:20px;height:20px;padding:0;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:.8rem;display:flex;align-items:center;justify-content:center;opacity:0;transition:all var(--transition);border:1px solid transparent;line-height:1}.week-row:hover .btn-unassign{opacity:1}.btn-unassign:hover{background:var(--danger-glow);color:var(--danger);border-color:#ff5c5c4d;box-shadow:none}.agent-badge{display:inline-block;padding:.2rem .6rem;border-radius:3px;font-family:var(--mono);font-size:.7rem;font-weight:600;color:#fff;white-space:nowrap;cursor:grab;text-shadow:0 1px 2px rgba(0,0,0,.3);letter-spacing:.02em;transition:transform var(--transition),box-shadow var(--transition)}.agent-badge:hover{transform:scale(1.05);box-shadow:0 2px 8px #0000004d}.btn-assign{padding:.15rem .6rem;border-radius:var(--radius-sm);background:transparent;color:var(--text-muted);font-size:.7rem;font-family:var(--mono);opacity:0;transition:all var(--transition);border:1px dashed var(--border)}.week-row:hover .btn-assign{opacity:1}.btn-assign:hover{background:var(--accent-glow);color:var(--accent);border-color:var(--accent);box-shadow:none}.drag-overlay{opacity:.95;transform:scale(1.15) rotate(-1deg);filter:drop-shadow(0 8px 16px rgba(0,0,0,.5))}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .15s ease both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;min-width:320px;box-shadow:var(--shadow-lg);animation:modalIn .25s cubic-bezier(.16,1,.3,1) both}@keyframes modalIn{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal h3{margin-bottom:1rem;font-family:var(--mono);font-size:.8rem;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--text-secondary)}.modal-agents{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1rem}.modal-agent-btn{display:flex;align-items:center;gap:.6rem;background:var(--bg-elevated);border:1px solid var(--border);padding:.6rem 1rem;border-radius:var(--radius-md);color:var(--text-primary);font-weight:500;font-size:.85rem;transition:all var(--transition)}.modal-agent-btn:hover{background:var(--bg-hover);border-color:var(--text-muted);box-shadow:none}.modal-agent-btn .legend-color{width:14px;height:14px;border-radius:3px;flex-shrink:0}.modal .btn-secondary{width:100%;text-align:center}.user-modal{min-width:480px;max-width:560px;max-height:80vh;overflow-y:auto}.user-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.user-modal-header h3{margin-bottom:0}.user-modal-header .btn-small{font-size:1rem;width:28px;height:28px;display:flex;align-items:center;justify-content:center;padding:0}.user-section{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.user-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.user-section h4{font-family:var(--mono);font-size:.68rem;font-weight:700;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:.6rem}.user-section .btn-secondary{width:auto;font-size:.72rem}.user-list{display:flex;flex-direction:column;gap:.4rem}.user-row{display:flex;align-items:center;gap:.5rem;padding:.45rem .6rem;background:var(--bg-elevated);border-radius:var(--radius-sm);flex-wrap:wrap}.user-row-name{font-size:.85rem;font-weight:500;min-width:80px}.user-row-role{font-family:var(--mono);font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.15rem .4rem;border-radius:3px;background:var(--bg-hover);color:var(--text-muted)}.user-row-role.admin{background:var(--accent-glow);color:var(--accent)}.user-row-you{font-size:.7rem;color:var(--text-muted);font-style:italic;margin-left:auto}.reset-pw-inline{display:flex;gap:.3rem;align-items:center}.reset-pw-inline input{width:120px;padding:.25rem .4rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem;background:var(--bg-deep);color:var(--text-primary)}.reset-pw-inline input:focus{outline:none;border-color:var(--border-focus)}.change-pw-form{display:flex;gap:.4rem;align-items:center;margin-top:.5rem}.change-pw-form input{flex:1;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;background:var(--bg-elevated);color:var(--text-primary)}.change-pw-form input:focus{outline:none;border-color:var(--border-focus)}.create-user-form{display:flex;gap:.4rem;align-items:center}.create-user-form input{flex:1;padding:.4rem .6rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.82rem;background:var(--bg-elevated);color:var(--text-primary)}.create-user-form input:focus{outline:none;border-color:var(--border-focus)}.create-user-form select{padding:.4rem .5rem;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:.78rem;font-family:var(--mono);background:var(--bg-elevated);color:var(--text-primary);cursor:pointer}.create-user-form select:focus{outline:none;border-color:var(--border-focus)}.success-message{color:var(--success);font-size:.78rem;font-family:var(--mono);padding:.4rem .6rem;background:#34d3991a;border-radius:var(--radius-sm);border:1px solid rgba(52,211,153,.2);margin-bottom:.8rem}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-family:var(--mono);font-size:.85rem;color:var(--text-muted);letter-spacing:.1em;text-transform:uppercase}.loading:after{content:"";display:inline-block;width:4px;height:16px;background:var(--accent);margin-left:8px;animation:blink .8s step-end infinite}@keyframes blink{50%{opacity:0}}
