*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;color:#333}.container{max-width:1200px;margin:0 auto;padding:10px 20px 100px}.header{background:white;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem;position:sticky;top:10px;z-index:100;border:1px solid #e5e7eb}.date-filter{display:flex;gap:1rem;margin:1rem 0;align-items:center;flex-wrap:wrap}.date-filter input{padding:.5rem;border:1px solid #ddd;border-radius:6px}.btn{padding:.75rem 1.5rem;border:none;border-radius:6px;cursor:pointer;font-weight:600;transition:all .2s}.btn-primary{background:#3b82f6;color:#fff}.btn-primary:hover{background:#2563eb}.btn-success{background:#10b981;color:#fff}.btn-success:hover{background:#059669}.btn-secondary{background:#6b7280;color:#fff}.btn-secondary:hover{background:#4b5563}.btn-excel{background:linear-gradient(135deg,#217346 0%,#185c37 100%);color:#fff}.btn-excel:hover{background:linear-gradient(135deg,#185c37 0%,#0d4026 100%)}.locations-grid{display:grid;gap:1rem;margin:2rem 0}.location-card{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 2px 5px #0000001a;border-left:4px solid #e5e7eb}.location-card.work{border-left-color:#10b981}.location-card.personal{border-left-color:#8b5cf6}.location-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.label-badge{padding:.25rem .75rem;border-radius:20px;font-size:.875rem;font-weight:600}.label-work{background:#d1fae5;color:#065f46}.label-personal{background:#ede9fe;color:#5b21b6}.label-unlabeled{background:#f3f4f6;color:#6b7280}.report-section{background:white;padding:2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-top:2rem}.sticky-footer{position:fixed;bottom:0;left:0;right:0;background:white;padding:1rem 2rem;box-shadow:0 -4px 20px #00000026;z-index:100;display:flex;justify-content:center;align-items:center;gap:1rem;border-top:1px solid #e5e7eb}.sticky-footer .btn{min-width:150px}.modal{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:200}.modal-content{background:white;padding:2rem;border-radius:12px;max-width:500px;width:90%;max-height:90vh;overflow-y:auto}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600}.form-group select,.form-group input,.form-group textarea{width:100%;padding:.75rem;border:1px solid #ddd;border-radius:6px;font-size:1rem}.report-content{background:white;padding:2rem;border-radius:12px}.report-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;flex-wrap:wrap}@media print{.header,.sticky-footer,.locations-grid,.report-actions,.btn{display:none!important}.container{padding:0}.report-section{box-shadow:none;margin:0;padding:1rem}.report-content{padding:0}body{background:white}}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:.75rem;margin-top:1rem;padding:.75rem;background:#f8f9fa;border-radius:8px}.summary-card{text-align:center;padding:.5rem}.summary-value{font-size:1.25rem;font-weight:700}.summary-label{font-size:.75rem;color:#6b7280}.calendar-container{background:white;padding:2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem}.calendar-header-row{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.calendar-container h2{margin-bottom:.5rem;color:#1f2937}.calendar-hint{color:#6b7280;font-size:.875rem;margin-bottom:0}.calendar-actions{display:flex;gap:.75rem;flex-wrap:wrap}.auto-label-btn{white-space:nowrap;animation:pulse 2s infinite}.auto-label-btn:disabled{animation:none;opacity:.7}.export-modal{max-width:500px}.export-info{background:#f0fdf4;border:2px solid #bbf7d0;border-radius:12px;padding:1rem;margin-top:1rem}.export-info h4{margin:0 0 .75rem;color:#166534}.export-info ul{margin:0;padding-left:1.25rem}.export-info li{margin:.25rem 0;color:#15803d}@keyframes pulse{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 8px #10b98100}}.month-navigation{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,#f8fafc 0%,#e2e8f0 100%);border-radius:12px;border:1px solid #e5e7eb}.month-nav-btn{padding:.5rem 1rem;border:1px solid #d1d5db;background:white;border-radius:8px;cursor:pointer;font-weight:600;color:#374151;transition:all .2s}.month-nav-btn:hover:not(:disabled){background:#3b82f6;color:#fff;border-color:#3b82f6}.month-nav-btn:disabled{opacity:.4;cursor:not-allowed}.current-month{text-align:center}.current-month h3{margin:0;color:#1f2937;font-size:1.25rem}.month-indicator{font-size:.75rem;color:#6b7280}.calendar-grid{border:1px solid #e5e7eb;border-radius:8px;overflow:hidden}.calendar-header{display:grid;grid-template-columns:repeat(7,1fr);background:#f3f4f6;border-bottom:1px solid #e5e7eb}.calendar-header span{padding:.75rem;text-align:center;font-weight:600;color:#4b5563;font-size:.875rem}.calendar-week{display:grid;grid-template-columns:repeat(7,1fr);border-bottom:1px solid #e5e7eb}.calendar-week:last-child{border-bottom:none}.calendar-day{min-height:90px;padding:.5rem;border-right:1px solid #e5e7eb;cursor:pointer;transition:all .2s;background:white}.calendar-day:last-child{border-right:none}.calendar-day:hover:not(.out-of-range){background:#f8fafc}.calendar-day.out-of-range{background:#f9fafb;cursor:default}.calendar-day.out-of-range .day-number{color:#d1d5db}.calendar-day.other-month{background:#f3f4f6}.calendar-day.other-month .day-number{color:#9ca3af}.calendar-day.has-activity{background:#fef3c7}.calendar-day.has-activity:hover{background:#fde68a}.calendar-day.has-work{background:#d1fae5;border-left:3px solid #10b981}.calendar-day.has-work:hover{background:#a7f3d0}.day-number{font-weight:600;font-size:.875rem;color:#374151;margin-bottom:.25rem}.day-info{font-size:.7rem;color:#6b7280}.activity-count{background:#e5e7eb;padding:.15rem .4rem;border-radius:4px;display:inline-block;margin-bottom:.25rem;font-weight:500}.has-work .activity-count{background:#065f46;color:#fff}.work-hours{color:#059669;font-weight:600;font-size:.75rem}.calendar-legend{display:flex;gap:2rem;margin-top:1rem;padding-top:1rem;border-top:1px solid #e5e7eb}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.legend-dot{width:16px;height:16px;border-radius:4px}.legend-dot.has-work{background:#d1fae5;border:2px solid #10b981}.legend-dot.has-activity{background:#fef3c7;border:2px solid #f59e0b}.day-detail-view{margin-bottom:2rem}.day-detail-header{background:white;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:1.5rem;display:flex;flex-direction:column;gap:1rem}.day-detail-actions{display:flex;gap:.75rem;flex-wrap:wrap}.day-detail-actions .btn:disabled{opacity:.6;cursor:not-allowed}.day-detail-header h2{margin:0;color:#1f2937}.day-summary{display:flex;gap:1rem;color:#6b7280;font-size:.9rem}.location-card-layout{display:flex;gap:1.5rem;align-items:flex-start}.location-info{flex:1;min-width:0}.location-title{margin-top:.5rem;color:#4b5563;font-size:.9rem;word-break:break-word}.location-time,.location-duration,.location-route{font-size:.85rem;color:#6b7280;margin:.25rem 0}.location-controls{display:flex;flex-direction:column;gap:.75rem;min-width:160px;padding-left:1rem;border-left:2px solid #e5e7eb}.label-buttons{display:grid;grid-template-columns:1fr 1fr;gap:.4rem}.label-btn{padding:.4rem .6rem;border:2px solid #e5e7eb;border-radius:6px;background:white;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s;white-space:nowrap}.label-btn:hover{background:#f3f4f6;border-color:#d1d5db}.label-btn.active{border-color:#3b82f6;background:#eff6ff;color:#1d4ed8}.hours-input{display:flex;flex-direction:column;gap:.25rem}.hours-input label{font-size:.7rem;color:#6b7280;font-weight:600}.hours-input input{padding:.4rem .6rem;border:1px solid #d1d5db;border-radius:6px;font-size:.85rem;width:100%}.hours-input input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f633}.current-label{padding:.5rem;border-radius:6px;text-align:center;font-weight:600;font-size:.8rem;text-transform:capitalize}@media (max-width: 768px){.calendar-day{min-height:70px;padding:.25rem}.day-info{font-size:.6rem}.calendar-header span{padding:.5rem;font-size:.75rem}.activity-count{font-size:.6rem;padding:.1rem .25rem}.location-card-layout{flex-direction:column}.location-controls{width:100%;min-width:unset;border-left:none;border-top:2px solid #e5e7eb;padding-left:0;padding-top:1rem}.label-buttons{grid-template-columns:repeat(4,1fr)}}.hours-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;margin-bottom:1.5rem}.hours-card{background:white;border-radius:12px;padding:1rem;border:2px solid #e5e7eb;transition:all .2s}.hours-card:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.hours-card.weekly{border-color:#93c5fd;background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%)}.hours-card.monthly{border-color:#86efac;background:linear-gradient(135deg,#f0fdf4 0%,#dcfce7 100%)}.hours-card.yearly{border-color:#c4b5fd;background:linear-gradient(135deg,#f5f3ff 0%,#ede9fe 100%)}.hours-card.vacation{border-color:#fcd34d;background:linear-gradient(135deg,#fffbeb 0%,#fef3c7 100%)}.hours-card-header{font-size:.75rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.hours-card-value{font-size:1.5rem;font-weight:700;color:#1f2937}.hours-card-target{font-size:.875rem;font-weight:500;color:#9ca3af;margin-left:.25rem}.hours-card-balance{font-size:.875rem;font-weight:600;margin-top:.25rem}.hours-card-balance.positive{color:#059669}.hours-card-balance.negative{color:#dc2626}.hours-card-info{font-size:.75rem;color:#6b7280;margin-top:.25rem}.calendar-day.weekend{background:#f9fafb}.calendar-day.weekend .day-number{color:#9ca3af}.calendar-day.holiday{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border-left:3px solid #f59e0b}.calendar-day.sick-day{background:linear-gradient(135deg,#fee2e2 0%,#fecaca 100%);border-left:3px solid #ef4444}.calendar-day.vacation-day{background:linear-gradient(135deg,#dbeafe 0%,#bfdbfe 100%);border-left:3px solid #3b82f6}.calendar-day.vacation-half-day{background:linear-gradient(135deg,#e0f2fe 0%,#bae6fd 100%);border-left:3px solid #0ea5e9}.day-holiday-name{font-size:.6rem;color:#92400e;background:rgba(245,158,11,.2);padding:.1rem .3rem;border-radius:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:.25rem}.day-leave-badge{font-size:.65rem;padding:.1rem .3rem;border-radius:3px;font-weight:600;margin-bottom:.25rem}.sick-day .day-leave-badge{background:rgba(239,68,68,.2);color:#b91c1c}.vacation-day .day-leave-badge,.vacation-half-day .day-leave-badge{background:rgba(59,130,246,.2);color:#1d4ed8}.legend-dot.holiday{background:#fef3c7;border:2px solid #f59e0b}.legend-dot.sick{background:#fee2e2;border:2px solid #ef4444}.legend-dot.vacation{background:#dbeafe;border:2px solid #3b82f6}.btn-settings{background:linear-gradient(135deg,#6b7280 0%,#4b5563 100%);color:#fff}.btn-settings:hover{background:linear-gradient(135deg,#4b5563 0%,#374151 100%)}.settings-modal{max-width:600px}.settings-section{margin-bottom:1.5rem;padding-bottom:1.5rem;border-bottom:1px solid #e5e7eb}.settings-section h3{margin:0 0 1rem;color:#1f2937;font-size:1rem}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.daily-hours-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:.5rem;margin-top:.5rem}.daily-hour-input{text-align:center}.daily-hour-input label{display:block;font-size:.7rem;color:#6b7280;margin-bottom:.25rem;font-weight:600}.daily-hour-input input{width:100%;padding:.5rem;text-align:center;border:1px solid #d1d5db;border-radius:6px;font-size:.9rem}.settings-info{background:#f0f9ff;border:2px solid #bae6fd;border-radius:12px;padding:1rem;margin-top:1rem}.settings-info h4{margin:0 0 .75rem;color:#0369a1}.settings-info ul{margin:0;padding-left:1.25rem}.settings-info li{margin:.25rem 0;color:#0284c7;font-size:.875rem}.day-holiday-banner{background:linear-gradient(135deg,#fef3c7 0%,#fde68a 100%);border:2px solid #f59e0b;border-radius:8px;padding:.75rem 1rem;color:#92400e;font-size:.9rem}.day-leave-section{background:#f8fafc;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.leave-label{font-weight:600;color:#374151;font-size:.9rem}.leave-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.leave-btn{padding:.5rem 1rem;border:2px solid #e5e7eb;border-radius:8px;background:white;cursor:pointer;font-size:.85rem;font-weight:600;transition:all .2s}.leave-btn:hover{background:#f3f4f6}.leave-btn.sick{border-color:#fca5a5}.leave-btn.sick:hover{background:#fee2e2}.leave-btn.sick.active{background:#fee2e2;border-color:#ef4444;color:#b91c1c}.leave-btn.vacation,.leave-btn.vacation-half{border-color:#93c5fd}.leave-btn.vacation:hover,.leave-btn.vacation-half:hover{background:#dbeafe}.leave-btn.vacation.active,.leave-btn.vacation-half.active{background:#dbeafe;border-color:#3b82f6;color:#1d4ed8}.leave-status{font-size:.85rem;color:#059669;background:#d1fae5;padding:.5rem 1rem;border-radius:6px}.leave-badge{background:#dbeafe;color:#1d4ed8;padding:.2rem .5rem;border-radius:4px;font-weight:600}@media (max-width: 768px){.hours-summary-grid{grid-template-columns:repeat(2,1fr)}.daily-hours-grid{grid-template-columns:repeat(4,1fr)}.form-row{grid-template-columns:1fr}.leave-buttons{flex-direction:column}.leave-btn{width:100%;text-align:center}.calendar-legend{flex-wrap:wrap;gap:1rem}}
