:root{--color-bg: #FAFAF8;--color-surface: #FFFFFF;--color-border: #E0DDD7;--color-border-light: #F0EDEA;--color-text: #1A1A1A;--color-text-secondary:#6B6B5E;--color-text-muted: #A3A295;--color-primary: #F36C00;--color-primary-hover: #E06000;--color-primary-light: #FFF5EE;--color-danger: #D93025;--color-danger-hover: #C12B20;--color-danger-light: #FDF0EF;--color-success: #1E8E3E;--color-success-light: #EEF8F0;--color-green: #22C55E;--color-green-dark: #16A34A;--sp-1: 4px;--sp-2: 8px;--sp-3: 12px;--sp-4: 16px;--sp-5: 20px;--sp-6: 24px;--sp-8: 32px;--sp-10: 40px;--sp-12: 48px;--sp-16: 64px;--font-ui: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--text-xs: .6875rem;--text-sm: .8125rem;--text-base: .875rem;--text-lg: 1rem;--text-xl: 1.125rem;--text-2xl: 1.5rem;--radius-sm: 4px;--radius: 6px;--radius-lg: 8px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.08);--shadow-md: 0 4px 12px rgba(0,0,0,.08);--shadow-lg: 0 8px 24px rgba(0,0,0,.12);--transition: .15s ease;--transition-slow: .25s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased}body{font-family:var(--font-ui);color:var(--color-text);background:var(--color-bg);line-height:1.5}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}button,input,select,textarea{font-family:inherit;font-size:inherit;border:none;outline:none;background:none;color:inherit}ul,ol{list-style:none}table{border-collapse:collapse;width:100%}.topbar{background:#1a1a1a;height:50px;position:sticky;top:0;z-index:100}.topbar__inner{max-width:1200px;margin:0 auto;padding:0 var(--sp-6);height:100%;display:flex;align-items:center;justify-content:space-between}.topbar__left{display:flex;align-items:center;gap:var(--sp-6)}.topbar__logo{display:flex;align-items:center;text-decoration:none;flex-shrink:0}.topbar__logo:hover{text-decoration:none}.topbar__logo-img{height:28px;width:auto}.topbar__nav{display:flex;align-items:center;gap:0}.topbar__link{padding:0 var(--sp-3);height:50px;display:flex;align-items:center;font-size:var(--text-base);font-weight:500;color:#ffffffa6;text-decoration:none;transition:color var(--transition);position:relative}.topbar__link:hover{color:#fff;text-decoration:none}.topbar__link--active{color:var(--color-primary);font-weight:600}.topbar__link--active:after{content:"";position:absolute;bottom:0;left:var(--sp-3);right:var(--sp-3);height:3px;background:var(--color-primary);border-radius:3px 3px 0 0}.topbar__right{display:flex;align-items:center;gap:var(--sp-4)}.topbar__user{display:flex;align-items:center;gap:var(--sp-2)}.topbar__avatar{width:30px;height:30px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff}.topbar__user-name{font-size:var(--text-sm);color:#ffffffd9;font-weight:500}.topbar__logout{color:#fff6;cursor:pointer;padding:4px;display:flex;transition:color var(--transition)}.topbar__logout:hover{color:#fff}.main{min-height:calc(100vh - 50px)}.container{max-width:1200px;margin:0 auto;padding:var(--sp-8) var(--sp-6)}.layout-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--sp-6)}.layout-grid-2{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-6)}.ts-day-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-5)}.ts-day-header__left{display:flex;align-items:center;gap:var(--sp-4)}.ts-day-nav{display:flex;gap:var(--sp-1)}.ts-day-nav__btn{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);border:1px solid var(--color-border);cursor:pointer;color:var(--color-text-secondary);background:var(--color-surface);transition:all var(--transition)}.ts-day-nav__btn:hover{background:var(--color-border-light);color:var(--color-text);border-color:var(--color-text-muted)}.ts-day-header__title{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em}.ts-day-header__today-label{color:var(--color-text)}.ts-day-header__return{color:var(--color-primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;background:none;border:none;padding:0}.ts-day-header__return:hover{text-decoration:underline}.weekbar{display:flex;align-items:stretch;gap:0;margin-bottom:var(--sp-6);border-bottom:1px solid var(--color-border);padding-bottom:var(--sp-4)}.weekbar__add-btn{width:64px;min-height:64px;border-radius:var(--radius-lg);background:var(--color-green);color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;border:none;transition:background var(--transition),transform var(--transition);flex-shrink:0;margin-right:var(--sp-4)}.weekbar__add-btn:hover{background:var(--color-green-dark);transform:scale(1.05)}.weekbar__days{display:flex;flex:1;gap:0}.weekbar__day{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;padding:var(--sp-2) var(--sp-1);cursor:pointer;border:none;background:none;border-bottom:3px solid transparent;transition:all var(--transition);min-width:0}.weekbar__day:hover{background:var(--color-border-light)}.weekbar__day--selected{border-bottom-color:var(--color-text)}.weekbar__day--selected .weekbar__day-name,.weekbar__day--selected .weekbar__day-hours{font-weight:700;color:var(--color-text)}.weekbar__day--today .weekbar__day-name,.weekbar__day--today .weekbar__day-hours{color:var(--color-primary)}.weekbar__day--today.weekbar__day--selected{border-bottom-color:var(--color-primary)}.weekbar__day-name{font-size:var(--text-sm);font-weight:500;color:var(--color-text-secondary);text-transform:capitalize}.weekbar__day-hours{font-size:var(--text-sm);color:var(--color-text-muted)}.weekbar__total{display:flex;flex-direction:column;align-items:flex-end;justify-content:center;padding-left:var(--sp-4);min-width:90px;flex-shrink:0}.weekbar__total-label{font-size:var(--text-xs);color:var(--color-text-muted);font-weight:500}.weekbar__total-hours{font-size:var(--text-lg);font-weight:700;color:var(--color-text)}.day-entries{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;min-height:200px}.entry-row{display:flex;align-items:center;padding:var(--sp-4) var(--sp-5);border-bottom:1px solid var(--color-border-light);transition:background var(--transition);gap:var(--sp-4)}.entry-row:last-child{border-bottom:none}.entry-row:hover{background:var(--color-bg)}.entry-row:hover .entry-row__actions{opacity:1}.entry-row__color{width:4px;height:40px;border-radius:2px;flex-shrink:0}.entry-row__info{flex:1;min-width:0;cursor:pointer}.entry-row__project{display:flex;align-items:baseline;gap:var(--sp-2);margin-bottom:2px}.entry-row__project-name{font-size:var(--text-base);font-weight:600;color:var(--color-text)}.entry-row__client{font-size:var(--text-xs);color:var(--color-text-muted)}.entry-row__task{font-size:var(--text-sm);color:var(--color-text-secondary)}.entry-row__notes{font-size:var(--text-xs);color:var(--color-text-muted);margin-top:2px;font-style:italic}.entry-row__hours{font-size:var(--text-lg);font-weight:700;color:var(--color-text);min-width:60px;text-align:right;flex-shrink:0}.entry-row__actions{display:flex;gap:var(--sp-1);opacity:0;transition:opacity var(--transition);flex-shrink:0}.entry-row__action{width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition)}.entry-row__action:hover{background:var(--color-border-light);color:var(--color-text)}.entry-row__action--danger:hover{background:var(--color-danger-light);color:var(--color-danger)}.day-entries__footer{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-3) var(--sp-5);background:var(--color-bg);border-top:1px solid var(--color-border)}.day-entries__footer-label{font-size:var(--text-sm);font-weight:600;color:var(--color-text-secondary)}.day-entries__footer-hours{font-size:var(--text-lg);font-weight:800;color:var(--color-text)}.day-entries__empty{text-align:center;padding:var(--sp-16) var(--sp-8)}.day-entries__empty-icon{margin-bottom:var(--sp-4)}.day-entries__empty-title{font-size:var(--text-lg);font-weight:600;color:var(--color-text-secondary);margin-bottom:var(--sp-2)}.day-entries__empty-sub{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;margin:0 auto}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--sp-6)}.page-header__title{font-size:var(--text-2xl);font-weight:700;letter-spacing:-.02em}.page-header__actions{display:flex;align-items:center;gap:var(--sp-3)}.skin-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--sp-6)}.skin-card--elevated{box-shadow:var(--shadow)}.skin-tag{display:inline-flex;align-items:center;padding:2px 8px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:600;line-height:1.6;white-space:nowrap}.skin-tag--project{color:#fff}.skin-tag--client{background:var(--color-border-light);color:var(--color-text-secondary)}.avatar{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}.avatar--sm{width:26px;height:26px;font-size:10px}.login{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg)}.login__card{width:100%;max-width:380px;padding:var(--sp-10)}.login__logo{text-align:center;margin-bottom:var(--sp-6)}.login__logo-img{height:48px;width:auto}.login__subtitle{text-align:center;color:var(--color-text-secondary);font-size:var(--text-sm);margin-top:calc(-1 * var(--sp-4));margin-bottom:var(--sp-6)}.login__form{display:flex;flex-direction:column;gap:var(--sp-4)}.login__error{background:var(--color-danger-light);color:var(--color-danger);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius);font-size:var(--text-sm)}.dashboard__period-bar{display:flex;align-items:center;gap:var(--sp-2);margin-bottom:var(--sp-6);flex-wrap:wrap}.dashboard__date-inputs{display:flex;gap:var(--sp-2);align-items:center}.dashboard__total{text-align:right}.dashboard__total-label{font-size:var(--text-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.06em;font-weight:600}.dashboard__section-title{font-size:var(--text-base);font-weight:700;margin-bottom:var(--sp-4)}.dashboard__widget{padding:var(--sp-5);display:flex;flex-direction:column;gap:var(--sp-3)}.dashboard__widget-name{font-weight:600;font-size:var(--text-sm)}.dashboard__stat-number{font-size:var(--text-xl);font-weight:800;letter-spacing:-.03em}.dashboard__widget-list{font-size:var(--text-xs);color:var(--color-text-secondary);display:flex;flex-direction:column;gap:2px}.dashboard__widget-list-item{display:flex;justify-content:space-between}.dashboard__bar-chart{height:5px;background:var(--color-border-light);border-radius:3px;overflow:hidden}.dashboard__bar-chart-fill{height:100%;border-radius:3px;transition:width var(--transition-slow)}.report__filters{display:flex;gap:var(--sp-3);flex-wrap:wrap;align-items:flex-end;margin-bottom:var(--sp-6)}.report__filters .form-field{min-width:150px}.report__table th,.report__table td{padding:var(--sp-3) var(--sp-4);text-align:left;border-bottom:1px solid var(--color-border-light)}.report__table th{background:var(--color-bg);font-weight:600;font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-secondary)}.report__table tr:hover td{background:var(--color-primary-light)}.report__footer{display:flex;justify-content:space-between;align-items:center;padding:var(--sp-5)}.report__total{font-size:var(--text-xl);font-weight:800}.report__cost{font-size:var(--text-base);color:var(--color-text-secondary)}.clients-projects__list{display:flex;flex-direction:column;gap:1px}.clients-projects__item{display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-3) var(--sp-4);border-radius:var(--radius);cursor:pointer;transition:background var(--transition)}.clients-projects__item:hover{background:var(--color-bg)}.clients-projects__item--active{background:var(--color-primary-light)}.clients-projects__item-name{flex:1;font-weight:500;font-size:var(--text-sm)}.clients-projects__item-meta{font-size:var(--text-xs);color:var(--color-text-muted)}.clients-projects__item-actions{display:flex;gap:var(--sp-1);opacity:0;transition:opacity var(--transition)}.clients-projects__item:hover .clients-projects__item-actions{opacity:1}.clients-projects__color-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.form-field{display:flex;flex-direction:column;gap:var(--sp-1)}.form-label{font-size:var(--text-xs);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.04em}.form-input,.form-select,.form-textarea{padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);font-size:var(--text-base);color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition),box-shadow var(--transition)}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #f36c001f}.form-textarea{resize:vertical;min-height:72px}.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' fill='none' stroke='%237A7A6E' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:32px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--sp-2);padding:8px 20px;border-radius:var(--radius);font-size:var(--text-base);font-weight:600;cursor:pointer;transition:all var(--transition);white-space:nowrap;border:1px solid transparent}.btn--primary{background:var(--color-green);color:#fff}.btn--primary:hover{background:var(--color-green-dark)}.btn--ghost{color:var(--color-text-secondary);border-color:var(--color-border);background:var(--color-surface)}.btn--ghost:hover{background:var(--color-bg);color:var(--color-text)}.btn--danger{background:var(--color-danger);color:#fff}.btn--danger:hover{background:var(--color-danger-hover)}.btn--sm{padding:5px 12px;font-size:var(--text-sm)}.btn--icon{width:32px;height:32px;padding:0;border-radius:var(--radius)}.btn--icon svg{width:16px;height:16px}.btn--active{background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:flex-start;justify-content:center;z-index:1000;padding-top:80px;animation:fadeIn var(--transition) ease}.modal{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);width:100%;max-width:520px;max-height:85vh;overflow-y:auto;animation:modalIn var(--transition-slow) ease}.modal__header{display:flex;align-items:center;justify-content:space-between;padding:var(--sp-4) var(--sp-6);border-bottom:1px solid var(--color-border-light);background:var(--color-bg);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.modal__header h3{font-size:var(--text-base);font-weight:600}.modal__close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius);cursor:pointer;color:var(--color-text-muted);transition:all var(--transition);font-size:18px}.modal__close:hover{background:var(--color-border-light);color:var(--color-text)}.modal__body{padding:var(--sp-6) var(--sp-6) var(--sp-8);display:flex;flex-direction:column;gap:var(--sp-4)}.modal__footer{display:flex;justify-content:flex-end;gap:var(--sp-3);padding:var(--sp-4) var(--sp-6);border-top:1px solid var(--color-border-light)}.color-picker{display:flex;gap:var(--sp-2)}.color-picker__swatch{width:28px;height:28px;border-radius:50%;cursor:pointer;border:3px solid transparent;transition:all var(--transition)}.color-picker__swatch:hover{transform:scale(1.15)}.color-picker__swatch--selected{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-surface)}.toast-container{position:fixed;top:60px;right:var(--sp-6);z-index:9999;display:flex;flex-direction:column;gap:var(--sp-2)}.toast{padding:var(--sp-3) var(--sp-5);border-radius:var(--radius);font-size:var(--text-sm);font-weight:600;box-shadow:var(--shadow-md);animation:slideInRight var(--transition-slow) ease;max-width:360px}.toast--success{background:var(--color-success);color:#fff}.toast--error{background:var(--color-danger);color:#fff}.empty-state{text-align:center;padding:var(--sp-12) var(--sp-8);color:var(--color-text-muted)}.empty-state__text{font-size:var(--text-sm);margin-bottom:var(--sp-4)}.spinner{width:28px;height:28px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .6s linear infinite}.spinner--center{margin:var(--sp-12) auto}.search-select{position:relative}.search-select__trigger{width:100%;display:flex;align-items:center;gap:var(--sp-2);padding:8px 12px;border:1px solid var(--color-border);border-radius:var(--radius);background:var(--color-surface);cursor:pointer;transition:border-color var(--transition),box-shadow var(--transition);text-align:left;font-size:var(--text-base)}.search-select__trigger:hover{border-color:var(--color-text-muted)}.search-select__trigger--open{border-color:var(--color-primary);box-shadow:0 0 0 3px #f36c001f}.search-select__icon{display:flex;align-items:center;flex-shrink:0}.search-select__value{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-select__value--placeholder{color:var(--color-text-muted)}.search-select__chevron{flex-shrink:0;color:var(--color-text-muted);transition:transform var(--transition)}.search-select__clear{flex-shrink:0;color:var(--color-text-muted);display:flex;align-items:center;cursor:pointer;padding:2px;border-radius:var(--radius-sm);transition:color var(--transition),background var(--transition)}.search-select__clear:hover{color:var(--color-danger);background:var(--color-danger-light)}.search-select__trigger--open .search-select__chevron{transform:rotate(180deg)}.search-select__dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-md);z-index:50;animation:fadeIn .1s ease}.search-select__search{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);border-bottom:1px solid var(--color-border-light)}.search-select__search-input{flex:1;border:none;outline:none;background:none;font-size:var(--text-sm);padding:4px 0;color:var(--color-text)}.search-select__search-input::placeholder{color:var(--color-text-muted)}.search-select__options{max-height:220px;overflow-y:auto;padding:var(--sp-1) 0}.search-select__option{width:100%;display:flex;flex-direction:column;align-items:flex-start;gap:1px;padding:var(--sp-2) var(--sp-3);cursor:pointer;transition:background var(--transition);border:none;background:none;text-align:left;font-size:var(--text-sm);color:var(--color-text)}.search-select__option:hover{background:var(--color-bg)}.search-select__option--selected{background:var(--color-primary-light);font-weight:600}.search-select__option-label{line-height:1.3}.search-select__option-sub{font-size:var(--text-xs);color:var(--color-text-muted)}.search-select__empty{padding:var(--sp-4) var(--sp-3);text-align:center;font-size:var(--text-sm);color:var(--color-text-muted)}.asana-linked{display:flex;align-items:center;gap:var(--sp-2);padding:var(--sp-2) var(--sp-3);background:#fff4f0;border:1px solid #FDDDD5;border-radius:var(--radius);font-size:var(--text-sm);color:var(--color-text-secondary)}.asana-linked__name{font-weight:600;color:var(--color-text);flex:1}.asana-badge{display:inline-flex;align-items:center;color:var(--color-text-muted);transition:color var(--transition)}.asana-badge:hover{color:#f06a6a;text-decoration:none}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideInRight{0%{opacity:0;transform:translate(16px)}to{opacity:1;transform:translate(0)}}@keyframes modalIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 768px){.topbar__inner{padding:0 var(--sp-3)}.topbar__nav{gap:0}.topbar__link{padding:0 var(--sp-2);font-size:var(--text-sm)}.topbar__user-name{display:none}.container{padding:var(--sp-4) var(--sp-3)}.layout-grid-3,.layout-grid-2{grid-template-columns:1fr}.weekbar{flex-wrap:wrap}.weekbar__add-btn{width:48px;min-height:48px}.weekbar__add-label{display:none}.weekbar__days{min-width:0;overflow-x:auto}.weekbar__day{min-width:48px}}@media (max-width: 480px){.ts-day-header{flex-direction:column;align-items:flex-start;gap:var(--sp-2)}.ts-day-header__title{font-size:var(--text-xl)}.entry-row{flex-wrap:wrap}.entry-row__hours{min-width:auto}}.hidden{display:none!important}.text-muted{color:var(--color-text-muted)}.text-sm{font-size:var(--text-sm)}.text-right{text-align:right}.mt-4{margin-top:var(--sp-4)}.mb-4{margin-bottom:var(--sp-4)}.gap-2{gap:var(--sp-2)}.flex{display:flex}.items-center{align-items:center}
