*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f0f14;--bg-raised: #1a1a24;--bg-card: #1e1e2a;--bg-input: #252535;--bg-hover: #2a2a3c;--border: rgba(255,255,255,.08);--border-focus: rgba(232,160,32,.5);--text: #f0ebe0;--text-muted: #8a8a9a;--text-faint: #4a4a5a;--accent: #e8a020;--accent-dim: rgba(232,160,32,.15);--accent-hover: #f0b040;--danger: #e85d3a;--danger-dim: rgba(232,93,58,.15);--success: #2eb87e;--success-dim: rgba(46,184,126,.15);--font-display: "Bricolage Grotesque", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "DM Mono", monospace;--radius: 8px;--radius-lg: 12px;--radius-sm: 4px;--transition: .15s ease}html{font-size:15px}body{font-family:var(--font-body);background:var(--bg);color:var(--text);line-height:1.6;-webkit-font-smoothing:antialiased;min-height:100vh}a{color:var(--accent);text-decoration:none}a:hover{color:var(--accent-hover)}button{cursor:pointer;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg)}::-webkit-scrollbar-thumb{background:var(--text-faint);border-radius:3px}.app-layout{display:flex;min-height:100vh}.sidebar{width:220px;min-height:100vh;background:var(--bg-raised);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:24px 16px;position:sticky;top:0;height:100vh;flex-shrink:0}.sidebar-brand{display:flex;align-items:center;gap:10px;padding:0 8px 24px;border-bottom:1px solid var(--border);margin-bottom:16px}.brand-icon{font-size:20px}.brand-icon--lg{font-size:32px;display:block;margin-bottom:8px}.brand-name{font-family:var(--font-display);font-weight:700;font-size:1.1rem;letter-spacing:-.02em;color:var(--text)}.sidebar-nav{display:flex;flex-direction:column;gap:4px;flex:1}.nav-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius);color:var(--text-muted);font-size:.9rem;font-weight:450;background:none;border:none;text-decoration:none;transition:background var(--transition),color var(--transition);width:100%;text-align:left}.nav-item:hover{background:var(--bg-hover);color:var(--text)}.nav-item--active{background:var(--accent-dim);color:var(--accent)}.nav-item--logout{margin-top:auto;color:var(--text-faint)}.nav-item--logout:hover{background:var(--danger-dim);color:var(--danger)}.main-content{flex:1;overflow-y:auto;padding:32px 36px;max-width:1200px}.page{display:flex;flex-direction:column;gap:24px}.page-header{display:flex;align-items:baseline;justify-content:space-between;gap:16px;padding-bottom:16px;border-bottom:1px solid var(--border)}.page-title{font-family:var(--font-display);font-size:1.75rem;font-weight:700;letter-spacing:-.03em;color:var(--text)}.page-loading{display:flex;align-items:center;justify-content:center;min-height:200px}.week-total{font-size:.85rem;color:var(--text-muted)}.week-total strong{color:var(--accent)}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.card-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text);letter-spacing:-.01em}.section-title{font-family:var(--font-display);font-size:1rem;font-weight:600;color:var(--text);display:flex;align-items:center;gap:8px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.spinner{width:28px;height:28px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .7s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:spin .7s linear infinite}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 18px;border-radius:var(--radius);font-size:.88rem;font-weight:500;border:1px solid transparent;transition:background var(--transition),color var(--transition),border-color var(--transition);white-space:nowrap}.btn--primary{background:var(--accent);color:#0f0f14;border-color:var(--accent)}.btn--primary:hover:not(:disabled){background:var(--accent-hover)}.btn--ghost{background:transparent;color:var(--text-muted);border-color:var(--border)}.btn--ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text)}.btn--danger{background:var(--danger);color:#fff;border-color:var(--danger)}.btn--danger:hover:not(:disabled){filter:brightness(1.1)}.btn--export{background:var(--bg-hover);color:var(--text-muted);border-color:var(--border);font-size:.82rem;padding:6px 12px}.btn--export:hover:not(:disabled){color:var(--text);border-color:var(--accent)}.btn--full{width:100%;justify-content:center}.btn--sm{padding:6px 12px;font-size:.82rem}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-group{display:flex;gap:8px}.icon-btn{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:var(--radius-sm);background:none;border:none;color:var(--text-faint);transition:background var(--transition),color var(--transition)}.icon-btn:hover{background:var(--bg-hover);color:var(--text)}.icon-btn--edit:hover{color:var(--accent)}.icon-btn--delete:hover{color:var(--danger);background:var(--danger-dim)}.form-group{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.form-group--inline{flex-direction:row;align-items:center;gap:10px}.form-group--inline .form-label{white-space:nowrap}.form-label{font-size:.8rem;font-weight:500;color:var(--text-muted);letter-spacing:.02em;text-transform:uppercase}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);padding:10px 12px;font-size:.9rem;transition:border-color var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-dim)}.form-input--duration{width:70px;text-align:center}.form-input--sm{padding:7px 10px;font-size:.85rem}.form-select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%238a8a9a' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.form-textarea{resize:vertical;min-height:80px}input[type=date]::-webkit-calendar-picker-indicator{filter:invert(.6);cursor:pointer}.duration-inputs{display:flex;gap:12px;align-items:center}.duration-field{display:flex;align-items:center;gap:6px}.duration-unit{font-size:.85rem;color:var(--text-muted)}.form-feedback{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius);font-size:.85rem;margin-bottom:12px}.form-feedback--success{background:var(--success-dim);color:var(--success)}.form-feedback--error{background:var(--danger-dim);color:var(--danger)}.form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.entry-layout{display:grid;grid-template-columns:380px 1fr;gap:24px;align-items:start}@media (max-width: 900px){.entry-layout{grid-template-columns:1fr}}.entry-form-section{flex-shrink:0}.summary-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:12px}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-left:3px solid var(--accent);border-radius:var(--radius);padding:16px;transition:transform var(--transition)}.summary-card:hover{transform:translateY(-2px)}.summary-card__label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);margin-bottom:8px}.summary-card__value{font-family:var(--font-display);font-size:1.35rem;font-weight:700;color:var(--text);letter-spacing:-.02em}.summary-card__subtitle{font-size:.75rem;color:var(--text-faint);margin-top:4px}.period-tabs{display:flex;flex-direction:column;gap:12px}.period-tabs__row{display:flex;gap:4px;flex-wrap:wrap}.period-tab{padding:7px 14px;border-radius:var(--radius);background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);font-size:.83rem;font-weight:450;transition:all var(--transition)}.period-tab:hover{background:var(--bg-hover);color:var(--text)}.period-tab--active{background:var(--accent-dim);border-color:var(--accent);color:var(--accent);font-weight:500}.period-custom{padding:12px;background:var(--bg-card);border-radius:var(--radius);border:1px solid var(--border)}.period-custom__inputs{display:flex;gap:12px;align-items:flex-end;flex-wrap:wrap}.table-wrapper{overflow-x:auto}.data-table{width:100%;border-collapse:collapse;font-size:.875rem}.data-table th{padding:10px 12px;text-align:left;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.th-sortable:hover{color:var(--text)}.th-right,.td-right{text-align:right}.th-actions{text-align:center}.data-table td{padding:10px 12px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-hover)}.td-date{font-family:var(--font-mono);font-size:.8rem;color:var(--text-muted);white-space:nowrap}.td-duration{font-family:var(--font-mono);font-weight:500}.td-activity{color:var(--text-muted);font-size:.85rem}.td-description{color:var(--text-muted);font-size:.85rem;max-width:280px}.td-actions{text-align:center;white-space:nowrap}.project-badge{display:inline-flex;align-items:center;gap:6px;font-size:.82rem;padding:3px 8px;border-radius:var(--radius-sm);background:color-mix(in srgb,var(--color) 15%,transparent);color:var(--color);white-space:nowrap}.empty-state{text-align:center;color:var(--text-faint);padding:32px;font-size:.9rem}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 6px;border-radius:10px;background:var(--accent-dim);color:var(--accent);font-size:.72rem;font-weight:600}.dashboard-controls{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;flex-wrap:wrap}.project-filter{display:flex;gap:8px;flex-wrap:wrap;padding:4px 0}.project-filter-btn{display:flex;align-items:center;gap:6px;padding:6px 14px;border-radius:20px;background:var(--bg-card);border:1px solid var(--border);color:var(--text-muted);font-size:.83rem;transition:all var(--transition)}.project-filter-btn:hover{border-color:var(--color, var(--accent));color:var(--text)}.project-filter-btn--active{background:color-mix(in srgb,var(--color, var(--accent)) 15%,transparent);border-color:var(--color, var(--accent));color:var(--color, var(--accent))}.project-totals-list{display:flex;flex-direction:column;gap:10px;margin-top:12px}.project-total-row{display:grid;grid-template-columns:180px 1fr 100px;align-items:center;gap:12px}.project-total-info{display:flex;align-items:center;gap:8px}.project-total-name{font-size:.88rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.project-total-bar-wrap{background:var(--bg-input);border-radius:4px;height:6px;overflow:hidden}.project-total-bar{height:100%;border-radius:4px;transition:width .4s ease;min-width:2px}.project-total-value{font-family:var(--font-mono);font-size:.82rem;color:var(--text-muted);text-align:right}.export-panel{display:flex;align-items:center;gap:8px;flex-shrink:0}.export-panel__label{display:flex;align-items:center;gap:5px;font-size:.8rem;color:var(--text-faint)}.export-panel__actions{display:flex;gap:6px}.project-manager__header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.project-list{display:flex;flex-direction:column;gap:2px}.project-row{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:var(--radius);transition:background var(--transition)}.project-row:hover{background:var(--bg-hover)}.project-row__info{display:flex;align-items:center;gap:10px;flex:1;min-width:120px}.project-row__name{font-size:.9rem;font-weight:500}.project-row__share{display:flex;align-items:center;gap:6px;flex:1}.project-row__actions{display:flex;gap:4px}.project-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.project-dot--lg{width:14px;height:14px}.share-token{font-family:var(--font-mono);font-size:.75rem;color:var(--text-faint);background:var(--bg-input);padding:3px 8px;border-radius:var(--radius-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.color-picker{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.color-swatch{width:24px;height:24px;border-radius:50%;border:2px solid transparent;transition:transform var(--transition),border-color var(--transition)}.color-swatch:hover{transform:scale(1.2)}.color-swatch--active{border-color:var(--text);transform:scale(1.1)}.color-custom{width:28px;height:28px;border-radius:50%;border:none;padding:0;cursor:pointer;background:none}.type-chips{display:flex;gap:8px;flex-wrap:wrap}.type-chip{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;border-radius:20px;background:var(--bg-input);border:1px solid var(--border);font-size:.83rem;color:var(--text-muted)}.type-chip--removable{padding-right:6px}.type-chip__remove{background:none;border:none;color:var(--text-faint);cursor:pointer;padding:0;display:flex}.type-chip__remove:hover{color:var(--danger)}.type-editor{display:flex;flex-direction:column;gap:12px}.type-add{display:flex;gap:8px;align-items:center}.settings-layout{display:flex;flex-direction:column;gap:24px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .2s ease}@keyframes slideUp{0%{transform:translateY(16px);opacity:0}to{transform:translateY(0);opacity:1}}.modal--sm{max-width:380px}.modal--md{max-width:520px}.modal--lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border)}.modal-title{font-family:var(--font-display);font-size:1rem;font-weight:600}.modal-close{background:none;border:none;color:var(--text-muted);padding:4px;border-radius:var(--radius-sm);display:flex}.modal-close:hover{color:var(--text);background:var(--bg-hover)}.modal-body{padding:20px 24px 24px}.confirm-delete p{color:var(--text-muted);font-size:.9rem;line-height:1.5;margin-bottom:8px}.confirm-delete__warning{font-size:.8rem;color:var(--danger);opacity:.8}.confirm-delete__actions{display:flex;justify-content:flex-end;gap:8px;margin-top:16px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);background-image:linear-gradient(var(--border) 1px,transparent 1px),linear-gradient(90deg,var(--border) 1px,transparent 1px);background-size:40px 40px}.login-card{width:100%;max-width:380px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:40px}.login-brand{text-align:center;margin-bottom:32px}.login-title{font-family:var(--font-display);font-size:1.8rem;font-weight:700;letter-spacing:-.04em;color:var(--text);margin-bottom:4px}.login-subtitle{font-size:.85rem;color:var(--text-muted)}.auth-loading{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.shared-page{min-height:100vh;background:var(--bg);display:flex;flex-direction:column}.shared-header{background:var(--bg-raised);border-bottom:1px solid var(--border);padding:16px 32px;display:flex;align-items:center;gap:24px}.shared-header__brand{display:flex;align-items:center;gap:8px;opacity:.6}.shared-header__project{display:flex;align-items:center;gap:10px;flex:1}.shared-header__title{font-family:var(--font-display);font-size:1.2rem;font-weight:700;letter-spacing:-.02em}.shared-header__badge{font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;padding:4px 10px;border-radius:20px;background:var(--bg-input);color:var(--text-faint);border:1px solid var(--border)}.shared-content{flex:1;max-width:1100px;width:100%;margin:0 auto;padding:32px 24px;display:flex;flex-direction:column;gap:24px}.shared-loading,.shared-notfound{min-height:100vh;display:flex;align-items:center;justify-content:center}.shared-notfound__inner{text-align:center;max-width:320px}.shared-notfound__icon{font-size:48px;display:block;margin-bottom:16px;opacity:.4}.shared-notfound__inner h1{font-family:var(--font-display);font-size:1.3rem;margin-bottom:8px}.shared-notfound__inner p{color:var(--text-muted);font-size:.9rem}.shared-footer{padding:16px 32px;text-align:center;font-size:.75rem;color:var(--text-faint);border-top:1px solid var(--border)}@media (max-width: 768px){.sidebar{display:none}.main-content{padding:20px 16px}.project-total-row{grid-template-columns:1fr auto}.project-total-bar-wrap{display:none}.shared-header{padding:12px 16px;flex-wrap:wrap;gap:12px}.shared-content{padding:20px 16px}}
