*,*:before,*:after{box-sizing:border-box}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.6;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;color:#1f2328;background-color:#f6f8fa}body{margin:0;padding:0;min-height:100vh;display:flex;justify-content:center}#root{width:100%;max-width:1000px;padding:40px 20px}a{font-weight:500;color:#0969da;text-decoration:none}a:hover{text-decoration:underline}.contribution-grid-container{display:inline-block;padding:0;border:none;background-color:transparent;-webkit-user-select:none;user-select:none;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Noto Sans,Helvetica,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji"}.contribution-table{border-spacing:3px;border-collapse:separate;font-family:inherit}.contribution-table td,.contribution-table th{padding:0;box-sizing:border-box}.grid-header-row{height:15px}.grid-header-empty{width:29px}.grid-header-cell{padding:0;text-align:left;vertical-align:bottom;font-size:12px;font-weight:400;color:#656d76;position:relative}.month-label-text{position:absolute;left:0;bottom:2px;font-size:12px;font-weight:400;color:#656d76;white-space:nowrap}.grid-day-label{padding:0;width:29px;vertical-align:middle;text-align:left}.day-label-text{display:block;height:10px;padding-right:8px;font-size:12px;font-weight:400;line-height:10px;color:#656d76;text-align:right}.grid-row{height:10px}.grid-cell-container{padding:0;width:10px;height:10px;line-height:0}.grid-cell{width:10px;height:10px;border-radius:2px;background-color:#ebedf0;outline:1px solid rgba(27,31,35,.04);outline-offset:-1px;cursor:pointer;transition:outline .1s ease}.grid-cell:hover{position:relative;z-index:1;outline:2px solid rgba(27,31,35,.4)}.contribution-legend{display:flex;align-items:center;justify-content:flex-end;gap:4px;margin-top:8px;padding-right:30px;font-size:12px;color:#656d76}.legend-text{margin:0 4px}.legend-colors{display:flex;gap:3px;margin:0;padding:0;list-style:none}.legend-colors li{width:10px;height:10px;border-radius:2px;outline:1px solid rgba(27,31,35,.04);outline-offset:-1px}.color-palette{display:flex;align-items:center;gap:16px}.palette-label{font-size:13px;color:#656d76;font-weight:500}.palette-options{display:flex;gap:4px}.palette-swatch{width:20px;height:20px;border:1px solid rgba(27,31,35,.06);border-radius:3px;cursor:pointer;transition:transform .1s ease,border-color .1s ease;padding:0}.palette-swatch:hover{transform:scale(1.1);border-color:#1b1f234d}.palette-swatch.active{border:2px solid #0969da;transform:scale(1.1)}.palette-swatch:focus-visible{outline:2px solid #0969da;outline-offset:1px}.app-container{display:flex;flex-direction:column;align-items:center;gap:32px}.app-header{text-align:center}.app-header h1{margin:0;font-size:24px;font-weight:600;color:#1f2328;letter-spacing:-.02em}.app-header p{color:#656d76;font-size:14px;margin-top:8px}.controls{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;background:#fff;padding:16px 24px;border:1px solid #d0d7de;border-radius:8px;box-shadow:0 1px 2px #00000005;margin-bottom:.5rem}.export-btn{background-color:#1f883d;color:#fff;border:1px solid rgba(27,31,35,.15);border-radius:6px;padding:0 16px;height:32px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;box-shadow:0 1px #1b1f231a;transition:background-color .2s ease}.export-btn:hover{background-color:#1a7f37}.export-btn:active{background-color:#1a7f37;box-shadow:inset 0 1px #1b1f2333}.history-controls{display:flex;gap:8px}.history-btn{background-color:#f6f8fa;color:#24292f;border:1px solid rgba(27,31,35,.15);border-radius:6px;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;box-shadow:0 1px #1b1f230a;transition:background-color .2s cubic-bezier(.3,0,.5,1)}.history-btn:hover:not(:disabled){background-color:#ebecf0;border-color:#1b1f2326}.history-btn:active:not(:disabled){background-color:#dfe1e5;box-shadow:inset 0 1px #1b1f231a}.history-btn:disabled{color:#8c959f;background-color:#f6f8fa;border-color:#1b1f2326;cursor:default;box-shadow:none;opacity:.7}.clear-btn:hover:not(:disabled){background-color:#ffebe9;border-color:#a40e2680;color:#a40e26}.modal-overlay{position:fixed;inset:0;background:#1b1f2380;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{background:#fff;border-radius:12px;padding:24px;max-width:400px;width:90%;box-shadow:0 8px 24px #00000026;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.modal h2{margin:0 0 8px;font-size:18px;font-weight:600;color:#1f2328}.modal p{margin:0 0 20px;font-size:14px;color:#656d76;line-height:1.5}.modal-actions{display:flex;justify-content:flex-end;gap:12px}.modal-btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.modal-btn-cancel{background:#f6f8fa;border:1px solid rgba(27,31,35,.15);color:#24292f}.modal-btn-cancel:hover{background:#ebecf0}.modal-btn-confirm{background:#cf222e;border:1px solid rgba(27,31,35,.15);color:#fff}.modal-btn-confirm:hover{background:#a40e26}.canvas-area{display:flex;justify-content:center;overflow-x:auto;max-width:100%;padding:40px;background:#fff;border:1px solid #d0d7de;border-radius:8px;box-shadow:0 1px 2px #00000005}.instructions{color:#656d76;font-size:13px;text-align:center}.mobile-message{display:none;text-align:center;padding:2rem 1rem;background:#fff;border:1px solid #d0d7de;border-radius:8px;box-shadow:0 1px 2px #00000005;width:100%;box-sizing:border-box}.mobile-message h2{font-size:18px;font-weight:600;letter-spacing:-.02em;color:#1f2328;margin:0 0 8px}.mobile-message p{color:#656d76;font-size:16px;margin:0}@media(max-width:900px){#root{padding:20px}.app-main{width:100%}.controls,.canvas-area,.instructions{display:none!important}.mobile-message{display:block}}
