:root{--bg: #fdf8ef;--text: #555;--text-light: #aaa;--text-faint: #ccc;--border: #eae8e4;--accent: #4ECDC4;--accent2: #45B7D1}*{margin:0;padding:0;box-sizing:border-box;text-transform:lowercase}html,body{height:100%}body{font-family:Nunito,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);text-transform:lowercase}#root{min-height:100%;display:flex;align-items:center;justify-content:center}.app{display:flex;flex-direction:column;align-items:center;padding:2rem 1rem;gap:1.25rem;max-width:600px;width:100%}header{text-align:center}header h1{font-size:1.6rem;font-weight:300;letter-spacing:.08em;color:var(--text)}.presence{margin-top:.3rem;font-size:.85rem;color:var(--text-light)}.streak{margin-top:.2rem;font-size:.75rem;color:var(--accent);font-weight:500;letter-spacing:.06em}.shape-scroller{width:100%;overflow-x:auto;overflow-y:hidden;-webkit-overflow-scrolling:touch;scrollbar-width:none;padding:4px 0}.shape-scroller::-webkit-scrollbar{display:none}.shape-track{display:flex;gap:10px;padding:0 1rem;width:max-content}.shape-thumb{position:relative;display:flex;flex-direction:column;align-items:center;gap:4px;background:none;border:2px solid transparent;border-radius:10px;padding:6px;cursor:pointer;font-family:inherit;transition:border-color .15s,transform .15s;flex-shrink:0}.shape-thumb canvas{width:56px;height:56px;border-radius:6px;image-rendering:pixelated;box-shadow:0 1px 6px #0000000f;pointer-events:none}.shape-thumb-name{font-size:.65rem;color:var(--text-light)}.shape-thumb:hover{border-color:var(--border);transform:scale(1.05)}.shape-thumb.active{border-color:var(--accent);background:#4ecdc40f}.shape-thumb:disabled{opacity:.4;cursor:default;transform:none}.status-dot{position:absolute;top:2px;right:2px;width:8px;height:8px;border-radius:50%}.status-dot.open{border:2px solid var(--accent);background:transparent}.status-dot.filled{background:var(--accent)}.canvas-area{width:100%;max-width:512px;position:relative}canvas{width:100%;height:auto;display:block;border-radius:12px;box-shadow:0 2px 24px #0000000f;cursor:crosshair;image-rendering:pixelated;touch-action:none;background:#fff;transition:box-shadow .6s ease}@keyframes breathe{0%,to{box-shadow:0 0 30px #4ecdc440}50%{box-shadow:0 0 60px #4ecdc480}}.canvas-area.celebrating canvas{animation:breathe 1.8s ease-in-out infinite;cursor:default}.canvas-area.replaying canvas{box-shadow:0 0 30px #4ecdc426;cursor:default}@keyframes fadeUp{0%{opacity:0;transform:translate(-50%,-50%) translateY(12px)}to{opacity:1;transform:translate(-50%,-50%) translateY(0)}}.completion-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center;animation:fadeUp .8s ease both;pointer-events:none}.done-overlay{pointer-events:auto}.completion-word{font-size:2rem;font-weight:300;color:#fff;text-shadow:0 2px 20px rgba(0,0,0,.3);letter-spacing:.12em}.completion-sub{margin-top:.4rem;font-size:.85rem;color:#ffffffd9;text-shadow:0 1px 8px rgba(0,0,0,.3)}.next-btn{background:#ffffffeb;border:none;border-radius:24px;padding:10px 28px;font-size:.9rem;font-family:inherit;color:var(--text);cursor:pointer;box-shadow:0 2px 16px #0000001a;transition:transform .15s,box-shadow .15s}.next-btn:hover{transform:scale(1.06);box-shadow:0 4px 24px #00000026}.progress{margin-top:.75rem;background:var(--border);border-radius:4px;height:6px;position:relative;overflow:hidden}.progress-fill{height:100%;border-radius:4px;background:linear-gradient(90deg,var(--accent),var(--accent2));transition:width .4s ease}.progress-label{position:absolute;right:0;top:12px;font-size:.7rem;color:var(--text-light)}.palette{display:flex;gap:8px;flex-wrap:wrap;justify-content:center}.swatch{width:34px;height:34px;border-radius:50%;border:3px solid transparent;cursor:pointer;transition:transform .12s ease,border-color .12s ease;outline:none}.swatch:hover{transform:scale(1.18)}.swatch.active{border-color:#444;transform:scale(1.18)}.rainbow-swatch{background:conic-gradient(from 0deg,#ff6b6b,#ff9f43,#ffe66d,#96ceb4,#4ecdc4,#45b7d1,#54a0ff,#5f27cd 84%,#ff9ff3,#ff6b6b)!important;box-shadow:0 0 6px #00000014}.stats-row{display:flex;align-items:center;gap:6px;font-size:.75rem;color:var(--text-faint)}.stats-dot{width:3px;height:3px;border-radius:50%;background:var(--text-faint)}.gallery-link{background:none;border:none;font-family:inherit;font-size:inherit;color:var(--text-light);cursor:pointer;text-decoration:underline;text-underline-offset:2px}.gallery-link:hover{color:var(--text)}.hint{font-size:.75rem;color:var(--text-faint);letter-spacing:.04em;min-height:1.2em}.gallery-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:fadeIn .25s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.gallery-panel{background:#fff;border-radius:16px;padding:1.5rem;max-width:520px;width:90vw;max-height:80vh;overflow-y:auto;box-shadow:0 8px 40px #00000026}.gallery-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.gallery-header h2{font-size:1.1rem;font-weight:400;color:var(--text)}.gallery-close{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-light);line-height:1}.gallery-empty{text-align:center;color:var(--text-light);font-size:.85rem;padding:2rem 0}.gallery-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:1rem}.gallery-item{display:flex;flex-direction:column;align-items:center;gap:.4rem}.gallery-thumb{width:128px;height:128px;border-radius:8px;image-rendering:pixelated;box-shadow:0 1px 8px #0000000f}.gallery-meta{display:flex;flex-direction:column;align-items:center;gap:1px}.gallery-name{font-size:.78rem;font-weight:500;color:var(--text)}.gallery-date{font-size:.68rem;color:var(--text-light)}.gallery-people{font-size:.68rem;color:var(--text-faint)}.cursor-overlay{position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;border-radius:12px;overflow:hidden}@keyframes cursorPulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:.5}50%{transform:translate(-50%,-50%) scale(1.4);opacity:.3}}.cursor-dot{position:absolute;width:10px;height:10px;border-radius:50%;animation:cursorPulse 2s ease-in-out infinite;transition:left .08s linear,top .08s linear}.share-preview{width:200px;height:200px;border-radius:12px;box-shadow:0 4px 20px #00000026;margin-bottom:1rem}.share-actions{display:flex;gap:8px;margin-bottom:.75rem}.share-btn{background:#ffffffeb;border:none;border-radius:20px;padding:8px 20px;font-size:.82rem;font-family:inherit;color:var(--text);cursor:pointer;box-shadow:0 2px 12px #00000014;transition:transform .15s,box-shadow .15s}.share-btn:hover{transform:scale(1.05);box-shadow:0 3px 16px #0000001f}.share-btn-primary{background:var(--accent);color:#fff}@media (max-width: 540px){.app{padding:1.5rem .75rem}header h1{font-size:1.3rem}.shape-nav{gap:5px}.shape-btn{padding:4px 9px;font-size:.72rem}}
