@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";
:root{--bg:#080808;--bg2:#111;--surface:#181818;--surface2:#202020;--border:#2a2a2a;--border2:#333;--text:#f0f0f0;--text2:#aaa;--muted:#555;--income:#4a7c59;--expense:#7c4a4a;--radius:8px;--radius-lg:14px;--shadow:0 2px 12px #0009;--transition:.18s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg);height:100%;color:var(--text);-webkit-font-smoothing:antialiased;font-family:Inter,system-ui,sans-serif;font-size:14px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit;font-size:inherit;color:var(--text);background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);transition:border-color var(--transition);outline:none}input:focus,textarea:focus,select:focus{border-color:var(--border2)}textarea{resize:vertical}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.w-full{width:100%}.h-full{height:100%}.text-muted{color:var(--text2)}.text-sm{font-size:12px}.font-medium{font-weight:500}.font-semibold{font-weight:600}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}.btn{border-radius:var(--radius);transition:background var(--transition), opacity var(--transition), transform var(--transition);border:1px solid #0000;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;display:inline-flex}.btn:active{transform:scale(.97)}.btn-primary{background:var(--text);color:var(--bg);border-color:var(--text)}.btn-primary:hover{opacity:.88}.btn-ghost{color:var(--text2);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.btn-danger{color:#c0504a;background:0 0;border-color:#7c4a4a}.btn-danger:hover{background:#3a1a1a}.btn-sm{padding:5px 10px;font-size:12px}.btn-icon{border:1px solid var(--border);border-radius:var(--radius);width:30px;height:30px;color:var(--text2);transition:background var(--transition), color var(--transition);background:0 0;justify-content:center;align-items:center;padding:6px;display:inline-flex}.btn-icon:hover{background:var(--surface2);color:var(--text)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.card-sm{padding:12px}.input{border-radius:var(--radius);background:var(--surface2);border:1px solid var(--border);width:100%;color:var(--text);transition:border-color var(--transition), box-shadow var(--transition);padding:9px 12px;font-size:14px}.input:focus{border-color:var(--border2);box-shadow:0 0 0 3px #ffffff0a}.input::placeholder{color:var(--muted)}.form-group{flex-direction:column;gap:6px;display:flex}.form-label{color:var(--text2);letter-spacing:.02em;font-size:12px;font-weight:500}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;background:#000000bf;justify-content:center;align-items:center;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(480px,95vw);max-height:85vh;box-shadow:var(--shadow);padding:24px;animation:.2s slideUp;overflow-y:auto}.modal-title{margin-bottom:20px;font-size:16px;font-weight:600}.modal-footer{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.dashboard-layout{height:100vh;display:flex;overflow:hidden}.sidebar{background:var(--bg2);border-right:1px solid var(--border);flex-direction:column;gap:4px;width:220px;min-width:220px;padding:20px 12px;display:flex}.sidebar-logo{color:var(--text);letter-spacing:-.02em;border-bottom:1px solid var(--border);margin-bottom:8px;padding:4px 10px 16px;font-size:15px;font-weight:700}.sidebar-link{border-radius:var(--radius);color:var(--text2);transition:background var(--transition), color var(--transition);cursor:pointer;text-align:left;background:0 0;border:1px solid #0000;align-items:center;gap:10px;width:100%;padding:9px 12px;font-size:13.5px;font-weight:500;display:flex}.sidebar-link:hover{background:var(--surface);color:var(--text)}.sidebar-link.active{background:var(--surface2);color:var(--text);border-color:var(--border)}.sidebar-link svg{flex-shrink:0}.sidebar-bottom{border-top:1px solid var(--border);margin-top:auto;padding-top:12px}.main-content{flex-direction:column;flex:1;padding:32px;display:flex;overflow:auto}.page-header{justify-content:space-between;align-items:center;margin-bottom:28px;display:flex}.page-title{letter-spacing:-.02em;font-size:22px;font-weight:700}.home-grid{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.home-card:hover{border-color:var(--border2)!important;background:var(--surface2)!important}.login-page{background-color:var(--bg);background-image:radial-gradient(var(--border) 1px, transparent 1px);background-position:50%;background-size:32px 32px;justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-box{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-lg);width:min(380px,92vw);box-shadow:var(--shadow);z-index:10;opacity:0;padding:48px 40px;animation:.6s cubic-bezier(.16,1,.3,1) forwards slideUpFade;position:relative}@keyframes slideUpFade{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.login-header{text-align:center;flex-direction:column;align-items:center;margin-bottom:40px;display:flex}.login-brand{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);width:56px;height:56px;color:var(--text);justify-content:center;align-items:center;margin-bottom:24px;display:flex;box-shadow:inset 0 1px #ffffff05}.login-title{letter-spacing:-.02em;color:var(--text);margin-bottom:4px;font-size:18px;font-weight:500}.login-subtitle{color:var(--text2);font-size:13px;font-weight:400}.login-form{flex-direction:column;gap:24px;display:flex}.login-input-group{flex-direction:column;gap:6px;display:flex}.login-label{color:var(--text2);letter-spacing:.05em;text-transform:uppercase;font-size:11px;font-weight:500}.login-input{border:none;border-bottom:1px solid var(--border);width:100%;color:var(--text);transition:border-color var(--transition);background:0 0;border-radius:0;outline:none;padding:8px 0;font-size:15px}.login-input::placeholder{color:var(--muted)}.login-input:focus{border-bottom-color:var(--text)}.login-btn{background:var(--text);width:100%;color:var(--bg);border-radius:var(--radius);cursor:pointer;transition:opacity var(--transition), transform var(--transition);border:none;justify-content:center;align-items:center;gap:8px;margin-top:8px;padding:12px 16px;font-size:14px;font-weight:500;display:flex}.login-btn:hover:not(:disabled){opacity:.88;transform:translateY(-1px)}.login-btn:active:not(:disabled){transform:translateY(0)}.login-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.login-spinner{border-color:#0003;border-top-color:var(--bg);width:16px;height:16px}.login-error-toast{border-radius:var(--radius);color:#e07070;text-align:center;background:0 0;border:1px solid #7c4a4a;justify-content:center;align-items:center;padding:10px 14px;font-size:13px;animation:.3s forwards slideDown;display:flex}@keyframes slideDown{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.kanban-board{flex:1;align-items:flex-start;gap:16px;padding-bottom:16px;display:flex;overflow-x:auto}.kanban-list{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;min-width:280px;max-width:280px;max-height:calc(100vh - 160px);display:flex}.kanban-list-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:14px 16px 10px;font-size:13px;font-weight:600;display:flex}.kanban-cards{flex-direction:column;flex:1;gap:8px;padding:10px;display:flex;overflow-y:auto}.kanban-card{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);cursor:grab;transition:border-color var(--transition), box-shadow var(--transition), transform var(--transition);padding:12px;position:relative}.kanban-card:hover{border-color:var(--border2);box-shadow:0 2px 8px #0006}.kanban-card:active{cursor:grabbing;transform:scale(.99)}.kanban-card.drag-over{border-color:var(--text2)}.kanban-card-title{margin-bottom:4px;font-size:13px;font-weight:500}.kanban-card-due{color:var(--muted);align-items:center;gap:4px;margin-top:6px;font-size:11px;display:flex}.kanban-add-list{background:var(--surface);border:1px dashed var(--border);border-radius:var(--radius-lg);min-width:260px;color:var(--text2);cursor:pointer;transition:background var(--transition), color var(--transition), border-color var(--transition);align-self:flex-start;align-items:center;gap:8px;padding:14px 16px;font-size:13px;font-weight:500;display:flex}.kanban-add-list:hover{background:var(--surface2);color:var(--text);border-color:var(--border2)}.kanban-add-card{color:var(--text2);cursor:pointer;border-radius:var(--radius);transition:background var(--transition), color var(--transition);background:0 0;border:none;align-items:center;gap:6px;margin:4px;padding:8px 12px;font-size:12px;display:flex}.kanban-add-card:hover{background:var(--surface);color:var(--text)}.kanban-list--dragging{opacity:.45;border-style:dashed;border-color:var(--border2)}.kanban-list--drag-over{border-color:var(--text2);box-shadow:0 0 0 2px #ffffff0f}.kanban-list-drag-handle{width:22px;height:22px;color:var(--muted);cursor:grab;transition:color var(--transition), background var(--transition);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;margin-right:4px;display:flex}.kanban-list-drag-handle:active{cursor:grabbing}.kanban-list-drag-handle:hover{color:var(--text2);background:var(--surface2)}.kanban-list-name{white-space:nowrap;text-overflow:ellipsis;cursor:default;-webkit-user-select:none;user-select:none;flex:1;overflow:hidden}.kanban-list-name:hover{color:var(--text)}.kanban-list-rename-input{background:var(--bg2);border:1px solid var(--border2);min-width:0;color:var(--text);border-radius:4px;outline:none;flex:1;padding:2px 6px;font-size:13px;font-weight:600;box-shadow:0 0 0 2px #ffffff0f}.notes-layout{flex:1;gap:20px;display:flex;overflow:hidden}.notes-list{flex-direction:column;gap:4px;width:240px;min-width:240px;display:flex;overflow-y:auto}.notes-search-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);transition:border-color var(--transition);flex-shrink:0;align-items:center;margin-bottom:6px;display:flex;position:relative}.notes-search-wrap:focus-within{border-color:var(--border2)}.notes-search-icon{color:var(--muted);pointer-events:none;flex-shrink:0;position:absolute;left:10px}.notes-search-input{border-radius:var(--radius);width:100%;color:var(--text);background:0 0;border:none;outline:none;padding:8px 32px 8px 30px;font-size:13px}.notes-search-input::placeholder{color:var(--muted)}.notes-search-clear{background:var(--surface2);width:18px;height:18px;color:var(--text2);cursor:pointer;transition:background var(--transition), color var(--transition);border:none;border-radius:50%;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:8px}.notes-search-clear:hover{background:var(--border2);color:var(--text)}.note-item{border-radius:var(--radius);cursor:pointer;transition:background var(--transition), border-color var(--transition);border:1px solid #0000;padding:12px}.note-item:hover{background:var(--surface2)}.note-item.active{background:var(--surface2);border-color:var(--border)}.note-item-title{margin-bottom:2px;font-size:13px;font-weight:500}.note-item-date{color:var(--muted);font-size:11px}.note-editor{flex-direction:column;flex:1;gap:12px;display:flex;overflow:hidden}.note-title-input{color:var(--text);background:0 0;border:none;border-radius:0;padding:0;font-size:20px;font-weight:700}.note-title-input:focus{box-shadow:none;border:none}.note-title-input::placeholder{color:var(--muted)}.note-content-input{color:var(--text);resize:none;background:0 0;border:none;border-radius:0;flex:1;padding:0;font-family:Inter,monospace;font-size:14px;line-height:1.7}.note-content-input:focus{box-shadow:none;border:none}.note-tag{background:var(--surface2);border:1px solid var(--border);color:var(--text2);cursor:pointer;transition:background var(--transition), border-color var(--transition);white-space:nowrap;border-radius:999px;align-items:center;padding:2px 8px;font-size:11px;font-weight:500;display:inline-flex}.note-tag:hover{background:var(--border)}.note-tag.active{background:var(--text);color:var(--bg);border-color:var(--text)}.note-preview{color:var(--text);font-size:14px;line-height:1.8}.note-preview h1,.note-preview h2,.note-preview h3,.note-preview h4,.note-preview h5,.note-preview h6{color:var(--text);margin:1.2em 0 .5em;font-weight:700;line-height:1.3}.note-preview h1{border-bottom:1px solid var(--border);padding-bottom:.3em;font-size:1.8em}.note-preview h2{border-bottom:1px solid var(--border);padding-bottom:.2em;font-size:1.5em}.note-preview h3{font-size:1.25em}.note-preview h4{font-size:1.1em}.note-preview p{margin:.6em 0}.note-preview a{color:var(--text);text-decoration:underline;-webkit-text-decoration-color:var(--muted);text-decoration-color:var(--muted)}.note-preview a:hover{-webkit-text-decoration-color:var(--text);text-decoration-color:var(--text)}.note-preview code{background:var(--surface2);border-radius:4px;padding:2px 6px;font-family:Fira Code,Cascadia Code,monospace;font-size:.9em}.note-preview pre{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius);margin:1em 0;padding:16px;overflow-x:auto}.note-preview pre code{background:0 0;padding:0}.note-preview blockquote{border-left:3px solid var(--border);color:var(--muted);margin:1em 0;padding-left:16px}.note-preview ul,.note-preview ol{padding-left:24px}.note-preview li{margin:.3em 0}.note-preview hr{border:none;border-top:1px solid var(--border);margin:1.5em 0}.note-preview table{border-collapse:collapse;width:100%;margin:1em 0}.note-preview th,.note-preview td{border:1px solid var(--border);text-align:left;padding:8px 12px}.note-preview th{background:var(--surface2);font-weight:600}.note-preview input[type=checkbox]{accent-color:var(--text);margin-right:8px}.note-preview img{border-radius:var(--radius);max-width:100%}.note-footer-stats{color:var(--muted);border-top:1px solid var(--border);flex-shrink:0;align-items:center;gap:16px;padding:8px 16px;font-size:11px;display:flex}.note-footer-stats span{align-items:center;gap:4px;display:inline-flex}.finance-summary{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:28px;display:grid}.finance-stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:20px}.finance-stat-label{color:var(--text2);text-transform:uppercase;letter-spacing:.05em;margin-bottom:8px;font-size:11px;font-weight:500}.finance-stat-value{letter-spacing:-.03em;font-size:26px;font-weight:700}.finance-stat-value.income{color:#6bab7c}.finance-stat-value.expense{color:#c07070}.finance-stat-value.balance{color:var(--text)}.finance-table-wrap{overflow-x:auto}.finance-table{border-collapse:collapse;width:100%}.finance-table th{text-align:left;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border);padding:10px 12px;font-size:11px;font-weight:500}.finance-table td{border-bottom:1px solid var(--border);padding:12px;font-size:13px}.finance-table tr:last-child td{border-bottom:none}.finance-table tr:hover td{background:var(--surface2)}.badge-income{color:#6bab7c;background:#6bab7c1f;border-radius:100px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.badge-expense{color:#c07070;background:#c070701f;border-radius:100px;align-items:center;padding:2px 8px;font-size:11px;font-weight:600;display:inline-flex}.calendar-wrapper{flex-direction:column;flex:1;display:flex;overflow:hidden}.calendar-grid-header{background:var(--border);border:1px solid var(--border);border-radius:var(--radius-lg) var(--radius-lg) 0 0;grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.calendar-day-name{background:var(--surface);text-align:center;color:var(--text2);text-transform:uppercase;letter-spacing:.05em;padding:10px;font-size:11px;font-weight:600}.calendar-grid{background:var(--border);border:1px solid var(--border);border-radius:0 0 var(--radius-lg) var(--radius-lg);border-top:none;grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.calendar-cell{background:var(--surface);cursor:pointer;min-height:0;transition:background var(--transition);flex-direction:column;gap:4px;padding:8px;display:flex;overflow:hidden}.calendar-cell:hover{background:var(--surface2)}.calendar-cell.other-month{opacity:.35}.calendar-cell.today .cal-day-num{background:var(--text);color:var(--bg);border-radius:50%;justify-content:center;align-items:center;width:26px;height:26px;display:flex}.cal-day-num{justify-content:center;align-items:center;width:26px;height:26px;font-size:13px;font-weight:600;display:flex}.cal-event{background:var(--surface2);border-left:2px solid var(--border2);white-space:nowrap;text-overflow:ellipsis;color:var(--text2);cursor:pointer;border-radius:4px;flex-shrink:0;padding:2px 6px;font-size:11px;transition:opacity .15s;overflow:hidden}.cal-event:hover{opacity:.85}.cal-event-multi{background:var(--border);border-left:none;border-top:2px solid var(--border2);border-radius:3px;font-style:italic}.calendar-cell.drag-over{background:var(--border);outline:2px dashed var(--text2);outline-offset:-2px}.calendar-nav{align-items:center;gap:16px;margin-bottom:16px;display:flex}.calendar-month{font-size:18px;font-weight:700}.mail-layout{border:1px solid var(--border);border-radius:var(--radius-lg);flex:1;gap:0;display:flex;overflow:hidden}.mail-list-pane{border-right:1px solid var(--border);flex-direction:column;width:320px;min-width:320px;display:flex;overflow-y:auto}.mail-list-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:16px;font-size:14px;font-weight:600;display:flex}.mail-item{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--transition);padding:14px 16px}.mail-item:hover{background:var(--surface2)}.mail-item.active{background:var(--surface2);border-left:2px solid var(--text)}.mail-item.unread .mail-item-subject{font-weight:600}.mail-item-from{color:var(--text2);margin-bottom:2px;font-size:12px}.mail-item-subject{margin-bottom:2px;font-size:13px}.mail-item-date{color:var(--muted);font-size:11px}.mail-detail-pane{flex-direction:column;flex:1;gap:16px;padding:24px;display:flex;overflow-y:auto}.mail-detail-subject{font-size:18px;font-weight:700}.mail-meta{flex-direction:column;gap:4px;display:flex}.mail-meta-row{color:var(--text2);font-size:12px}.mail-meta-row span{color:var(--text)}.mail-divider{border:none;border-top:1px solid var(--border)}.mail-body{font-size:14px;line-height:1.7}.mail-body iframe{background:var(--surface2);border-radius:var(--radius);border:none;width:100%;min-height:300px}.mail-empty{color:var(--muted);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:8px;display:flex}.mail-empty-icon{opacity:.3;font-size:40px}.compose-modal{width:min(600px,95vw)}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border2);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--muted)}.spinner{border:2px solid var(--border);border-top-color:var(--text2);border-radius:50%;width:20px;height:20px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}.loading-state{color:var(--text2);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.empty-state{color:var(--text2);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:12px;padding:60px 20px;display:flex}.empty-state-icon{opacity:.3;font-size:36px}.empty-state-text{font-size:14px}.ds-header-title{background:linear-gradient(135deg,#fff 0%,#a5b4fc 100%);-webkit-text-fill-color:transparent;text-shadow:0 4px 12px #6366f133;-webkit-background-clip:text;background-clip:text}.ds-icon-wrapper{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#6366f114;border:1px solid #6366f126;border-radius:14px;justify-content:center;align-items:center;width:50px;height:50px;display:flex;position:relative;box-shadow:0 8px 30px #6366f11f,inset 0 0 20px #6366f10a}.ds-card{border-radius:var(--radius-lg);background:linear-gradient(145deg, var(--surface) 0%, #141414cc 100%);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid #ffffff0d;flex-direction:column;gap:12px;padding:24px;text-decoration:none;transition:all .3s cubic-bezier(.25,.8,.25,1);display:flex;position:relative;overflow:hidden;box-shadow:0 4px 20px #0000004d}.ds-card:after{content:"";border-radius:inherit;pointer-events:none;position:absolute;inset:0;box-shadow:inset 0 1px 1px #ffffff0a}.ds-card:hover{border-color:#6366f159;transform:translateY(-5px);box-shadow:0 12px 40px #00000080,0 0 24px #6366f11f}.ds-card-arrow{transition:transform .3s cubic-bezier(.25,.8,.25,1),color .3s}.ds-card:hover .ds-card-arrow{transform:translate(4px);color:#a5b4fc!important}.ds-badge{color:var(--text2);letter-spacing:.01em;background:#ffffff0a;border:1px solid #ffffff0d;border-radius:100px;align-items:center;gap:6px;padding:5px 10px;font-size:12px;font-weight:500;transition:all .3s;display:inline-flex}.ds-card:hover .ds-badge{color:#c7d2fe;background:#6366f10f;border-color:#6366f126}.ds-empty-box{text-align:center;border-radius:var(--radius-lg);background:radial-gradient(circle at center, #6366f108 0%, transparent 70%), var(--bg);border:2px dashed #ffffff0f;padding:64px 24px;transition:border-color .3s,background .3s}.ds-empty-box:hover{background:radial-gradient(circle at center, #6366f114 0%, transparent 80%), var(--bg);border-color:#6366f140}.ds-table-wrap{border-radius:var(--radius-lg);background:var(--surface);border:1px solid #ffffff0f;box-shadow:0 8px 32px #0006}.ds-table-header th{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);color:#a0a0a0;text-transform:uppercase;letter-spacing:.06em;z-index:10;background:#141414e0;border-bottom:1px solid #ffffff0f;padding:14px 16px;font-size:11.5px;font-weight:600;position:sticky;top:0}.ds-table-cell{vertical-align:middle;padding:8px 16px;font-size:13px}.ds-input-seamless{width:100%;color:var(--text);background:0 0;border:1px solid #0000;border-radius:6px;padding:8px 12px;font-size:13px;transition:all .2s}.ds-input-seamless:hover{background:#ffffff05;border-color:#ffffff0f}.ds-input-seamless:focus{background:var(--surface2);border-color:#6366f166;outline:none;box-shadow:0 0 0 3px #6366f11a}.ds-header-title{color:var(--text);font-weight:700}.ds-icon-wrapper{border-radius:var(--radius);background:var(--surface2);border:1px solid var(--border);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.ds-card{border-radius:var(--radius-lg);background:var(--surface);border:1px solid var(--border);flex-direction:column;gap:10px;padding:18px 20px;text-decoration:none;transition:border-color .15s,background .15s;display:flex;position:relative}.ds-card:hover{border-color:var(--border2);background:var(--surface2)}.ds-card-arrow{color:var(--muted);transition:color .15s}.ds-card:hover .ds-card-arrow{color:var(--text2)}.ds-badge{background:var(--surface2);border:1px solid var(--border);color:var(--text2);border-radius:5px;align-items:center;gap:5px;padding:3px 8px;font-size:12px;font-weight:500;display:inline-flex}.ds-empty-box{text-align:center;border:1px dashed var(--border);border-radius:var(--radius-lg);background:var(--bg);padding:56px 24px}.ds-table-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);overflow:hidden}.ds-table-header th{background:var(--surface2);border-bottom:1px solid var(--border);color:var(--text2);text-transform:uppercase;letter-spacing:.05em;z-index:10;white-space:nowrap;padding:11px 14px;font-size:11px;font-weight:600;position:sticky;top:0}.ds-table-row{border-bottom:1px solid var(--border);transition:background .12s}.ds-table-row:hover{background:var(--surface2)}.ds-table-row:last-child{border-bottom:none}.ds-table-cell{vertical-align:middle;color:var(--text);padding:6px 14px;font-size:13px}.ds-input-seamless{width:100%;color:var(--text);background:0 0;border:1px solid #0000;border-radius:5px;padding:6px 8px;font-family:inherit;font-size:13px;transition:border-color .15s,background .15s}.ds-input-seamless:hover{border-color:var(--border)}.ds-input-seamless:focus{background:var(--surface2);border-color:var(--border2);box-shadow:none;outline:none}.ds-input-seamless:disabled{opacity:.5;cursor:not-allowed}.mobile-topbar,.sidebar-overlay,.sidebar-close-btn{display:none}@media (max-width:768px){.dashboard-layout{flex-direction:column}.mobile-topbar{background:var(--bg2);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;height:60px;padding:0 16px;display:flex}.mobile-menu-btn{color:var(--text);background:0 0;border:none}.sidebar{z-index:100;background:var(--bg2);width:260px;height:100vh;transition:transform .3s;position:fixed;top:0;left:0;transform:translate(-100%);border-right:1px solid var(--border)!important;border-top:none!important;flex-direction:column!important;justify-content:flex-start!important;padding:20px 12px!important}.sidebar.open{transform:translate(0)}.sidebar-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:90;background:#0009;animation:.15s fadeIn;display:block;position:fixed;inset:0}.sidebar-logo,.sidebar-link-label{display:block!important}.sidebar-link{flex-direction:row!important;justify-content:flex-start!important;gap:10px!important;width:100%!important;padding:9px 12px!important;font-size:13.5px!important}.sidebar-link.active{background:var(--surface2)!important;border-color:var(--border)!important;color:var(--text)!important}.sidebar-bottom{border-top:1px solid var(--border);margin-top:auto;padding-top:12px;display:flex}.sidebar-close-btn{color:var(--text2);cursor:pointer;background:0 0;border:none;padding:4px;display:flex;position:absolute;top:16px;right:16px}.main-content{order:1;height:calc(100vh - 60px);padding:16px;overflow-y:auto}.page-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:20px}.page-title{font-size:20px}.home-grid{grid-template-columns:1fr}.finance-summary{grid-template-columns:1fr;gap:12px}.notes-layout{flex-direction:column}.notes-list{border-bottom:1px solid var(--border);width:100%;min-width:100%;max-height:180px;padding-bottom:12px}.mail-layout{border:none;flex-direction:column}.mail-list-pane{border-right:none;border-bottom:1px solid var(--border);width:100%;min-width:100%;max-height:40vh}.kanban-list{min-width:260px;max-height:calc(100vh - 220px)}.calendar-wrapper{overflow-x:auto}.calendar-grid-header,.calendar-grid{min-width:700px}.calendar-nav>div:last-child button span{display:none}.calendar-nav>div:last-child button{padding:5px 10px}.modal{width:95vw;padding:20px}.login-box{padding:24px 20px}}@keyframes toastIn{0%{opacity:0;transform:translate(110%)}to{opacity:1;transform:translate(0)}}.msg-toast-container{z-index:9999;pointer-events:none;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.msg-toast{pointer-events:auto;background:var(--surface);border:1px solid var(--border2);border-radius:var(--radius-lg);cursor:pointer;min-width:300px;max-width:360px;transition:background var(--transition), transform var(--transition);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);align-items:flex-start;gap:12px;padding:14px 14px 14px 16px;animation:.3s cubic-bezier(.34,1.56,.64,1) both toastIn;display:flex;box-shadow:0 8px 32px #0009,0 0 0 1px #ffffff0a}.msg-toast:hover{background:var(--surface2);transform:translate(-3px)}.msg-toast-icon{background:var(--text);width:32px;height:32px;color:var(--bg);border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;margin-top:1px;display:flex}.msg-toast-body{flex:1;min-width:0}.msg-toast-title{white-space:nowrap;text-overflow:ellipsis;margin-bottom:3px;font-size:13px;font-weight:600;overflow:hidden}.msg-toast-sender{color:var(--text)}.msg-toast-channel{color:var(--muted);font-weight:400}.msg-toast-preview{color:var(--text2);-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;font-size:12px;line-height:1.4;display:-webkit-box;overflow:hidden}.msg-toast-close{color:var(--muted);cursor:pointer;transition:color var(--transition);background:0 0;border:none;border-radius:4px;flex-shrink:0;margin-top:1px;padding:2px;line-height:1}.msg-toast-close:hover{color:var(--text)}@keyframes banner-slide-in{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.active-call-banner{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;gap:16px;padding:12px 20px;animation:.2s ease-out both banner-slide-in;display:flex}.active-call-banner-info{flex:1;align-items:center;gap:14px;min-width:0;display:flex}@keyframes waveform{0%,to{opacity:.5;transform:scaleY(.4)}50%{opacity:1;transform:scaleY(1)}}.active-call-waveform{align-items:center;gap:3px;height:18px;padding:0 4px;display:flex}.active-call-waveform .bar{transform-origin:bottom;background:#22c55e;border-radius:3px;width:3px;animation:.9s ease-in-out infinite waveform}.active-call-waveform .bar:first-child{height:8px;animation-delay:0s}.active-call-waveform .bar:nth-child(2){height:14px;animation-delay:.2s}.active-call-waveform .bar:nth-child(3){height:10px;animation-delay:.4s}.active-call-waveform .bar:nth-child(4){height:12px;animation-delay:.1s}.active-call-banner-title{color:var(--text);margin-bottom:6px;font-size:13px;font-weight:500}.active-call-banner-participants{flex-wrap:wrap;gap:8px;display:flex}.active-call-participant-chip{background:var(--surface2);border:1px solid var(--border);color:var(--text);border-radius:6px;align-items:center;gap:6px;padding:4px 10px 4px 4px;font-size:12px;font-weight:500;display:inline-flex}.active-call-chip-avatar{background:var(--surface);width:20px;height:20px;color:var(--text1);border-radius:4px;flex-shrink:0;justify-content:center;align-items:center;font-size:10px;font-weight:600;display:flex}.active-call-banner-actions{flex-shrink:0;gap:8px;display:flex}.active-call-join-btn{color:#000;cursor:pointer;white-space:nowrap;background:#fff;border:1px solid #fff;border-radius:6px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:600;transition:all .2s;display:inline-flex}.active-call-join-btn:hover{background:#e5e5e5;border-color:#e5e5e5}.active-call-join-btn.video{color:var(--text);border:1px solid var(--border);background:0 0}.active-call-join-btn.video:hover{background:var(--surface2)}.call-overlay-global{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:9999;background:#000000a6;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.call-modal{background:var(--surface);border:1px solid var(--border);border-radius:20px;flex-direction:column;align-items:center;gap:12px;min-width:280px;padding:40px 48px;display:flex;box-shadow:0 20px 60px #0000004d}.call-modal-avatar{background:var(--text);width:72px;height:72px;color:var(--bg);border-radius:50%;justify-content:center;align-items:center;margin-bottom:4px;font-size:28px;font-weight:600;display:flex}.call-modal-avatar.ringing{animation:1.2s infinite ring-pulse}.call-modal-name{color:var(--text);font-size:18px;font-weight:600}.call-modal-status{color:var(--muted);margin-bottom:8px;font-size:13px}.call-modal-actions{gap:24px;margin-top:8px;display:flex}.call-action-btn{cursor:pointer;border:none;border-radius:50%;justify-content:center;align-items:center;width:56px;height:56px;padding:0;transition:transform .15s,opacity .15s;display:flex}.call-action-btn:hover{transform:scale(1.08)}.call-action-btn.accept{color:#fff;background:#22c55e}.call-action-btn.accept:hover{background:#16a34a}.call-action-btn.reject,.call-action-btn.hangup{color:#fff;background:#e05252}.call-action-btn.reject:hover,.call-action-btn.hangup:hover{background:#c13f3f}.call-widget-global{-webkit-backdrop-filter:blur(36px);z-index:9998;background:#0a0a0aa6;border:1px solid #ffffff14;border-radius:24px;flex-direction:column;transition:all .4s cubic-bezier(.25,1,.5,1);display:flex;position:fixed;bottom:24px;right:24px;overflow:hidden;box-shadow:0 16px 40px #00000080,inset 0 1px #ffffff26}.call-widget-global.audio-mode{width:310px}.call-widget-global.video-mode{width:350px}.call-widget-global.fullscreen{background:#050505d9;width:100vw!important;max-width:none!important;height:100vh!important;max-height:none!important;box-shadow:none!important;z-index:9999!important;border:none!important;border-radius:0!important;padding:0!important;inset:0!important}.call-widget-header{background:#ffffff08;border-bottom:1px solid #ffffff0f;justify-content:space-between;align-items:center;padding:12px 20px;display:flex}.call-widget-global.fullscreen .call-widget-header{z-index:10;background:0 0;border-bottom:none;padding:0;position:absolute;top:16px;left:24px;right:24px}.call-widget-content{flex-direction:column;flex:1;display:flex;position:relative;overflow:hidden}.call-timer{font-variant-numeric:tabular-nums;opacity:.9;color:#22c55e;font-size:13px;font-weight:600}.call-widget-audio-wrap{flex:1;justify-content:center;align-items:center;padding:32px 0;display:flex}.call-audio-grid{justify-items:center;gap:16px;max-height:280px;padding:24px;display:grid;overflow-y:auto}.call-widget-global.fullscreen .call-audio-grid{align-content:center;height:100%;max-height:none}.call-grid-item{flex-direction:column;align-items:center;gap:8px;display:flex}.call-grid-name{color:var(--text);white-space:nowrap;text-overflow:ellipsis;text-align:center;max-width:120px;font-size:13px;font-weight:500;overflow:hidden}.call-audio-avatar{background:linear-gradient(135deg, var(--surface2) 0%, #ffffff0d 100%);width:64px;height:64px;color:var(--text);z-index:2;border:1px solid #ffffff26;border-radius:50%;justify-content:center;align-items:center;font-size:24px;font-weight:600;display:flex;position:relative;box-shadow:0 8px 24px #0000004d}.call-widget-global.fullscreen .call-audio-avatar{border:2px solid #ffffff1a;width:120px;height:120px;font-size:40px}.call-mesh-grid.focus-strip{background:#0006;border-top:1px solid #ffffff0d;flex-direction:row;justify-content:center;gap:8px;max-height:120px;padding:12px 12px 90px;overflow:auto hidden;min-height:auto!important;display:flex!important}.call-widget-global:not(.fullscreen) .call-mesh-grid.focus-strip{padding-bottom:12px}.focus-strip .mesh-tile{border:1px solid #0000;flex-shrink:0;width:140px;min-width:140px;height:90px;transition:all .2s cubic-bezier(.2,.8,.2,1);min-height:auto!important}.mesh-tile{transition:transform .2s,box-shadow .2s}.mesh-tile:hover{transform:scale(.98);box-shadow:0 0 0 2px #ffffff1a}.focus-strip .mesh-tile:hover{border-color:#ffffff4d;transform:translateY(-4px)scale(1.02);box-shadow:0 8px 24px #00000080}.focus-strip .call-audio-avatar{width:48px;height:48px;font-size:18px}.focus-strip .call-widget-video{border-radius:8px;object-fit:cover!important}@keyframes speak-pulse{0%{opacity:.6;transform:scale(1)}50%{opacity:0;transform:scale(1.3)}to{opacity:0;transform:scale(1)}}.speaking-ring{opacity:0;z-index:1;border:2px solid #22c55e;border-radius:50%;position:absolute;inset:-4px}.pulse-active .speaking-ring{animation:2s cubic-bezier(.2,.8,.2,1) infinite speak-pulse}.call-widget-video-wrap{aspect-ratio:4/3;background:#000;width:100%;display:flex;position:relative}.call-widget-global.fullscreen .call-widget-video-wrap{aspect-ratio:auto;flex:1;height:100%}.call-widget-video{object-fit:cover;width:100%;height:100%}.call-widget-global.fullscreen .call-widget-video{object-fit:contain}.call-widget-local-video{object-fit:cover;z-index:5;border:2px solid #fff6;border-radius:8px;width:80px;height:60px;transition:all .3s;position:absolute;bottom:12px;right:12px;box-shadow:0 4px 16px #0006}.call-widget-global.fullscreen .call-widget-local-video{border-radius:12px;width:200px;height:150px;bottom:100px;right:32px}.call-widget-controls{z-index:10;background:#0000004d;border-top:1px solid #ffffff0d;flex-wrap:wrap;justify-content:center;align-items:center;gap:12px;padding:16px 12px;display:flex}.call-widget-global.fullscreen .call-widget-controls{-webkit-backdrop-filter:blur(28px);background:#14141499;border:1px solid #ffffff1a;border-radius:99px;gap:20px;padding:12px 24px;position:absolute;bottom:32px;left:50%;transform:translate(-50%);box-shadow:0 12px 40px #0009}.call-ctrl-btn{width:44px;height:44px;color:var(--text);cursor:pointer;background:#ffffff0d;border:1px solid #ffffff14;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;padding:0;transition:all .25s cubic-bezier(.2,.8,.2,1);display:flex;box-shadow:inset 0 1px #ffffff0d}.call-ctrl-btn:hover{background:#ffffff2e;border-color:#fff3;transform:translateY(-2px)scale(1.05)}.call-ctrl-btn:active{transform:translateY(1px)scale(.97)}.call-ctrl-btn.active{background:var(--text);color:var(--bg)}.call-ctrl-btn.hangup{color:#fff;background:#ef4444d9;border-color:#ef4444f2}.call-ctrl-btn.hangup:hover{background:#dc2626}.fintech-layout{border-top:1px solid var(--border);height:calc(100vh - 160px);margin-top:24px;display:flex}.fintech-sidebar{border-right:1px solid var(--border);flex-direction:column;width:320px;min-width:320px;display:flex;overflow-y:auto}.fintech-list-item{border-bottom:1px solid var(--border);cursor:pointer;background:0 0;justify-content:space-between;align-items:center;padding:18px 20px;transition:background .15s;display:flex}.fintech-list-item:hover{background:var(--surface)}.fintech-list-item.active{background:var(--surface2);border-left:2px solid var(--text);padding-left:18px}.fintech-detail{flex-direction:column;flex:1;padding:0 60px 80px;display:flex;overflow-y:auto}.fintech-huge-balance{letter-spacing:-.05em;color:var(--text);margin:16px 0 24px;font-family:Inter,system-ui;font-size:72px;font-weight:300;line-height:1}.fintech-action-btn{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:100px;align-items:center;gap:8px;padding:10px 20px;font-size:13px;font-weight:500;transition:all .2s;display:inline-flex}.fintech-action-btn:hover{background:var(--text);color:var(--bg)}.fintech-tx-row{border-bottom:1px solid var(--border);background:0 0;justify-content:space-between;align-items:center;padding:24px 0;display:flex}.fintech-tx-row:last-child{border-bottom:none}.fintech-tx-row:hover{background:#ffffff03}.finance-charts-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:24px;display:grid}@media (max-width:900px){.finance-charts-grid{grid-template-columns:1fr}}.chart-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px}.chart-card h3{color:var(--text);margin-bottom:12px;font-size:14px;font-weight:600}.tag-badge{background:var(--surface);border:1px solid var(--border);color:var(--text2);white-space:nowrap;border-radius:99px;margin-right:4px;padding:2px 8px;font-size:11px;display:inline-block}.tag-badge.clickable{cursor:pointer;transition:background .15s}.tag-badge.clickable:hover{background:#ffffff14}.budgets-section{margin-bottom:20px}.budgets-section h3{color:var(--text);align-items:center;gap:8px;margin-bottom:12px;font-size:14px;font-weight:600;display:flex}.budget-bar{margin-bottom:12px}.budget-bar-header{justify-content:space-between;margin-bottom:4px;font-size:13px;display:flex}.budget-bar-category{color:var(--text);font-weight:500}.budget-bar-amount{color:var(--text2)}.budget-bar-track{background:var(--surface);border:1px solid var(--border);border-radius:4px;height:8px;overflow:hidden}.budget-bar-fill{background:var(--income);border-radius:4px;height:100%;transition:width .3s}.budget-bar-fill.warning{background:#c09050}.budget-bar-fill.danger{background:#c07070}.finance-filter-bar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:12px 16px;display:flex}.finance-filter-bar .input{width:auto;min-width:140px}.finance-filter-bar .input-sm{min-width:110px}.search-input-wrap{flex:1;min-width:180px;position:relative}.search-input-wrap input{width:100%;padding-left:32px}.search-input-wrap .search-icon{color:var(--text2);pointer-events:none;position:absolute;top:50%;left:10px;transform:translateY(-50%)}.finance-pagination{justify-content:center;align-items:center;gap:4px;padding:16px;display:flex}.finance-pagination button{border:1px solid var(--border);min-width:32px;height:32px;color:var(--text2);cursor:pointer;background:0 0;border-radius:6px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex}.finance-pagination button:hover:not(:disabled){background:var(--surface);color:var(--text)}.finance-pagination button.active{background:var(--text);color:var(--bg);border-color:var(--text)}.finance-pagination button:disabled{opacity:.3;cursor:default}.finance-pagination .page-info{color:var(--text2);margin:0 8px;font-size:12px}.category-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;display:grid}.category-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);cursor:pointer;align-items:center;gap:10px;padding:10px 14px;transition:all .15s;display:flex}.category-card:hover{border-color:var(--text2);background:#ffffff08}.category-color-dot{border-radius:50%;flex-shrink:0;width:14px;height:14px}.category-card-name{flex:1;font-size:13px;font-weight:500}.category-card-actions{gap:4px;display:flex}.category-card-actions button{color:var(--text2);cursor:pointer;background:0 0;border:none;padding:2px;font-size:14px}.category-card-actions button:hover{color:var(--text)}.account-selector{flex-wrap:wrap;gap:6px;margin-bottom:12px;display:flex}.account-chip{border:1px solid var(--border);color:var(--text2);cursor:pointer;background:0 0;border-radius:99px;align-items:center;gap:6px;padding:6px 12px;font-size:12px;transition:all .15s;display:flex}.account-chip:hover{border-color:var(--text2)}.account-chip.active{background:var(--text);color:var(--bg);border-color:var(--text)}.column-mapper{grid-template-columns:1fr 1fr;gap:8px;margin:12px 0;display:grid}.import-preview{border:1px solid var(--border);border-radius:var(--radius);max-height:200px;padding:8px;font-size:12px;overflow:auto}.import-preview table{border-collapse:collapse;width:100%}.import-preview th,.import-preview td{text-align:left;border-bottom:1px solid var(--border);padding:4px 8px;font-size:11px}.import-preview th{color:var(--text2);font-weight:500}.tags-input-wrap{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface2);flex-wrap:wrap;align-items:center;gap:4px;min-height:38px;padding:6px 8px;display:flex}.tags-input-wrap .tag-badge{cursor:pointer}.tags-input-wrap input{min-width:80px;color:var(--text);background:0 0;border:none;outline:none;flex:1;padding:2px 4px;font-size:13px}.badge-recurring{color:#7b8bd4;background:#5b6abf26;border:1px solid #5b6abf4d;border-radius:99px;padding:2px 8px;font-size:10px;display:inline-block}.badge-receipt{color:#5bbf8b;cursor:pointer;background:#5bbf8b1f;border:1px solid #5bbf8b40;border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:10px;display:inline-flex}.finance-actions-row{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:8px;padding:12px 16px;display:flex}.finance-summary.extended{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}@media (max-width:768px){.finance-summary.extended{grid-template-columns:repeat(2,1fr)}}.finance-stat-value.savings{color:#5b8bbf}.modal.modal-wide{max-width:640px}.color-picker-row{flex-wrap:wrap;gap:6px;display:flex}.color-swatch{cursor:pointer;border:2px solid #0000;border-radius:50%;width:24px;height:24px;transition:transform .1s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.active{border-color:var(--text)}.finance-sub-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:16px;display:flex}.finance-sub-tab{color:var(--text2);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 16px;font-size:13px;transition:all .15s}.finance-sub-tab:hover{color:var(--text)}.finance-sub-tab.active{color:var(--text);border-bottom-color:var(--text)}
