:root{--bg-primary:#fff;--bg-secondary:#f5f5f7;--text-primary:#1d1d1f;--text-secondary:#86868b;--accent:#0071e3;--danger:#ff3b30;--success:#34c759;--warning:#ff9500;--border:#00000014;--card-bg:#ffffffe6;--shadow-card:0 2px 16px #0000000f;--shadow-bar:0 1px 0 #00000014;--pix-invert:0;color:var(--text-primary);background:var(--bg-secondary);-webkit-font-smoothing:antialiased;font-family:-apple-system,BlinkMacSystemFont,SF Pro Display,Segoe UI,sans-serif;font-size:16px;line-height:1.5}[data-theme=dark]{--bg-primary:#000;--bg-secondary:#1d1d1f;--text-primary:#f5f5f7;--text-secondary:#86868b;--border:#ffffff1a;--card-bg:#2c2c2ef2;--shadow-card:0 2px 16px #0000004d;--shadow-bar:0 1px 0 #ffffff0f;--pix-invert:1}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-secondary)}#root{min-height:100svh}@keyframes fadeUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse{0%,to{filter:brightness()drop-shadow(0 0 #0000)}50%{filter:brightness()drop-shadow(0 0 20px)}}.app{flex-direction:column;min-height:100svh;display:flex}.app-header{z-index:100;-webkit-backdrop-filter:blur(20px)saturate(180%);border-bottom:1px solid var(--border);background:#ffffffb8;position:sticky;top:0}[data-theme=dark] .app-header{background:#000000b8}.header-inner{justify-content:space-between;align-items:center;max-width:800px;height:56px;margin:0 auto;padding:0 24px;display:flex}.header-logo{align-items:center;gap:10px;display:flex}.header-logo-img{object-fit:contain;border-radius:6px;width:28px;height:28px}.header-title{color:var(--text-primary);letter-spacing:-.4px;font-size:19px;font-weight:600}.header-right{align-items:center;gap:8px;display:flex}.header-thin{font-weight:300}.profile-btn{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;border-radius:980px;align-items:center;gap:8px;padding:6px 14px 6px 6px;transition:all .2s;display:flex}.profile-btn:hover{filter:brightness(.95)}.profile-avatar{background:var(--accent);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:28px;height:28px;font-size:13px;font-weight:700;display:flex}.profile-name{color:var(--text-primary);font-size:13px;font-weight:500}.dark-toggle{cursor:pointer;color:var(--text-primary);background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:background .2s;display:flex}.dark-toggle:hover{background:var(--border)}.pix-btn{cursor:pointer;color:#1d1d1f;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;padding:8px;transition:background .2s;display:flex}.pix-btn:hover{background:#00000014}[data-theme=dark] .pix-btn{color:var(--accent)}[data-theme=dark] .pix-btn:hover{background:#0071e326}.summary-bar{background:var(--bg-primary);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:center;align-items:center;gap:0;padding:12px 24px;display:flex}.summary-item{flex-direction:column;align-items:center;padding:4px 32px;display:flex}.summary-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.7px;font-size:10px;font-weight:600}.summary-value{color:var(--text-primary);letter-spacing:-.3px;margin-top:2px;font-size:20px;font-weight:600}.summary-value.accent{color:var(--accent)}.summary-divider{background:var(--border);align-self:center;width:1px;height:28px}.client-filter-bar{background:var(--bg-primary);border-bottom:1px solid var(--border);padding:10px 24px}.client-pills{-webkit-overflow-scrolling:touch;scrollbar-width:none;align-items:center;gap:8px;max-width:800px;margin:0 auto;display:flex;overflow-x:auto}.client-pills::-webkit-scrollbar{display:none}.client-pill{background:var(--bg-secondary);color:var(--text-secondary);border:1.5px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:980px;flex-shrink:0;align-items:center;gap:6px;padding:6px 14px;font-family:inherit;font-size:13px;font-weight:500;transition:all .15s;display:inline-flex}.client-pill:hover{border-color:var(--accent);color:var(--accent)}.client-pill.active{background:var(--accent);color:#fff;border-color:var(--accent)}.client-pill.active:hover{filter:brightness(1.1)}.client-pill-dot{opacity:.85;border-radius:50%;flex-shrink:0;width:7px;height:7px}.client-pill.active .client-pill-dot{opacity:1;filter:brightness(2)}.client-pill-name{text-overflow:ellipsis;max-width:160px;overflow:hidden}.client-pill-edit{opacity:0;cursor:pointer;border-radius:4px;padding:2px;font-size:11px;transition:opacity .15s}.client-pill:hover .client-pill-edit{opacity:.7}.client-pill.active .client-pill-edit{opacity:.8}.client-pill-add{color:var(--accent);border-style:dashed;border-color:#0071e34d}.client-pill-add:hover{background:#0071e30f}.btn-delete-client{border:1px solid var(--danger);width:100%;color:var(--danger);cursor:pointer;background:0 0;border-radius:10px;margin-top:4px;padding:10px;font-family:inherit;font-size:13px;transition:background .15s}.btn-delete-client:hover{background:#ff3b300f}.view-tabs{gap:0;width:100%;max-width:800px;margin:0 auto;padding:16px 24px 0;display:flex}.view-tab{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-bottom:2px solid #0000;padding:10px 24px;font-family:inherit;font-size:15px;font-weight:500;transition:all .2s}.view-tab:hover{color:var(--text-primary)}.view-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.period-nav{justify-content:space-between;align-items:center;width:100%;max-width:800px;margin:0 auto;padding:12px 24px;display:flex}.period-arrow{background:var(--card-bg);border:1px solid var(--border);cursor:pointer;width:36px;height:36px;color:var(--text-primary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:20px;transition:all .15s;display:flex}.period-arrow:hover{background:var(--bg-secondary);filter:brightness(.95)}.period-center{flex:1;justify-content:center;align-items:center;gap:12px;display:flex}.period-label{color:var(--text-primary);letter-spacing:-.2px;text-transform:capitalize;text-align:center;font-size:16px;font-weight:600}.period-nav-side{justify-content:center;align-items:center;min-width:60px;display:flex}.btn-ghost{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:980px;padding:4px 12px;font-family:inherit;font-size:12px;font-weight:500;transition:all .15s}.btn-ghost:hover{color:var(--text-primary);border-color:var(--text-primary)}.main-content{width:100%;max-width:800px;margin:0 auto;padding:0 24px 48px}.view-content{flex-direction:column;gap:24px;display:flex}.card{background:var(--card-bg);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);box-shadow:var(--shadow-card);border-radius:18px;animation:.3s both fadeUp}.entry-form{padding:24px}.form-title{color:var(--text-primary);letter-spacing:-.4px;margin-bottom:20px;font-size:20px;font-weight:600}.form-grid{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-field{flex-direction:column;gap:4px;display:flex}.form-field.full-width{grid-column:1/-1}.form-field label{color:var(--text-secondary);letter-spacing:.2px;text-transform:uppercase;font-size:12px;font-weight:600}.form-field input,.form-field textarea,.form-field select{background:var(--bg-secondary);border:1.5px solid var(--border);color:var(--text-primary);border-radius:10px;outline:none;width:100%;min-height:44px;padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .2s,box-shadow .2s}.form-field input:focus,.form-field textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #0071e31f}.form-field input.readonly{color:var(--text-secondary);cursor:default}.form-field input.accent-field{color:var(--accent);font-weight:600}.form-field textarea{resize:vertical;min-height:80px}.field-error{color:var(--danger);font-size:11px}.field-hint{color:var(--text-secondary);margin-top:2px;font-size:11px}.form-actions{justify-content:flex-end;gap:8px;margin-top:20px;display:flex}.form-accordion{overflow:hidden}.form-accordion-header{cursor:pointer;width:100%;color:var(--text-primary);background:0 0;border:none;justify-content:space-between;align-items:center;padding:16px 24px;font-family:inherit;transition:background .15s;display:flex}.form-accordion-header:hover{background:var(--bg-secondary)}.form-accordion-label{color:var(--text-primary);align-items:center;gap:8px;font-size:15px;font-weight:600;display:flex}.form-accordion-chevron{color:var(--text-secondary);flex-shrink:0;transition:transform .2s}.form-accordion-chevron.open{transform:rotate(180deg)}.form-accordion .entry-form{border-top:1px solid var(--border);padding-top:0}.btn-primary{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:980px;min-height:44px;padding:12px 28px;font-family:inherit;font-size:15px;font-weight:500;transition:all .2s}.btn-primary:hover{filter:brightness(1.1);transform:scale(1.02)}.btn-primary:active{transform:scale(.98)}.btn-primary.btn-success{background:var(--success);pointer-events:none}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1.5px solid var(--border);cursor:pointer;border-radius:980px;min-height:44px;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:500;transition:all .2s}.btn-secondary:hover{filter:brightness(.95)}.btn-export{background:var(--bg-secondary);color:var(--text-primary);border:1.5px solid var(--border);cursor:pointer;white-space:nowrap;border-radius:980px;align-items:center;gap:6px;padding:8px 16px;font-family:inherit;font-size:13px;font-weight:500;transition:all .2s;display:flex}.btn-export:hover{border-color:var(--accent);color:var(--accent)}.btn-export:disabled{opacity:.5;cursor:default}.btn-export-ir{color:#1a7a35;border-color:#34c75966}[data-theme=dark] .btn-export-ir{color:var(--success)}.btn-export-ir:hover{border-color:var(--success)!important;color:var(--success)!important}.btn-logout{width:100%;color:var(--danger);cursor:pointer;background:#ff3b301a;border:1.5px solid #ff3b304d;border-radius:10px;justify-content:center;align-items:center;gap:8px;min-height:44px;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:500;transition:all .2s;display:flex}.btn-logout:hover{border-color:var(--danger);background:#ff3b3026;transform:translateY(-1px)}.btn-logout:active{transform:translateY(0)}.day-section{flex-direction:column;gap:12px;display:flex}.day-section-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;padding:0 4px;display:flex}.day-section-info{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.day-section-date{color:var(--text-primary);font-size:14px;font-weight:600}.day-section-count{color:var(--text-secondary);font-size:13px}.day-section-hours{color:var(--text-primary);font-size:13px;font-weight:600}.day-section-value{color:var(--accent);font-size:13px;font-weight:600}.day-dot{color:var(--border);font-size:12px}.entries-list{flex-direction:column;gap:10px;display:flex}.entry-card{justify-content:space-between;align-items:flex-start;gap:16px;padding:16px;transition:box-shadow .2s,transform .2s;display:flex}.entry-card:hover{transform:translateY(-1px);box-shadow:0 8px 32px #0000001a}.entry-card-main{flex-direction:column;flex:1;gap:8px;min-width:0;display:flex}.entry-time{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.time-badge{color:var(--text-primary);font-size:15px;font-weight:600}.entry-meta{flex-direction:column;gap:4px;display:flex}.entry-meta-top{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.entry-project{color:var(--accent);font-size:14px;font-weight:600}.entry-client-badge{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);white-space:nowrap;border-radius:980px;padding:2px 8px;font-size:11px;font-weight:500}.entry-description{color:var(--text-secondary);white-space:nowrap;text-overflow:ellipsis;font-size:12px;overflow:hidden}.entry-stats{gap:16px;display:flex}.stat{flex-direction:column;display:flex}.stat-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.4px;font-size:10px;font-weight:600}.stat-value{color:var(--text-primary);font-size:14px;font-weight:600}.stat-value.accent{color:var(--accent)}.entry-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.action-btn{cursor:pointer;min-width:36px;min-height:36px;color:var(--text-primary);background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;padding:8px;font-size:15px;transition:background .15s;display:flex}.action-btn:hover{background:var(--bg-secondary)}.action-btn:disabled{opacity:.5;cursor:default}.delete-confirm{align-items:center;gap:6px;font-size:12px;animation:.15s both fadeUp;display:flex}.delete-confirm span{color:var(--text-secondary)}.confirm-yes,.confirm-no{cursor:pointer;border:none;border-radius:980px;min-height:28px;padding:4px 10px;font-family:inherit;font-size:12px;font-weight:500}.confirm-yes{background:var(--danger);color:#fff}.confirm-no{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border)}.period-summary{padding:20px 24px}.period-summary-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;display:flex}.period-summary-title{color:var(--text-primary);font-size:18px;font-weight:600}.period-summary-sub{color:var(--text-secondary);margin-top:2px;font-size:13px}.period-totals{border-top:1px solid var(--border);gap:0;padding-top:16px;display:flex}.period-total-item{flex-direction:column;flex:1;align-items:center;display:flex}.period-total-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.6px;font-size:10px;font-weight:600}.period-total-value{color:var(--text-primary);margin-top:4px;font-size:18px;font-weight:600}.period-total-value.accent{color:var(--accent)}.year-export-btns{flex-wrap:wrap;gap:8px;display:flex}.month-days-list{flex-direction:column;gap:10px;display:flex}.month-day-card{text-align:left;cursor:pointer;background:var(--card-bg);border:1px solid var(--border);width:100%;color:var(--text-primary);border-radius:12px;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;transition:box-shadow .2s,transform .2s;display:flex}.month-day-card:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0000001a}.month-day-left{flex-direction:column;gap:2px;display:flex}.month-day-date{color:var(--text-primary);font-size:15px;font-weight:600}.month-day-name,.month-day-count{color:var(--text-secondary);font-size:12px}.month-day-clients{flex-wrap:wrap;gap:4px;margin-top:4px;display:flex}.month-day-client-badge{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);white-space:nowrap;border-radius:980px;padding:2px 8px;font-size:11px;font-weight:500}.month-day-right{align-items:center;gap:12px;display:flex}.month-day-hours{color:var(--text-primary);font-size:14px;font-weight:600}.month-day-value{color:var(--accent);font-size:14px;font-weight:600}.month-day-arrow{color:var(--text-secondary)}.year-months-grid{grid-template-columns:repeat(3,1fr);gap:12px;display:grid}.year-month-card{cursor:pointer;text-align:left;background:var(--card-bg);border:1px solid var(--border);min-height:100px;color:var(--text-primary);border-radius:12px;flex-direction:column;gap:4px;padding:16px;transition:box-shadow .2s,transform .2s;display:flex}.year-month-card.has-data:hover{transform:translateY(-1px);box-shadow:0 6px 24px #0000001a}.year-month-card.no-data{opacity:.45;cursor:default}.year-month-name{color:var(--text-primary);font-size:14px;font-weight:600}.year-month-hours{color:var(--text-secondary);margin-top:4px;font-size:13px}.year-month-value{color:var(--accent);font-size:15px;font-weight:700}.year-month-count{color:var(--text-secondary);margin-top:2px;font-size:11px}.year-month-empty{color:var(--border);margin-top:8px;font-size:20px}.year-month-clients{flex-wrap:wrap;gap:3px;margin-top:4px;display:flex}.year-month-client-badge{color:var(--text-secondary);background:var(--bg-secondary);border:1px solid var(--border);white-space:nowrap;border-radius:980px;padding:1px 6px;font-size:10px;font-weight:500}.empty-state{text-align:center;padding:48px 24px;animation:.4s both fadeUp}.empty-icon{margin-bottom:16px;font-size:48px}.empty-title{color:var(--text-primary);margin-bottom:8px;font-size:20px;font-weight:600}.empty-subtitle{color:var(--text-secondary);font-size:14px}.modal-overlay{z-index:1000;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;justify-content:center;align-items:center;padding:24px;animation:.2s both fadeUp;display:flex;position:fixed;inset:0}.modal-box{width:100%;max-width:420px;padding:28px;animation:.25s both fadeUp}.modal-header{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.modal-title{color:var(--text-primary);letter-spacing:-.3px;font-size:20px;font-weight:600}.modal-subtitle{color:var(--text-secondary);margin-top:4px;font-size:13px}.modal-close{background:var(--bg-secondary);border:1px solid var(--border);cursor:pointer;width:32px;height:32px;color:var(--text-secondary);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:14px;display:flex}.profile-form{flex-direction:column;gap:16px;display:flex}.color-picker-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex;position:relative}.color-swatch{cursor:pointer;border:2.5px solid #0000;border-radius:50%;flex-shrink:0;width:28px;height:28px;transition:transform .15s,box-shadow .15s}.color-swatch:hover{transform:scale(1.15)}.color-swatch.selected{box-shadow:0 0 0 2px var(--bg-primary), 0 0 0 4px currentColor;transform:scale(1.1)}.color-swatch-custom{color:var(--text-secondary);justify-content:center;align-items:center;font-size:16px;font-weight:400;display:flex;background:var(--bg-tertiary,#e5e5ea)!important}.color-swatch-custom.selected{color:#fff}.receipt{color:#1d1d1f;background:#fff;border:none;width:380px;font-family:Courier New,Courier,monospace;overflow:hidden}.receipt-wide{width:440px}.receipt-header{text-align:center;padding:20px 24px 14px}.receipt-app-name{color:#1d1d1f;letter-spacing:.3px;justify-content:center;align-items:center;gap:7px;font-size:15px;font-weight:700;display:flex}.receipt-title{color:#555;text-transform:uppercase;letter-spacing:1.2px;margin-top:6px;font-size:11px;font-weight:700}.receipt-period{color:#1d1d1f;margin-top:4px;font-size:12px;font-weight:600}.receipt-id{color:#999;word-break:break-all;margin-top:6px;font-size:9px}.receipt-section-label{color:#888;text-transform:uppercase;letter-spacing:1.2px;padding:8px 24px 3px;font-size:9px;font-weight:700}.receipt-section-label.ir-section{color:#1d1d1f}.receipt-row{justify-content:space-between;align-items:baseline;padding:5px 24px;font-size:12px;display:flex}.receipt-row .label{color:#666;font-weight:400}.receipt-row .value{color:#1d1d1f;text-align:right;word-break:break-word;max-width:65%;font-weight:600}.receipt-divider{border:none;border-top:1px dashed #0000002e;margin:6px 24px}.receipt-total{text-align:center;padding:14px 24px}.receipt-total .label{color:#888;text-transform:uppercase;letter-spacing:1px;font-size:9px;font-weight:700}.receipt-total .amount{color:#1d1d1f;letter-spacing:-1px;margin-top:6px;font-size:28px;font-weight:700}.receipt-footer{text-align:center;color:#999;padding:12px 24px;font-size:9px;line-height:1.6}.receipt-entry-row{border-bottom:1px dashed #00000014;grid-template-columns:20px 80px 1fr 40px 80px;align-items:center;gap:4px;padding:5px 24px;font-size:11px;display:grid}.receipt-entry-index{color:#999}.receipt-entry-time{color:#1d1d1f;font-variant-numeric:tabular-nums}.receipt-entry-proj{color:#1d1d1f;text-overflow:ellipsis;white-space:nowrap;font-weight:600;overflow:hidden}.receipt-entry-hrs{text-align:right;color:#555}.receipt-entry-val{text-align:right;color:#1d1d1f;font-weight:700}.receipt-table-header{color:#888;text-transform:uppercase;letter-spacing:.8px;background:#f5f5f5;justify-content:space-between;padding:5px 24px;font-size:9px;font-weight:700;display:flex}.receipt-table-header.ir-table-header span:last-child{text-align:right}.receipt-table-row{color:#1d1d1f;border-bottom:1px dashed #00000014;justify-content:space-between;padding:5px 24px;font-size:11px;display:flex}.receipt-table-row.receipt-table-row-empty{color:#bbb}.receipt-table-row span:not(:first-child){text-align:right}.punch-card{flex-direction:column;gap:12px;padding:16px;animation:.25s both fadeUp;display:flex}.punch-header{justify-content:space-between;align-items:center;display:flex}.punch-header-left{align-items:center;gap:6px;display:flex}.punch-clock-icon{color:var(--text-secondary);flex-shrink:0}.punch-title{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px;font-size:12px;font-weight:700}.punch-discard{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-radius:6px;align-items:center;gap:4px;padding:4px 8px;font-size:11px;font-weight:500;transition:background .15s,color .15s;display:flex}.punch-discard:hover{color:var(--danger);background:#ff3b3014}.punch-active-info{justify-content:space-between;align-items:center;padding:0 2px;display:flex}.punch-active-time{color:var(--text-primary);font-size:13px}.punch-active-time strong{font-variant-numeric:tabular-nums}.punch-active-date{color:var(--text-secondary);font-size:11px}.slide-track{background:var(--bg-secondary);-webkit-user-select:none;user-select:none;border:1px solid var(--border);border-radius:28px;height:56px;position:relative;overflow:hidden}.slide-fill{background:var(--slide-accent);pointer-events:none;border-radius:28px;position:absolute;top:0;bottom:0;left:0}.slide-chevrons{color:var(--text-secondary);pointer-events:none;gap:2px;display:flex;position:absolute;top:50%;left:68px;transform:translateY(-50%)}.slide-label{color:var(--text-secondary);pointer-events:none;justify-content:center;align-items:center;padding-left:48px;font-size:13px;font-weight:600;display:flex;position:absolute;inset:0}.slide-thumb{background:var(--slide-accent);cursor:grab;touch-action:none;z-index:1;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;display:flex;position:absolute;top:4px;box-shadow:0 2px 12px #0000002e}.slide-thumb:active{cursor:grabbing}.punch-complete{flex-direction:column;gap:10px;display:flex}.punch-time-summary{background:var(--bg-secondary);border-radius:10px;flex-wrap:wrap;align-items:center;gap:8px;padding:10px 14px;display:flex}.punch-times{color:var(--text-primary);font-variant-numeric:tabular-nums;flex:1;font-size:15px;font-weight:600}.punch-arrow{color:var(--text-secondary);margin:0 2px}.punch-hrs-badge,.punch-val-badge{background:var(--card-bg);border:1px solid var(--border);color:var(--text-primary);white-space:nowrap;border-radius:20px;padding:3px 8px;font-size:12px;font-weight:600}.punch-val-badge{color:var(--accent)}.punch-field{flex-direction:column;gap:4px;display:flex}.punch-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:11px;font-weight:600}.punch-field input,.punch-field select,.punch-field textarea{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-primary);resize:none;border-radius:8px;padding:8px 10px;font-family:inherit;font-size:14px;transition:border-color .15s}.punch-field input:focus,.punch-field select:focus,.punch-field textarea:focus{border-color:var(--accent);outline:none}.punch-field.has-error input{border-color:var(--danger)}.punch-field-error{color:var(--danger);font-size:11px}.req{color:var(--danger)}.punch-optional{color:var(--text-secondary);text-transform:none;letter-spacing:0;font-weight:400}.punch-fields-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.punch-actions{gap:8px;padding-top:2px;display:flex}.punch-btn-discard{border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;background:0 0;border-radius:10px;flex:none;padding:10px 16px;font-size:13px;font-weight:500;transition:background .15s,color .15s}.punch-btn-discard:hover{color:var(--danger);background:#ff3b300f}.punch-btn-save{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;flex:1;padding:10px 16px;font-size:13px;font-weight:600;transition:opacity .15s,transform .12s}.punch-btn-save:hover:not(:disabled){opacity:.88;transform:scale(1.01)}.punch-btn-save.saved{background:var(--success)}.punch-btn-save:disabled{opacity:.7;cursor:default}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:.8s linear infinite spin}.empty-icon-svg{color:var(--text-tertiary,#c7c7cc);margin:0 auto 16px;display:block}.btn-ghost-icon{cursor:pointer;color:var(--text-secondary);background:0 0;border:none;border-radius:8px;align-items:center;padding:6px;transition:background .15s;display:flex}.btn-ghost-icon:hover{background:var(--bg-tertiary)}.login-page{background:var(--bg-secondary);justify-content:center;align-items:center;min-height:100svh;padding:24px;display:flex}.login-container{flex-direction:column;gap:32px;width:100%;max-width:360px;animation:.4s both fadeUp;display:flex}.login-header{text-align:center}.login-header h1{color:var(--text-primary);letter-spacing:-.6px;margin-bottom:8px;font-size:32px;font-weight:700}.login-header p{color:var(--text-secondary);letter-spacing:-.3px;font-size:16px}.login-form{flex-direction:column;gap:16px;display:flex}.login-error{color:var(--danger);text-align:center;background:#ff3b301a;border:1px solid #ff3b304d;border-radius:8px;padding:12px 16px;font-size:14px;animation:.3s both fadeUp}.login-email-form{flex-direction:column;gap:16px;display:flex}.login-field{flex-direction:column;gap:8px;display:flex}.login-field label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-size:12px;font-weight:600}.login-input-wrapper{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-secondary);border-radius:10px;align-items:center;gap:10px;padding:0 12px;display:flex}.login-input-wrapper input{color:var(--text-primary);background:0 0;border:none;outline:none;flex:1;padding:12px 0;font-family:inherit;font-size:15px}.login-input-wrapper input::placeholder{color:var(--text-secondary)}.login-input-wrapper input:focus{color:var(--text-primary)}.login-button-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:10px;padding:12px 24px;font-size:15px;font-weight:600;transition:all .2s}.login-button-submit:hover:not(:disabled){opacity:.9;transform:scale(1.01)}.login-button-submit:disabled{opacity:.6;cursor:not-allowed}.login-success{text-align:center;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;flex-direction:column;align-items:center;gap:16px;padding:32px 24px;display:flex}.login-success-icon{background:var(--success);color:#fff;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;font-size:28px;font-weight:700;display:flex}.login-success h2{color:var(--text-primary);margin:0;font-size:20px;font-weight:600}.login-success p{color:var(--text-secondary);margin:0;font-size:14px}.login-success p strong{color:var(--text-primary);font-weight:600}.login-success-subtitle{color:var(--text-secondary)!important;font-size:13px!important}.login-button-back{background:var(--bg-primary);color:var(--text-secondary);border:1px solid var(--border);cursor:pointer;border-radius:8px;margin-top:8px;padding:10px 16px;font-size:14px;font-weight:500;transition:all .2s}.login-button-back:hover{background:var(--bg-secondary);color:var(--text-primary)}.login-footer{text-align:center;color:var(--text-secondary);margin-top:8px;font-size:13px}.login-button-google{background:var(--bg-primary);border:1.5px solid var(--border);color:var(--text-primary);cursor:pointer;border-radius:10px;justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s;display:flex}.login-button-google:hover:not(:disabled){background:var(--bg-secondary);border-color:var(--accent);transform:translateY(-1px);box-shadow:0 2px 8px #00000014}.login-button-google:disabled{opacity:.6;cursor:not-allowed}.login-button-google-full{border:1.5px solid var(--border);width:100%;color:var(--text-primary);cursor:pointer;background:#fff;border-radius:10px;justify-content:center;align-items:center;gap:12px;padding:14px 24px;font-family:inherit;font-size:15px;font-weight:600;transition:all .2s;display:flex;box-shadow:0 1px 3px #0000000d}.login-button-google-full:hover:not(:disabled){background:var(--bg-secondary);border-color:#4285f4;transform:translateY(-2px);box-shadow:0 4px 12px #4285f433}.login-button-google-full:active:not(:disabled){transform:translateY(0)}.login-button-google-full:disabled{opacity:.6;cursor:not-allowed}.loading-page,.auth-callback-page{background:var(--bg-secondary);flex-direction:column;justify-content:center;align-items:center;gap:16px;min-height:100svh;display:flex}.loading-page p,.auth-callback-page p{color:var(--text-secondary);letter-spacing:-.3px;font-size:16px}.spinner{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:.8s linear infinite spin}@media (width<=600px){.summary-item{padding:4px 16px}.summary-divider{display:none}.summary-value{font-size:16px}.view-tabs{padding:12px 16px 0}.view-tab{padding:8px 16px;font-size:14px}.period-nav{padding:10px 16px}.period-label{font-size:14px}.main-content{padding:0 16px 48px}.form-grid{grid-template-columns:1fr}.form-field.full-width{grid-column:1}.year-months-grid{grid-template-columns:repeat(2,1fr)}.entry-card{flex-direction:column}.entry-actions{align-self:flex-end}.period-summary-header,.year-export-btns{flex-direction:column}.login-header h1{font-size:28px}.login-button-google{padding:11px 20px;font-size:14px}}
