:root,[data-theme=light]{--primary: #6366f1;--primary-hover: #4f46e5;--primary-light: #eef2ff;--success: #10b981;--success-bg: #ecfdf5;--danger: #ef4444;--danger-bg: #fef2f2;--warning: #f59e0b;--warning-bg: #fffbeb;--info: #3b82f6;--info-bg: #eff6ff;--text: #1f2937;--text-muted: #6b7280;--border: #e5e7eb;--bg: #f9fafb;--white: #ffffff;--shadow: 0 1px 3px rgba(0, 0, 0, .08), 0 1px 2px rgba(0, 0, 0, .06);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--radius: 12px;--radius-sm: 8px}[data-theme=dark]{--primary: #818cf8;--primary-hover: #6366f1;--primary-light: #1e1b4b;--success: #34d399;--success-bg: #064e3b;--danger: #f87171;--danger-bg: #450a0a;--warning: #fbbf24;--warning-bg: #451a03;--info: #60a5fa;--info-bg: #172554;--text: #f1f5f9;--text-muted: #94a3b8;--border: #334155;--bg: #0f172a;--white: #1e293b;--shadow: 0 1px 3px rgba(0, 0, 0, .3), 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3), 0 2px 4px rgba(0, 0, 0, .2);--shadow-lg: 0 10px 15px rgba(0, 0, 0, .4), 0 4px 6px rgba(0, 0, 0, .3);color-scheme:dark}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased;overflow-x:hidden;padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding-bottom:2rem}.loading-screen,.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-muted);font-size:1rem}.navbar{background:var(--white);border-bottom:1px solid var(--border);padding:0 1rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow)}.navbar-inner{max-width:1200px;margin:0 auto;display:flex;align-items:center;height:60px;gap:1.5rem}.navbar-brand a{font-size:1.25rem;font-weight:700;color:var(--primary);text-decoration:none}.navbar-links{display:flex;gap:.25rem;flex:1}.navbar-links a{padding:.5rem .875rem;border-radius:var(--radius-sm);text-decoration:none;color:var(--text-muted);font-weight:500;font-size:.9rem;transition:all .15s}.navbar-links a:hover{color:var(--text);background:var(--bg)}.navbar-links a.active{color:var(--primary);background:var(--primary-light)}.navbar-user{display:flex;align-items:center;gap:.75rem}.navbar-username{font-weight:500;font-size:.9rem;color:var(--text-muted)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 1rem;background:linear-gradient(135deg,var(--primary-light) 0%,var(--bg) 100%)}.auth-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow-lg);padding:2.5rem;width:100%;max-width:420px}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.75rem;color:var(--primary);margin-bottom:.25rem}.auth-header p{color:var(--text-muted)}.auth-form{display:flex;flex-direction:column;gap:1rem}.auth-footer{text-align:center;margin-top:1.5rem;color:var(--text-muted);font-size:.9rem}.auth-footer a{color:var(--primary);text-decoration:none;font-weight:500}.auth-footer a:hover{text-decoration:underline}.page{max-width:1200px;margin:0 auto;padding:1.5rem 1rem;overflow-x:hidden}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.page-header h1{font-size:1.5rem;font-weight:700}.text-muted{color:var(--text-muted)}.card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.5rem;margin-bottom:1.5rem}.card h2{font-size:1.1rem;font-weight:600;margin-bottom:1rem}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.card-header h2{margin-bottom:0}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.stats-grid-3{grid-template-columns:repeat(3,1fr)}.stats-grid-4{grid-template-columns:repeat(4,1fr)}.stat-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);padding:1.25rem}.stat-card.highlight{background:linear-gradient(135deg,var(--primary),var(--primary-hover));color:#fff}.stat-card.highlight .stat-label{color:#ffffffd9}.stat-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600;margin-bottom:.25rem}.stat-value{font-size:1.5rem;font-weight:700}.stat-value.accent{color:var(--primary)}.stat-sub{font-size:.8rem;color:var(--text-muted);margin-top:.25rem}.stat-sub.overtime{color:var(--warning);font-weight:500}.overtime-value{color:var(--warning)}.month-nav{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-bottom:1.5rem;flex-wrap:wrap}.month-label{font-size:1.1rem;font-weight:600;min-width:180px;text-align:center}.form-group{display:flex;flex-direction:column;gap:.375rem;flex:1}.form-group label{font-size:.875rem;font-weight:500;color:var(--text)}.form-group input,.form-group select,.form-group textarea{padding:.625rem .875rem;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:.95rem;font-family:inherit;transition:border-color .15s,box-shadow .15s;background:var(--white)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f126}.form-row{display:flex;gap:1rem}.form-actions{display:flex;gap:.75rem;margin-top:.5rem}.form-card{border:2px solid var(--primary-light)}.entry-form{display:flex;flex-direction:column;gap:1rem}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.375rem;padding:.625rem 1.25rem;font-size:.9rem;font-weight:500;font-family:inherit;border-radius:var(--radius-sm);border:1.5px solid transparent;cursor:pointer;transition:all .15s;text-decoration:none}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--primary);color:#fff;border-color:var(--primary)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);border-color:var(--primary-hover)}.btn-outline{background:var(--white);color:var(--text);border-color:var(--border)}.btn-outline:hover:not(:disabled){background:var(--bg);border-color:var(--text-muted)}.btn-ghost{background:transparent;color:var(--text-muted);border:none;padding:.375rem .75rem}.btn-ghost:hover:not(:disabled){background:var(--bg);color:var(--text)}.btn-danger{color:var(--danger)}.btn-danger:hover:not(:disabled){background:var(--danger-bg);color:var(--danger)}.btn-sm{padding:.375rem .75rem;font-size:.8rem}.btn-block{width:100%}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:1rem}.alert-error{background:var(--danger-bg);color:var(--danger);border:1px solid #fecaca}.alert-success{background:var(--success-bg);color:#047857;border:1px solid #a7f3d0}.alert-info{background:var(--info-bg);color:var(--info);border:1px solid #bfdbfe}.alert a{color:inherit;font-weight:600}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border);font-size:.9rem}.table th{font-weight:600;color:var(--text-muted);font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.table tfoot td{font-weight:600;border-top:2px solid var(--border);border-bottom:none}.entries-list{display:flex;flex-direction:column;gap:.5rem}.entry-card{display:flex;align-items:center;justify-content:space-between;background:var(--white);border-radius:var(--radius-sm);box-shadow:var(--shadow);padding:1rem 1.25rem;gap:1rem;transition:box-shadow .15s}.entry-card:hover{box-shadow:var(--shadow-md)}.entry-card.overtime{border-left:3px solid var(--warning)}.entry-info{flex:1;min-width:0}.entry-date{font-weight:600;margin-bottom:.125rem}.entry-hours{font-size:1.1rem;font-weight:700;color:var(--primary)}.entry-comment{font-size:.85rem;color:var(--text-muted);margin-top:.25rem}.overtime-badge{font-size:.75rem;background:var(--warning-bg);color:var(--warning);padding:.125rem .5rem;border-radius:99px;margin-left:.5rem;font-weight:500}.entry-actions{display:flex;gap:.25rem;flex-shrink:0}.pay-month-badge{display:inline-block;font-size:.7rem;background:var(--info-bg);color:var(--info);padding:.1rem .4rem;border-radius:4px;margin-left:.5rem;font-weight:600;vertical-align:middle}.empty-state{text-align:center;padding:2rem;color:var(--text-muted)}.empty-state .btn{margin-top:1rem}.salary-params .params-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.param{display:flex;flex-direction:column}.param-label{font-size:.8rem;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.param-value{font-size:1.25rem;font-weight:700}.charts-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem;margin-bottom:1.5rem}.chart-card{margin-bottom:0}.chart-container{margin-top:.5rem}.input-mode-toggle{display:flex;gap:0;margin-bottom:1rem;border-radius:var(--radius-sm);overflow:hidden;border:1.5px solid var(--border)}.toggle-btn{flex:1;padding:.5rem 1rem;border:none;background:var(--white);color:var(--text-muted);font-size:.85rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s}.toggle-btn.active{background:var(--primary);color:#fff}.toggle-btn:not(.active):hover{background:var(--bg)}.auto-calc-info{padding:.5rem .75rem;background:var(--success-bg);border-radius:var(--radius-sm);color:#047857;font-size:.9rem;border:1px solid #a7f3d0}.entry-time{font-size:.85rem;color:var(--text-muted);margin-bottom:.125rem}.admin-badge{display:inline-block;font-size:.65rem;background:var(--primary);color:#fff;padding:.1rem .4rem;border-radius:4px;margin-left:.5rem;text-transform:uppercase;font-weight:700;letter-spacing:.05em;vertical-align:middle}.nav-admin{color:var(--primary)!important;font-weight:600!important}.role-badge{display:inline-block;font-size:.75rem;padding:.15rem .5rem;border-radius:4px;font-weight:600;text-transform:uppercase}.role-badge.admin{background:var(--primary-light);color:var(--primary)}.role-badge.user{background:var(--bg);color:var(--text-muted)}.admin-actions{display:flex;gap:.25rem;flex-wrap:wrap}.params-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem}.theme-toggle{background:none;border:none;color:var(--text-muted);cursor:pointer;padding:.375rem;border-radius:var(--radius-sm);display:flex;align-items:center;transition:all .15s}.theme-toggle:hover{background:var(--bg);color:var(--text)}.toast-container{position:fixed;bottom:1.5rem;right:1.5rem;z-index:1000;display:flex;flex-direction:column;gap:.5rem}.toast{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border-radius:var(--radius-sm);font-size:.9rem;font-weight:500;box-shadow:var(--shadow-lg);animation:toast-in .3s ease,toast-out .3s ease 2.7s forwards}.toast-success{background:#059669;color:#fff}.toast-error{background:var(--danger);color:#fff}@keyframes toast-in{0%{opacity:0;transform:translateY(1rem)}to{opacity:1;transform:translateY(0)}}@keyframes toast-out{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(1rem)}}.week-divider{display:flex;align-items:center;justify-content:space-between;padding:.375rem .75rem;font-size:.8rem;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-top:.5rem}.week-divider:before{content:"";flex:1;height:1px;background:var(--border);margin-right:.75rem;display:none}.week-total{color:var(--primary);font-weight:700}.entry-earn{font-size:.85rem;font-weight:500;color:var(--text-muted)}.settings-form{display:flex;flex-direction:column;gap:1rem}.table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.schedule-compare{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.5rem}.compare-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:.75rem;text-align:center}.compare-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.25rem}.compare-value{font-size:1.6rem;font-weight:700}.compare-value.plan{color:var(--primary)}.compare-value.fact,.compare-value.positive{color:#22c55e}.compare-value.negative{color:#ef4444}.compare-value.forecast{color:#6366f1;font-size:1.3rem}.compare-card.compare-forecast{background:color-mix(in srgb,#6366f1 8%,transparent);border-color:color-mix(in srgb,#6366f1 25%,transparent)}.compare-sub{font-size:.7rem;color:var(--text-secondary);margin-top:.15rem}.schedule-form-card{margin-bottom:1.5rem}.schedule-form-modes{display:flex;gap:.5rem;margin-bottom:1rem}.mode-btn{padding:.4rem 1rem;border:2px solid var(--border);background:var(--card-bg);color:var(--text);border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;transition:all .15s}.mode-btn:hover{border-color:var(--primary);color:var(--primary)}.mode-btn.active{background:var(--primary);border-color:var(--primary);color:#fff}.multi-hint{padding:.5rem .75rem;background:color-mix(in srgb,var(--primary) 8%,transparent);border-radius:6px;font-size:.85rem;margin-bottom:.75rem;color:var(--text-secondary)}.auto-calc{padding:.5rem .75rem;background:color-mix(in srgb,var(--primary) 10%,transparent);border-radius:6px;font-weight:700;color:var(--primary);font-size:1rem;text-align:center}.cal-grid{background:var(--card-bg);border:1px solid var(--border);border-radius:12px;overflow:hidden;margin-bottom:1rem}.cal-header{display:grid;grid-template-columns:repeat(7,1fr);background:var(--primary)}.cal-header-cell{padding:.6rem;text-align:center;font-weight:600;font-size:.8rem;color:#fff;text-transform:uppercase;letter-spacing:.5px}.cal-body{display:grid;grid-template-columns:repeat(7,1fr)}.cal-cell{min-height:85px;padding:.35rem;border:1px solid var(--border);cursor:pointer;transition:all .15s;position:relative}.cal-cell:hover{background:color-mix(in srgb,var(--primary) 8%,transparent)}.cal-cell-empty{cursor:default;background:color-mix(in srgb,var(--text) 3%,transparent)}.cal-cell-empty:hover{background:color-mix(in srgb,var(--text) 3%,transparent)}.cal-plan{background:color-mix(in srgb,var(--primary) 6%,transparent)}.cal-both{background:color-mix(in srgb,#22c55e 6%,transparent)}.cal-fact-only{background:color-mix(in srgb,#f59e0b 6%,transparent)}.cal-weekend{background:color-mix(in srgb,var(--text) 3%,transparent)}.cal-today{box-shadow:inset 0 0 0 2px var(--primary)}.cal-holiday{background:color-mix(in srgb,#ef4444 10%,transparent);border-color:color-mix(in srgb,#ef4444 40%,transparent)}.cal-observance{background:color-mix(in srgb,#a855f7 6%,transparent)}.cal-holiday-badge{font-size:.55rem;font-weight:700;line-height:1.1;padding:.05rem .25rem;border-radius:3px;margin-bottom:.15rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.cal-holiday-badge.public{background:#ef4444;color:#fff}.cal-holiday-badge.observance{background:#a855f7;color:#fff}.mob-holiday{background:color-mix(in srgb,#ef4444 8%,transparent)!important;border-left:3px solid #ef4444}.mob-holiday-badge{display:inline-block;font-size:.7rem;font-weight:600;padding:.1rem .4rem;border-radius:3px;margin-bottom:.2rem}.mob-holiday-badge.public{background:#ef4444;color:#fff}.mob-holiday-badge.observance{background:color-mix(in srgb,#a855f7 20%,transparent);color:#a855f7}.cal-legend-holiday{background:color-mix(in srgb,#ef4444 30%,transparent);border:1px solid #ef4444}.cal-legend-observance{background:color-mix(in srgb,#a855f7 30%,transparent);border:1px solid #a855f7}.schedule-modal-holiday{padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;font-size:.9rem}.schedule-modal-holiday.public{background:color-mix(in srgb,#ef4444 12%,transparent);border-left:3px solid #ef4444}.schedule-modal-holiday.observance{background:color-mix(in srgb,#a855f7 10%,transparent);border-left:3px solid #a855f7}.cal-multi-selected{box-shadow:inset 0 0 0 2px #f59e0b;background:color-mix(in srgb,#f59e0b 12%,transparent)!important}.cal-day-num{font-weight:600;font-size:.85rem;margin-bottom:.15rem}.cal-plan-time{font-size:.6rem;color:var(--primary);font-weight:500;line-height:1.2}.cal-plan-hours{font-size:.6rem;color:var(--primary);font-weight:600}.cal-fact-hours{font-size:.6rem;background:#22c55e;color:#fff;padding:.05rem .25rem;border-radius:3px;display:inline-block;font-weight:600;margin-top:.1rem}.cal-diff{position:absolute;top:3px;right:3px;font-size:.55rem;font-weight:700;border-radius:3px;padding:.05rem .2rem}.cal-diff.ok{color:#16a34a}.cal-diff.under{color:#ef4444}.cal-legend{display:flex;gap:1.2rem;flex-wrap:wrap;margin-bottom:1.5rem;font-size:.8rem;color:var(--text-secondary)}.cal-legend-item{display:flex;align-items:center;gap:.3rem}.cal-legend-dot{width:10px;height:10px;border-radius:3px}.cal-legend-plan{background:color-mix(in srgb,var(--primary) 30%,transparent);border:1px solid var(--primary)}.cal-legend-fact{background:color-mix(in srgb,#f59e0b 30%,transparent);border:1px solid #f59e0b}.cal-legend-both{background:color-mix(in srgb,#22c55e 30%,transparent);border:1px solid #22c55e}.week-summary-section{margin-top:1rem}.week-summary-section h3{margin-bottom:.75rem;font-size:1rem}.week-summaries{display:flex;flex-direction:column;gap:.5rem}.week-summary-card{background:var(--card-bg);border:1px solid var(--border);border-radius:10px;padding:.75rem 1rem}.week-summary-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.week-num{font-weight:700;font-size:.85rem}.week-dates{font-size:.75rem;color:var(--text-secondary)}.week-bars{display:flex;flex-direction:column;gap:.35rem}.week-bar-row{display:flex;align-items:center;gap:.5rem}.week-bar-label{font-size:.7rem;color:var(--text-secondary);min-width:32px}.week-bar-track{flex:1;height:8px;background:color-mix(in srgb,var(--text) 10%,transparent);border-radius:4px;overflow:hidden}.week-bar-fill{height:100%;border-radius:4px;transition:width .3s}.week-bar-fill.plan{background:var(--primary)}.week-bar-fill.fact{background:#22c55e}.week-bar-fill.fact.over{background:#f59e0b}.week-bar-value{font-size:.75rem;font-weight:600;min-width:36px;text-align:right}.week-summary-footer{display:flex;gap:.75rem;margin-top:.4rem;align-items:center}.week-pct{font-size:.8rem;font-weight:700}.week-pct.ok{color:#22c55e}.week-pct.under{color:#ef4444}.week-pct.neutral{color:var(--text-secondary)}.week-diff{font-size:.75rem;font-weight:600}.week-diff.positive{color:#22c55e}.week-diff.negative{color:#ef4444}.schedule-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.schedule-modal{background:var(--bg);border:1px solid var(--border);border-radius:16px;padding:1.75rem;width:100%;max-width:420px;box-shadow:0 25px 80px #00000059,0 0 0 1px #0000000d;position:relative;z-index:1001}.schedule-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.schedule-modal-header h3{margin:0;font-size:1.15rem;font-weight:700}.btn-close{background:var(--card-bg);border:1px solid var(--border);width:32px;height:32px;border-radius:8px;font-size:1.25rem;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .15s;line-height:1}.btn-close:hover{color:var(--text);background:color-mix(in srgb,var(--text) 8%,transparent)}.schedule-modal-info{padding:.6rem .85rem;background:color-mix(in srgb,var(--primary) 8%,transparent);border:1px solid color-mix(in srgb,var(--primary) 20%,transparent);border-radius:8px;font-size:.85rem;margin-bottom:.75rem;color:var(--primary);font-weight:500}.modal-comment{font-size:.8rem;color:var(--text-secondary);margin-top:.2rem}.schedule-modal-actual{padding:.6rem .85rem;background:color-mix(in srgb,#22c55e 8%,transparent);border:1px solid color-mix(in srgb,#22c55e 20%,transparent);border-radius:8px;font-size:.85rem;margin-bottom:.75rem;color:#16a34a;font-weight:500}.schedule-modal-diff{padding:.5rem .85rem;border-radius:8px;font-size:.85rem;font-weight:600;margin-bottom:.75rem}.schedule-modal-diff.positive{background:color-mix(in srgb,#22c55e 8%,transparent);border:1px solid color-mix(in srgb,#22c55e 20%,transparent);color:#16a34a}.schedule-modal-diff.negative{background:color-mix(in srgb,#ef4444 8%,transparent);border:1px solid color-mix(in srgb,#ef4444 20%,transparent);color:#ef4444}.schedule-modal-form{display:flex;flex-direction:column;gap:.85rem;margin-top:.5rem}.schedule-modal-form .form-row{flex-direction:row;gap:.75rem}.schedule-modal-actions{display:flex;gap:.5rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border)}.btn-danger{background:#ef4444;color:#fff;border:none;padding:.5rem 1rem;border-radius:6px;cursor:pointer;font-size:.85rem}.btn-danger:hover{background:#dc2626}.modal-earn{margin-top:.3rem;font-weight:700;color:#16a34a}.schedule-tabs{display:flex;gap:.5rem;margin-bottom:1rem}.schedule-tab{padding:.5rem 1.25rem;border:2px solid var(--border);background:var(--card-bg);color:var(--text);border-radius:8px;cursor:pointer;font-size:.9rem;font-weight:600;transition:all .15s}.schedule-tab:hover{border-color:var(--primary);color:var(--primary)}.schedule-tab.active{background:var(--primary);border-color:var(--primary);color:#fff}.cal-mobile{display:none}.mob-week{margin-bottom:.5rem}.mob-week-header{display:flex;justify-content:space-between;align-items:center;padding:.5rem .75rem;background:var(--primary);color:#fff;border-radius:8px 8px 0 0;font-size:.8rem;font-weight:600}.mob-week-totals{display:flex;gap:.4rem;align-items:center}.mob-plan-tag,.mob-fact-tag,.mob-diff-tag{padding:.1rem .4rem;border-radius:4px;font-size:.65rem;font-weight:700}.mob-plan-tag{background:#ffffff40}.mob-fact-tag{background:#22c55e;color:#fff}.mob-diff-tag.ok{background:#fff3}.mob-diff-tag.under{background:#ef4444;color:#fff}.mob-day-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border);border-top:none;background:var(--card-bg);cursor:pointer;transition:background .1s}.mob-day-row:last-child{border-radius:0 0 8px 8px}.mob-day-row:hover{background:color-mix(in srgb,var(--primary) 5%,transparent)}.mob-today{background:color-mix(in srgb,var(--primary) 8%,transparent)!important;border-left:3px solid var(--primary)}.mob-weekend{opacity:.5}.mob-multi-selected{background:color-mix(in srgb,#f59e0b 12%,transparent)!important;border-left:3px solid #f59e0b}.mob-day-left{display:flex;flex-direction:column;align-items:center;min-width:32px}.mob-day-num{font-weight:700;font-size:1rem}.mob-day-name{font-size:.6rem;color:var(--text-secondary);text-transform:uppercase}.mob-day-center{flex:1}.mob-day-plan,.mob-day-fact{display:flex;align-items:center;gap:.3rem;font-size:.8rem;line-height:1.4}.mob-day-plan{color:var(--primary)}.mob-day-fact{color:#16a34a}.mob-hours-badge{padding:.05rem .3rem;border-radius:3px;font-size:.65rem;font-weight:700}.mob-hours-badge.plan{background:color-mix(in srgb,var(--primary) 15%,transparent);color:var(--primary)}.mob-hours-badge.fact{background:#22c55e;color:#fff}.mob-day-empty{font-size:.8rem;color:var(--text-secondary)}.mob-day-right{min-width:28px;text-align:right}.mob-status{font-size:.8rem;font-weight:700}.mob-status.ok{color:#22c55e}.mob-status.under{color:#ef4444}.salary-cards{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.salary-card{padding:.85rem;border-radius:10px;text-align:center}.salary-card.gross{background:color-mix(in srgb,var(--primary) 8%,transparent);border:1px solid color-mix(in srgb,var(--primary) 20%,transparent)}.salary-card.tax{background:color-mix(in srgb,#ef4444 6%,transparent);border:1px solid color-mix(in srgb,#ef4444 15%,transparent)}.salary-card.net{background:color-mix(in srgb,#22c55e 6%,transparent);border:1px solid color-mix(in srgb,#22c55e 15%,transparent)}.salary-card-label{font-size:.7rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-secondary);margin-bottom:.2rem}.salary-card-value{font-size:1.5rem;font-weight:800}.salary-card.gross .salary-card-value{color:var(--primary)}.salary-card.tax .salary-card-value{color:#ef4444}.salary-card.net .salary-card-value{color:#22c55e}.salary-card.forecast .salary-card-value{color:#6366f1}.salary-card.forecast{background:color-mix(in srgb,#6366f1 8%,transparent);border:1px solid color-mix(in srgb,#6366f1 25%,transparent);position:relative}.forecast-tag{display:inline-block;font-size:.55rem;font-weight:600;background:#6366f1;color:#fff;padding:.05rem .3rem;border-radius:3px;margin-left:.25rem;vertical-align:middle;text-transform:none;letter-spacing:0}.salary-card-sub{font-size:.7rem;color:var(--text-secondary);margin-top:.1rem}.salary-forecast{background:var(--card-bg);border:1px solid var(--border);border-radius:8px;padding:.75rem 1rem;margin-bottom:1.25rem}.salary-forecast-title{font-size:.75rem;text-transform:uppercase;color:var(--text-secondary);margin-bottom:.3rem}.salary-forecast-row{font-size:.85rem;display:flex;justify-content:space-between;flex-wrap:wrap;gap:.25rem}.salary-forecast-row strong{color:var(--primary)}.salary-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;margin-bottom:1.5rem}.salary-table{width:100%;border-collapse:collapse;font-size:.82rem}.salary-table th{background:var(--primary);color:#fff;padding:.5rem .6rem;text-align:left;font-weight:600;white-space:nowrap;position:sticky;top:0}.salary-table td{padding:.4rem .6rem;border-bottom:1px solid var(--border);vertical-align:middle}.salary-table tbody tr:hover{background:color-mix(in srgb,var(--primary) 5%,transparent)}.salary-row-today{background:color-mix(in srgb,var(--primary) 8%,transparent)!important;font-weight:600}.salary-date{font-weight:700;min-width:28px}.salary-dayname{color:var(--text-secondary)}.sal-plan{color:var(--primary);font-size:.8rem}.sal-plan small{color:var(--text-secondary)}.sal-fact{color:#16a34a;font-size:.8rem}.sal-fact small{font-weight:600}.sal-money{text-align:right;white-space:nowrap;font-weight:500}.sal-tax{color:#ef4444}.sal-net{color:#22c55e;font-weight:700}.salary-total-row{background:color-mix(in srgb,var(--primary) 8%,transparent);font-weight:700}.salary-total-row td{border-top:2px solid var(--primary);padding:.6rem}.salary-mobile{display:none}.sal-mob-week{margin-bottom:.5rem}.sal-mob-week-header{display:flex;justify-content:space-between;align-items:center;padding:.4rem .75rem;background:var(--primary);color:#fff;border-radius:8px 8px 0 0;font-size:.8rem;font-weight:600}.sal-mob-week-total{font-weight:700}.sal-mob-day{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border:1px solid var(--border);border-top:none;background:var(--card-bg)}.sal-mob-day:last-child{border-radius:0 0 8px 8px}.sal-mob-today{background:color-mix(in srgb,var(--primary) 8%,transparent);border-left:3px solid var(--primary)}.sal-mob-left{display:flex;flex-direction:column;align-items:center;min-width:30px}.sal-mob-num{font-weight:700;font-size:.95rem}.sal-mob-dayname{font-size:.55rem;color:var(--text-secondary);text-transform:uppercase}.sal-mob-center{flex:1}.sal-mob-plan{font-size:.75rem;color:var(--primary)}.sal-mob-fact{font-size:.75rem;color:#16a34a;font-weight:500}.sal-mob-right{text-align:right;min-width:60px}.sal-mob-gross{font-size:.8rem;font-weight:600}.sal-mob-net{font-size:.7rem;color:#22c55e;font-weight:700}.sal-mob-est{font-size:.7rem;color:var(--text-secondary);font-style:italic}.sal-mob-total{margin-top:.5rem;padding:.75rem;background:var(--card-bg);border:2px solid var(--primary);border-radius:8px}.sal-mob-total-row{display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.salary-transfers{background:color-mix(in srgb,#f59e0b 6%,transparent);border:1px solid color-mix(in srgb,#f59e0b 20%,transparent);border-radius:8px;padding:.75rem 1rem;margin-bottom:1.25rem}.salary-transfers-title{font-size:.8rem;font-weight:600;color:#d97706;margin-bottom:.5rem}.salary-transfers-list{display:flex;flex-direction:column;gap:.25rem}.salary-transfer-item{display:flex;gap:.75rem;align-items:center;font-size:.8rem}.transfer-date{font-weight:600;min-width:70px}.transfer-comment{color:var(--text-secondary);font-style:italic}.transfer-badge{display:inline-block;padding:.05rem .4rem;background:#f59e0b;color:#fff;border-radius:3px;font-size:.6rem;font-weight:700;text-transform:uppercase;letter-spacing:.3px}.salary-row-transfer{background:color-mix(in srgb,#f59e0b 5%,transparent)}.hamburger{display:none;flex-direction:column;justify-content:center;align-items:center;width:36px;height:36px;padding:0;background:none;border:none;cursor:pointer;gap:5px}.hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:all .3s ease}.hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.open span:nth-child(2){opacity:0}.hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}.mobile-menu-overlay,.mobile-menu{display:none}@media (max-width: 768px){.navbar{padding:0 .75rem}.navbar-inner{height:52px;gap:.5rem}.navbar-brand a{font-size:1rem}.navbar-brand svg{width:18px;height:18px}.navbar-links,.navbar-username,.navbar-logout-desktop{display:none}.hamburger{display:flex}.navbar-user{gap:.5rem;margin-left:auto}.theme-toggle{width:32px;height:32px}.mobile-menu-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background:#0006;z-index:998;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.mobile-menu{display:flex;flex-direction:column;position:fixed;top:0;right:-280px;width:280px;height:100vh;height:100dvh;background:var(--white);z-index:999;box-shadow:-4px 0 20px #00000026;transition:right .3s ease;padding:0;overflow-y:auto}.mobile-menu.open{right:0}.mobile-menu-user{display:flex;align-items:center;gap:.5rem;padding:1.25rem 1.25rem 1rem;border-bottom:1px solid var(--border)}.mobile-menu-username{font-weight:600;font-size:1rem;color:var(--text)}.mobile-menu-links{display:flex;flex-direction:column;padding:.5rem 0;flex:1}.mobile-menu-links a{display:flex;align-items:center;gap:.75rem;padding:.875rem 1.25rem;text-decoration:none;color:var(--text-muted);font-weight:500;font-size:.95rem;transition:all .15s}.mobile-menu-links a:hover{background:var(--bg);color:var(--text)}.mobile-menu-links a.active{color:var(--primary);background:var(--primary-light)}.mobile-menu-links a svg{flex-shrink:0;opacity:.7}.mobile-menu-links a.active svg{opacity:1}.mobile-menu-logout{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;margin-top:auto;border-top:1px solid var(--border);background:none;border-left:none;border-right:none;border-bottom:none;width:100%;cursor:pointer;color:var(--danger, #ef4444);font-weight:500;font-size:.95rem;text-align:left}.mobile-menu-logout:hover{background:var(--bg)}.stats-grid{grid-template-columns:repeat(2,1fr)}.stats-grid-3{grid-template-columns:1fr}.stats-grid-4{grid-template-columns:repeat(2,1fr)}.stat-value{font-size:1.25rem}.form-row{flex-direction:column;gap:1rem}.form-row:has(input[type=time]){flex-direction:row;flex-wrap:wrap}.charts-row{grid-template-columns:1fr}.entry-card{flex-direction:column;align-items:flex-start}.entry-actions{align-self:flex-end}.page-header{flex-direction:column;align-items:flex-start}.table{font-size:.8rem}.table th,.table td{padding:.5rem}.auth-card{padding:1.5rem}.month-nav{gap:.35rem}.month-nav .btn{padding:.3rem .6rem;font-size:.8rem}.month-label{font-size:.95rem;min-width:auto;text-align:center}.page-title{font-size:1.2rem}.cal-desktop{display:none}.cal-mobile{display:block}.salary-table-wrap{display:none}.salary-mobile{display:block}.schedule-compare{grid-template-columns:repeat(2,1fr);gap:.4rem}.compare-card{padding:.5rem .35rem}.compare-value.forecast{font-size:.95rem}.compare-label{font-size:.6rem}.compare-value{font-size:1rem}.compare-sub{font-size:.55rem}.salary-cards{grid-template-columns:1fr;gap:.5rem}.salary-card{padding:.6rem}.salary-card-value{font-size:1.3rem}.salary-forecast{padding:.6rem .75rem;font-size:.8rem}.salary-forecast-row{flex-direction:column}.salary-transfers{padding:.6rem .75rem}.salary-transfer-item{flex-wrap:wrap;font-size:.75rem}.schedule-tab{flex:1;text-align:center;font-size:.8rem;padding:.4rem .5rem}.schedule-tabs{gap:.35rem}.schedule-form-card{padding:.75rem}.schedule-form-modes{gap:.35rem}.mode-btn{padding:.35rem .75rem;font-size:.8rem}.week-summary-card{padding:.5rem .6rem}.week-bar-label{font-size:.6rem;min-width:28px}.week-bar-value{font-size:.7rem;min-width:30px}.schedule-modal{padding:1.25rem;margin:.5rem;max-width:100%}.schedule-modal-overlay{padding:.5rem}.schedule-modal-header h3{font-size:1rem}.schedule-modal-actions{flex-wrap:wrap}.schedule-modal-actions .btn{flex:1;min-width:0;text-align:center;font-size:.8rem;padding:.45rem .5rem}}@media (max-width: 480px){.stats-grid,.stats-grid-4,.schedule-compare{grid-template-columns:1fr}.compare-card{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;text-align:left}.compare-label{min-width:55px}.compare-value{font-size:1.2rem;flex:1}.compare-sub{font-size:.65rem}.cal-cell{min-height:48px}}
