:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:dark;color:#ffffffde;background:#1a1a2e;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#fff;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.step-tracker{max-width:100%;min-height:100vh;padding:1rem;background:linear-gradient(135deg,#1a1a2e,#16213e);color:#fff}.header{text-align:center;margin-bottom:1.5rem}.header h1{font-size:1.5rem;margin:0 0 .5rem;color:#fff}.subtitle{font-size:.85rem;color:#8892b0;margin:0}.saving-indicator{display:inline-block;margin-top:.5rem;font-size:.75rem;color:#64ffda;animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.loading{display:flex;justify-content:center;align-items:center;min-height:100vh;font-size:1.2rem;color:#8892b0}.summary-cards{display:flex;justify-content:center;margin-bottom:1.5rem}.pot-card{display:flex;align-items:center;gap:.75rem;background:linear-gradient(135deg,#0f3460,#16213e);border:1px solid #64ffda;border-radius:12px;padding:1rem 1.5rem;box-shadow:0 4px 20px #64ffda1a}.pot-icon{font-size:2rem}.pot-info{display:flex;flex-direction:column}.pot-label{font-size:.75rem;color:#8892b0;text-transform:uppercase;letter-spacing:1px}.pot-amount{font-size:1.75rem;font-weight:700;color:#64ffda}.table-container{overflow-x:auto;margin:0 -1rem;padding:0 1rem;-webkit-overflow-scrolling:touch}.steps-table{width:100%;border-collapse:collapse;font-size:.85rem}.steps-table th{position:sticky;top:0;background:#1a1a2e;padding:.75rem .5rem;text-align:center;font-weight:600;color:#ccd6f6;border-bottom:2px solid #233554;white-space:nowrap}.date-col{min-width:70px}.participant-col{min-width:80px}.steps-table td{padding:.5rem .25rem;text-align:center;border-bottom:1px solid #233554}.date-cell{font-weight:500;color:#8892b0;white-space:nowrap;position:relative}.today-row{background:#64ffda0d}.today-badge{display:block;font-size:.6rem;color:#64ffda;font-weight:600}.step-cell-container{padding:.25rem!important}.step-cell{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:.5rem .25rem;border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:50px}.step-cell.success{background:#2ed57326;border:1px solid rgba(46,213,115,.3)}.step-cell.fail{background:#ff475726;border:1px solid rgba(255,71,87,.3)}.step-cell.empty{background:#8892b01a;border:1px dashed rgba(136,146,176,.3)}.step-cell.empty:hover{background:#8892b033;border-color:#8892b080}.step-cell.future{color:#4a5568;cursor:not-allowed}.step-icon{font-size:1rem}.step-count{font-size:.7rem;color:#8892b0;margin-top:.125rem}.tap-hint{font-size:.65rem;color:#8892b0}.step-input{width:100%;padding:.5rem;font-size:.85rem;text-align:center;border:2px solid #64ffda;border-radius:6px;background:#0f3460;color:#fff;outline:none}.step-input::placeholder{color:#4a5568}.stats-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #233554}.stats-section h2{font-size:1.1rem;margin:0 0 1rem;text-align:center;color:#ccd6f6}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:.75rem}.stat-card{background:linear-gradient(135deg,#0f3460,#16213e);border:1px solid #233554;border-radius:12px;padding:1rem}.stat-card h3{font-size:.9rem;margin:0 0 .75rem;color:#64ffda;text-align:center}.stat-row{display:flex;justify-content:space-between;align-items:center;font-size:.8rem;color:#8892b0;margin-bottom:.4rem}.stat-value{font-weight:600;color:#ccd6f6}.fail-text{color:#ff4757}.footer{text-align:center;margin-top:2rem;padding:1rem;color:#4a5568;font-size:.75rem}@media (min-width: 768px){.step-tracker{max-width:800px;margin:0 auto;padding:2rem}.header h1{font-size:2rem}.subtitle{font-size:1rem}.steps-table{font-size:.95rem}.step-cell{min-height:60px}.step-icon{font-size:1.25rem}.step-count{font-size:.8rem}.stat-card{padding:1.25rem}}.scroll-top-btn{position:fixed;bottom:2rem;right:1.5rem;background:linear-gradient(135deg,#64ffda,#00bfa5);color:#0a192f;border:none;border-radius:50px;padding:.75rem 1.25rem;font-size:.9rem;font-weight:600;cursor:pointer;box-shadow:0 4px 15px #64ffda4d;transition:all .3s ease;z-index:100}.scroll-top-btn:hover{transform:translateY(-2px);box-shadow:0 6px 20px #64ffda66}.scroll-top-btn:active{transform:translateY(0)}#root{width:100%;min-height:100vh}
