@import "https://fonts.googleapis.com/css2?family=Sora:wght@300;400;500;600;700;800&family=Plus+Jakarta+Sans:wght@300;400;500;600;700;800&display=swap";body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:Plus Jakarta Sans,sans-serif}::selection{color:#fff;background:#2563eb}:root{--blue-50:#eff6ff;--blue-100:#dbeafe;--blue-200:#bfdbfe;--blue-300:#93c5fd;--blue-400:#60a5fa;--blue-500:#3b82f6;--blue-600:#2563eb;--blue-700:#1d4ed8;--white:#fff;--gray-50:#f8fafc;--gray-100:#f1f5f9;--gray-200:#e2e8f0;--gray-300:#cbd5e1;--gray-400:#94a3b8;--gray-500:#64748b;--gray-600:#475569;--gray-700:#334155;--gray-800:#1e293b;--gray-900:#0f172a;--font-display:"Sora", sans-serif;--font-body:"Plus Jakarta Sans", sans-serif;--radius:16px;--radius-sm:10px;--radius-xs:8px}*{box-sizing:border-box;margin:0;padding:0}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:var(--font-body);-webkit-font-smoothing:antialiased}::selection{background:var(--blue-500);color:#fff}::-webkit-scrollbar{width:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--blue-300);border-radius:3px}input,textarea{outline:none;font-family:inherit}.app{background:linear-gradient(160deg, var(--white) 0%, var(--blue-50) 40%, var(--blue-100) 100%);flex-direction:column;width:100vw;height:100vh;display:flex;position:relative;overflow:hidden}.app-content{z-index:1;flex:1;justify-content:center;align-items:center;min-height:0;display:flex;position:relative}.particle-canvas{z-index:0;pointer-events:none;position:fixed;inset:0}.bg-dots{z-index:0;background-image:radial-gradient(circle, var(--blue-200) .8px, transparent .8px);opacity:.2;pointer-events:none;background-size:32px 32px;position:fixed;inset:0}.bg-blob{filter:blur(100px);pointer-events:none;z-index:0;border-radius:50%;position:fixed}.bg-blob-1{background:#3b82f612;width:600px;height:600px;animation:25s ease-in-out infinite blobMove;top:-200px;right:-150px}.bg-blob-2{background:#60a5fa0d;width:450px;height:450px;animation:30s ease-in-out infinite reverse blobMove;bottom:-150px;left:-100px}@keyframes blobMove{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-25px)scale(1.04)}66%{transform:translate(-25px,30px)scale(.96)}}.app-footer{z-index:10;color:var(--gray-400);letter-spacing:.01em;justify-content:center;align-items:center;gap:8px;padding:16px 20px 20px;font-size:.78rem;font-weight:500;display:flex;position:relative}.footer-text{font-family:var(--font-body)}.heart{vertical-align:middle;font-size:.85rem;line-height:1}.footer-sep{color:var(--gray-300)}.footer-link{color:var(--blue-500);font-weight:600;text-decoration:none;transition:color .15s}.footer-link:hover{color:var(--blue-700);text-decoration:underline}.logo-img{object-fit:cover;image-rendering:-webkit-optimize-contrast;image-rendering:crisp-edges;border-radius:22%;flex-shrink:0;display:block}.step-container{z-index:10;flex-direction:column;align-items:center;width:100%;max-width:780px;padding:0 20px;display:flex;position:relative}.brand-row{align-items:center;gap:18px;margin-bottom:28px;display:flex}.brand-logo{width:64px;height:64px;box-shadow:0 4px 16px #2563eb26}.brand-title{font-family:var(--font-display);color:var(--gray-800);letter-spacing:-.03em;font-size:clamp(1.6rem,4vw,2.4rem);font-weight:800;line-height:1.1}.brand-title .highlight{background:linear-gradient(135deg, var(--blue-500), var(--blue-700));-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text}.brand-subtitle{color:var(--gray-400);margin-top:2px;font-size:.88rem;font-weight:400}.input-card{background:var(--white);border-radius:var(--radius);width:100%;box-shadow:0 2px 20px #2563eb0f, 0 0 0 1px var(--gray-100);padding:28px 24px}.input-columns{align-items:flex-start;gap:24px;display:flex}.input-col-form{flex:1.2;min-width:0}.input-col-list{flex-direction:column;flex:1;min-width:0;display:flex}.list-header{background:var(--blue-50);border-radius:var(--radius-xs);border:1px solid var(--blue-100);margin-bottom:8px;padding:7px 14px}.list-header-text{font-family:var(--font-display);color:var(--blue-600);letter-spacing:.06em;text-transform:uppercase;font-size:.78rem;font-weight:700}.contestant-list{max-height:256px;padding-right:4px;overflow-y:auto}.contestant-list::-webkit-scrollbar{width:4px}.contestant-list::-webkit-scrollbar-thumb{background:var(--blue-300);border-radius:2px}.contestant-list::-webkit-scrollbar-track{background:0 0}.contestant-list-items{flex-direction:column;gap:4px;display:flex}.contestant-list-empty{text-align:center;color:var(--gray-300);border:1.5px dashed var(--gray-200);border-radius:var(--radius-sm);justify-content:center;align-items:center;min-height:160px;padding:40px 16px;font-size:.82rem;display:flex}.contestant-item{background:var(--gray-50);border:1px solid var(--gray-100);border-radius:var(--radius-xs);align-items:center;gap:10px;padding:9px 14px;transition:background .15s,border-color .15s;display:flex}.contestant-item:hover{background:var(--blue-50);border-color:var(--blue-200)}.contestant-num{background:var(--blue-600);color:#fff;min-width:26px;height:26px;font-size:.68rem;font-weight:700;font-family:var(--font-display);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;display:flex}.contestant-name{color:var(--gray-700);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.85rem;font-weight:500;overflow:hidden}.input-label{font-family:var(--font-display);color:var(--blue-600);letter-spacing:.12em;text-transform:uppercase;align-items:center;gap:6px;margin-bottom:8px;font-size:.7rem;font-weight:700;display:flex}.text-input{background:var(--gray-50);border:1.5px solid var(--gray-200);border-radius:var(--radius-sm);width:100%;color:var(--gray-800);padding:11px 16px;font-size:.92rem;transition:border-color .2s,box-shadow .2s}.text-input::placeholder{color:var(--gray-400)}.text-input:focus{border-color:var(--blue-400);box-shadow:0 0 0 3px #3b82f61f}.text-input.textarea{resize:none;line-height:1.6}.duration-badge{background:var(--blue-600);color:#fff;border-radius:999px;justify-content:center;align-items:center;margin-left:4px;padding:1px 8px;font-size:.68rem;font-weight:700;display:inline-flex}.range-row{align-items:center;gap:10px;margin-top:4px;display:flex}.range-label{font-family:var(--font-display);color:var(--gray-400);text-align:center;min-width:24px;font-size:.72rem;font-weight:600}.range-track-wrapper{flex:1;align-items:center;height:28px;display:flex;position:relative}.range-fill{background:var(--blue-500);pointer-events:none;z-index:1;border-radius:3px;height:5px;position:absolute;top:50%;left:0;transform:translateY(-50%)}.range-input{appearance:none;background:var(--gray-200);z-index:2;border-radius:3px;outline:none;width:100%;height:5px;position:relative}.range-input::-webkit-slider-thumb{appearance:none;background:var(--white);border:2.5px solid var(--blue-500);cursor:pointer;border-radius:50%;width:20px;height:20px;transition:transform .15s;box-shadow:0 1px 6px #2563eb33}.range-input::-webkit-slider-thumb:hover{transform:scale(1.15)}.range-input::-moz-range-thumb{background:var(--white);border:2.5px solid var(--blue-500);cursor:pointer;border-radius:50%;width:20px;height:20px}.start-btn{background:var(--blue-600);border-radius:var(--radius-sm);width:100%;max-width:480px;font-family:var(--font-display);color:var(--white);cursor:pointer;border:none;margin-top:20px;padding:14px 32px;font-size:.92rem;font-weight:600;transition:background .2s,transform .15s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 2px 12px #2563eb40}.start-btn:hover:not(:disabled){background:var(--blue-700);transform:translateY(-1px);box-shadow:0 4px 20px #2563eb4d}.start-btn:active:not(:disabled){transform:translateY(0)}.start-btn:disabled{background:var(--gray-200);color:var(--gray-400);cursor:default;box-shadow:none}.start-btn .btn-shimmer{background:linear-gradient(105deg,#0000 30%,#ffffff26 50%,#0000 70%);position:absolute;inset:0;transform:translate(-100%)}.start-btn:hover:not(:disabled) .btn-shimmer{animation:.5s shimmer}@keyframes shimmer{to{transform:translate(100%)}}.spin-container{z-index:10;flex-direction:column;align-items:center;gap:24px;width:100%;max-width:860px;padding:0 20px;display:flex;position:relative}.spin-header{text-align:left;align-items:center;gap:14px;display:flex}.spin-logo{width:48px;height:48px;box-shadow:0 2px 10px #2563eb1f}.spin-title{font-family:var(--font-display);color:var(--gray-800);letter-spacing:-.01em;font-size:clamp(1.1rem,2.8vw,1.6rem);font-weight:700;line-height:1.2}.spin-subtitle{color:var(--gray-400);margin-top:1px;font-size:.82rem;font-weight:500}.reel-wrapper{width:100%}.reel-frame{background:var(--white);border:2px solid var(--blue-200);border-radius:var(--radius);width:100%;height:clamp(360px,48vh,480px);box-shadow:0 4px 24px #2563eb0f, 0 0 0 1px var(--blue-100);position:relative;overflow:hidden}.reel-frame:before,.reel-frame:after{content:"";z-index:5;pointer-events:none;height:30%;position:absolute;left:0;right:0}.reel-frame:before{background:linear-gradient(#fffffff2,#0000);top:0}.reel-frame:after{background:linear-gradient(#0000,#fffffff2);bottom:0}.reel-selector{border:2px solid var(--blue-400);z-index:6;pointer-events:none;background:linear-gradient(#3b82f60a 0%,#3b82f614 50%,#3b82f60a 100%);border-radius:16px;height:84px;position:absolute;top:50%;left:32px;right:32px;transform:translateY(-50%);box-shadow:0 0 0 1px #3b82f60f,inset 0 1px #ffffff80,inset 0 -1px #ffffff80,0 0 24px #3b82f614}.reel-selector:before{content:"";border-top:10px solid #0000;border-bottom:10px solid #0000;border-right:11px solid var(--blue-500);filter:drop-shadow(-2px 0 3px #3b82f626);width:0;height:0;position:absolute;top:50%;left:-10px;transform:translateY(-50%)}.reel-selector:after{content:"";border-top:10px solid #0000;border-bottom:10px solid #0000;border-left:11px solid var(--blue-500);filter:drop-shadow(2px 0 3px #3b82f626);width:0;height:0;position:absolute;top:50%;right:-10px;transform:translateY(-50%)}.reel-scroll-area{justify-content:center;align-items:center;width:100%;height:100%;display:flex;position:relative;overflow:hidden}.reel-item{text-align:center;white-space:nowrap;will-change:transform, opacity;pointer-events:none;position:absolute;top:50%;left:0;right:0}.reel-item-center{font-family:var(--font-display);color:var(--blue-700);letter-spacing:-.01em;font-size:clamp(1.8rem,4.5vw,2.8rem);font-weight:800}.reel-item-dim{font-family:var(--font-display);color:var(--gray-400);letter-spacing:0;font-size:clamp(1rem,2.2vw,1.35rem);font-weight:500}.reel-static{width:100%;height:100%;font-family:var(--font-display);color:var(--gray-300);justify-content:center;align-items:center;gap:10px;font-size:1.05rem;font-weight:600;display:flex}.reel-static-logo{opacity:.5;width:36px;height:36px}.spin-btn{background:var(--blue-600);border-radius:var(--radius-sm);width:100%;max-width:380px;font-family:var(--font-display);color:var(--white);cursor:pointer;border:none;padding:18px 36px;font-size:1.05rem;font-weight:700;transition:background .2s,transform .15s,box-shadow .2s;position:relative;overflow:hidden;box-shadow:0 4px 20px #2563eb40}.spin-btn:hover:not(:disabled){background:var(--blue-700);transform:translateY(-2px);box-shadow:0 6px 28px #2563eb4d}.spin-btn:active:not(:disabled){transform:translateY(0)}.spin-btn.spinning{background:var(--gray-300);color:var(--gray-500);box-shadow:none;cursor:default}.spin-btn .btn-shimmer{background:linear-gradient(105deg,#0000 30%,#ffffff2e 50%,#0000 70%);position:absolute;inset:0;transform:translate(-100%)}.spin-btn:hover:not(:disabled) .btn-shimmer{animation:.5s shimmer}.spin-btn-loading{justify-content:center;align-items:center;gap:6px;display:flex}.back-btn{color:var(--gray-400);font-family:var(--font-body);cursor:pointer;background:0 0;border:none;border-radius:8px;align-items:center;gap:4px;margin-top:4px;padding:8px 14px;font-size:.82rem;font-weight:600;transition:all .15s;display:flex}.back-btn:hover{color:var(--blue-600);background:var(--blue-50)}.winner-overlay{z-index:100;-webkit-backdrop-filter:blur(10px);background:#0f172a99;flex-direction:column;justify-content:center;align-items:center;gap:24px;display:flex;position:fixed;inset:0}.winner-card{background:var(--white);border-radius:20px;width:90vw;max-width:460px;position:relative;overflow:hidden;box-shadow:0 20px 60px #00000026,0 0 0 1px #3b82f614}.winner-card-bar{background:linear-gradient(90deg, var(--blue-400), var(--blue-600));height:4px}.winner-card-inner{flex-direction:column;align-items:center;gap:12px;padding:40px 44px 28px;display:flex}.winner-card-top{justify-content:center;align-items:center;display:flex}.winner-logo{border-radius:22%;width:52px;height:52px;box-shadow:0 3px 12px #2563eb1f}.winner-trophy-wrap{justify-content:center;align-items:center;margin:4px 0;display:flex}.winner-trophy{color:var(--blue-500)}.winner-label{font-family:var(--font-display);color:var(--blue-500);letter-spacing:.3em;text-transform:uppercase;font-size:.68rem;font-weight:800}.winner-contest-tag{font-family:var(--font-body);color:var(--gray-400);background:var(--gray-50);border:1px solid var(--gray-100);border-radius:999px;padding:4px 14px;font-size:.8rem;font-weight:500}.winner-name{font-family:var(--font-display);color:var(--gray-900);letter-spacing:-.02em;text-align:center;word-break:break-word;max-width:100%;min-height:1.2em;padding:8px 0 4px;font-weight:900;line-height:1.15}.winner-card-separator{background:var(--gray-200);width:40px;height:1px;margin:4px 0}.winner-card-footer{align-items:center;gap:6px;margin-top:4px;display:flex}.winner-footer-logo{opacity:.5;border-radius:22%;width:20px;height:20px}.winner-footer-text{color:var(--gray-400);letter-spacing:.03em;font-size:.7rem;font-weight:500}.winner-actions{z-index:101;flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.btn-primary{background:var(--blue-600);border-radius:var(--radius-sm);font-family:var(--font-display);color:var(--white);cursor:pointer;letter-spacing:.01em;border:none;padding:12px 28px;font-size:.88rem;font-weight:600;transition:background .2s,transform .15s;box-shadow:0 2px 12px #2563eb33}.btn-primary:hover{background:var(--blue-700);transform:translateY(-1px)}.btn-secondary{background:var(--white);border:1.5px solid var(--blue-200);border-radius:var(--radius-sm);font-family:var(--font-display);color:var(--blue-600);cursor:pointer;align-items:center;gap:4px;padding:12px 24px;font-size:.88rem;font-weight:600;transition:all .15s;display:flex}.btn-secondary:hover{background:var(--blue-50);border-color:var(--blue-400)}.btn-secondary:disabled{opacity:.5;cursor:default}.btn-ghost{border-radius:var(--radius-sm);font-family:var(--font-display);color:#ffffffb3;cursor:pointer;background:0 0;border:1.5px solid #fff3;padding:12px 20px;font-size:.88rem;font-weight:600;transition:all .15s}.btn-ghost:hover{color:#fff;background:#ffffff0d;border-color:#fff6}@media (width<=700px){.input-columns{flex-direction:column}.step-container{max-width:520px}.brand-logo{width:52px;height:52px}.brand-title{font-size:clamp(1.4rem,5vw,2rem)}}@media (width<=500px){.step-container{padding:0 14px}.input-card{padding:20px 16px}.spin-container{gap:16px}.contestant-list{max-height:180px}.winner-card-inner{padding:28px 22px 20px}.winner-actions{flex-direction:column;align-items:stretch;width:90vw;max-width:320px}.winner-actions button{text-align:center;justify-content:center;width:100%}}@media (width>=1400px){.step-container{max-width:1000px}.input-card{padding:36px 32px}.brand-title{font-size:3rem}.brand-logo{width:80px!important;height:80px!important}.text-input{padding:14px 18px;font-size:1.05rem}.contestant-list{max-height:320px}.spin-container{max-width:960px}.reel-frame{height:520px!important}.reel-selector{height:100px}.reel-item-center{font-size:3.5rem!important}.reel-item-dim{font-size:1.6rem!important}.spin-btn{max-width:440px;font-size:1.2rem}.winner-card{max-width:540px}.winner-card-inner{padding:52px 56px 36px}.winner-trophy svg{width:40px;height:40px}}@media (width>=1800px){.reel-frame{height:600px!important}.reel-item-center{font-size:4.5rem!important}}
