@import "https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";
.stw-page{z-index:9999;position:fixed;inset:0;background:#fff!important}.stw-page:before,.stw-page:after{display:none!important}.stw-back-button{z-index:10000;color:#888;border-radius:8px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;transition:all .2s;position:absolute;top:1rem;left:1rem}.stw-back-button:hover{color:#1a1a1a;background:#f5f5f5}.app-container{color:#1a1a1a;background:#fff;height:100vh;font-family:Inter,sans-serif;display:flex;position:relative;overflow:hidden}.confetti-canvas{pointer-events:none;z-index:1000;width:100vw;height:100vh;position:fixed;top:0;left:0}.wheel-section{background:#fff;flex-direction:column;flex:1;justify-content:center;align-items:center;padding:2rem;display:flex;overflow:hidden}.app-header{text-align:center;margin-bottom:.5rem}.app-header h1{color:#1a1a1a;letter-spacing:-.02em;margin:0 0 .5rem;font-size:1.75rem;font-weight:700}.subtitle{color:#888;margin:0;font-size:.9rem}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.input-section-wrapper{flex-shrink:0;width:340px;height:100vh;overflow:hidden}.app-footer{justify-content:center;align-items:center;gap:.75rem;margin-top:1.5rem;display:flex}.footer-link{color:#888;align-items:center;gap:.4rem;text-decoration:none;transition:color .2s;display:flex}.footer-link:hover{color:#1a1a1a}.footer-link svg{flex-shrink:0}.footer-text{font-size:.8rem;font-weight:500}.footer-divider{color:#ccc;font-size:.75rem}.wheel-container{flex-direction:column;justify-content:center;align-items:center;padding:2rem 2rem 1.5rem;display:flex;position:relative}.pointer{z-index:10;filter:drop-shadow(0 2px 4px #0003);border-top:28px solid #333;border-left:14px solid #0000;border-right:14px solid #0000;width:0;height:0;position:absolute;top:.75rem;left:50%;transform:translate(-50%)}.wheel-wrapper{will-change:transform;transform-origin:50%;z-index:1;justify-content:center;align-items:center;transition:transform 5s cubic-bezier(.17,.67,.12,.99);display:flex}.wheel-wrapper canvas{border-radius:50%}.spin-button{letter-spacing:.1em;color:#1a1a1a;cursor:pointer;background:linear-gradient(135deg,#fffdf7 0%,#ffe66d 50%,#ff9f43 100%);border:none;border-radius:50px;margin-top:1.5rem;padding:.875rem 2.5rem;font-size:1rem;font-weight:600;transition:all .3s;box-shadow:0 4px 15px #ff9f434d}.spin-button:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #ff9f4366}.spin-button:active:not(:disabled){transform:translateY(0)}.spin-button:disabled{color:#888;cursor:not-allowed;box-shadow:none;background:linear-gradient(135deg,#e5e5e5 0%,#ccc 100%)}.input-panel{background:#fff;border-left:1px solid #eee;flex-direction:column;height:100%;padding:1.5rem;display:flex;overflow:hidden}.panel-header{border-bottom:1px solid #f0f0f0;flex-shrink:0;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;display:flex}.panel-header h2{color:#1a1a1a;margin:0;font-size:1.1rem;font-weight:600}.option-count{color:#888;background:#f5f5f5;border-radius:20px;padding:.2rem .6rem;font-size:.8rem}.input-section{flex-shrink:0;margin-bottom:1rem}.input-section label{color:#1a1a1a;margin-bottom:.2rem;font-size:.85rem;font-weight:500;display:block}.input-hint{color:#aaa;margin:0 0 .5rem;font-size:.75rem}.input-section textarea{color:#1a1a1a;resize:none;background:#fafafa;border:1px solid #e5e5e5;border-radius:10px;width:100%;padding:.75rem;font-family:inherit;font-size:.875rem;line-height:1.5;transition:all .2s}.input-section textarea:focus{background:#fff;border-color:#333;outline:none;box-shadow:0 0 0 3px #0000000d}.input-section textarea::placeholder{color:#bbb}.button-group{flex-shrink:0;gap:.5rem;margin-bottom:1rem;display:flex}.btn{cursor:pointer;border:none;border-radius:8px;flex:1;padding:.6rem .75rem;font-size:.8rem;font-weight:600;transition:all .2s}.btn-sample{color:#1a1a1a;background:linear-gradient(135deg,#e8fff8 0%,#95e1d3 50%,#4ecdc4 100%);box-shadow:0 3px 10px #4ecdc440}.btn-sample:hover{transform:translateY(-1px);box-shadow:0 4px 15px #4ecdc459}.btn-clear{color:#1a1a1a;background:linear-gradient(135deg,#fff0f0 0%,#fcbad3 50%,#f38181 100%);box-shadow:0 3px 10px #f3818140}.btn-clear:hover{transform:translateY(-1px);box-shadow:0 4px 15px #f3818159}.settings-section{flex-shrink:0;margin-bottom:1rem}.checkbox-label{color:#1a1a1a;cursor:pointer;-webkit-user-select:none;user-select:none;background:#fafafa;border:1px solid #e5e5e5;border-radius:8px;align-items:center;gap:.5rem;padding:.5rem;font-size:.85rem;transition:all .2s;display:flex}.checkbox-label:hover{background:#f5f5f5;border-color:#d5d5d5}.checkbox-label input[type=checkbox]{cursor:pointer;accent-color:#333;width:1rem;height:1rem}.options-preview{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.options-preview h3{color:#999;text-transform:uppercase;letter-spacing:.08em;flex-shrink:0;margin:0 0 .5rem;font-size:.75rem;font-weight:500}.chips-container{flex-wrap:wrap;flex:1;align-content:flex-start;gap:.4rem;padding-right:.25rem;display:flex;overflow-y:auto}.chip{color:#1a1a1a;opacity:0;white-space:nowrap;text-overflow:ellipsis;background:linear-gradient(135deg,#f0f0ff 0%,#e8e8ff 50%,#ddd8ff 100%);border:1px solid #d8d0ff;border-radius:16px;max-width:100%;padding:.4rem .75rem;font-size:.8rem;font-weight:500;animation:.3s forwards fadeIn;display:inline-block;overflow:hidden;box-shadow:0 2px 6px #aa96da26}.empty-message{color:#bbb;font-size:.85rem;font-style:italic}.chips-container::-webkit-scrollbar{width:4px}.chips-container::-webkit-scrollbar-track{background:0 0}.chips-container::-webkit-scrollbar-thumb{background:#e0e0e0;border-radius:2px}.chips-container::-webkit-scrollbar-thumb:hover{background:#d0d0d0}@media (max-width:900px){.app-container{flex-direction:column;height:auto;min-height:100vh;overflow:auto}.wheel-section{min-height:60vh;padding:1.5rem}.app-header h1{font-size:1.5rem}.input-section-wrapper{width:100%;height:auto;max-height:50vh}}@media (max-width:768px){.wheel-container{padding:1.5rem 1rem 1rem}.pointer{border-top:24px solid #333;border-left:12px solid #0000;border-right:12px solid #0000}.spin-button{padding:.75rem 2rem}.input-panel{border-top:1px solid #eee;border-left:none;padding:1.25rem}}
