@import url("https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;0,600;1,300;1,400&family=Outfit:wght@300;400;500&display=swap");*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--bg:#F8F4EE;--bg-warm:#F2EDE4;--text:#1A1710;--text-muted:#7A7060;--accent:#B8870B;--accent-pale:#EDD98A;--border:#DDD0BC;--border-light:#EAE3D8;--surface:#FDFAF5;--surface-hover:#F5EFE5;--danger:#C0392B;--green:#5A7A5A;--font-display:"Cormorant Garamond",Georgia,serif;--font-body:"Outfit",system-ui,sans-serif;--radius:4px;--radius-lg:8px;--shadow:0 1px 3px rgba(26,23,16,0.08),0 4px 12px rgba(26,23,16,0.04);--shadow-lg:0 4px 24px rgba(26,23,16,0.12)}html{font-size:16px}body,html{overflow-x:hidden;background-color:var(--bg)}body{font-family:var(--font-body);color:var(--text);font-weight:300;line-height:1.6;min-height:100vh;-webkit-font-smoothing:antialiased;position:relative}body:before{content:"";position:fixed;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");pointer-events:none;z-index:1000;opacity:.5}.sr-only{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.login-card{width:100%;max-width:360px;text-align:center}.login-eyebrow{font-family:var(--font-body);font-size:.7rem;font-weight:500;letter-spacing:.18em;text-transform:uppercase;color:var(--accent);margin-bottom:1.5rem}.login-title{font-family:var(--font-display);font-size:2.8rem;font-weight:300;line-height:1.1;color:var(--text);margin-bottom:.5rem}.login-subtitle{font-size:.85rem;color:var(--text-muted);font-weight:300;margin-bottom:2.5rem}.login-form{display:flex;flex-direction:column;gap:1rem}.login-input{width:100%;padding:.875rem 1.125rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-family:var(--font-body);font-size:1rem;font-weight:300;color:var(--text);letter-spacing:.12em;text-align:center;transition:border-color .2s;outline:none}.login-input:focus{border-color:var(--accent)}.login-input::placeholder{color:var(--text-muted);letter-spacing:.08em}.login-btn{width:100%;padding:.875rem;background:var(--text);color:var(--bg);border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.8rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:background .2s,opacity .2s}.login-btn:hover:not(:disabled){background:#2C2820}.login-btn:disabled{opacity:.5;cursor:not-allowed}.login-error{font-size:.8rem;color:var(--danger);font-weight:400;margin-top:.25rem}.login-divider{width:48px;height:1px;background:var(--border);margin:2rem auto}.dashboard{min-height:100vh;display:flex;flex-direction:column;max-width:100%;overflow-x:hidden}.header{padding:max(2rem,env(safe-area-inset-top)) max(3rem,env(safe-area-inset-right)) 1.5rem max(3rem,env(safe-area-inset-left));border-bottom:1px solid var(--border-light);display:flex;align-items:flex-end;justify-content:space-between;gap:1rem}.header-eyebrow{font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:.25rem}.header-title{font-family:var(--font-display);font-size:2.4rem;font-weight:300;line-height:1;color:var(--text);font-style:italic}.header-right{display:flex;align-items:center;gap:1.5rem}.header-count{font-size:.75rem;color:var(--text-muted);font-weight:300}.logout-btn{background:none;border:1px solid var(--border);padding:.4rem .875rem;border-radius:var(--radius);font-family:var(--font-body);font-size:.72rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;color:var(--text-muted);cursor:pointer;transition:all .2s}.logout-btn:hover{border-color:var(--text);color:var(--text)}.main-grid{flex:1 1;display:grid;grid-template-columns:1fr 1fr;grid-gap:0;gap:0}.wheel-column{padding:3rem;display:flex;flex-direction:column;align-items:center;border-right:1px solid var(--border-light);gap:2rem}@media (max-width:900px){.main-grid{grid-template-columns:1fr}.header{padding:1.25rem 1.25rem 1rem}.header-title{font-size:1.8rem}.wheel-column{padding:1.5rem 1.25rem;border-right:none;border-bottom:1px solid var(--border-light);gap:1.25rem;align-items:center;max-width:380px;margin-left:auto;margin-right:auto;width:100%}.wheel-section-label{align-self:center}.wheel-canvas-container{max-width:280px;margin:0 auto}.wheel-items-preview{justify-content:center}.list-column{padding:1.5rem 1.25rem;max-height:none}.winner-panel{max-width:calc(100% - 2rem);padding:2rem 1.5rem;margin:1rem}.winner-text{font-size:1.8rem}.winner-actions{flex-direction:column}.spin-btn,.winner-accept,.winner-dismiss{width:100%}.spin-btn{padding:.7rem 2rem;font-size:.72rem;max-width:320px}}@media (max-width:400px){.header{padding:1rem;flex-direction:column;align-items:flex-start}.header-right{width:100%;justify-content:space-between}.header-title{font-size:1.5rem}.list-column,.wheel-column{padding:1.25rem 1rem}}.wheel-section-label{font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted);align-self:flex-start}.wheel-wrap{flex-direction:column;align-items:center;gap:1.5rem;overflow:hidden}.wheel-canvas-container,.wheel-wrap{position:relative;display:flex;width:100%}.wheel-canvas-container{max-width:420px;justify-content:center}.spin-btn{padding:.75rem 3rem;background:var(--text);color:var(--bg);border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.14em;text-transform:uppercase;cursor:pointer;transition:all .2s}.spin-btn:hover:not(:disabled){background:#2C2820;transform:translateY(-1px)}.spin-btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.wheel-empty{text-align:center;padding:2rem 0;color:var(--text-muted);font-size:.85rem;font-weight:300}.add-section{padding:1.5rem 0 0;width:100%}.add-form{display:flex;gap:.5rem}.add-input{flex:1 1;min-width:0;padding:.7rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);font-family:var(--font-body);font-size:1rem;font-weight:300;color:var(--text);outline:none;transition:border-color .2s}.add-input:focus{border-color:var(--accent)}.add-input::placeholder{color:var(--text-muted)}.add-btn{padding:.7rem 1.25rem;background:var(--accent);color:white;border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s;white-space:nowrap}.add-btn:hover:not(:disabled){background:#9A6F09}.add-btn:disabled{opacity:.5;cursor:not-allowed}.list-column{padding:3rem;display:flex;flex-direction:column;gap:2rem;overflow-y:auto;max-height:calc(100vh - 97px)}.list-section-label{font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--text-muted)}.list-title{font-family:var(--font-display);font-size:1.6rem;font-weight:300;margin-bottom:1.25rem}.list-empty{color:var(--text-muted);font-size:.85rem;font-weight:300;font-style:italic;padding:1rem 0}.bucket-items{display:flex;flex-direction:column;gap:0}.bucket-item{display:flex;align-items:center;gap:.875rem;padding:.875rem 0;border-bottom:1px solid var(--border-light);animation:itemAppear .4s ease}.bucket-item:first-child{border-top:1px solid var(--border-light)}@keyframes itemAppear{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.item-checkbox{width:18px;height:18px;border:1.5px solid var(--border);border-radius:50%;background:none;cursor:pointer;flex-shrink:0;display:flex;align-items:center;justify-content:center;transition:all .2s;position:relative}.item-checkbox:hover{border-color:var(--accent)}.item-checkbox.checked{background:var(--green);border-color:var(--green)}.item-checkbox.checked:after{content:"";width:5px;height:9px;border-right:1.5px solid white;border-bottom:1.5px solid white;transform:rotate(45deg) translateY(-1px)}.item-text{flex:1 1;min-width:0;overflow-wrap:break-word;word-break:break-word;font-size:.9rem;font-weight:300;color:var(--text);transition:all .2s}.item-text.completed{text-decoration:line-through;color:var(--text-muted)}.item-delete{background:none;border:none;color:var(--border);cursor:pointer;font-size:1rem;line-height:1;padding:.125rem .25rem;border-radius:var(--radius);transition:color .2s}.item-delete:hover{color:var(--danger)}.wheel-items-preview{width:100%;display:flex;flex-wrap:wrap;gap:.4rem}.wheel-tag{font-size:.72rem;font-weight:400;color:var(--text-muted);background:var(--bg-warm);border:1px solid var(--border-light);border-radius:20px;padding:.2rem .6rem;display:flex;align-items:center;gap:.3rem}.wheel-tag-delete{background:none;border:none;color:var(--text-muted);cursor:pointer;font-size:.8rem;line-height:1;padding:0;margin-left:.1rem;transition:color .15s}.wheel-tag-delete:hover{color:var(--danger)}.winner-overlay{position:fixed;inset:0;background:rgba(26,23,16,.4);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:100;animation:overlayIn .3s ease}@keyframes overlayIn{0%{opacity:0}to{opacity:1}}.winner-panel{background:var(--surface);width:100%;max-width:560px;padding:3rem;border-radius:12px;text-align:center;animation:panelIn .4s cubic-bezier(.16,1,.3,1);box-shadow:var(--shadow-lg)}@keyframes panelIn{0%{opacity:0;transform:scale(.95) translateY(12px)}to{opacity:1;transform:scale(1) translateY(0)}}.winner-eyebrow{font-size:.65rem;font-weight:500;letter-spacing:.2em;text-transform:uppercase;color:var(--accent);margin-bottom:1rem}.winner-text{font-family:var(--font-display);font-size:2.4rem;font-weight:400;color:var(--text);line-height:1.2;margin-bottom:.5rem}.winner-subtext{font-size:.8rem;color:var(--text-muted);font-weight:300;margin-bottom:2rem}.winner-actions{display:flex;gap:.75rem;justify-content:center}.winner-accept{padding:.75rem 2rem;background:var(--text);color:var(--bg);border:none;border-radius:var(--radius);font-family:var(--font-body);font-size:.78rem;font-weight:500;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;transition:all .2s}.winner-accept:hover{background:#2C2820}.winner-dismiss{padding:.75rem 1.5rem;background:none;color:var(--text-muted);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-body);font-size:.78rem;font-weight:400;letter-spacing:.1em;text-transform:uppercase;cursor:pointer;transition:all .2s}.winner-dismiss:hover{border-color:var(--text-muted);color:var(--text)}.section-sep{width:32px;height:1px;background:var(--border)}.progress-line{height:2px;background:var(--border-light);border-radius:1px;overflow:hidden;margin-bottom:.5rem}.progress-fill{height:100%;background:var(--green);border-radius:1px;transition:width .4s ease}.progress-label{font-size:.72rem;color:var(--text-muted);font-weight:300}