*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#f5f5f5;min-height:100vh}.app{padding:20px}.header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:0 10px}.header h1{font-size:24px;color:#333}.year-nav{display:flex;align-items:center;gap:15px}.year-nav button{background:#fff;border:1px solid #ddd;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.year-nav button:hover{background:#f0f0f0}.year-nav span{font-size:20px;font-weight:600;min-width:60px;text-align:center}.year-summary{display:flex;gap:20px;padding:10px 16px;background:#fff;border-radius:6px;box-shadow:0 1px 3px #0000001a}.summary-item{display:flex;align-items:center;gap:6px}.summary-label{font-size:13px;color:#666}.summary-value{font-size:16px;font-weight:600;color:#333}.summary-total{color:#4a90d9}.daily-rate-input{display:flex;align-items:center;gap:8px}.daily-rate-input label{font-size:14px;color:#555}.daily-rate-input input{width:100px;padding:8px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px}.daily-rate-input input:focus{outline:none;border-color:#4a90d9}.manage-btn{background:#4a90d9;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px}.manage-btn:hover{background:#3a7fc8}.export-btn{background:#5cb85c;color:#fff;border:none;padding:10px 20px;border-radius:6px;cursor:pointer;font-size:14px}.export-btn:hover{background:#4cae4c}.export-btn:disabled{background:#ccc;cursor:not-allowed}.calendar-export-area{background:#f5f5f5}.export-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px;padding:0 10px}.export-title{font-size:24px;font-weight:600;color:#333}.export-summary{font-size:14px;color:#555}.calendar-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:15px}.month{background:#fff;border-radius:8px;padding:12px;box-shadow:0 1px 3px #0000001a}.month-header{font-weight:600;font-size:14px;color:#333;margin-bottom:8px;text-align:center}.weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px}.weekday{text-align:center;font-size:10px;color:#888;font-weight:500}.days{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.day{aspect-ratio:1;display:flex;align-items:center;justify-content:center;font-size:11px;border-radius:4px;cursor:pointer;transition:all .15s;position:relative;background:transparent;border:none}.day:hover:not(.empty){transform:scale(1.1);z-index:1;box-shadow:0 2px 8px #0003}.day.empty{cursor:default}.day.weekend{font-weight:600}.day.today{outline:2px solid #333;outline-offset:-2px}.day.anchor{outline:2px solid #4a90d9;outline-offset:-2px}.day.in-range{outline:2px solid #4a90d9;outline-offset:-2px;background-color:#e3f0ff!important}.day.selected{outline:2px solid #4a90d9;outline-offset:-2px;box-shadow:inset 0 0 0 2px #fff}.modal-overlay{position:fixed;inset:0;background:#00000080;z-index:100;display:flex;align-items:center;justify-content:center}.modal{background:#fff;border-radius:12px;padding:24px;min-width:320px;max-width:90vw;max-height:80vh;overflow-y:auto;position:relative}.modal h2{margin-bottom:16px;font-size:18px;padding-right:30px}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;font-size:24px;cursor:pointer;color:#888;line-height:1}.modal-close:hover{color:#333}.activity-list{display:flex;flex-direction:column;gap:8px}.activity-option{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #ddd;border-radius:6px;cursor:pointer;transition:background .15s;background:#fff}.activity-option:hover{background:#f5f5f5}.activity-option.selected{border-color:#4a90d9;background:#f0f7ff}.activity-color{width:20px;height:20px;border-radius:4px;flex-shrink:0}.activity-name{flex:1;text-align:left}.clear-btn{background:#f5f5f5;border:1px dashed #ccc;color:#666}.section-label{font-size:12px;color:#888;margin-bottom:8px;margin-top:16px}.section-label:first-of-type{margin-top:0}.remove-activity-btn{background:none;border:none;color:#999;cursor:pointer;font-size:18px;padding:0 5px;line-height:1}.remove-activity-btn:hover{color:#d9534f}.clear-all-btn{width:100%;padding:10px;margin-top:16px;background:#fff;border:1px solid #d9534f;border-radius:6px;color:#d9534f;cursor:pointer;font-size:14px}.clear-all-btn:hover{background:#fef2f2}.modal-hint{font-size:12px;color:#888;margin-bottom:12px}.activity-type-item{display:flex;align-items:center;gap:10px;padding:10px 12px;border:1px solid #ddd;border-radius:6px;margin-bottom:8px;background:#fff;cursor:grab;transition:all .15s}.activity-type-item:active{cursor:grabbing}.activity-type-item.dragging{opacity:.5;background:#f0f0f0}.activity-type-item.drag-over{border-color:#4a90d9;border-style:dashed;background:#f0f7ff}.drag-handle{color:#aaa;cursor:grab;font-size:14px;-webkit-user-select:none;user-select:none}.drag-handle:active{cursor:grabbing}.activity-type-item input[type=text]{flex:1;border:none;font-size:14px;outline:none;background:transparent}.activity-type-item input[type=color]{width:30px;height:30px;border:none;cursor:pointer;border-radius:4px;padding:0}.delete-type-btn{background:none;border:none;color:#d9534f;cursor:pointer;font-size:18px;padding:0 5px}.delete-type-btn:hover{color:#c9302c}.add-type-btn{width:100%;padding:10px;background:#f5f5f5;border:1px dashed #ccc;border-radius:6px;cursor:pointer;font-size:14px;color:#666}.add-type-btn:hover{background:#eee}.modal-actions{display:flex;gap:10px;margin-top:16px}.modal-actions button{flex:1;padding:10px;border-radius:6px;cursor:pointer;font-size:14px}.save-btn{background:#4a90d9;color:#fff;border:none}.save-btn:hover{background:#3a7fc8}.cancel-btn{background:#fff;border:1px solid #ddd}.cancel-btn:hover{background:#f5f5f5}.legend{display:flex;flex-wrap:wrap;gap:15px;margin-top:20px;padding:15px;background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a}.legend-item{display:flex;align-items:center;gap:6px;font-size:13px}.legend-color{width:16px;height:16px;border-radius:3px}.hint{text-align:center;font-size:12px;color:#888;margin-top:15px}.range-info{font-size:14px;color:#555;margin-bottom:16px;padding:10px;background:#f5f5f5;border-radius:6px}.day-count{margin-left:8px;color:#888;font-size:13px}.selected-dates{display:block;font-size:12px;color:#888;margin-top:4px}.multi-select-bar{position:fixed;bottom:20px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fff;border-radius:8px;box-shadow:0 4px 20px #0003;z-index:50}.multi-select-bar span{font-size:14px;font-weight:500}.multi-select-bar .apply-btn{background:#4a90d9;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.multi-select-bar .apply-btn:hover{background:#3a7fc8}.multi-select-bar .cancel-btn{background:#fff;color:#666;border:1px solid #ddd;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px}.multi-select-bar .cancel-btn:hover{background:#f5f5f5}@media(max-width:1200px){.calendar-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:900px){.calendar-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:600px){.calendar-grid{grid-template-columns:1fr}}.working-day-toggle{display:flex;align-items:center;gap:6px;font-size:13px;color:#555;cursor:pointer;white-space:nowrap}.working-day-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer}.modal-wide{min-width:450px}.month-footer{margin-top:8px;padding-top:8px;border-top:1px solid #eee;font-size:12px;color:#666;text-align:center}.month-footer strong{color:#333}.month-earnings{margin-left:8px;color:#4a90d9}.loading{display:flex;align-items:center;justify-content:center;height:100vh;font-size:18px;color:#666}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.login-box{background:#fff;padding:40px;border-radius:12px;box-shadow:0 10px 40px #0003;text-align:center;min-width:320px}.login-box h1{font-size:24px;color:#333;margin-bottom:24px}.login-box form{display:flex;flex-direction:column;gap:16px}.login-box input[type=password]{padding:14px 16px;font-size:16px;border:2px solid #e0e0e0;border-radius:8px;outline:none;transition:border-color .2s}.login-box input[type=password]:focus{border-color:#667eea}.login-box button[type=submit]{padding:14px 16px;font-size:16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:600;transition:transform .15s,box-shadow .15s}.login-box button[type=submit]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}.login-box button[type=submit]:disabled{opacity:.6;cursor:not-allowed}.login-error{color:#d9534f;font-size:14px;margin-top:8px}
