.dashboard-shell{background:var(--off-white);min-height:100vh;font-family:var(--font-body);display:flex}.dashboard-sidebar{background:var(--ink);flex-direction:column;flex-shrink:0;width:240px;height:100vh;min-height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff14;padding:28px 24px 20px}.sidebar-brand-name{font-family:var(--font-head);color:var(--white);letter-spacing:.01em;font-size:1.3rem;font-weight:600}.sidebar-brand-sub{color:var(--accent-gold);letter-spacing:.06em;text-transform:uppercase;margin-top:2px;font-size:.72rem}.sidebar-nav{flex-direction:column;flex:1;gap:4px;padding:20px 12px;display:flex}.sidebar-nav-label{color:#ffffff59;text-transform:uppercase;letter-spacing:.1em;margin-top:8px;padding:8px 12px 4px;font-size:.65rem}.sidebar-nav-link{color:#ffffffa6;cursor:pointer;border-radius:8px;align-items:center;gap:10px;padding:9px 12px;font-size:.875rem;font-weight:450;text-decoration:none;transition:background .15s,color .15s;display:flex}.sidebar-nav-link:hover{color:var(--white);background:#ffffff14}.sidebar-nav-link.active{color:var(--white);background:#21686959;font-weight:500}.sidebar-nav-link.active .nav-icon{color:var(--accent-gold)}.nav-icon{flex-shrink:0;width:16px;height:16px}.sidebar-footer{border-top:1px solid #ffffff14;padding:16px 12px 24px}.sidebar-client-info{margin-bottom:8px;padding:8px 12px}.sidebar-client-name{color:var(--white);font-size:.8rem;font-weight:500}.sidebar-client-plan{color:var(--accent-gold);margin-top:2px;font-size:.7rem}.sidebar-signout{color:#ffffff80;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:8px;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:.875rem;transition:background .15s,color .15s;display:flex}.sidebar-signout:hover{color:#ff7070;background:#ff50501f}.dashboard-main{flex:1;min-width:0;padding:36px 40px;overflow-y:auto}.dashboard-header{margin-bottom:28px}.dashboard-welcome{font-family:var(--font-head);color:var(--ink);font-size:1.9rem;font-weight:600;line-height:1.2}.dashboard-sub{color:var(--ink-light);margin-top:6px;font-size:.9rem}.stats-grid{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;margin-bottom:32px;display:grid}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:12px;padding:20px 22px;transition:box-shadow .2s}.stat-card:hover{box-shadow:0 4px 20px #00121912}.stat-label{color:var(--ink-light);text-transform:uppercase;letter-spacing:.06em;font-size:.75rem;font-weight:500}.stat-value{font-family:var(--font-head);color:var(--ink);margin-top:8px;font-size:2.4rem;font-weight:700;line-height:1.1}.stat-value.accent{color:var(--accent)}.stat-value.gold{color:#c49a00}.stat-hint{color:var(--ink-light);margin-top:4px;font-size:.72rem}.dashboard-section{background:var(--white);border:1px solid var(--border);border-radius:12px;margin-bottom:24px;padding:24px 26px}.section-header{justify-content:space-between;align-items:center;margin-bottom:18px;display:flex}.section-title{color:var(--ink);font-size:1rem;font-weight:600}.section-link{color:var(--accent);font-size:.8rem;font-weight:500;text-decoration:none}.section-link:hover{text-decoration:underline}.activity-list{flex-direction:column;gap:0;display:flex}.activity-item{border-bottom:1px solid var(--border);align-items:flex-start;gap:12px;padding:12px 0;display:flex}.activity-item:last-child{border-bottom:none;padding-bottom:0}.activity-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;margin-top:5px}.activity-dot.completed{background:#22c55e}.activity-dot.in_progress{background:var(--accent)}.activity-dot.pending{background:#f59e0b}.activity-name{color:var(--ink);flex:1;font-size:.875rem;font-weight:450;line-height:1.4}.activity-time{color:var(--ink-light);flex-shrink:0;margin-top:1px;font-size:.75rem}.task-filters{flex-wrap:wrap;align-items:flex-end;gap:12px;margin-bottom:20px;display:flex}.filter-group{flex-direction:column;gap:5px;display:flex}.filter-label{color:var(--ink-light);text-transform:uppercase;letter-spacing:.05em;font-size:.72rem;font-weight:500}.filter-select,.filter-input{border:1px solid var(--border);background:var(--white);color:var(--ink);font-size:.85rem;font-family:var(--font-body);border-radius:8px;outline:none;min-width:140px;padding:7px 12px;transition:border-color .15s}.filter-select:focus,.filter-input:focus{border-color:var(--accent)}.filter-btn{background:var(--accent);color:var(--white);font-size:.85rem;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;align-self:flex-end;padding:7px 18px;font-weight:500;transition:background .15s}.filter-btn:hover{background:var(--ink-light)}.filter-reset{color:var(--ink-light);border:1px solid var(--border);font-size:.85rem;font-family:var(--font-body);cursor:pointer;background:0 0;border-radius:8px;align-self:flex-end;padding:7px 14px;transition:all .15s}.filter-reset:hover{border-color:var(--ink-light);color:var(--ink)}.task-table-wrap{overflow-x:auto}.task-table{border-collapse:collapse;width:100%}.task-table th{text-align:left;color:var(--ink-light);text-transform:uppercase;letter-spacing:.06em;border-bottom:2px solid var(--border);padding:8px 12px;font-size:.72rem;font-weight:600}.task-table td{color:var(--ink);border-bottom:1px solid var(--border);vertical-align:middle;padding:13px 12px;font-size:.875rem}.task-table tr:last-child td{border-bottom:none}.task-table tr:hover td{background:var(--off-white)}.task-name{font-weight:500;line-height:1.4}.task-link{color:var(--ink);text-decoration:none}.task-link:hover{color:var(--accent);text-decoration:underline}.status-badge{text-transform:capitalize;letter-spacing:.02em;white-space:nowrap;border-radius:20px;align-items:center;gap:5px;padding:3px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.status-badge.completed{color:#166534;background:#dcfce7}.status-badge.in_progress{background:var(--accent-dim);color:var(--accent)}.status-badge.pending{color:#92400e;background:#fef3c7}.status-badge.paid{color:#166534;background:#dcfce7}.status-badge.unpaid{color:#92400e;background:#fef3c7}.status-badge.overdue{color:#991b1b;background:#fee2e2}.invoice-client-list{flex-direction:column;gap:0;display:flex}.invoice-client-row{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 4px;display:flex}.invoice-client-row:last-child{border-bottom:none}.invoice-client-period{color:var(--ink);font-size:.9rem;font-weight:500}.invoice-client-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.invoice-client-view{background:var(--off-white);border:1px solid var(--border);font-size:.82rem;font-family:var(--font-body);color:var(--ink);white-space:nowrap;border-radius:7px;align-items:center;gap:5px;padding:5px 12px;text-decoration:none;transition:all .15s;display:inline-flex}.invoice-client-view:hover{border-color:var(--accent);color:var(--accent)}.weekly-summary-list{flex-direction:column;gap:8px;display:flex}.weekly-summary-item{background:var(--off-white);color:var(--ink);border-radius:8px;align-items:center;gap:10px;padding:10px 14px;font-size:.875rem;display:flex}.weekly-check{color:#22c55e;flex-shrink:0}.weekly-empty{color:var(--ink-light);text-align:center;padding:24px 0;font-size:.875rem}.notes-form{flex-direction:column;gap:12px;margin-bottom:28px;display:flex}.notes-textarea{border:1px solid var(--border);background:var(--off-white);width:100%;min-height:110px;color:var(--ink);font-size:.9rem;font-family:var(--font-body);resize:vertical;border-radius:10px;outline:none;padding:14px 16px;line-height:1.6;transition:border-color .15s}.notes-textarea:focus{border-color:var(--accent);background:var(--white)}.notes-submit-btn{background:var(--accent);color:var(--white);font-size:.875rem;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;align-self:flex-end;padding:9px 24px;font-weight:500;transition:background .15s}.notes-submit-btn:hover:not(:disabled){background:var(--ink-light)}.notes-submit-btn:disabled{opacity:.6;cursor:not-allowed}.notes-list{flex-direction:column;gap:12px;display:flex}.note-card{background:var(--off-white);border:1px solid var(--border);border-radius:10px;padding:16px 18px}.note-content{color:var(--ink);white-space:pre-wrap;font-size:.9rem;line-height:1.6}.note-meta{color:var(--ink-light);margin-top:8px;font-size:.72rem}.notes-success{color:#166534;background:#dcfce7;border-radius:6px;padding:8px 14px;font-size:.8rem}.notes-error{color:#991b1b;background:#fee2e2;border-radius:6px;padding:8px 14px;font-size:.8rem}.login-shell{background:var(--off-white);min-height:100vh;font-family:var(--font-body);justify-content:center;align-items:center;display:flex}.login-card{background:var(--white);border:1px solid var(--border);border-radius:16px;width:100%;max-width:420px;padding:44px 48px;box-shadow:0 8px 40px #00121914}.login-brand{text-align:center;margin-bottom:32px}.login-brand-name{font-family:var(--font-head);color:var(--ink);font-size:1.6rem;font-weight:600}.login-brand-sub{color:var(--ink-light);margin-top:4px;font-size:.8rem}.login-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:6px;display:flex}.login-label{color:var(--ink-light);font-size:.8rem;font-weight:500}.login-input{border:1px solid var(--border);background:var(--off-white);color:var(--ink);font-size:.9rem;font-family:var(--font-body);border-radius:8px;outline:none;padding:10px 14px;transition:border-color .15s}.login-input:focus{border-color:var(--accent);background:var(--white)}.login-btn{background:var(--ink);color:var(--white);font-size:.9rem;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;margin-top:4px;padding:11px;font-weight:500;transition:background .15s}.login-btn:hover:not(:disabled){background:var(--accent)}.login-btn:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#991b1b;text-align:center;background:#fee2e2;border-radius:8px;padding:10px 14px;font-size:.82rem}.empty-state{text-align:center;color:var(--ink-light);padding:40px 20px;font-size:.9rem}.loading-dots{justify-content:center;align-items:center;gap:6px;padding:24px;display:flex}.loading-dots span{background:var(--accent);border-radius:50%;width:8px;height:8px;animation:.9s ease-in-out infinite bounce}.loading-dots span:nth-child(2){animation-delay:.15s}.loading-dots span:nth-child(3){animation-delay:.3s}@keyframes bounce{0%,80%,to{opacity:.5;transform:translateY(0)}40%{opacity:1;transform:translateY(-6px)}}.cta-btn{background:var(--accent);color:var(--white);font-size:.875rem;font-family:var(--font-body);cursor:pointer;border:none;border-radius:8px;align-items:center;gap:8px;padding:9px 20px;font-weight:500;text-decoration:none;transition:background .15s;display:inline-flex}.cta-btn:hover{background:var(--ink-light)}.mobile-header,.mobile-nav{display:none}@media (max-width:768px){.dashboard-sidebar{display:none}.dashboard-shell{flex-direction:column}.mobile-header{background:var(--ink);z-index:50;flex-shrink:0;justify-content:space-between;align-items:center;padding:14px 20px;display:flex;position:sticky;top:0}.mobile-header-brand{flex-direction:column;display:flex}.mobile-header-name{font-family:var(--font-head);color:var(--white);letter-spacing:.01em;font-size:1rem;font-weight:600}.mobile-header-sub{color:var(--accent-gold);letter-spacing:.06em;text-transform:uppercase;margin-top:1px;font-size:.65rem}.mobile-signout-btn{color:#fff9;cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;padding:6px;transition:color .15s,background .15s;display:flex}.mobile-signout-btn:hover{color:#ff7070;background:#ff50501f}.mobile-nav{background:var(--ink);z-index:50;padding:8px 0 calc(8px + env(safe-area-inset-bottom));border-top:1px solid #ffffff14;justify-content:space-around;align-items:center;display:flex;position:fixed;bottom:0;left:0;right:0}.mobile-nav-item{color:#ffffff80;border-radius:8px;flex-direction:column;flex:1;align-items:center;gap:4px;padding:4px 20px;text-decoration:none;transition:color .15s;display:flex}.mobile-nav-item.active{color:var(--accent-gold)}.mobile-nav-item .nav-icon{width:20px;height:20px}.mobile-nav-label{letter-spacing:.03em;font-size:.65rem;font-weight:500}.dashboard-main{padding:20px 16px;padding-bottom:calc(72px + env(safe-area-inset-bottom) + 16px)}.dashboard-welcome{font-size:1.4rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px;margin-bottom:20px}.stat-card{padding:16px 14px}.stat-value{font-size:2rem}.dashboard-section{padding:18px 16px}.activity-item{flex-wrap:wrap}.activity-time{width:100%;margin-top:2px;padding-left:20px}.task-filters{flex-direction:column;align-items:stretch;gap:10px}.filter-group{width:100%}.filter-select,.filter-input{width:100%;min-width:unset;box-sizing:border-box}.filter-btn,.filter-reset{text-align:center;width:100%;padding:10px}.task-table-wrap{-webkit-overflow-scrolling:touch;border-radius:8px;overflow-x:auto}.task-table th,.task-table td{white-space:nowrap}.task-table .task-name{white-space:normal;min-width:160px}.notes-submit-btn{text-align:center;justify-content:center;width:100%}.login-card{margin:0 16px;padding:32px 24px}}
