:root{--color-primary:#5e6ad2;--color-primary-hover:#4f5bd5;--color-primary-light:#7b85db;--color-background:#fafbfc;--color-surface:#fff;--color-border:#e5e7eb;--color-text-primary:#1f2937;--color-text-secondary:#6b7280;--color-text-tertiary:#9ca3af;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--spacing-xs:0.25rem;--spacing-sm:0.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--radius-sm:4px;--radius-md:6px;--radius-lg:8px;--radius-xl:12px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}*{box-sizing:border-box;padding:0}*,body{margin:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fafbfc;background-color:var(--color-background);color:#1f2937;color:var(--color-text-primary);font-family:-apple-system,BlinkMacSystemFont,Inter,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Helvetica Neue,sans-serif;font-size:14px;line-height:1.5;overflow-x:hidden}code{background:#5e6ad214;border-radius:4px;border-radius:var(--radius-sm);color:#5e6ad2;color:var(--color-primary);font-family:SF Mono,Monaco,Inconsolata,Fira Code,Fira Mono,source-code-pro,Menlo,Consolas,Courier New,monospace;font-size:.875em;padding:.125rem .375rem}.App{background-color:var(--color-background);min-height:100vh}h1{font-size:2rem;letter-spacing:-.02em;line-height:1.2}h1,h2{color:var(--color-text-primary);font-weight:500;margin:0}h2{font-size:1.5rem;letter-spacing:-.015em;line-height:1.3}h3{font-size:1.125rem;letter-spacing:-.01em;line-height:1.4}h3,h4,h5,h6{color:var(--color-text-primary);font-weight:500;margin:0}a{color:var(--color-primary);text-decoration:none;transition:color .15s ease}a:hover{color:var(--color-primary-hover)}button{border:none;cursor:pointer}button,input,select,textarea{font-family:inherit;font-size:inherit;outline:none;transition:all .15s ease}.dashboard-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #00000008;margin-bottom:1.5rem;padding:1rem;transition:all .2s ease}.dashboard-card:hover{border-color:#5e6ad24d;box-shadow:0 2px 8px 0 #5e6ad214}.dashboard-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between;margin-bottom:.75rem;padding-bottom:0}.dashboard-header h3{color:var(--color-text-primary);font-size:1rem;font-weight:600;letter-spacing:0;margin:0}.dashboard-summary{color:var(--color-primary);font-size:1.125rem;font-weight:600;letter-spacing:-.01em}.dashboard-content{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:180px 1fr 180px}.dashboard-sidebar{display:flex;flex-direction:column;gap:4px;max-height:200px;overflow-x:hidden;overflow-y:auto;padding-right:4px}.dashboard-sidebar::-webkit-scrollbar{width:6px}.dashboard-sidebar::-webkit-scrollbar-track{background:#f0f4f8;border-radius:3px}.dashboard-sidebar::-webkit-scrollbar-thumb{background:#c4d0dd;border-radius:3px}.dashboard-sidebar::-webkit-scrollbar-thumb:hover{background:#a8b8c8}.dashboard-sidebar{scrollbar-color:#c4d0dd #f0f4f8;scrollbar-width:thin}.sidebar-title{color:var(--color-text-tertiary);font-size:.6875rem;font-weight:600;letter-spacing:.05em;margin:0 0 var(--spacing-sm) 0;text-transform:uppercase}.sidebar-title-spaced{margin-top:var(--spacing-lg)}.tile-grid{display:flex;flex-direction:column;gap:var(--spacing-xs)}.tile{align-items:center;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:default;display:flex;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);transition:all .15s ease}.tile:hover{background:var(--color-surface);border-color:var(--color-primary);transform:translateX(2px)}.tile-icon{border-radius:var(--radius-sm);color:#fff;font-size:.625rem;font-weight:700}.tile-icon,.tile-icon-emoji{align-items:center;display:flex;flex-shrink:0;height:20px;justify-content:center;width:20px}.tile-icon-emoji{font-size:1rem;opacity:.7}.tile-name{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dashboard-chart-wrap{align-items:flex-end;display:flex;overflow:hidden;padding-top:var(--spacing-md);width:100%}.dashboard-chart{display:block;height:180px;max-width:100%;width:100%}.dashboard-label{fill:var(--color-text-tertiary);font-size:.75rem;font-weight:500}.dashboard-error,.dashboard-loading{color:var(--color-text-secondary);font-size:.875rem;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.dashboard-bar{cursor:pointer;transition:opacity .15s ease}.dashboard-bar:hover{opacity:.85}.empty-message{color:var(--color-text-tertiary);font-size:.75rem;font-style:italic;padding:var(--spacing-md);text-align:center}@media (max-width:999px){.dashboard-content{gap:0;grid-template-columns:1fr}.dashboard-sidebar{display:none}.dashboard-chart-wrap{padding:0 12px}}.project-list-container{margin:0 auto;max-width:1280px;padding:2rem 1.5rem}.project-list-container h1{color:var(--color-text-primary);font-size:1.875rem;font-weight:600;letter-spacing:-.02em;margin-bottom:2rem}.overall-stats{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:var(--spacing-xl)}.stat-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--spacing-sm);padding:var(--spacing-lg)}.stat-item .stat-icon{font-size:1.5rem;opacity:.6}.stat-item .stat-value{color:var(--color-text-primary);font-size:1.75rem;font-weight:600;letter-spacing:-.02em}.stat-item .stat-label{color:var(--color-text-tertiary);font-size:.8125rem;font-weight:500}.projects-controls{align-items:center;display:flex;flex-wrap:wrap;gap:var(--spacing-md);justify-content:space-between;margin-bottom:var(--spacing-lg)}.filter-buttons{display:flex;gap:var(--spacing-xs)}.filter-btn{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem 1rem;transition:all .15s ease}.filter-btn.active,.filter-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.filter-btn.active{background:#5e6ad20d}.sort-controls{align-items:center;display:flex;gap:var(--spacing-sm)}.sort-controls label{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.sort-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;font-size:.875rem;padding:.5rem .75rem;transition:border-color .15s ease}.sort-select:focus,.sort-select:hover{border-color:var(--color-primary)}.sort-select:focus{outline:none}.projects-grid{grid-gap:var(--spacing-md);display:grid;gap:var(--spacing-md);grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.project-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:inherit;display:flex;flex-direction:column;gap:var(--spacing-md);padding:var(--spacing-lg);text-decoration:none;transition:all .15s ease}.project-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-md);transform:translateY(-2px)}.project-card-header{align-items:flex-start;display:flex;gap:var(--spacing-sm);justify-content:space-between}.project-name{flex:1 1;font-size:1.125rem;font-weight:600;letter-spacing:-.01em;margin:0;word-break:break-word}.time-badge{background:#5e6ad21a;border-radius:var(--radius-md);color:var(--color-primary);font-size:.75rem;font-weight:600;padding:.25rem .625rem;white-space:nowrap}.mini-chart{align-items:flex-end;display:flex;gap:3px;height:32px;padding:var(--spacing-xs) 0}.mini-chart-bar{background:#5e6ad233;border-radius:2px;flex:1 1;min-height:2px;transition:background .2s ease}.project-card:hover .mini-chart-bar{background:#5e6ad266}.project-card-footer{align-items:center;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;padding-top:var(--spacing-sm)}.project-meta{display:flex;flex-direction:column;gap:2px}.project-meta-item{align-items:center;display:flex;font-size:.75rem;gap:.25rem}.arrow-icon,.project-meta-item{color:var(--color-text-tertiary)}.arrow-icon{font-size:1.125rem;transition:transform .2s ease,color .2s ease}.project-card:hover .arrow-icon{color:var(--color-primary);transform:translateX(4px)}.empty-state{margin:3rem auto;max-width:400px;padding:var(--spacing-xl) var(--spacing-md);text-align:center}.empty-state-icon{font-size:3rem;margin-bottom:var(--spacing-md);opacity:.3}.empty-state h3{color:var(--color-text-primary);font-size:1.125rem;font-weight:600;margin:0 0 var(--spacing-sm) 0}.empty-state p{margin:0}.empty-state p,.error-message,.loading{color:var(--color-text-secondary);font-size:.875rem}.error-message,.loading{margin:3rem 0;text-align:center}@media (max-width:768px){.project-list-container{padding:1.5rem 1rem}.overall-stats{grid-template-columns:repeat(2,1fr)}.projects-controls{align-items:stretch;flex-direction:column}.filter-buttons{flex-wrap:wrap}.sort-controls{justify-content:space-between}.projects-grid{grid-template-columns:1fr}}@media (max-width:480px){.overall-stats{grid-template-columns:1fr}.project-card-header{align-items:flex-start;flex-direction:column}.time-badge{align-self:flex-start}}.project-detail-container{margin:0 auto;max-width:1280px;padding:2rem 1.5rem}.back-link{align-items:center;color:var(--color-text-secondary);display:inline-flex;font-size:.875rem;font-weight:500;margin-bottom:1.5rem;text-decoration:none;transition:color .15s ease}.back-link:hover{color:var(--color-primary)}.project-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem}.project-header h1{color:var(--color-text-primary);font-size:1.875rem;font-weight:600;letter-spacing:-.02em;margin:0}.project-total-time{color:var(--color-text-secondary);font-size:.875rem;font-weight:500}.project-total-time .time-value{color:var(--color-primary);font-size:1.25rem;font-weight:600;letter-spacing:-.01em;margin-left:.5rem}.pd-error-message,.pd-loading,.pd-no-data{color:var(--color-text-secondary);font-size:.875rem;margin:3rem 0;text-align:center}.pd-error-message{color:var(--color-error)}.pd-stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:1.5rem}.pd-stat-card{align-items:flex-start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:1rem;padding:1.25rem;transition:all .15s ease}.pd-stat-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.pd-stat-icon{font-size:1.5rem;min-width:1.5rem;opacity:.8}.pd-stat-content{flex:1 1}.pd-stat-label{color:var(--color-text-tertiary);font-size:.75rem;font-weight:500;letter-spacing:.05em;margin-bottom:.375rem;text-transform:uppercase}.pd-stat-value{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.25rem}.pd-stat-trend{align-items:center;color:var(--color-text-secondary);display:flex;font-size:.75rem;gap:.25rem}.pd-stat-trend.positive{color:var(--color-success)}.pd-stat-trend.negative{color:var(--color-error)}.pd-stat-description{color:var(--color-text-tertiary);font-size:.75rem}.pd-activity-section{grid-gap:1.5rem;align-items:stretch;display:grid;gap:1.5rem;grid-template-columns:1fr 520px;margin-bottom:1.5rem}.pd-weekly-chart{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;height:100%;padding:1.5rem}.pd-weekly-chart h3{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0 0 1.25rem}.pd-chart-container{display:flex;flex:1 1;flex-direction:column;padding:.5rem 0 1rem}.pd-chart-bars-area{align-items:flex-end;display:flex;gap:1rem;height:200px;justify-content:space-evenly;padding:0 .5rem}.pd-chart-column{align-items:center;display:flex;flex:1 1;flex-direction:column;height:100%;justify-content:flex-end;min-width:50px}.pd-chart-bar{align-items:flex-start;background:var(--color-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;cursor:pointer;display:flex;justify-content:center;min-height:2px;padding-top:.375rem;position:relative;transition:all .3s ease;width:100%}.pd-chart-bar-empty{background:var(--color-border);min-height:2px}.pd-chart-bar:hover{background:var(--color-primary-hover)}.pd-chart-bar-value{color:#fff;font-size:.6875rem;font-weight:600;white-space:nowrap}.pd-chart-bar-label{color:var(--color-text-tertiary);font-size:.75rem;font-weight:500;margin-top:.5rem;text-align:center}.pd-stats-sidebar{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(2,1fr);height:100%}.pd-stats-sidebar .pd-stat-card{flex-direction:column;height:100%}.pd-top-files-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1.5rem}.pd-top-files-section h3{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0 0 1.25rem}.pd-top-files-list{display:flex;flex-direction:column;gap:.75rem}.pd-top-file-item{align-items:center;background:var(--color-background);border:1px solid #0000;border-radius:var(--radius-md);display:flex;gap:.75rem;padding:.75rem;transition:all .15s ease}.pd-top-file-item:hover{background:#5e6ad20a;border-color:var(--color-border)}.pd-top-file-rank{color:var(--color-primary);font-size:1rem;font-weight:600;min-width:1.75rem}.pd-top-file-icon{font-size:1.25rem;min-width:1.25rem}.pd-top-file-info{flex:1 1;min-width:0}.pd-top-file-name{color:var(--color-text-primary);font-size:.875rem;font-weight:500;margin-bottom:.375rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pd-top-file-progress{align-items:center;display:flex;gap:.625rem}.pd-progress-bar{background:var(--color-border);border-radius:3px;flex:1 1;height:6px;overflow:hidden}.pd-progress-fill{background:var(--color-primary);border-radius:3px;height:100%;transition:width .3s ease}.pd-progress-text{color:var(--color-text-tertiary);font-size:.75rem;font-weight:600;min-width:2.5rem;text-align:right}.pd-top-file-time{color:var(--color-primary);font-size:.875rem;font-weight:600;min-width:4.5rem;text-align:right}.pd-files-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.pd-files-header{align-items:center;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;margin-bottom:1.25rem}.pd-files-header h3{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0}.pd-files-controls{display:flex;gap:.5rem}.pd-file-search{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.875rem;min-width:200px;outline:none;padding:.5rem .75rem;transition:all .15s ease}.pd-file-search:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #5e6ad21a}.pd-file-type-filter{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;outline:none;padding:.5rem .75rem;transition:all .15s ease}.pd-file-type-filter:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #5e6ad21a}.pd-file-list{display:flex;flex-direction:column;gap:.5rem}.pd-file-item{align-items:center;background:var(--color-background);border:1px solid #0000;border-radius:var(--radius-md);display:flex;gap:.75rem;padding:.75rem;transition:all .15s ease}.pd-file-item:hover{background:#5e6ad20a;border-color:var(--color-border)}.pd-file-item-icon{font-size:1.25rem;min-width:1.25rem}.pd-file-item-info{flex:1 1;min-width:0}.pd-file-name{color:var(--color-text-primary);font-size:.875rem;font-weight:500;margin-bottom:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.pd-file-stats{align-items:center;display:flex;font-size:.75rem;gap:.5rem}.pd-file-percentage{color:var(--color-text-tertiary)}.pd-file-type-badge{background:#5e6ad21a;border-radius:var(--radius-sm);font-size:.6875rem;padding:.125rem .375rem}.pd-file-time,.pd-file-type-badge{color:var(--color-primary);font-weight:600}.pd-file-time{font-size:.875rem;min-width:4.5rem;text-align:right;white-space:nowrap}.pd-no-files-message{color:var(--color-text-tertiary);font-size:.875rem;padding:2rem;text-align:center}.nav-bar{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background-color:var(--color-surface);background-color:#fffc;border-bottom:1px solid var(--color-border);padding:.75rem 1.5rem;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.nav-container{align-items:center;display:flex;height:48px;justify-content:space-between;margin:0 auto;max-width:1280px}.logo{color:var(--color-text-primary);font-size:1.125rem;font-weight:600;letter-spacing:-.02em}.nav-links{align-items:center;display:flex;gap:.5rem}.nav-link{border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:.875rem;font-weight:500;padding:.5rem .75rem;text-decoration:none;transition:all .15s ease}.nav-link:hover{background-color:#0000000a;color:var(--color-text-primary)}.nav-link.active{background-color:#5e6ad214;color:var(--color-primary)}.logout-button{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;margin-left:.5rem;padding:.5rem .875rem;transition:all .15s ease}.logout-button:hover{background:#ef44440a;border-color:var(--color-error);color:var(--color-error)}.yandex-tracker-button{background:#fc3f1d;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem .875rem;transition:all .15s ease}.yandex-tracker-button:hover{background:#e63913;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.pomodoro-dropdown-wrapper{position:relative}.pomodoro-nav-button{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:var(--color-surface);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:500;gap:.375rem;padding:.5rem .875rem;transition:all .15s ease}.pomodoro-nav-button:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.pomodoro-dropdown-wrapper .pomodoro-modal-card.open+.pomodoro-nav-button,.pomodoro-nav-button:active{background:var(--color-primary)}.profile-menu{position:relative}.profile-button{background:#0000;border:none;cursor:pointer;padding:0}.profile-button,.profile-icon{align-items:center;display:flex;justify-content:center}.profile-icon{background:var(--color-primary);border-radius:50%;color:#fff;font-size:.875rem;font-weight:600;height:32px;transition:all .15s ease;width:32px}.profile-button:hover .profile-icon{background:var(--color-primary-hover)}.profile-dropdown{animation:slideDown .15s ease;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:260px;position:absolute;right:0;top:calc(100% + 8px);z-index:1000}.profile-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:.75rem;padding:1rem}.profile-avatar{align-items:center;background:var(--color-primary);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.125rem;font-weight:600;height:40px;justify-content:center;width:40px}.profile-email{color:var(--color-text-primary);font-size:.875rem;font-weight:500;word-break:break-word}.profile-error,.profile-loading{color:var(--color-text-secondary);font-size:.875rem;padding:1rem;text-align:center}.profile-error{color:var(--color-error)}.profile-actions{border-bottom:1px solid var(--color-border);padding:.75rem}.api-key-button-dropdown{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem .875rem;transition:all .15s ease;width:100%}.api-key-button-dropdown:hover:not(:disabled){background:#5e6ad20a;border-color:var(--color-primary);color:var(--color-primary)}.api-key-button-dropdown:disabled{cursor:not-allowed;opacity:.5}.yandex-tracker-button-dropdown{background:#fc3f1d;border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem .875rem;transition:all .15s ease;width:100%}.yandex-tracker-button-dropdown:hover{background:#e63913}.profile-status{align-items:center;color:var(--color-success);display:flex;font-size:.8125rem;font-weight:500;gap:.5rem;padding:.875rem}.status-indicator{font-size:1rem}.logout-button-dropdown{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.5rem .875rem;transition:all .15s ease;width:100%}.logout-button-dropdown:hover{background:#ef44440a;border-color:var(--color-error);color:var(--color-error)}.copy-notification{animation:slideInNotification .3s ease,slideOutNotification .3s ease 2.7s;background:var(--color-success);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);color:#fff;font-size:.875rem;font-weight:500;padding:.75rem 1.25rem;pointer-events:none;position:fixed;right:20px;top:70px;white-space:nowrap;z-index:2000}@keyframes slideInNotification{0%{opacity:0;transform:translateY(-10px) scale(.95)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes slideOutNotification{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(-10px) scale(.95)}}.pomodoro-modal-card{animation:slideDown .2s ease;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);opacity:0;padding:1.25rem;pointer-events:none;position:absolute;right:0;top:calc(100% + .5rem);transform:translateY(-10px);transition:opacity .2s ease,transform .2s ease;width:340px;z-index:1000}.pomodoro-modal-card.open{opacity:1;pointer-events:all;transform:translateY(0)}.pomodoro-modal-card.work{border-top:3px solid #667eea}.pomodoro-modal-card.shortBreak{border-top:3px solid #f5576c}.pomodoro-modal-card.longBreak{border-top:3px solid #4facfe}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.pomodoro-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.pomodoro-header h2{align-items:center;color:var(--color-text-primary);display:flex;font-size:1rem;font-weight:600;gap:.5rem;margin:0}.mode-emoji{font-size:1.5rem}.header-buttons{display:flex;gap:.5rem}.settings-button{align-items:center;background:#0000;border:1px solid #e6eef5;border-radius:50%;cursor:pointer;display:flex;font-size:1.25rem;height:36px;justify-content:center;transition:all .2s ease;width:36px}.settings-button:hover{background:#f0f4f8;transform:rotate(90deg)}.close-button{align-items:center;background:#0000;border:none;border-radius:4px;color:#6b7c8a;cursor:pointer;display:flex;font-size:32px;height:36px;justify-content:center;line-height:1;padding:0;transition:all .2s ease;width:36px}.close-button:hover{background:#f0f4f8;color:#333}.mode-tabs{display:flex;gap:.375rem;margin-bottom:1rem}.mode-tab{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-secondary);cursor:pointer;flex:1 1;font-family:inherit;font-size:.8125rem;font-weight:500;padding:.5rem .75rem;transition:all .15s ease}.mode-tab:hover:not(:disabled){background:var(--color-surface);border-color:var(--color-primary)}.mode-tab.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.mode-tab:disabled{cursor:not-allowed;opacity:.5}.timer-display{margin-bottom:1rem;text-align:center}.mode-title{color:var(--color-text-tertiary);font-size:.875rem;font-weight:500;margin:0 0 1rem}.time-circle{height:160px;margin:0 auto;position:relative;width:160px}.progress-ring{height:160px;transform:rotate(-90deg);width:160px}.progress-ring-bg{fill:none;stroke:var(--color-background);stroke-width:6}.progress-ring-progress{fill:none;stroke:var(--color-primary);stroke-width:6;stroke-linecap:round;stroke-dasharray:452;transition:stroke-dashoffset .5s ease}.time-text{color:var(--color-text-primary);font-family:Courier New,monospace;font-size:2rem;font-weight:300;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}.timer-controls{display:flex;gap:.5rem;justify-content:center;margin-bottom:1rem}.control-button{border:none;border-radius:var(--radius-md);cursor:pointer;flex:1 1;font-family:inherit;font-size:.8125rem;font-weight:600;padding:.625rem 1.25rem;transition:all .15s ease}.control-button.start{background:var(--color-primary);color:#fff}.control-button.start:hover{background:var(--color-primary-hover);box-shadow:var(--shadow-sm);transform:translateY(-1px)}.control-button.pause{background:#f5576c;color:#fff}.control-button.pause:hover{background:#e04357;box-shadow:var(--shadow-sm);transform:translateY(-1px)}.control-button.reset{background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text-secondary)}.control-button.reset:hover{background:var(--color-surface);border-color:var(--color-primary)}.control-button:active{transform:translateY(0)}.session-counter{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:.75rem;text-align:center}.counter-label{color:var(--color-text-tertiary);font-size:.6875rem;font-weight:500;margin-bottom:.25rem}.counter-value{color:var(--color-primary);font-size:1.25rem;font-weight:600;line-height:1.2;margin-bottom:.5rem}.counter-circles{display:flex;gap:.375rem;justify-content:center}.counter-circle{background:#e6eef5;border-radius:50%;height:10px;transition:background .3s ease;width:10px}.counter-circle.filled{background:#667eea}.settings-panel{animation:fadeIn .2s ease;background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:1rem;padding:1rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-panel h3{color:var(--color-text-primary);font-size:.875rem;font-weight:600;margin:0 0 .75rem}.setting-item{align-items:center;display:flex;justify-content:space-between;margin-bottom:.75rem}.setting-item label{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500}.setting-item input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-sm);font-family:inherit;font-size:.8125rem;padding:.375rem .5rem;text-align:center;width:60px}.setting-item input:focus{border-color:var(--color-primary);outline:none}.apply-settings-button{background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:600;margin-top:.75rem;padding:.625rem;transition:all .15s ease;width:100%}.apply-settings-button:hover{background:var(--color-primary-hover)}.apply-settings-button:active{transform:translateY(1px)}@media (max-width:600px){.pomodoro-modal-card{left:auto;padding:1rem;right:-1rem;width:300px}.progress-ring,.time-circle{height:140px;width:140px}.time-text{font-size:1.75rem}}.login-container{align-items:center;background:var(--color-background);display:flex;justify-content:center;min-height:100vh;padding:1.5rem}.login-card{animation:slideIn .3s ease-out;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);max-width:400px;padding:2.5rem;width:100%}@keyframes slideIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.login-header{margin-bottom:2rem;text-align:center}.login-header h1{color:var(--color-text-primary);font-size:1.75rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .5rem}.login-header p{color:var(--color-text-secondary);font-size:.875rem;margin:0}.login-form{gap:1.25rem}.form-group,.login-form{display:flex;flex-direction:column}.form-group{gap:.5rem}.form-group label{color:var(--color-text-primary);font-size:.8125rem;font-weight:500}.email-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;padding:.625rem .875rem;transition:all .15s ease}.email-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #5e6ad21a;outline:none}.email-input:disabled{background:var(--color-background);cursor:not-allowed;opacity:.6}.email-input::placeholder{color:var(--color-text-tertiary)}.password-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);font-family:inherit;font-size:.875rem;padding:.625rem .875rem;transition:all .15s ease}.password-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #5e6ad21a;outline:none}.password-input:disabled{background:var(--color-background);cursor:not-allowed;opacity:.6}.password-input::placeholder{color:var(--color-text-tertiary)}.login-button{background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;font-family:inherit;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:all .15s ease}.login-button:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-md);transform:translateY(-1px)}.login-button:disabled{cursor:not-allowed;opacity:.5}.error-message{background:#ef444414;border:1px solid #ef44444d;border-radius:var(--radius-md);color:var(--color-error);font-size:.8125rem;padding:.75rem 1rem;text-align:center}.login-footer{margin-top:1.5rem;text-align:center}.login-footer p{color:var(--color-text-tertiary);font-size:.75rem;line-height:1.5;margin:0}.toggle-mode-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-family:inherit;font-size:.8125rem;font-weight:500;padding:.5rem;transition:all .15s ease}.toggle-mode-button:hover:not(:disabled){color:var(--color-primary-hover);text-decoration:underline}.toggle-mode-button:disabled{cursor:not-allowed;opacity:.5}@media (max-width:480px){.login-card{padding:2rem 1.5rem}.login-header h1{font-size:28px}}.insights-container{margin:0 auto;max-width:1400px;padding:2rem 1.5rem}.insights-container.command-center{display:flex;flex-direction:column;gap:1.5rem}.insights-header{margin-bottom:.5rem}.insights-header h1{color:var(--color-text-primary);font-size:1.875rem;font-weight:600;letter-spacing:-.02em;margin:0 0 .375rem}.insights-subtitle{color:var(--color-text-secondary);font-size:.875rem;margin:0}.heatmap-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem;padding:1rem}.section-header{align-items:center;display:flex;flex-shrink:0;justify-content:space-between}.section-header h2{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0}.heatmap-legend{align-items:center;color:var(--color-text-tertiary);display:flex;font-size:.75rem;gap:.375rem}.legend-item{border:1px solid var(--color-border);border-radius:2px;height:12px;width:12px}.heat-none{background:var(--color-background)}.heat-low{background:#5e6ad233}.heat-medium{background:#5e6ad280}.heat-high{background:#5e6ad2bf}.heat-very-high{background:var(--color-primary)}.heatmap-grid{display:flex;flex-shrink:0;gap:.5rem;max-width:100%;overflow-x:auto;overflow-y:hidden}.heatmap-days-labels{display:flex;flex-direction:column;flex-shrink:0;justify-content:space-around;padding-right:.5rem}.day-label{align-items:center;color:var(--color-text-tertiary);display:flex;font-size:.6875rem;font-weight:500;height:12px}.heatmap-week,.heatmap-weeks{display:flex;flex-shrink:0;gap:2px}.heatmap-week{flex-direction:column}.heatmap-cell{border:1px solid var(--color-border);border-radius:2px;cursor:pointer;height:12px;transition:all .15s ease;width:12px}.heatmap-cell:hover{box-shadow:var(--shadow-sm);transform:scale(1.3);z-index:10}.heatmap-stats{border-top:1px solid var(--color-border);display:flex;flex-shrink:0;gap:2rem;padding-top:.75rem}.heatmap-stat{display:flex;flex-direction:column;gap:.125rem}.heatmap-stat .stat-number{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;letter-spacing:-.02em;line-height:1.2}.heatmap-stat .stat-text{color:var(--color-text-tertiary);font-size:.75rem;line-height:1.2}.stats-widgets-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:1.5rem}.widget{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:1rem;padding:1.25rem;transition:all .15s ease}.widget:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.widget-icon{font-size:2rem;line-height:1}.widget-content{flex:1 1}.widget-value{color:var(--color-text-primary);font-size:1.75rem;font-weight:600;letter-spacing:-.02em;line-height:1;margin-bottom:.25rem}.widget-label{color:var(--color-text-tertiary);font-size:.75rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.widget-sub,.widget-trend{color:var(--color-text-secondary);font-size:.75rem;margin-top:.375rem}.detailed-charts{display:flex;flex-direction:column;gap:1.5rem}.charts-row{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(2,1fr)}.chart-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem}.chart-card h3{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0 0 1.25rem}.time-distribution-card{grid-column:1/-1}.no-data{color:var(--color-text-secondary);font-size:.875rem;margin:0;padding:2rem;text-align:center}.projects-chart{gap:1rem}.project-bar-item,.projects-chart{display:flex;flex-direction:column}.project-bar-item{gap:.5rem}.project-bar-header{align-items:center;display:flex;justify-content:space-between}.project-bar-name{color:var(--color-text-primary);font-size:.875rem;font-weight:500}.project-bar-hours{color:var(--color-primary);font-size:.8125rem;font-weight:600}.project-bar-track{background:var(--color-background);border-radius:4px;height:8px;overflow:hidden;position:relative}.project-bar-fill{align-items:center;background:var(--color-primary);border-radius:4px;display:flex;height:100%;justify-content:flex-end;padding-right:.5rem;transition:width .5s ease}.project-bar-label{color:#fff;font-size:.6875rem;font-weight:600}.languages-breakdown{display:flex;flex-direction:column;gap:1rem}.language-bar-item{display:flex;flex-direction:column;gap:.5rem}.language-bar-header{align-items:center;display:flex;justify-content:space-between}.language-header{align-items:center;display:flex;gap:.5rem}.language-dot{border-radius:50%;height:10px;width:10px}.language-title{color:var(--color-text-primary);font-size:.875rem;font-weight:500}.language-value{color:var(--color-text-secondary);font-size:.8125rem;font-weight:600}.language-bar-track{background:var(--color-background);border-radius:4px;height:8px;overflow:hidden;position:relative}.language-bar-fill{align-items:center;border-radius:4px;display:flex;height:100%;justify-content:flex-end;padding-right:.5rem;transition:width .5s ease}.language-bar-label{color:#fff;font-size:.6875rem;font-weight:600}.weekly-bars{align-items:flex-end;display:flex;gap:.5rem;height:180px;justify-content:space-between}.weekly-bar-item{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:.5rem;height:100%}.weekly-bar-track{align-items:flex-end;display:flex;flex:1 1;width:100%}.weekly-bar-fill{align-items:flex-start;background:var(--color-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;display:flex;justify-content:center;min-height:20px;padding-top:.375rem;transition:height .3s ease;width:100%}.weekly-bar-fill:hover{background:var(--color-primary-hover)}.weekly-bar-value{color:#fff;font-size:.6875rem;font-weight:600}.weekly-bar-label{color:var(--color-text-tertiary);font-size:.75rem;font-weight:500}.time-distribution{display:flex;flex-direction:column;gap:1rem}.time-bar-item{align-items:center;display:flex;gap:.75rem}.time-bar-info{display:flex;flex-direction:column;min-width:60px}.time-bar-label{color:var(--color-text-primary);font-size:.8125rem;font-weight:600}.time-bar-value{color:var(--color-text-secondary);font-size:.75rem}.time-bar-track{background:var(--color-background);border-radius:12px;flex:1 1;height:24px;overflow:hidden}.time-bar-fill{background:var(--color-success);border-radius:12px;height:100%;transition:width .5s ease}.time-bar-percentage{color:var(--color-text-secondary);font-size:.8125rem;font-weight:600;min-width:40px;text-align:right}.summary-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:1.5rem}.stat-card{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:1rem;padding:1.25rem;transition:all .15s ease}.stat-card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-sm)}.stat-card.primary{border-left:3px solid var(--color-primary)}.stat-card.success{border-left:3px solid var(--color-success)}.stat-card.fire{border-left:3px solid var(--color-error)}.stat-card.info{border-left:3px solid var(--color-primary-light)}.stat-icon{font-size:2rem;line-height:1;opacity:.9}.stat-content{flex:1 1}.stat-label{color:var(--color-text-tertiary);font-size:.75rem;font-weight:500;letter-spacing:.05em;margin-bottom:.25rem;text-transform:uppercase}.stat-value{color:var(--color-text-primary);font-size:1.5rem;font-weight:600;letter-spacing:-.02em;line-height:1.2}.stat-trend{color:var(--color-success);font-size:.75rem;margin-top:.25rem}.insight-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:1.5rem;padding:1.5rem}.insight-card h2{color:var(--color-text-primary);font-size:1rem;font-weight:600;margin:0 0 1.25rem}.insights-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(500px,1fr));margin-bottom:1.5rem}.insight-card.half{margin-bottom:0}.weekly-chart{align-items:flex-end;display:flex;gap:.75rem;height:220px;justify-content:space-around;padding:1rem 0}.chart-bar-container{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:.5rem}.chart-bar-wrapper{align-items:flex-end;display:flex;height:180px;width:100%}.chart-bar{align-items:flex-start;background:var(--color-primary);border-radius:var(--radius-sm) var(--radius-sm) 0 0;display:flex;justify-content:center;min-height:20px;position:relative;transition:all .15s ease;width:100%}.chart-bar:hover{background:var(--color-primary-hover)}.chart-bar-value{color:#fff;font-size:.6875rem;font-weight:600;padding:.375rem}.chart-label{color:var(--color-text-tertiary);font-size:.75rem;font-weight:500}.projects-list{gap:.75rem}.project-item,.projects-list{display:flex;flex-direction:column}.project-item{gap:.5rem}.project-info{gap:.75rem}.project-info,.project-rank{align-items:center;display:flex}.project-rank{background:#5e6ad21a;border-radius:50%;color:var(--color-primary);font-size:.8125rem;font-weight:600;height:28px;justify-content:center;width:28px}.project-details{align-items:center;display:flex;flex:1 1;justify-content:space-between}.project-name{color:var(--color-text-primary);font-size:.875rem;font-weight:500}.project-hours{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500}.project-bar-container{background:var(--color-background);border-radius:2.5px;height:5px;overflow:hidden}.project-bar{background:var(--color-primary);border-radius:2.5px;height:100%;transition:width .5s ease}.languages-list{display:flex;flex-direction:column;gap:.75rem}.language-item{align-items:center;display:flex;gap:.75rem}.language-color{border-radius:50%;height:14px;width:14px}.language-info{align-items:center;display:flex;flex:1 1;justify-content:space-between}.language-name{color:var(--color-text-primary);font-size:.875rem;font-weight:500}.language-hours{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500}.time-of-day{display:flex;flex-direction:column;gap:.875rem;margin-bottom:1rem}.time-slot{align-items:center;display:flex;gap:.75rem}.time-slot-label{color:var(--color-text-primary);font-size:.8125rem;font-weight:500;min-width:60px}.time-slot-bar-container{background:var(--color-background);border-radius:10px;flex:1 1;height:20px;overflow:hidden}.time-slot-bar{background:var(--color-success);border-radius:10px;height:100%;transition:width .5s ease}.time-slot-value{color:var(--color-text-secondary);font-size:.8125rem;font-weight:500;min-width:60px;text-align:right}.insight-highlight{align-items:center;background:#5e6ad20f;border-radius:var(--radius-md);color:var(--color-text-primary);display:flex;font-size:.8125rem;gap:.5rem;padding:.875rem}.highlight-icon{font-size:1.125rem}.best-day-content{padding:1.5rem 0;text-align:center}.best-day-icon{font-size:3rem;margin-bottom:.75rem}.best-day-name{color:var(--color-primary);font-size:1.5rem;font-weight:600;letter-spacing:-.02em;margin-bottom:.375rem}.best-day-description{color:var(--color-text-secondary);font-size:.8125rem}.top-language-badge{align-items:center;background:#5e6ad214;border:1px solid #5e6ad233;border-radius:var(--radius-md);color:var(--color-text-primary);display:flex;gap:.875rem;margin-top:1.25rem;padding:.875rem}.badge-icon{font-size:1.75rem}.badge-content{flex:1 1}.badge-label{color:var(--color-text-tertiary);font-size:.6875rem;font-weight:500;letter-spacing:.05em;margin-bottom:.125rem;text-transform:uppercase}.badge-value{color:var(--color-primary);font-size:1.125rem;font-weight:600}.achievements-grid{grid-gap:.875rem;display:grid;gap:.875rem;grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.achievement-item{background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.25rem;position:relative;text-align:center;transition:all .15s ease}.achievement-item.unlocked{background:#5e6ad20a;border-color:var(--color-primary)}.achievement-item.unlocked:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.achievement-item.locked{filter:grayscale(1);opacity:.5}.achievement-icon{font-size:2rem;margin-bottom:.5rem}.achievement-title{color:var(--color-text-primary);font-size:.8125rem;font-weight:600;margin-bottom:.25rem}.achievement-description{color:var(--color-text-tertiary);font-size:.6875rem;line-height:1.4}.achievement-badge{align-items:center;background:var(--color-success);border-radius:50%;color:#fff;display:flex;font-size:.75rem;font-weight:600;height:20px;justify-content:center;position:absolute;right:.5rem;top:.5rem;width:20px}@media (max-width:1200px){.command-center-layout{grid-template-columns:1fr 240px}.charts-row{grid-template-columns:1fr}}@media (max-width:1024px){.insights-row{grid-template-columns:1fr}.insight-card.half{margin-bottom:1.5rem}.stats-widgets-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.insights-container{padding:1.5rem 1rem}.summary-grid{grid-template-columns:1fr}.weekly-chart{height:180px}.chart-bar-wrapper{height:140px}.achievements-grid{grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.best-day-icon{font-size:2.5rem}.stats-widgets-grid{grid-template-columns:1fr}.heatmap-weeks{overflow-x:auto}.weekly-bars{height:140px}}
/*# sourceMappingURL=main.f682afd6.css.map*/