*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif;background:#f0f2f5;color:#1a1a1a;min-height:100vh;-webkit-font-smoothing:antialiased}.app{min-height:100vh;display:flex;flex-direction:column;max-width:100%;overflow-x:hidden}.header{background:linear-gradient(135deg,#1e3a5f,#2d5a87);color:#fff;padding:12px 16px;display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;box-shadow:0 2px 8px #0003;position:sticky;top:0;z-index:100}.header h1{font-size:1.2rem;font-weight:600}.header-actions{display:flex;flex-wrap:wrap;gap:8px}.btn{padding:8px 14px;border:none;border-radius:6px;cursor:pointer;font-size:.8rem;font-weight:500;transition:all .2s;white-space:nowrap}.btn-primary{background:#4a90d9;color:#fff}.btn-primary:hover{background:#3a7bc8}.btn-secondary{background:#ffffff26;color:#fff}.btn-secondary:hover{background:#ffffff40}.btn-danger{background:#e74c3c;color:#fff}.btn-danger:hover{background:#c0392b}.main-content{flex:1;padding:16px;overflow-y:auto}.update-banner{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;border-radius:8px}.update-banner button{padding:8px 16px;background:#fff;color:#27ae60;border:none;border-radius:6px;font-weight:600;cursor:pointer}.summary-bar{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;margin-bottom:16px}.summary-card{background:#fff;border-radius:12px;padding:12px 14px;box-shadow:0 2px 8px #00000014}.summary-card h3{font-size:.65rem;text-transform:uppercase;color:#666;margin-bottom:6px}.summary-card .value{font-size:1.4rem;font-weight:700;color:#1e3a5f}.summary-card .value.positive{color:#27ae60}.summary-card .value.negative{color:#e74c3c}.summary-card .sub{font-size:.7rem;color:#888;margin-top:4px}.calendar-nav{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;flex-wrap:wrap;gap:8px}.calendar-nav h2{font-size:1.1rem;color:#1e3a5f}.nav-btn{background:#fff;border:1px solid #ddd;padding:6px 12px;border-radius:8px;cursor:pointer;font-size:.85rem;transition:all .2s}.nav-btn:hover{background:#f5f5f5;border-color:#ccc}.year-selector{display:flex;align-items:center;gap:8px}.year-selector select{padding:6px 10px;border-radius:6px;border:1px solid #ddd;font-size:.9rem;background:#fff}.month-grid{background:#fff;border-radius:12px;box-shadow:0 2px 8px #00000014;overflow:hidden;margin-bottom:16px}.month-header{display:grid;grid-template-columns:repeat(7,1fr);background:#f8f9fa;border-bottom:1px solid #eee}.day-name{padding:8px;text-align:center;font-size:.65rem;font-weight:600;color:#666;text-transform:uppercase}.calendar-grid{display:grid;grid-template-columns:repeat(7,1fr)}.calendar-day{min-height:60px;border-right:1px solid #eee;border-bottom:1px solid #eee;padding:4px;cursor:pointer;transition:background .15s}.calendar-day:nth-child(7n){border-right:none}.calendar-day:hover{background:#f0f7ff}.calendar-day.empty{background:#fafafa;cursor:default}.day-number{font-size:.75rem;font-weight:600;color:#333;margin-bottom:2px}.day-code{display:inline-block;padding:2px 5px;border-radius:4px;font-size:.65rem;font-weight:600;margin-bottom:2px}.day-hours{font-size:.6rem;color:#666}.legend{display:flex;flex-wrap:wrap;gap:6px;margin-top:8px;padding:8px;background:#fff;border-radius:8px}.legend-item{display:flex;align-items:center;gap:4px;font-size:.65rem}.legend-color{width:12px;height:12px;border-radius:3px}.tabs{display:flex;gap:4px;margin-bottom:16px;background:#f0f0f0;padding:4px;border-radius:8px}.tab-btn{padding:8px 14px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:.85rem;font-weight:500;color:#666;transition:all .2s;flex:1}.tab-btn.active{background:#fff;color:#1e3a5f;box-shadow:0 1px 4px #0000001a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.modal{background:#fff;border-radius:16px;padding:20px;width:100%;max-width:400px;box-shadow:0 8px 32px #0003;max-height:90vh;overflow-y:auto}.modal h2{margin-bottom:12px;color:#1e3a5f;font-size:1.1rem}.modal-date{font-size:.85rem;color:#666;margin-bottom:12px}.code-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.code-btn{padding:10px 6px;border:2px solid #eee;border-radius:8px;background:#fff;cursor:pointer;text-align:center;transition:all .2s}.code-btn:hover{border-color:#4a90d9;background:#f0f7ff}.code-btn.selected{border-color:#1e3a5f;background:#1e3a5f;color:#fff}.code-btn .code{font-size:1rem;font-weight:700;border-radius:4px;padding:4px 8px;display:inline-block}.code-btn .label{font-size:.6rem;color:#666;margin-top:2px}.code-btn.selected .label{color:#fffc}.modal-actions{display:flex;justify-content:space-between;gap:8px;margin-top:16px}.modal-actions button{padding:10px 16px;border-radius:8px;border:none;cursor:pointer;font-size:.85rem;font-weight:500}.btn-cancel{background:#eee;color:#333}.btn-delete{background:#e74c3c;color:#fff}.btn-save{background:#27ae60;color:#fff}.settings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:.75rem;color:#666;font-weight:500}.form-group input,.form-group select{padding:8px 10px;border:1px solid #ddd;border-radius:6px;font-size:.85rem}.user-list{display:flex;flex-direction:column;gap:8px;margin-top:12px}.user-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f5f5f5;border-radius:8px}.user-item.active{background:#e8f4fd}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600}.user-date{font-size:.75rem;color:#888}.user-actions{display:flex;gap:8px}.warning-box{background:#fff3cd;border:2px solid #ffc107;border-radius:8px;padding:16px;margin:16px 0}.warning-box h3{color:#856404;margin-bottom:8px;font-size:.95rem}.warning-box p{color:#856404;font-size:.85rem;line-height:1.4}.backup-info{background:#fff;border-radius:12px;padding:16px;margin-top:16px;box-shadow:0 2px 8px #00000014}.backup-info h3{color:#1e3a5f;font-size:.95rem;margin-bottom:12px}.backup-buttons{display:flex;flex-wrap:wrap;gap:8px}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;gap:16px}.loading-spinner{width:40px;height:40px;border:4px solid #eee;border-top-color:#1e3a5f;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media (max-width: 600px){.summary-bar,.code-grid{grid-template-columns:repeat(2,1fr)}.calendar-day{min-height:50px;padding:2px}.day-name{padding:6px 2px;font-size:.55rem}.header h1{font-size:1rem}}
