.reel-editor{height:100%;display:flex;flex-direction:column}.reel-editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:.75rem}.symbol-selection-indicator{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:var(--selection-bg);border:1px solid var(--selection-border);border-radius:6px;font-size:.875rem;color:var(--selection-text);transition:background .3s ease,border-color .3s ease,color .3s ease}.symbol-selection-indicator strong{color:var(--selection-text);font-weight:600}.symbol-selection-indicator .hint{color:var(--selection-text);opacity:.8;font-size:.8rem;font-style:italic}.reel-actions{display:flex;gap:.5rem}.reel-editor-header h2{font-size:1.5rem;color:var(--text-primary);transition:color .3s ease}.reel-info{color:var(--text-secondary);font-size:.875rem;display:flex;gap:.5rem;align-items:center;transition:color .3s ease}.reel-tag{background:#eef2ff;color:#4338ca;padding:.125rem .5rem;border-radius:4px;font-size:.75rem;border:1px solid #c7d2fe}.reel-grid{display:flex;gap:1.1rem;flex-wrap:nowrap;padding-bottom:1rem;flex:1;align-items:flex-start;justify-content:center;overflow-x:auto;position:relative;-webkit-user-select:none;user-select:none}.reel-column{min-width:160px;display:flex;flex-direction:column;position:relative}.reel-header{display:flex;justify-content:space-between;align-items:center;padding:.6rem;background:linear-gradient(120deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:8px 8px 0 0;font-size:.875rem;font-weight:500;gap:.5rem;color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}.reel-header-left{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.reel-swap-controls{display:flex;gap:.125rem;margin-right:.25rem}.reel-swap-btn{background:var(--card-bg);border:1px solid var(--input-border);border-radius:4px;padding:.25rem .4rem;font-size:.875rem;cursor:pointer;color:var(--text-secondary);transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:24px;height:24px}.reel-swap-btn:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--border-color);color:var(--text-primary)}.reel-swap-btn:active:not(:disabled){background:var(--panel-bg);transform:scale(.95)}.reel-swap-btn:disabled{opacity:.4;cursor:not-allowed;background:var(--panel-bg)}.reel-number{color:var(--text-primary);transition:color .3s ease}.reel-length{color:var(--text-secondary);font-size:.75rem;transition:color .3s ease}.constraint-violations{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;margin-bottom:.75rem;border-radius:6px;font-size:.85rem}.constraint-violations.global{background:linear-gradient(135deg,#fef2f2,#fee2e2);border:1px solid #fecaca;color:#991b1b}.violation-icon{font-size:1rem}.violation-text{flex:1}.reel-column.has-violations .reel-header{background:linear-gradient(120deg,#fef2f2,#fee2e2);border-color:#fecaca}.reel-column.has-violations .reel-strip{border-color:#fecaca}.reel-violation-badge{background:#ef4444;color:#fff;padding:.1rem .4rem;border-radius:4px;font-size:.7rem;font-weight:600;cursor:help}.reel-stop.violation{border-color:#ef4444!important;box-shadow:0 0 0 2px #ef444466;background:linear-gradient(135deg,#fef2f2,#fee2e2)!important;animation:violation-pulse 1.5s ease-in-out infinite}.reel-stop.violation .symbol-label{color:#b91c1c!important;font-weight:700}.reel-stop.violation:after{content:"!";position:absolute;top:2px;right:2px;width:14px;height:14px;background:#ef4444;border-radius:50%;z-index:5;color:#fff;font-size:10px;font-weight:700;display:flex;align-items:center;justify-content:center;line-height:1}@keyframes violation-pulse{0%,to{box-shadow:0 0 0 2px #ef444466}50%{box-shadow:0 0 0 4px #ef444433}}.validate-btn{position:relative}.validate-btn.has-issues{animation:attention-pulse 2s ease-in-out infinite}.validate-btn .violation-count{position:absolute;top:-6px;right:-6px;background:#ef4444;color:#fff;font-size:.65rem;font-weight:700;min-width:16px;height:16px;border-radius:8px;display:flex;align-items:center;justify-content:center;padding:0 4px;box-shadow:0 1px 3px #0003}.button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);border-color:#dc2626;color:#fff}.button.danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c)}@keyframes attention-pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.reel-strip{background:var(--card-bg);border:1px solid var(--border-color);border-top:none;border-radius:0 0 8px 8px;padding:.6rem;display:flex;flex-direction:column;gap:.35rem;min-height:220px;flex:1;box-shadow:0 4px 18px var(--shadow);transition:background .3s ease,border-color .3s ease}.reel-stop{width:100%;min-height:52px;display:flex;align-items:center;justify-content:center;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:4px;font-weight:700;font-size:1.1rem;transition:all .3s ease;cursor:default;position:relative;gap:.5rem;padding:.35rem .5rem;box-sizing:border-box;touch-action:none;-webkit-user-select:none;user-select:none;color:var(--text-primary)}.reel-stop:hover{background:var(--bg-tertiary);border-color:var(--accent-light);transform:translateY(-1px)}.reel-stop[data-animation=pulse-glow]{animation:pulse-glow 2s ease-in-out infinite}.reel-stop[data-animation=shimmer]{background-size:200% 200%;animation:shimmer 3s linear infinite}.reel-stop[data-animation=sparkle]{animation:sparkle 1.5s ease-in-out infinite}.reel-stop[data-animation=rainbow-glow]{animation:rainbow-glow 3s ease-in-out infinite}.reel-stop[data-animation=neon-pulse]{animation:neon-pulse 2s ease-in-out infinite}.reel-stop[data-animation=fire-flicker]{animation:fire-flicker 1.5s ease-in-out infinite}.reel-stop[data-animation=cosmic-swirl]{animation:cosmic-swirl 2.5s ease-in-out infinite}.reel-stop[data-animation=ice-shimmer]{animation:ice-shimmer 2.5s ease-in-out infinite}.reel-stop[data-animation=plasma-wave]{animation:plasma-wave 2s ease-in-out infinite}.reel-stop[data-animation=void-pulse]{animation:void-pulse 2.5s ease-in-out infinite}.reel-stop[data-animation=golden-radiance]{animation:golden-radiance 2s ease-in-out infinite}.reel-stop.dragging{opacity:.8;box-shadow:0 12px 28px #6366f133;border-color:#a5b4fc;background:#eef2ff}.reel-stop.in-drag{opacity:0;min-height:0;height:0;padding:0;margin:0;border:0}.drag-overlay{display:flex;flex-direction:column;gap:.35rem;padding:.4rem}.overlay-stop{box-shadow:0 8px 18px #0000001f;cursor:grabbing}.drop-placeholder{border:none!important;background:transparent!important;border-top:3px dashed #667eea!important;border-radius:0!important;box-sizing:border-box;margin:.5rem 0!important;padding:0!important;height:3px!important;min-height:3px!important;max-height:3px!important;width:100%;flex:none!important;display:block!important;overflow:hidden}.reel-stop.selected{border-color:#f97316;box-shadow:0 0 0 2px #f9731640}.drag-handle{cursor:grab;font-size:1rem;color:#9ca3af;line-height:1;padding:0 .25rem;-webkit-user-select:none;user-select:none;position:relative;z-index:10}.drag-handle:active{cursor:grabbing}.selection-rect{position:absolute;border:2px solid rgba(249,115,22,.8);background:#f973161f;pointer-events:none;z-index:5}.reel-stop.add-stop{background:#f5f7ff;border:2px dashed #667eea;color:#667eea;font-size:1.4rem;cursor:pointer}.add-stop-container{position:relative}.add-popover{position:absolute;left:0;top:110%;width:220px;background:#fff;border:1px solid #e5e7eb;border-radius:10px;padding:.75rem;box-shadow:0 10px 30px #00000014;z-index:10;display:grid;gap:.5rem}.add-row{display:grid;gap:.25rem}.add-row label{font-size:.85rem;color:#4b5563}.add-row select,.add-row input{width:100%;padding:.45rem .55rem;border:1px solid #d1d5db;border-radius:6px}.add-actions{display:flex;justify-content:flex-end;gap:.5rem}.stop-delete{margin-left:auto;border:none;background:transparent;color:#9ca3af;cursor:pointer;font-size:.85rem;position:relative;z-index:10}.stop-duplicate{border:none;background:transparent;color:#22c55e;position:relative;z-index:10;cursor:pointer;font-size:.9rem;padding:0 .15rem}.symbol-label{flex:1;text-align:center;position:relative;z-index:1}.reel-stop.symbol-type-wild{background:#fff5f5;border-color:#ff6b6b;color:#ff6b6b}.reel-stop.symbol-type-scatter{background:#f0fffe;border-color:#4ecdc4;color:#4ecdc4}.reel-stop.symbol-type-bonus{background:#fffef5;border-color:#ffe66d;color:#d4a017}.reel-stop.tone-lv{background:#eef2ff;border-color:#c7d2fe;color:#1f2937}.reel-stop.tone-lv1{background:#dbeafe}.reel-stop.tone-lv2{background:#c7d2fe}.reel-stop.tone-lv3{background:#a5b4fc}.reel-stop.tone-lv4{background:#818cf8;color:#0b1021}.reel-stop.tone-hv{background:#fff1f2;border-color:#fecdd3;color:#7f1d1d}.reel-stop.tone-hv1{background:#ffe4e6}.reel-stop.tone-hv2{background:#fecdd3}.reel-stop.tone-hv3{background:#fca5a5}.reel-stop.tone-hv4{background:#f87171;color:#2d0a0a}.reel-stop.tone-mv{background:#e0f7ff;border-color:#bae6fd;color:#0f172a}.reel-stop.tone-mv1{background:#e0f2fe}.reel-stop.tone-mv2{background:#bae6fd}.reel-stop.tone-mv3{background:#7dd3fc}.reel-stop.tone-mv4{background:#38bdf8;color:#0b1021}.reel-stop.tone-other{background:#fef9c3;border-color:#fef08a;color:#854d0e}.reel-stop.tone-wild{background:linear-gradient(135deg,#ff64644d,#ffc8644d,#c8ff644d,#64ffc84d,#64c8ff4d,#c864ff4d);background-size:200% 200%;animation:rainbow-sheen 12s ease-in-out infinite;border:2px solid transparent;border-image:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3,#ff6b6b) 1;position:relative;color:#1f2937;font-weight:700}.reel-stop.tone-wild:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.4) 50%,transparent 100%);background-size:200% 200%;animation:shimmer-wild 8s ease-in-out infinite;border-radius:3px;pointer-events:none;z-index:0}@keyframes rainbow-sheen{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes shimmer-wild{0%{background-position:-100% -100%}to{background-position:200% 200%}}.reel-stop.tone-freespin{background:linear-gradient(135deg,#fef3c7,#fcd34d,#f59e0b);border:2px solid #f59e0b;color:#78350f;font-weight:700;position:relative;box-shadow:0 0 10px #f59e0b66,0 0 20px #f59e0b33,inset 0 1px #ffffff80;animation:glow-pulse 6s ease-in-out infinite}.reel-stop.tone-freespin:before{content:"✦";position:absolute;top:2px;right:4px;font-size:.6rem;color:#f59e0b;animation:sparkle 4s ease-in-out infinite;pointer-events:none;z-index:1}.reel-stop.tone-freespin:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);background-size:200% 100%;animation:gold-shine 8s ease-in-out infinite;border-radius:3px;pointer-events:none;z-index:0}@keyframes glow-pulse{0%,to{box-shadow:0 0 10px #f59e0b66,0 0 20px #f59e0b33,inset 0 1px #ffffff80}50%{box-shadow:0 0 15px #f59e0b99,0 0 30px #f59e0b4d,inset 0 1px #ffffff80}}@keyframes sparkle{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.3)}}@keyframes gold-shine{0%{background-position:-200% 0}to{background-position:200% 0}}.symbol-palette h2{font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary);transition:color .3s ease}.symbol-list{display:flex;flex-direction:column;gap:.35rem}.symbol-item{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--panel-bg);border:1px solid var(--border-color);border-radius:6px;transition:all .3s ease;cursor:pointer}.symbol-item:hover{background:var(--bg-tertiary);border-color:var(--border-color)}.symbol-item.selected{background:var(--selection-bg);border-color:var(--selection-border);box-shadow:0 0 0 2px var(--shadow);cursor:pointer}.symbol-item.selected:hover{background:var(--selection-bg);opacity:.9;border-color:var(--selection-border)}.symbol-item.selected .symbol-display{border-color:#2196f3;box-shadow:0 0 0 1px #2196f34d}.symbol-display{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--card-bg);border:2px solid var(--border-color);border-radius:4px;font-weight:700;font-size:.9rem;flex-shrink:0;color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}.symbol-type-wild .symbol-display{border-color:#ff6b6b;background:#fff5f5;color:#ff6b6b}.symbol-type-scatter .symbol-display{border-color:#4ecdc4;background:#f0fffe;color:#4ecdc4}.symbol-type-bonus .symbol-display{border-color:#ffe66d;background:#fffef5;color:#d4a017}.symbol-item.tone-lv .symbol-display{border-color:#c7d2fe;background:#e8ecff;color:#1f2937}.symbol-item.tone-lv1 .symbol-display{background:#dbeafe}.symbol-item.tone-lv2 .symbol-display{background:#c7d2fe}.symbol-item.tone-lv3 .symbol-display{background:#a5b4fc;color:#111827}.symbol-item.tone-lv4 .symbol-display{background:#818cf8;color:#0b1021}.symbol-item.tone-hv .symbol-display{border-color:#fecdd3;background:#ffe4e6;color:#7f1d1d}.symbol-item.tone-hv1 .symbol-display{background:#ffe4e6}.symbol-item.tone-hv2 .symbol-display{background:#fecdd3}.symbol-item.tone-hv3 .symbol-display{background:#fca5a5}.symbol-item.tone-hv4 .symbol-display{background:#f87171;color:#2d0a0a}.symbol-item.tone-mv .symbol-display{border-color:#bae6fd;background:#e0f2fe;color:#0f172a}.symbol-item.tone-mv1 .symbol-display{background:#e0f2fe}.symbol-item.tone-mv2 .symbol-display{background:#bae6fd}.symbol-item.tone-mv3 .symbol-display{background:#7dd3fc;color:#0b1021}.symbol-item.tone-mv4 .symbol-display{background:#38bdf8;color:#0b1021}.symbol-item.tone-other .symbol-display{border-color:#fef08a;background:#fef9c3;color:#854d0e}.symbol-item.tone-wild .symbol-display{background:linear-gradient(135deg,#ff646466,#ffc86466,#c8ff6466,#64ffc866,#64c8ff66,#c864ff66);background-size:200% 200%;animation:palette-rainbow 12s ease-in-out infinite;border:2px solid;border-image:linear-gradient(135deg,#ff6b6b,#feca57,#48dbfb,#ff9ff3) 1;color:#1f2937;font-weight:700;position:relative}.symbol-item.tone-wild .symbol-display:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.5) 50%,transparent 100%);background-size:200% 200%;animation:palette-shimmer 8s ease-in-out infinite;border-radius:2px}.symbol-item.tone-freespin .symbol-display{background:linear-gradient(135deg,#fef3c7,#fcd34d,#f59e0b);border:2px solid #f59e0b;color:#78350f;font-weight:700;position:relative;box-shadow:0 0 8px #f59e0b66,inset 0 1px #ffffff80;animation:palette-glow 6s ease-in-out infinite}.symbol-item.tone-freespin .symbol-display:before{content:"✦";position:absolute;top:1px;right:2px;font-size:.5rem;color:#f59e0b;animation:palette-sparkle 4s ease-in-out infinite}.symbol-item.tone-freespin .symbol-display:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(120deg,transparent 0%,rgba(255,255,255,.6) 50%,transparent 100%);background-size:200% 100%;animation:palette-gold-shine 8s ease-in-out infinite;border-radius:2px}@keyframes palette-rainbow{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes palette-shimmer{0%{background-position:-100% -100%}to{background-position:200% 200%}}@keyframes palette-glow{0%,to{box-shadow:0 0 8px #f59e0b66,inset 0 1px #ffffff80}50%{box-shadow:0 0 12px #f59e0b99,inset 0 1px #ffffff80}}@keyframes palette-sparkle{0%,to{opacity:.5;transform:scale(1)}50%{opacity:1;transform:scale(1.2)}}@keyframes palette-gold-shine{0%{background-position:-200% 0}to{background-position:200% 0}}.symbol-info{flex:1;min-width:0}.symbol-name{font-weight:500;color:var(--text-primary);margin-bottom:.125rem;font-size:.85rem;transition:color .3s ease}.symbol-count{font-size:.75rem;color:var(--text-secondary);transition:color .3s ease}.badge{padding:.2rem .35rem;border-radius:4px;font-size:.65rem;font-weight:700;flex-shrink:0}.badge.wild{background:#ff6b6b;color:#fff}.badge.scatter{background:#4ecdc4;color:#fff}.badge.rule{background:#fb923c;color:#7c2d12;border:1px solid #f97316}.badge.substitute{background:#dbeafe;color:#1e40af;border:1px solid #bfdbfe}.symbol-adder{display:flex;gap:.5rem;margin-bottom:.75rem}.symbol-adder input,.symbol-adder select{padding:.4rem .5rem;border:1px solid #d1d5db;border-radius:4px;font-size:.9rem}.rule-popover{background:var(--card-bg);border:1px solid var(--border-color);border-radius:10px;padding:.75rem;width:360px;max-width:calc(100vw - 24px);box-shadow:0 12px 30px var(--shadow-lg);display:grid;grid-template-columns:1fr 1fr;column-gap:.75rem;row-gap:.5rem;z-index:20;transition:background .3s ease,border-color .3s ease}.rule-header{display:flex;justify-content:space-between;align-items:center;grid-column:1 / -1}.rule-title{font-weight:700;color:var(--text-primary);transition:color .3s ease}.rule-field{display:grid;gap:.25rem}.rule-field span{font-size:.85rem;color:var(--text-secondary);transition:color .3s ease}.rule-field input{width:100%;padding:.45rem .55rem;border:1px solid var(--input-border);border-radius:6px;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,background .3s ease,color .3s ease}.rule-checkbox{display:flex;gap:.5rem;align-items:center;font-size:.9rem;color:var(--text-primary);grid-column:1 / -1;transition:color .3s ease}.rule-actions{display:flex;justify-content:flex-end;gap:.5rem;grid-column:1 / -1}.rule-errors{grid-column:1 / -1;background:var(--warning-bg);border:1px solid var(--warning-border);color:var(--warning-text);border-radius:8px;padding:.5rem .6rem;font-size:.9rem;display:grid;gap:.25rem;transition:background .3s ease,border-color .3s ease,color .3s ease}.rule-section-divider{grid-column:1 / -1;height:1px;background:var(--border-color);margin:.5rem 0;transition:background .3s ease}.rule-section-header{grid-column:1 / -1;font-weight:600;font-size:.9rem;color:var(--text-primary);margin-bottom:.25rem;transition:color .3s ease}.color-picker{width:100%;height:40px;border:1px solid var(--input-border);border-radius:6px;cursor:pointer;background:var(--input-bg);transition:border-color .3s ease,background .3s ease}.color-picker::-webkit-color-swatch-wrapper{padding:0}.color-picker::-webkit-color-swatch{border:none;border-radius:5px}@keyframes pulse-glow{0%,to{box-shadow:0 0 10px #f59e0b99,0 0 20px #f59e0b4d}50%{box-shadow:0 0 20px #f59e0be6,0 0 40px #f59e0b80}}@keyframes shimmer{0%{background-position:-200% center}to{background-position:200% center}}@keyframes sparkle{0%,to{opacity:1}50%{opacity:.8}}@keyframes rainbow-glow{0%{box-shadow:0 0 20px #667eeacc,0 0 40px #667eea66}33%{box-shadow:0 0 20px #ec4899cc,0 0 40px #ec489966}66%{box-shadow:0 0 20px #3b82f6cc,0 0 40px #3b82f666}to{box-shadow:0 0 20px #667eeacc,0 0 40px #667eea66}}@keyframes neon-pulse{0%,to{box-shadow:0 0 15px #0ea5e9e6,0 0 30px #0ea5e980,inset 0 0 10px #0ea5e94d}50%{box-shadow:0 0 25px #0ea5e9,0 0 50px #0ea5e9b3,inset 0 0 15px #0ea5e980}}@keyframes fire-flicker{0%,to{box-shadow:0 0 20px #ef4444cc,0 0 40px #ef444466}25%{box-shadow:0 0 25px #ef4444e6,0 0 45px #ef444480}50%{box-shadow:0 0 18px #dc2626cc,0 0 38px #dc262666}75%{box-shadow:0 0 22px #ef4444e6,0 0 42px #ef444480}}@keyframes cosmic-swirl{0%,to{box-shadow:0 0 18px #a855f7cc,0 0 35px #a855f766,0 0 50px #8b5cf633}50%{box-shadow:0 0 25px #a855f7,0 0 50px #a855f799,0 0 70px #8b5cf666}}@keyframes ice-shimmer{0%,to{box-shadow:0 0 15px #38bdf8b3,0 0 30px #38bdf84d,inset 0 0 15px #ffffff80}50%{box-shadow:0 0 20px #38bdf8e6,0 0 40px #38bdf880,inset 0 0 20px #ffffffb3}}@keyframes plasma-wave{0%,to{box-shadow:0 0 18px #3b82f6cc,0 0 35px #3b82f666,0 0 50px #2563eb33}50%{box-shadow:0 0 25px #3b82f6,0 0 50px #3b82f699,0 0 70px #2563eb66}}@keyframes void-pulse{0%,to{box-shadow:0 0 20px #6366f1e6,0 0 40px #6366f180,inset 0 0 20px #6366f133}50%{box-shadow:0 0 30px #6366f1,0 0 60px #6366f1b3,inset 0 0 30px #6366f166}}@keyframes golden-radiance{0%,to{box-shadow:0 0 20px #fbbf24cc,0 0 40px #fbbf2466,inset 0 0 15px #ffd7004d}50%{box-shadow:0 0 30px #fbbf24,0 0 60px #fbbf2499,inset 0 0 25px #ffd70080}}.symbol-display[data-animation=pulse-glow],.reel-stop[data-animation=pulse-glow]{animation:pulse-glow 2s ease-in-out infinite}.symbol-display[data-animation=shimmer],.reel-stop[data-animation=shimmer]{background-size:200% 200%;animation:shimmer 3s linear infinite}.symbol-display[data-animation=sparkle],.reel-stop[data-animation=sparkle]{animation:sparkle 1.5s ease-in-out infinite}.symbol-display[data-animation=rainbow-glow],.reel-stop[data-animation=rainbow-glow]{animation:rainbow-glow 3s ease-in-out infinite}.symbol-display[data-animation=neon-pulse],.reel-stop[data-animation=neon-pulse]{animation:neon-pulse 2s ease-in-out infinite}.symbol-display[data-animation=fire-flicker],.reel-stop[data-animation=fire-flicker]{animation:fire-flicker 1.5s ease-in-out infinite}.symbol-display[data-animation=cosmic-swirl],.reel-stop[data-animation=cosmic-swirl]{animation:cosmic-swirl 2.5s ease-in-out infinite}.symbol-display[data-animation=ice-shimmer],.reel-stop[data-animation=ice-shimmer]{animation:ice-shimmer 2.5s ease-in-out infinite}.symbol-display[data-animation=plasma-wave],.reel-stop[data-animation=plasma-wave]{animation:plasma-wave 2s ease-in-out infinite}.symbol-display[data-animation=void-pulse],.reel-stop[data-animation=void-pulse]{animation:void-pulse 2.5s ease-in-out infinite}.symbol-display[data-animation=golden-radiance],.reel-stop[data-animation=golden-radiance]{animation:golden-radiance 2s ease-in-out infinite}.reel-generator-pro{background:linear-gradient(145deg,#1a1a2e,#16213e,#0f3460);border-radius:12px;padding:1.25rem;color:#e8e8e8;box-shadow:0 20px 60px #0006,inset 0 1px #ffffff1a;font-family:JetBrains Mono,Fira Code,SF Mono,monospace;font-size:.85rem}.generator-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.header-main h3{font-size:1.25rem;font-weight:700;margin:0 0 .15rem;background:linear-gradient(135deg,#00d9ff,#0f8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent}.header-subtitle{font-size:.65rem;color:#8892b0;text-transform:uppercase;letter-spacing:.1em}.header-badges{display:flex;gap:.4rem}.badge{padding:.3rem .6rem;border-radius:12px;font-size:.65rem;font-weight:600}.badge.info{background:#64ffda26;color:#64ffda}.badge.accent{background:#ff6b6b26;color:#ff6b6b}.control-section{background:#ffffff08;border-radius:10px;padding:1rem;margin-bottom:.75rem;border:1px solid rgba(255,255,255,.06)}.control-section h4{font-size:.8rem;font-weight:600;margin:0 0 .75rem;color:#ccd6f6}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.section-header h4{margin:0}.section-hint{font-size:.65rem;color:#64ffda;opacity:.8}.control-row{display:flex;flex-direction:column;gap:.75rem}.control-field.compact{display:flex;flex-direction:column;gap:.4rem}.field-label{font-size:.7rem;color:#8892b0;text-transform:uppercase;letter-spacing:.03em}.field-with-slider{display:flex;align-items:center;gap:.5rem}.field-with-slider input[type=number]{width:60px;padding:.4rem .5rem;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:5px;color:#fff;font-size:.85rem;font-family:inherit}.field-with-slider input[type=range]{flex:1;height:4px;background:#ffffff1a;border-radius:2px;-webkit-appearance:none;-moz-appearance:none;appearance:none}.field-with-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:linear-gradient(135deg,#00d9ff,#0f8);border-radius:50%;cursor:pointer}.control-field select{padding:.5rem;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:5px;color:#fff;font-size:.8rem;font-family:inherit}.targets-section{background:#64ffda08;border-color:#64ffda26}.target-row{display:flex;align-items:center;justify-content:space-between;padding:.5rem 0;border-bottom:1px solid rgba(255,255,255,.05)}.target-row:last-child{border-bottom:none}.target-toggle{display:flex;align-items:center;gap:.5rem;cursor:pointer}.target-toggle input[type=checkbox]{width:16px;height:16px;accent-color:#64ffda}.toggle-label{font-size:.8rem;color:#ccd6f6}.target-inputs{display:flex;align-items:center;gap:.5rem}.target-value{display:flex;align-items:center;gap:.25rem}.target-value input{width:55px;padding:.35rem .5rem;background:#0006;border:1px solid rgba(100,255,218,.3);border-radius:4px;color:#64ffda;font-size:.85rem;font-family:inherit;font-weight:600}.target-value span{color:#64ffda;font-size:.8rem}.tolerance{font-size:.65rem;color:#8892b0}.weights-section{background:#667eea0d;border-color:#667eea33}.weights-toolbar{display:flex;gap:.4rem;margin-bottom:.75rem}.btn-tool{padding:.35rem .6rem;font-size:.65rem;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#ccd6f6;border-radius:4px;cursor:pointer;font-family:inherit;transition:all .15s}.btn-tool:hover{background:#ffffff26;color:#fff}.weights-list{display:flex;flex-direction:column;gap:.4rem;max-height:280px;overflow-y:auto;padding-right:.5rem;overscroll-behavior:contain}.weights-list::-webkit-scrollbar{width:4px}.weights-list::-webkit-scrollbar-thumb{background:#64ffda4d;border-radius:2px}.weight-row{display:grid;grid-template-columns:45px 1fr 28px;align-items:center;gap:.5rem;padding:.5rem .6rem;background:#00000026;border-radius:6px;border-left:3px solid rgba(255,255,255,.1);transition:all .1s}.weight-row:hover{background:#00000040}.weight-row.type-wild{border-left-color:#ff6b6b;background:#ff6b6b14}.weight-row.type-scatter{border-left-color:#ffd93d;background:#ffd93d14}.weight-row.type-bonus{border-left-color:#c084fc;background:#c084fc14}.weight-symbol{display:flex;align-items:center;gap:.4rem}.symbol-tag{padding:.2rem .4rem;border-radius:3px;font-size:.7rem;font-weight:700;background:#64ffda33;color:#64ffda}.symbol-tag.wild{background:#ff6b6b4d;color:#ff6b6b}.symbol-tag.scatter{background:#ffd93d4d;color:#ffd93d}.symbol-tag.bonus{background:#c084fc4d;color:#c084fc}.weight-slider{position:relative;height:24px;display:flex;align-items:center;touch-action:none}.weight-slider input[type=range]{width:100%;height:24px;background:#ffffff1a;border-radius:4px;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer;position:relative;z-index:2}.weight-slider input[type=range]::-webkit-slider-runnable-track{height:8px;background:#ffffff1a;border-radius:4px}.weight-slider input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;background:linear-gradient(135deg,#fff,#e0e0e0);border-radius:50%;cursor:grab;box-shadow:0 2px 8px #0006;margin-top:-5px;transition:transform .1s}.weight-slider input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.15)}.weight-slider input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.1)}.weight-slider input[type=range]::-moz-range-track{height:8px;background:#ffffff1a;border-radius:4px}.weight-slider input[type=range]::-moz-range-thumb{width:18px;height:18px;background:linear-gradient(135deg,#fff,#e0e0e0);border-radius:50%;cursor:grab;border:none;box-shadow:0 2px 8px #0006}.weight-bar{position:absolute;top:50%;left:0;height:8px;transform:translateY(-50%);background:linear-gradient(90deg,#667eea,#764ba2);border-radius:4px;z-index:1;pointer-events:none}.weight-number{font-size:.75rem;color:#ccd6f6;font-weight:600;text-align:right}.exclusions-section{padding:.75rem}.exclusion-chips{display:flex;flex-wrap:wrap;gap:.4rem;margin-bottom:.5rem}.exclusion-chip{display:flex;align-items:center;gap:.3rem;padding:.25rem .5rem;background:#ff6b6b26;border:1px solid rgba(255,107,107,.3);border-radius:12px;font-size:.7rem;color:#ff6b6b}.exclusion-chip.near-miss-chip{background:#ffc10726;border:1px solid rgba(255,193,7,.3);color:#ffc107}.near-miss-description{font-size:.8rem;color:var(--text-secondary);margin:.5rem 0;line-height:1.4}.exclusion-chip button{background:none;border:none;color:inherit;cursor:pointer;font-size:.8rem;padding:0;line-height:1}.exclusion-add{display:flex;gap:.4rem}.exclusion-add select{flex:1;padding:.4rem;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;font-size:.75rem;font-family:inherit}.btn-small{padding:.4rem .75rem;background:#ff6b6b33;border:1px solid rgba(255,107,107,.4);border-radius:4px;color:#ff6b6b;font-size:.75rem;font-family:inherit;cursor:pointer}.btn-small:disabled{opacity:.4;cursor:not-allowed}.advanced-toggle{width:100%;padding:.6rem;background:transparent;border:1px dashed rgba(255,255,255,.15);border-radius:6px;color:#8892b0;font-size:.8rem;font-family:inherit;cursor:pointer}.advanced-toggle:hover{border-color:#64ffda4d;color:#64ffda}.advanced-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:.6rem;margin-top:.75rem;padding-top:.75rem;border-top:1px solid rgba(255,255,255,.1)}.control-field.mini{display:flex;flex-direction:column;gap:.3rem}.control-field.mini span{font-size:.65rem;color:#8892b0}.control-field.mini input,.control-field.mini select{padding:.35rem .5rem;background:#0000004d;border:1px solid rgba(255,255,255,.15);border-radius:4px;color:#fff;font-size:.8rem;font-family:inherit}.optimization-panel{background:#00d9ff0d;border:1px solid rgba(0,217,255,.2);border-radius:10px;padding:1rem;margin-bottom:.75rem}.optimization-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.status-indicator{width:8px;height:8px;border-radius:50%;background:#64ffda}.status-indicator.running{background:#00d9ff;animation:pulse 1s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.status-text{flex:1;font-size:.8rem;color:#ccd6f6}.btn-cancel{padding:.3rem .6rem;background:#ff6b6b33;border:1px solid rgba(255,107,107,.4);border-radius:4px;color:#ff6b6b;font-size:.7rem;font-family:inherit;cursor:pointer}.optimization-stats{display:flex;gap:1rem;margin-bottom:.75rem}.stat{display:flex;align-items:center;gap:.4rem}.stat-label{font-size:.65rem;color:#8892b0;text-transform:uppercase}.stat-current{font-size:.9rem;font-weight:700;color:#fff}.stat-target{font-size:.75rem;color:#64ffda}.mini-chart{display:flex;align-items:flex-end;gap:2px;height:40px;padding:.25rem;background:#0003;border-radius:4px;margin-bottom:.75rem}.mini-chart .chart-bar{flex:1;background:linear-gradient(to top,#0f3460,#00d9ff);border-radius:2px 2px 0 0;min-width:4px}.btn-apply{width:100%;padding:.6rem;background:linear-gradient(135deg,#0f8,#00d9ff);border:none;border-radius:6px;color:#0f3460;font-size:.85rem;font-weight:700;font-family:inherit;cursor:pointer}.btn-apply:hover{filter:brightness(1.1)}.generator-actions{display:flex;gap:.5rem;margin-top:.75rem}.btn-secondary{flex:1;padding:.7rem;background:#ffffff0d;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#ccd6f6;font-size:.85rem;font-weight:600;font-family:inherit;cursor:pointer;transition:all .15s}.btn-secondary:hover:not(:disabled){background:#ffffff1a}.btn-secondary:disabled{opacity:.4;cursor:not-allowed}.btn-primary{flex:1.5;padding:.7rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:8px;color:#fff;font-size:.85rem;font-weight:700;font-family:inherit;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.5rem;transition:all .15s}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 6px 20px #667eea66}.btn-primary:disabled{opacity:.6;cursor:not-allowed;transform:none}.spinner{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.metrics-dashboard{height:100%;display:flex;flex-direction:column}.metrics-dashboard h2{font-size:1.25rem;margin-bottom:1rem;color:var(--text-primary);transition:color .3s ease}.computing,.no-metrics{padding:2rem;text-align:center;color:var(--text-secondary);transition:color .3s ease}.metrics-content{display:flex;flex-direction:column;gap:1rem}.progress-bar{position:relative;width:100%;max-width:240px;height:8px;margin:.5rem auto .25rem;background:#e5e7eb;border-radius:999px;overflow:hidden}.progress-bar-fill{position:absolute;left:-40%;width:40%;height:100%;background:linear-gradient(90deg,#6366f1,#8b5cf6);border-radius:999px;animation:progress-indeterminate 1.2s infinite}@keyframes progress-indeterminate{0%{left:-40%}50%{left:60%}to{left:100%}}.computing-label{margin-top:.25rem;font-size:.875rem}.metric-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;padding:1rem;transition:background .3s ease,border-color .3s ease}.metric-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px;transition:color .3s ease}.metric-value{font-size:2rem;font-weight:700;color:var(--accent);margin-bottom:.25rem;transition:color .3s ease}.metric-delta{font-size:.85rem;color:var(--text-secondary);margin-top:.15rem;transition:color .3s ease}.metric-note{font-size:.75rem;color:var(--text-muted);font-style:italic;transition:color .3s ease}.metric-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;padding:1rem;transition:background .3s ease,border-color .3s ease}.metric-section h3{font-size:1rem;margin-bottom:.75rem;color:var(--text-primary);transition:color .3s ease}.symbol-stats{display:flex;flex-direction:column;gap:.5rem}.stat-item{display:flex;justify-content:space-between;padding:.5rem;background:var(--panel-bg);border-radius:4px;font-size:.875rem;transition:background .3s ease}.stat-label{color:var(--text-secondary);transition:color .3s ease}.stat-value{font-weight:500;color:var(--text-primary);transition:color .3s ease}.one-in{color:#6b7280;font-size:.8rem;margin-left:.35rem}.fs-section{background:linear-gradient(135deg,#fef3c7,#fef9c3);border-color:#f59e0b}.fs-section h3{color:#92400e}.metric-card.inline{display:inline-block;margin-right:.75rem;margin-bottom:.75rem;padding:.75rem;vertical-align:top;min-width:140px}.metric-card.inline .metric-value{font-size:1.25rem}.stat-header{font-weight:600;font-size:.8rem;color:var(--text-primary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem;padding-bottom:.25rem;border-bottom:1px solid var(--border-color);transition:color .3s ease,border-color .3s ease}.symbol-hit-breakdown{display:flex;flex-direction:column;gap:.75rem}.symbol-hit-row{background:var(--card-bg);border-radius:6px;padding:.75rem;border:1px solid var(--border-color);transition:background .3s ease,border-color .3s ease}.symbol-hit-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.symbol-hit-header .stat-label{font-weight:600;font-size:.95rem;color:var(--text-primary);transition:color .3s ease}.symbol-hit-lengths{display:flex;flex-wrap:wrap;gap:.35rem}.hit-length-badge{background:linear-gradient(135deg,#e0e7ff,#c7d2fe);color:#3730a3;padding:.2rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;border:1px solid #a5b4fc}.winlines-wrapper{background:linear-gradient(180deg,#2d2d2d08,#2d2d2d14,#2d2d2d1f);border-radius:20px;padding:2rem;min-height:100%}.winlines-viewer{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;max-width:900px;margin:0 auto;box-shadow:0 4px 6px -1px var(--shadow),0 10px 15px -3px var(--shadow),0 20px 40px -5px var(--shadow-lg),inset 0 1px #ffffff1a;transition:background .3s ease,border-color .3s ease}.winlines-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--accent);transition:border-color .3s ease}.winlines-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;transition:color .3s ease}.winlines-actions{display:flex;gap:.75rem;align-items:center}.winlines-count{color:var(--text-secondary);font-size:.875rem;font-weight:500;background:var(--panel-bg);padding:.35rem .75rem;border-radius:999px;transition:color .3s ease,background .3s ease}.winlines-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem}.winline-builder{border:2px dashed #f97316;border-radius:10px;padding:.75rem 1rem;background:linear-gradient(135deg,#fff7ed,#ffedd5);margin-bottom:1.25rem;display:flex;flex-direction:column;align-items:center;box-shadow:0 4px 12px #f973161a}.builder-label{font-weight:700;font-size:.75rem;color:#c2410c;margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.05em}.builder-grid{display:flex;gap:.35rem;margin-bottom:.6rem;justify-content:center}.builder-col{display:flex;flex-direction:column;align-items:center;gap:.2rem}.builder-cell{width:24px;height:24px;border:1px solid #fed7aa;border-radius:5px;background:#fff;cursor:pointer;font-size:.65rem;font-weight:600;color:#78716c;transition:all .2s}.builder-cell:hover{border-color:#fb923c;background:#fff7ed}.builder-cell.active{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border-color:#ea580c;box-shadow:0 3px 8px #f973164d;transform:scale(1.05)}.builder-reel{font-size:.6rem;font-weight:600;color:#9a8478;margin-top:.15rem}.winline-builder .button{background:linear-gradient(135deg,#f97316,#ea580c);color:#fff;border:none;padding:.4rem 1rem;font-size:.8rem;font-weight:700;border-radius:8px;box-shadow:0 3px 10px #f973164d;transition:all .2s}.winline-builder .button:hover{transform:translateY(-1px);box-shadow:0 5px 14px #f9731666}.winline-card{border:1px solid var(--border-color);border-radius:12px;padding:.75rem;background:var(--card-bg);cursor:grab;transition:all .3s ease}.winline-card:hover{border-color:var(--border-color);box-shadow:0 4px 12px var(--shadow);transform:translateY(-2px)}.winline-card:nth-child(odd){background:linear-gradient(135deg,var(--panel-bg),var(--bg-tertiary));border-color:var(--border-color)}.winline-card.dragging{border-color:var(--accent);box-shadow:0 12px 30px var(--shadow-lg);background:var(--panel-bg);transform:scale(1.02)}.winline-id{font-weight:700;font-size:.85rem;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;justify-content:space-between;transition:color .3s ease}.winline-grid{display:flex;gap:.3rem;justify-content:center}.winline-col{display:flex;flex-direction:column;align-items:center}.winline-cell{width:22px;height:22px;border:1px solid var(--border-color);border-radius:5px;background:var(--panel-bg);margin-bottom:3px;display:flex;align-items:center;justify-content:center;font-size:.65rem;color:var(--text-muted);cursor:pointer;transition:all .3s ease}.winline-cell:hover{border-color:var(--border-color);background:var(--bg-tertiary)}.winline-cell.active{background:linear-gradient(135deg,#f97316,#ea580c);border-color:#ea580c;color:#fff;font-weight:700;box-shadow:0 2px 6px #f973164d}.winline-reel-label{font-size:.65rem;font-weight:600;color:#94a3b8;margin-top:2px}.winline-delete{border:none;background:#fee2e2;color:#dc2626;cursor:pointer;font-size:1rem;width:20px;height:20px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s;line-height:1}.winline-delete:hover{background:#fecaca;transform:scale(1.1)}.winplan-wrapper{background:linear-gradient(180deg,#2d2d2d08,#2d2d2d14,#2d2d2d1f);border-radius:20px;padding:2rem;min-height:100%}.winplan-viewer{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;max-width:800px;margin:0 auto;box-shadow:0 4px 6px -1px var(--shadow),0 10px 15px -3px var(--shadow),0 20px 40px -5px var(--shadow-lg),inset 0 1px #ffffff1a;transition:background .3s ease,border-color .3s ease}.winplan-header{margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--accent);transition:border-color .3s ease}.winplan-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;transition:color .3s ease}.winplan-adder{display:grid;grid-template-columns:repeat(auto-fit,minmax(70px,1fr));gap:6px;align-items:center}.winplan-adder select,.winplan-adder input{padding:.5rem .6rem;border:1px solid var(--input-border);border-radius:8px;font-size:.875rem;width:100%;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.winplan-adder input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.adder-actions{display:flex;gap:.5rem;justify-content:flex-end}.winplan-add-row{margin-top:1rem;display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.add-button{padding:.6rem 1rem;border:2px dashed var(--accent);background:linear-gradient(135deg,var(--panel-bg),var(--bg-tertiary));color:var(--accent);border-radius:10px;cursor:pointer;font-weight:700;font-size:1.25rem;min-width:80px;transition:all .3s ease}.add-button:hover{background:linear-gradient(135deg,var(--bg-tertiary),var(--panel-bg));transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow);border-color:var(--accent-hover)}.add-button.full-width{width:100%;justify-content:center}.winplan-table{display:flex;flex-direction:column;gap:6px}.winplan-row{display:grid;gap:6px;align-items:center;cursor:grab;border-radius:10px;padding:4px;transition:all .2s}.winplan-row:hover:not(.header){background:#f973160a}.winplan-row.dragging{background:#fff7ed;box-shadow:0 10px 30px #f9731626;transform:scale(1.01)}.winplan-row.alt{background:linear-gradient(90deg,#f9731608,#fb923c0d)}.winplan-row.header{cursor:default;background:linear-gradient(135deg,#2d2d2d,#3d3d3d);border-radius:10px;margin-bottom:4px}.winplan-row.header .cell.header{background:transparent;color:#fff;border:none;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.cell{padding:.6rem .5rem;font-size:.875rem;color:var(--text-primary);background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;text-align:center;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.cell.header{background:var(--panel-bg);font-weight:600}.symbol-cell{text-align:left}.symbol-title{display:flex;flex-direction:column;gap:4px}.symbol-code-input,.symbol-long-input{width:100%;border:1px solid #e2e8f0;border-radius:6px;padding:.4rem .5rem;font-size:.875rem;transition:border-color .2s,box-shadow .2s}.symbol-code-input:focus,.symbol-long-input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px #f973161a}.symbol-code-input{font-weight:700;background:linear-gradient(135deg,#fffbeb,#fef3c7);border-color:#fbbf24;color:#92400e}.symbol-long-input{background:#fff;border-color:#e2e8f0;color:#64748b;font-size:.8rem}.symbol-code{font-weight:700}.symbol-long{font-size:.8rem;color:#64748b}.symbol-actions{margin-left:.4rem;display:inline-flex;gap:.25rem}.symbol-actions button{background:#fff7ed;border:1px solid #fed7aa;color:#ea580c;border-radius:6px;padding:4px 8px;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .2s}.symbol-actions button:hover{background:#ffedd5;border-color:#fb923c}.cell input{width:100%;padding:.4rem .5rem;border:1px solid var(--input-border);border-radius:6px;font-size:.875rem;text-align:center;font-weight:500;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.cell input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.cell input::placeholder{color:var(--text-muted)}.index-cell{text-align:center;color:#94a3b8;background:transparent!important;border:none!important;padding:0;font-size:.75rem;font-weight:600}.winplan-row.header .index-cell{color:#fff9}.chance-tables{background:var(--card-bg);border:1px solid var(--border-color);border-radius:8px;padding:1rem;transition:background .3s ease,border-color .3s ease}.chance-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem}.chance-header h3{margin:0;font-size:1rem;color:var(--text-primary);transition:color .3s ease}.tag{padding:.15rem .5rem;background:var(--accent-light);color:var(--accent);border-radius:4px;border:1px solid var(--accent);font-size:.8rem;transition:background .3s ease,border-color .3s ease,color .3s ease}.chance-section{margin-top:1rem}.chance-section h4{margin:0 0 .5rem;font-size:.95rem;color:var(--text-primary);transition:color .3s ease}.muted{color:#6b7280;font-size:.9rem}.chance-table{display:grid;grid-template-columns:var(--chance-cols, 2fr 1fr);border:1px solid #e5e7eb;border-radius:6px;overflow:hidden}.chance-row{display:contents}.chance-header-row .cell{background:var(--panel-bg);font-weight:600;transition:background .3s ease}.cell.editable-header{cursor:pointer;position:relative;transition:background-color .3s ease}.cell.editable-header:hover{background:var(--bg-tertiary)}.cell.editable-header .header-input{width:100%;padding:0;border:none;background:transparent;font-weight:600;font-size:inherit;color:var(--text-primary);text-align:inherit;outline:none;border-bottom:2px solid var(--accent);transition:border-color .3s ease,color .3s ease}.cell.editable-header .header-input:focus{border-bottom-color:var(--accent-hover)}.chance-row:not(.chance-header-row):nth-child(2n) .cell{background:var(--panel-bg)}.chance-row:not(.chance-header-row):nth-child(odd) .cell{background:var(--bg-tertiary)}.cell{padding:.5rem;border-bottom:1px solid var(--border-color);border-right:1px solid var(--border-color);font-size:.9rem;color:var(--text-primary);transition:border-color .3s ease,color .3s ease}.chance-table input{width:100%;border:1px solid var(--input-border);border-radius:4px;padding:.3rem;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,background .3s ease,color .3s ease}.cell-input{margin-bottom:4px}.chance-table .cell:last-child{border-right:none}.chance-row:last-child .cell{border-bottom:none}.add-row-cell{grid-column:1 / -1;border-right:none}.chance-block .chance-row:not(.chance-header-row):nth-child(2n) .cell{background:var(--panel-bg)}.chance-block .chance-row:not(.chance-header-row):nth-child(odd) .cell{background:var(--bg-tertiary)}.value-stack{display:flex;flex-direction:column;align-items:center;gap:2px}.value-stack.editable{align-items:flex-start}.value-stack .primary{font-weight:600}.value-stack .subtext{font-size:.8rem;color:var(--text-muted);transition:color .3s ease}.chance-table-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:.75rem}.chance-block{border:1px solid var(--border-color);border-radius:6px;background:var(--panel-bg);padding:.5rem;transition:background .3s ease,border-color .3s ease}.chance-block-title{font-weight:700;color:var(--text-primary);margin-bottom:.5rem;display:flex;align-items:center;gap:.35rem;flex-wrap:nowrap;min-width:0;transition:color .3s ease}.category-input{max-width:120px;padding:.35rem .45rem;border:1px solid #e5e7eb;border-radius:6px;font-size:.85rem}.chance-block-title input{flex:1;min-width:0;max-width:calc(100% - 60px);border:1px solid var(--input-border);border-radius:6px;padding:.4rem .55rem;font-weight:700;font-size:.95rem;background:linear-gradient(135deg,var(--panel-bg),var(--card-bg));color:var(--text-primary);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.type-toggle{padding:.2rem .5rem;border-radius:999px;border:1px solid var(--border-color);background:var(--card-bg);font-size:.75rem;font-weight:700;color:var(--text-secondary);cursor:pointer;transition:background .3s ease,border-color .3s ease,color .3s ease}.type-toggle.active{background:var(--accent);border-color:var(--accent-hover);color:#fff}.title-actions{display:flex;align-items:center;gap:.35rem;margin-top:.35rem;margin-bottom:.2rem}.chance-block-title input:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px #f9731633}.chance-block-title .icon-btn{width:28px;height:28px;border-radius:50%;border:1px solid #fcae70;background:linear-gradient(135deg,#fff0e6,#ffe5d0);color:#b45309;display:inline-flex;align-items:center;justify-content:center;padding:0;font-size:1rem;cursor:pointer;transition:transform .15s ease,box-shadow .15s ease,border-color .15s ease}.chance-block-title .icon-btn:hover{transform:scale(1.05);box-shadow:0 4px 12px #f9731640;border-color:#f97316}.chance-block-title .icon-btn:active{transform:scale(.97)}.add-button.full-width{width:100%;display:block;margin-top:.6rem}.add-button.full-width.tall{padding:.65rem 0;font-size:1.4rem;border-radius:10px}.chance-filter{display:flex;gap:.5rem;align-items:center;margin-bottom:.5rem}.chance-filter select{padding:.4rem .6rem;border-radius:8px;border:1px solid var(--input-border);background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,background .3s ease,color .3s ease}.chance-total{font-size:.85rem;padding:.15rem .35rem;border-radius:4px;border:1px solid var(--border-color);background:var(--panel-bg);color:var(--text-primary);transition:border-color .3s ease,background .3s ease,color .3s ease}.chance-total.ok{border-color:#10b981;background:#ecfdf3;color:#065f46}.chance-total.warn{border-color:#f59e0b;background:#fffbeb;color:#92400e}.chance-total.error{border-color:#ef4444;background:#fef2f2;color:#991b1b}.chance-alert{margin-top:.35rem;font-size:.85rem;padding:.35rem .5rem;border-radius:6px;border:1px solid #fcd34d;background:#fffbeb;color:#92400e}.chance-alert.error{border-color:#ef4444;background:#fef2f2;color:#991b1b}.meta-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem}.meta-item{background:linear-gradient(135deg,var(--panel-bg),var(--card-bg));border:1px solid var(--border-color);border-radius:10px;padding:.6rem .7rem;display:grid;grid-template-columns:1fr 1fr auto auto;align-items:center;gap:.5rem;box-shadow:0 4px 10px var(--shadow);transition:background .3s ease,border-color .3s ease}.meta-key{font-weight:600;color:var(--text-primary);margin-bottom:.25rem;transition:color .3s ease}.meta-value{color:var(--text-secondary);font-size:.9rem;transition:color .3s ease}.meta-item input{width:100%;max-width:calc(100% - 10px);padding:.45rem .55rem;border:1px solid var(--input-border);border-radius:6px;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.meta-item input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.meta-item .small.ghost{border-radius:50%;width:26px;height:26px;padding:0;display:inline-flex;align-items:center;justify-content:center;color:var(--text-secondary);border-color:var(--border-color);transition:color .3s ease,border-color .3s ease}.reel-set-wrapper{background:linear-gradient(180deg,#2d2d2d08,#2d2d2d14,#2d2d2d1f);border-radius:20px;padding:2rem;min-height:100%}.reel-set-viewer{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;max-width:700px;margin:0 auto;box-shadow:0 4px 6px -1px var(--shadow),0 10px 15px -3px var(--shadow),0 20px 40px -5px var(--shadow-lg),inset 0 1px #ffffff1a;transition:background .3s ease,border-color .3s ease}.reel-set-viewer .reel-set-header{margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:2px solid var(--accent);display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:border-color .3s ease}.reel-set-viewer .reel-set-header h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;transition:color .3s ease}.reel-set-table{display:flex;flex-direction:column;gap:6px}.reel-set-row{display:grid;grid-template-columns:1fr 80px 80px 140px;gap:6px;align-items:center;padding:.5rem;border-radius:8px;transition:background-color .2s}.reel-set-row:not(.header):nth-child(2n){background:linear-gradient(90deg,#f9731608,#fb923c0d)}.reel-set-row:not(.header):hover{background:#f973160f}.reel-set-row.header{background:linear-gradient(135deg,#2d2d2d,#3d3d3d);border-radius:10px;margin-bottom:4px;padding:.6rem .5rem}.reel-set-cell{padding:.5rem;font-size:.875rem;color:var(--text-primary);display:flex;align-items:center;transition:color .3s ease}.reel-set-row.header .reel-set-cell{background:transparent;color:#fff;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.05em}.reel-set-cell.label{font-weight:600;color:var(--text-primary);transition:color .3s ease}.reel-set-cell.label:hover{color:var(--accent)}.reel-set-cell.value{justify-content:flex-end}.reel-set-cell.value input{width:80px;padding:.4rem .5rem;border:1px solid var(--input-border);border-radius:6px;text-align:right;font-weight:500;background:var(--input-bg);color:var(--text-primary);font-size:.875rem;transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.reel-set-cell.value input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.reel-set-cell.value input[readOnly]{background:var(--panel-bg);color:var(--text-secondary);cursor:not-allowed}.reel-set-cell.value .value-stack{align-items:flex-end;gap:.2rem}.reel-set-cell.value .subtext{font-size:.75rem;color:var(--text-muted);font-style:italic;transition:color .3s ease}.reel-set-cell.stats-cell{font-size:.875rem;font-weight:500;color:var(--text-secondary);text-align:center;justify-content:center;transition:color .3s ease}.reel-set-footer{padding:.75rem .5rem 0;margin-top:.5rem;border-top:1px solid var(--border-color);text-align:right;transition:border-color .3s ease}.reel-set-total{font-weight:600;font-size:.875rem;color:var(--text-secondary);transition:color .3s ease}.metadata-button-table{width:24px;height:24px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--panel-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:50%;cursor:pointer;font-size:.875rem;font-weight:600;transition:all .3s ease;line-height:1;flex-shrink:0}.metadata-button-field{width:22px;height:22px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--panel-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:50%;cursor:pointer;font-size:.75rem;font-weight:600;transition:all .3s ease;line-height:1;flex-shrink:0}.metadata-button-table:hover,.metadata-button-field:hover{background:var(--bg-tertiary);color:var(--text-primary);border-color:var(--border-color);transform:scale(1.1)}.metadata-button-table.has-description,.metadata-button-field.has-description{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border)}.metadata-button-table.has-description:hover,.metadata-button-field.has-description:hover{background:var(--success-bg);color:var(--success-text);border-color:var(--success-border);opacity:.9}.metadata-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.metadata-modal{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:16px;padding:0;max-width:600px;width:90%;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 10px 25px -5px var(--shadow-lg),0 20px 40px -5px var(--shadow-lg),0 0 0 1px #ffffff1a;animation:slideUp .2s ease-out;transition:background .3s ease,border-color .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.metadata-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color);transition:border-color .3s ease}.metadata-modal-header h4{margin:0;font-size:1.1rem;font-weight:700;color:var(--text-primary);transition:color .3s ease}.modal-close{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:var(--panel-bg);color:var(--text-secondary);border:1px solid var(--border-color);border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .3s ease}.modal-close:hover{background:var(--warning-bg);color:var(--warning-text);border-color:var(--warning-border)}.metadata-modal-content{padding:1.5rem;overflow-y:auto;flex:1;display:flex;flex-direction:column;gap:1.25rem}.metadata-field{display:flex;flex-direction:column;gap:.5rem}.metadata-label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;transition:color .3s ease}.metadata-field textarea,.metadata-field input[type=text]{padding:.6rem .75rem;border:1px solid var(--input-border);border-radius:8px;font-size:.95rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease;font-family:inherit;resize:vertical}.metadata-field textarea:focus,.metadata-field input[type=text]:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.metadata-field textarea::placeholder,.metadata-field input[type=text]::placeholder{color:var(--text-muted)}.metadata-hint{font-size:.75rem;color:var(--text-muted);font-style:italic;margin-top:-.25rem;transition:color .3s ease}.metadata-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color);background:var(--panel-bg);border-radius:0 0 16px 16px;transition:background .3s ease,border-color .3s ease}.game-info-wrapper{background:linear-gradient(180deg,#2d2d2d08,#2d2d2d14,#2d2d2d1f);border-radius:20px;padding:2rem;min-height:100%}.game-info{background:linear-gradient(145deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:16px;padding:1.5rem;max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:1.5rem;box-shadow:0 4px 6px -1px var(--shadow),0 10px 15px -3px var(--shadow),0 20px 40px -5px var(--shadow-lg),inset 0 1px #ffffff1a;transition:background .3s ease,border-color .3s ease}.game-info>h3{margin:0;font-size:1.25rem;font-weight:700;color:var(--text-primary);letter-spacing:-.01em;padding-bottom:.75rem;border-bottom:2px solid var(--accent);transition:color .3s ease}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.info-grid.reel-dimensions{grid-template-columns:repeat(2,minmax(200px,1fr))}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-item .label{font-size:.8rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;transition:color .3s ease}.info-item input,.info-item select{padding:.6rem .75rem;border:1px solid var(--input-border);border-radius:8px;font-size:.95rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.info-item input:focus,.info-item select:focus{outline:none;border-color:#f97316;box-shadow:0 0 0 3px #f973161a}.target-settings{background:linear-gradient(135deg,var(--panel-bg),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:12px;padding:1rem;transition:background .3s ease,border-color .3s ease}.target-settings .section-header{margin-bottom:.75rem}.target-settings h4{margin:0;font-size:.9rem;font-weight:700;color:var(--text-primary);transition:color .3s ease}.target-grid{display:grid;gap:.5rem}.target-row{display:grid;grid-template-columns:1fr 1fr auto;gap:.5rem;align-items:center}.target-row input{padding:.5rem .6rem;border:1px solid var(--input-border);border-radius:6px;font-size:.875rem;background:var(--input-bg);color:var(--text-primary);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.target-row input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.target-row input::placeholder{color:var(--text-muted)}.target-row button{width:28px;height:28px;padding:0;display:flex;align-items:center;justify-content:center;background:#fee2e2;color:#dc2626;border:none;border-radius:6px;cursor:pointer;font-size:.85rem;transition:all .2s}.target-row button:hover{background:#fecaca;transform:scale(1.05)}.muted{color:var(--text-muted);font-size:.875rem;text-align:center;padding:.5rem;transition:color .3s ease}.confirm-dialog-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirm-dialog{background:var(--bg-secondary);border-radius:12px;padding:1.5rem;max-width:500px;width:90%;box-shadow:0 20px 25px -5px var(--shadow-lg),0 10px 10px -5px var(--shadow);transition:background .3s ease}.confirm-dialog h4{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:var(--text-primary);transition:color .3s ease}.confirm-dialog p{margin:.75rem 0;color:var(--text-secondary);font-size:.95rem;line-height:1.5;transition:color .3s ease}.confirm-dialog ul{margin:.75rem 0;padding-left:1.5rem;color:var(--text-secondary);font-size:.9rem;line-height:1.6;transition:color .3s ease}.confirm-dialog ul li{margin:.25rem 0}.confirm-dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}.bonus-symbols{background:linear-gradient(135deg,var(--panel-bg),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:12px;padding:1rem;margin-bottom:1.5rem;transition:background .3s ease,border-color .3s ease}.bonus-symbols .section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.bonus-symbols h4{margin:0;font-size:.9rem;font-weight:700;color:var(--text-primary);transition:color .3s ease}.bonus-symbols-grid{display:grid;gap:.5rem}.bonus-symbol-row{display:grid;grid-template-columns:1.5fr 2fr auto auto;gap:.5rem;align-items:center;padding:.5rem;background:var(--card-bg);border:1px solid var(--border-color);border-radius:6px;transition:background .3s ease,border-color .3s ease}.bonus-key-input{padding:.5rem .6rem;border:1px solid var(--input-border);border-radius:6px;font-size:.9rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.bonus-key-input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.bonus-symbol-select{padding:.5rem .6rem;border:1px solid var(--input-border);border-radius:6px;font-size:.9rem;color:var(--text-primary);background:var(--input-bg);transition:border-color .3s ease,box-shadow .3s ease,background .3s ease,color .3s ease}.bonus-symbol-select:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--shadow)}.bonus-symbol-id{font-size:.85rem;color:var(--text-secondary);font-weight:500;padding:0 .5rem;transition:color .3s ease}.bonus-symbols .muted{color:var(--text-muted);font-size:.9rem;font-style:italic;padding:1rem;text-align:center;transition:color .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:radial-gradient(circle at 20% 20%,var(--bg-gradient-start) 0,var(--bg-gradient-mid) 35%,var(--bg-primary) 70%,var(--bg-gradient-end) 100%);color:var(--text-primary);transition:background .3s ease,color .3s ease}.app-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2)}.welcome-screen{background:var(--bg-secondary);padding:3rem;border-radius:12px;box-shadow:0 10px 40px var(--shadow);text-align:center;max-width:500px;transition:background .3s ease,box-shadow .3s ease}.logo-title{display:flex;align-items:center;gap:.75rem}.logo{height:2.5rem;width:auto}.welcome-screen .logo{height:3.5rem}.welcome-screen .logo-title{justify-content:center;margin-bottom:1rem}.welcome-screen h1{font-size:2.5rem;margin-bottom:0;color:var(--accent)}.welcome-screen p{font-size:1.1rem;color:var(--text-secondary);margin-bottom:2rem}.actions{display:flex;gap:1rem;justify-content:center}.button{padding:.75rem 1.5rem;font-size:1rem;border:none;border-radius:6px;cursor:pointer;transition:all .2s;font-weight:500}.button.primary{background-color:var(--accent);color:#fff}.button.primary:hover:not(:disabled){background-color:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px var(--shadow)}.button.secondary{background-color:var(--button-secondary-bg);color:var(--button-secondary-text)}.button.secondary:hover:not(:disabled){background-color:var(--button-secondary-hover)}.button.small{padding:.5rem 1rem;font-size:.875rem}.button:disabled{opacity:.5;cursor:not-allowed}.app{display:flex;flex-direction:column;height:100vh;overflow:hidden}.app-header{background:linear-gradient(120deg,#454545,#555,#f97316);border-bottom:1px solid var(--border-color);padding:1rem 2rem;display:flex;align-items:center;justify-content:space-between;position:relative;box-shadow:0 8px 30px var(--shadow-lg);transition:background .3s ease,border-color .3s ease}.app-header .logo{flex-shrink:0;z-index:1}.app-header .header-title{position:absolute;left:50%;transform:translate(-50%);text-align:center;font-size:1.75rem;font-weight:800;letter-spacing:.15em;text-transform:uppercase;margin:0;background:linear-gradient(135deg,#fff,#fcd34d,#f97316,#fcd34d,#fff);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 0 30px rgba(249,115,22,.5);animation:shimmer 30s ease-in-out infinite;filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));pointer-events:none;z-index:0}@keyframes shimmer{0%,to{background-position:0% center}50%{background-position:100% center}}.app-header h1{font-size:1.5rem;color:#fff}.header-actions{display:flex;gap:.75rem;align-items:center;z-index:1}.nav-tabs{display:flex;gap:.5rem}.tab{padding:.45rem .85rem;border:1px solid rgba(255,255,255,.2);background:#ffffff1a;border-radius:999px;cursor:pointer;font-weight:600;color:#ffffffd9;transition:all .2s ease;box-shadow:0 3px 10px #0000001a}.tab:hover{background:#fff3;color:#fff}.tab.active{background:linear-gradient(120deg,#f97316,#fb923c);color:#fff;border-color:#ea580c;box-shadow:0 8px 18px #f9731659}.header-controls{display:flex;gap:.5rem;align-items:center;z-index:1}.header-btn-secondary{background:#4b5563!important;color:#fff!important;border:1px solid #374151!important}.header-btn-secondary:hover{background:#6b7280!important}.reel-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:1rem;margin-bottom:1rem;padding:.75rem 1rem;background:linear-gradient(135deg,var(--bg-secondary),var(--bg-tertiary));border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 18px var(--shadow);transition:background .3s ease,border-color .3s ease}.reel-toolbar-select{display:flex;align-items:flex-end;gap:.5rem;flex:1}.reel-toolbar-select label{font-weight:600;color:var(--text-primary);transition:color .3s ease}.reel-toolbar-actions{display:flex;gap:.5rem}.select{padding:.45rem .75rem;border-radius:8px;border:1px solid var(--input-border);background:var(--input-bg);min-width:220px;font-weight:600;color:var(--text-primary);box-shadow:0 3px 8px var(--shadow);transition:background .3s ease,border-color .3s ease,color .3s ease}.reel-generator{display:flex;flex-direction:column;gap:.75rem}.reel-generator-header{display:flex;justify-content:space-between;align-items:center}.rule-chip{background:#fff7ed;color:#c2410c;border:1px solid #fdba74;padding:.2rem .6rem;border-radius:999px;font-weight:700;font-size:.85rem}.reel-generator-grid{display:grid;gap:.75rem}.gen-field{display:grid;gap:.35rem;align-items:center}.gen-field input[type=number],.gen-field input[type=range],.weights-list input[type=number]{width:100%;padding:.35rem .45rem;border:1px solid var(--input-border);border-radius:6px;background:var(--input-bg);color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}.gen-field input[type=range]{padding:0}.weights{border:1px solid var(--border-color);border-radius:8px;padding:.6rem;background:var(--panel-bg);transition:background .3s ease,border-color .3s ease}.weights-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;gap:.35rem}.weights-list{display:flex;flex-direction:column;gap:.35rem}.weight-item{display:grid;grid-template-columns:60px 1fr 60px;align-items:center;gap:.4rem}.gen-actions{display:flex;justify-content:flex-end;align-items:center;gap:.5rem}.preset-row{display:flex;align-items:center;gap:.5rem}.preset-label{font-weight:600;color:var(--text-primary);transition:color .3s ease}.preset-buttons{display:flex;gap:.4rem;flex-wrap:wrap}.gen-stats{display:flex;gap:.35rem}.stat-pill{padding:.25rem .6rem;border:1px solid var(--border-color);border-radius:999px;background:var(--panel-bg);color:var(--text-primary);font-size:.85rem;transition:background .3s ease,border-color .3s ease,color .3s ease}.stat-pill.warning{border-color:var(--warning-border);background:var(--warning-bg);color:var(--warning-text)}.panel-toggle{display:flex;gap:.35rem;margin-bottom:.75rem}.pill{padding:.35rem .75rem;border-radius:999px;border:1px solid var(--border-color);background:var(--card-bg);cursor:pointer;font-weight:600;color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}.pill.active{background:linear-gradient(120deg,#667eea,#8b5cf6);color:#fff;border-color:#7c3aed}.preset-select{padding:.45rem .6rem;border-radius:8px;border:1px solid var(--input-border);background:var(--input-bg);min-width:160px;color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}.exclusion-editor{border:1px solid var(--border-color);border-radius:10px;padding:.75rem;background:var(--panel-bg);display:flex;flex-direction:column;gap:.5rem;transition:background .3s ease,border-color .3s ease}.exclusion-head{display:flex;flex-direction:column;gap:.35rem}.chip-row{display:flex;flex-wrap:wrap;gap:.35rem}.chip{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border-radius:999px;background:var(--card-bg);border:1px solid var(--border-color);font-weight:600;color:var(--text-secondary);transition:background .3s ease,border-color .3s ease,color .3s ease}.chip button{background:none;border:none;cursor:pointer;color:var(--text-muted);font-size:.9rem;transition:color .3s ease}.exclusion-controls{display:flex;gap:.4rem;align-items:center}.app-content{display:flex;flex:1;overflow:hidden}.left-panel{width:260px;min-width:240px;flex-shrink:0;background:linear-gradient(180deg,var(--bg-secondary),var(--bg-tertiary));border-right:1px solid var(--border-color);overflow-y:auto;padding:1rem;box-shadow:inset -1px 0 0 var(--shadow);transition:background .3s ease,border-color .3s ease}.right-panel{width:540px;min-width:500px;flex-shrink:0;background:linear-gradient(180deg,var(--bg-secondary),var(--bg-tertiary));border-left:1px solid var(--border-color);overflow-y:auto;padding:1rem;box-shadow:inset 1px 0 0 var(--shadow);transition:background .3s ease,border-color .3s ease}.center-panel{flex:1;background:radial-gradient(circle at 60% 30%,var(--bg-gradient-start) 0,var(--bg-gradient-mid) 45%,var(--bg-gradient-end) 100%);overflow:auto;padding:2rem;transition:background .3s ease}.button{padding:.75rem 1.2rem;border-radius:8px;font-weight:600;border:1px solid transparent;box-shadow:0 4px 14px #0000000f}.button.secondary{background:var(--panel-bg);border-color:var(--border-color);color:var(--text-primary);transition:background .3s ease,border-color .3s ease,color .3s ease}.button.secondary:hover:not(:disabled){background:var(--bg-tertiary);border-color:var(--accent-light)}.confirmation-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.confirmation-dialog{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;padding:1.5rem;max-width:400px;width:90%;box-shadow:0 20px 25px -5px var(--shadow-lg),0 10px 10px -5px var(--shadow)}.confirmation-dialog h3{margin:0 0 1rem;font-size:1.1rem;font-weight:700;color:var(--text-primary)}.confirmation-dialog p{margin:.75rem 0;color:var(--text-secondary);font-size:.95rem;line-height:1.5}.dialog-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.5rem}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;--bg-primary: #f8fbff;--bg-secondary: #ffffff;--bg-tertiary: #f1f5f9;--bg-gradient-start: #f1f5ff;--bg-gradient-mid: #f8fbff;--bg-gradient-end: #f4f4f6;--text-primary: #1f2937;--text-secondary: #64748b;--text-muted: #94a3b8;--border-color: #e2e8f0;--shadow: rgba(0, 0, 0, .1);--shadow-lg: rgba(0, 0, 0, .15);--accent: #667eea;--accent-hover: #5568d3;--accent-light: #e0e7ff;--button-secondary-bg: #e0e0e0;--button-secondary-hover: #d0d0d0;--button-secondary-text: #333;--input-bg: #ffffff;--input-border: #d1d5db;--panel-bg: #f8fafc;--card-bg: #ffffff;--warning-bg: #fff1f2;--warning-text: #b91c1c;--warning-border: #fecdd3;--selection-bg: #e3f2fd;--selection-border: #2196f3;--selection-text: #1565c0;--badge-bg: #f9fafb;--badge-text: #374151}:root.dark{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-gradient-start: #0f172a;--bg-gradient-mid: #1e293b;--bg-gradient-end: #334155;--text-primary: #f1f5f9;--text-secondary: #cbd5e1;--text-muted: #94a3b8;--border-color: #334155;--shadow: rgba(0, 0, 0, .3);--shadow-lg: rgba(0, 0, 0, .5);--accent: #818cf8;--accent-hover: #6366f1;--accent-light: #312e81;--button-secondary-bg: #334155;--button-secondary-hover: #475569;--button-secondary-text: #f1f5f9;--input-bg: #1e293b;--input-border: #475569;--panel-bg: #1e293b;--card-bg: #1e293b;--warning-bg: #7f1d1d;--warning-text: #fca5a5;--warning-border: #991b1b;--selection-bg: #1e3a5f;--selection-border: #3b82f6;--selection-text: #93c5fd;--badge-bg: #1e293b;--badge-text: #cbd5e1}body{margin:0;min-width:320px;min-height:100vh;background:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease}#root{width:100%;height:100vh}
