*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--purple-50: #f0f5f5;--purple-100: #C5D8DA;--purple-200: #8BBFC4;--purple-300: #6aaab0;--purple-400: #4f8f96;--purple-500: #3D5A5E;--purple-600: #2a3d40;--purple-700: #1e2d30;--purple-800: #141f21;--purple-900: #0a1112;--color-bg: #F5F0E8;--color-surface: #ffffff;--color-surface-alt: #edeae3;--color-border: #C5D8DA;--color-border-strong:#8BBFC4;--color-primary: #3D5A5E;--color-primary-hover: #2a3d40;--color-primary-soft: #C5D8DA;--color-success: #3D5A5E;--color-success-soft: #C5D8DA;--color-warning: #c45e32;--color-warning-soft: #FAD9CE;--color-danger: #c0392b;--color-danger-soft: #fde8e6;--color-text-primary: #2a3d40;--color-text-secondary: #4F6367;--color-text-muted: #8BBFC4;--font-sans: "Lato", sans-serif;--font-display: "Lato", sans-serif;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--shadow-sm: 0 1px 3px rgba(61,90,94,.08);--shadow-md: 0 4px 16px rgba(61,90,94,.12);--shadow-lg: 0 8px 32px rgba(61,90,94,.16)}body{font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text-primary);font-size:17px;line-height:1.7;-webkit-font-smoothing:antialiased}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--purple-200);border-radius:3px}input,textarea,select{font-family:var(--font-sans);font-size:14px;color:var(--color-text-primary);background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-md);padding:10px 14px;width:100%;transition:border-color .15s,box-shadow .15s;outline:none}input:focus,textarea:focus,select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #7c3aed1f}input::-moz-placeholder,textarea::-moz-placeholder{color:var(--color-text-muted)}input::placeholder,textarea::placeholder{color:var(--color-text-muted)}button{font-family:var(--font-sans);cursor:pointer;border:none;outline:none;transition:all .15s}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;box-shadow:var(--shadow-sm)}.btn-primary{background:var(--color-primary);color:#fff;padding:11px 24px;border-radius:var(--radius-md);font-size:16px;font-weight:500;box-shadow:0 2px 8px #7c3aed4d;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary:hover{background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:0 4px 12px #7c3aed66}.btn-primary:active{transform:translateY(0)}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-ghost{background:transparent;color:var(--color-text-secondary);padding:10px 20px;border-radius:var(--radius-md);font-size:14px;font-weight:500;border:1.5px solid var(--color-border)}.btn-ghost:hover{background:var(--color-surface-alt);border-color:var(--color-border-strong);color:var(--color-text-primary)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:var(--radius-full);font-size:12px;font-weight:500}.badge-purple{background:var(--purple-100);color:var(--purple-700)}.badge-green{background:var(--color-success-soft);color:var(--color-success)}.badge-amber{background:var(--color-warning-soft);color:var(--color-warning)}.badge-red{background:var(--color-danger-soft);color:var(--color-danger)}.avatar{width:38px;height:38px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;flex-shrink:0;background:var(--purple-100);color:var(--purple-700)}.page-shell{min-height:100vh;background:var(--color-bg)}.topnav{display:flex;align-items:center;justify-content:space-between;padding:0 2rem;height:60px;background:var(--color-surface);border-bottom:1.5px solid var(--color-border);position:sticky;top:0;z-index:10}.topnav-logo{font-family:var(--font-sans);font-weight:900;font-size:22px;color:#3d5a5e;letter-spacing:-.01em}.main-content{max-width:900px;margin:0 auto;padding:2rem 1.5rem}.auth-shell{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg);padding:1.5rem}.auth-card{width:100%;max-width:420px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);padding:2.5rem 2rem;box-shadow:var(--shadow-lg)}.auth-logo{font-family:var(--font-sans);font-weight:900;font-size:50px;color:#3d5a5e;text-align:center;margin-bottom:.25rem;letter-spacing:-.02em}.auth-tagline{text-align:center;color:var(--color-text-secondary);font-size:16px;margin-bottom:2rem}.form-group{margin-bottom:1rem}.form-label{display:block;font-size:15px;font-weight:500;color:var(--color-text-secondary);margin-bottom:6px}.form-error{font-size:15px;color:var(--color-danger);margin-top:1rem;text-align:center}.role-toggle{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:1rem}.role-btn{padding:14px 12px;border-radius:var(--radius-md);border:1.5px solid var(--color-border);background:var(--color-surface);text-align:center;cursor:pointer;transition:all .15s}.role-btn:hover{border-color:var(--color-border-strong);background:var(--color-surface-alt)}.role-btn.selected{border-color:var(--color-primary);background:var(--purple-50);box-shadow:0 0 0 3px #7c3aed1a}.role-btn-icon{font-size:22px;margin-bottom:4px}.role-btn-label{font-size:15px;font-weight:500;color:var(--color-text-primary)}.role-btn-sub{font-size:13px;color:var(--color-text-muted);margin-top:2px}.divider{display:flex;align-items:center;gap:12px;margin:1.25rem 0;color:var(--color-text-muted);font-size:12px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--color-border)}@keyframes fadeUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.fade-up{animation:fadeUp .3s ease forwards}.page-header{margin-bottom:1.75rem}.page-title{font-family:var(--font-sans);font-weight:700;font-size:28px;color:var(--color-text-primary);margin-bottom:4px}.page-subtitle{font-size:16px;color:var(--color-text-secondary)}.stats-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-bottom:1.75rem}.stat-card{background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:1rem 1.25rem}.stat-num{font-size:26px;font-weight:600;color:var(--color-primary)}.stat-label{font-size:14px;color:var(--color-text-secondary);margin-top:2px}.section-title{font-size:13px;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.07em;margin-bottom:10px;margin-top:1.5rem}.task-item{display:flex;align-items:flex-start;gap:12px;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-lg);padding:14px 16px;margin-bottom:8px;transition:border-color .15s,box-shadow .15s;cursor:pointer}.task-item:hover{border-color:var(--color-border-strong);box-shadow:var(--shadow-sm)}.task-item.completed{background:var(--color-surface-alt)}.task-check{width:22px;height:22px;border-radius:50%;border:2px solid var(--color-border-strong);flex-shrink:0;margin-top:1px;display:flex;align-items:center;justify-content:center;transition:all .15s;background:#fff}.task-check.checked{background:var(--color-success);border-color:var(--color-success)}.task-check.checked:after{content:"";width:5px;height:9px;border-right:2px solid white;border-bottom:2px solid white;transform:rotate(45deg) translate(-1px,-1px)}.task-title-text{font-size:16px;font-weight:500;color:var(--color-text-primary);margin-bottom:3px}.task-title-text.done{color:var(--color-text-muted);text-decoration:line-through}.task-meta-text{font-size:14px;color:var(--color-text-secondary)}.client-row{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid var(--color-border)}.client-row:last-child{border-bottom:none}.progress-bar{flex:1;height:6px;background:var(--purple-100);border-radius:3px;overflow:hidden}.progress-fill{height:100%;background:var(--color-primary);border-radius:3px;transition:width .4s ease}.modal-overlay{position:fixed;inset:0;background:#1e1b2e66;display:flex;align-items:center;justify-content:center;z-index:100;padding:1.5rem;animation:fadeUp .2s ease}.modal-card{background:var(--color-surface);border-radius:var(--radius-xl);padding:1.75rem;width:100%;max-width:460px;box-shadow:var(--shadow-lg);border:1.5px solid var(--color-border)}.modal-title{font-family:var(--font-display);font-size:22px;color:var(--color-text-primary);margin-bottom:1.25rem}
