:root{--bg-gradient: linear-gradient(135deg, #0f172a 0%, #1e1b4b 100%);--glass-bg: rgba(255, 255, 255, .05);--glass-border: rgba(255, 255, 255, .1);--primary: #8b5cf6;--primary-hover: #7c3aed;--secondary: #64748b;--text-main: #f8fafc;--text-muted: #94a3b8;--success: #10b981;--card-bg: rgba(30, 41, 59, .7);--font-family: "Outfit", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background:var(--bg-gradient);color:var(--text-main);min-height:100vh;display:flex;justify-content:center;align-items:center;overflow-x:hidden}#app{width:100%;max-width:1200px;padding:2rem;display:flex;flex-direction:column;align-items:center;gap:2rem}header{text-align:center;margin-bottom:1rem}header h1{font-size:3rem;font-weight:800;background:linear-gradient(to right,#c084fc,#6366f1);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;margin-bottom:.5rem;letter-spacing:-1px}header p{color:var(--text-muted);font-size:1.1rem}.panel{background:var(--glass-bg);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:24px;padding:2.5rem;width:100%;max-width:500px;box-shadow:0 25px 50px -12px #00000080;transition:transform .3s ease,opacity .3s ease}.input-group{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}label{font-weight:600;color:var(--text-main);font-size:.9rem;text-transform:uppercase;letter-spacing:1px}textarea{background:#0000004d;border:1px solid var(--glass-border);border-radius:12px;padding:1rem;color:var(--text-main);font-family:var(--font-family);font-size:1rem;min-height:200px;resize:vertical;outline:none;transition:border-color .2s}textarea:focus{border-color:var(--primary)}button{cursor:pointer;border:none;font-family:var(--font-family);font-weight:600;border-radius:12px;transition:all .2s}.primary-btn{background:var(--primary);color:#fff;padding:1rem 2rem;font-size:1.1rem;width:100%;box-shadow:0 4px 14px #8b5cf663}.primary-btn:hover{background:var(--primary-hover);transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf63b}.secondary-btn{background:transparent;border:1px solid var(--glass-border);color:var(--text-muted);padding:.5rem 1rem;font-size:.9rem}.secondary-btn:hover{background:#ffffff0d;color:var(--text-main)}#bracket-view{width:100%;display:flex;flex-direction:column;align-items:center;gap:2rem}.bracket-header{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:800px}#round-indicator{font-size:1.5rem;color:var(--text-main)}#new-tournament{top:.5rem}.bracket-container{display:flex;flex-wrap:wrap;justify-content:center;gap:3rem;width:100%}.bracket-pair{display:flex;flex-direction:column;gap:1.5rem;position:relative;justify-content:center}.bracket-pair.has-connector:after{content:"";position:absolute;right:-20px;top:25%;bottom:25%;width:20px;border-right:2px solid rgba(255,255,255,.3);border-top:2px solid rgba(255,255,255,.3);border-bottom:2px solid rgba(255,255,255,.3);border-top-right-radius:10px;border-bottom-right-radius:10px}.match-card{background:var(--card-bg);border:1px solid var(--glass-border);border-radius:16px;padding:1rem;width:280px;display:flex;flex-direction:column;gap:.5rem;position:relative;overflow:hidden}.match-card:before{content:"VS";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:3rem;font-weight:900;color:#ffffff08;pointer-events:none}.participant{padding:.75rem 1rem;background:#0003;border-radius:8px;cursor:pointer;transition:all .2s;border:1px solid transparent;display:flex;justify-content:space-between;align-items:center}.participant:hover{background:#ffffff1a;border-color:#fff3}.participant.winner{background:#10b98133;border-color:var(--success);color:#6ee7b7}.participant.loser{opacity:.5;text-decoration:line-through}#winner-view{text-align:center;animation:popIn .5s cubic-bezier(.175,.885,.32,1.275)}.winner-card{background:#ffffff1a;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);padding:4rem;border-radius:32px;border:1px solid rgba(255,255,255,.2);box-shadow:0 0 100px #8b5cf64d}#winner-view h2{color:var(--text-muted);margin-bottom:1rem;font-size:1.5rem}#winner-view h1{font-size:5rem;font-weight:800;margin-bottom:3rem;background:linear-gradient(to right,#fbbf24,#f59e0b);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;text-shadow:0 10px 30px rgba(245,158,11,.3)}.hidden{display:none!important}@keyframes popIn{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@media (max-width: 600px){header h1{font-size:2rem}#winner-view h1{font-size:3rem}.match-card{width:100%}}.checkbox-wrapper{display:flex;align-items:center;gap:.5rem;color:var(--text-main);margin-top:.5rem;font-size:.9rem}.checkbox-wrapper input[type=checkbox]{accent-color:var(--primary);width:1.1rem;height:1.1rem;cursor:pointer}.hint-text{margin-top:2rem;color:var(--text-muted);text-align:center;opacity:.8;width:100%}.participant.bye-slot{cursor:pointer!important;border:1px dashed var(--glass-border);transition:all .2s;opacity:.7}.participant.bye-slot:hover{background:#ffffff1a;border-color:var(--success);opacity:1;color:var(--success);transform:scale(1.02)}#history-panel{margin-top:2rem;max-width:800px;overflow:hidden;display:flex;flex-direction:column;gap:1rem}.history-header{display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--glass-border);padding-bottom:1rem}.history-header h3{font-size:1.2rem;color:var(--text-main)}.small-btn{padding:.25rem .5rem;font-size:1.2rem;line-height:1}.history-log{max-height:300px;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem;padding-right:.5rem}.history-item{background:#ffffff0d;padding:.75rem;border-radius:8px;font-size:.9rem;display:flex;flex-direction:column;gap:.25rem;border-left:3px solid var(--primary);animation:slideIn .3s ease-out}.history-item.tournament-start{border-left-color:#3b82f6;background:#3b82f61a}.history-item.match-winner{border-left-color:var(--success)}.history-item.tournament-end{border-left-color:#f59e0b;background:#f59e0b1a;font-weight:700}.history-time{font-size:.75rem;color:var(--text-muted)}.empty-state{text-align:center;color:var(--text-muted);font-style:italic;padding:2rem}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:#0000001a;border-radius:4px}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:4px}.past-tournaments-section{width:100%;margin-top:2rem;border-top:1px solid var(--glass-border);padding-top:1.5rem}.past-tournaments-section h3{color:var(--text-muted);font-size:1rem;text-transform:uppercase;letter-spacing:1px;margin-bottom:1rem}.tournaments-list{display:flex;flex-direction:column;gap:.75rem;max-height:250px;overflow-y:auto}.tournament-summary-card{background:#ffffff08;border:1px solid var(--glass-border);border-radius:12px;padding:1rem;cursor:pointer;transition:all .2s;position:relative;display:flex;flex-direction:column;gap:.25rem}.tournament-summary-card:hover{background:#ffffff14;border-color:#fff3}.t-name{font-weight:600;color:var(--text-main)}.t-details{font-size:.8rem;color:var(--text-muted)}.t-champion{font-size:.9rem;color:#fbbf24;margin-top:.25rem;font-weight:500}.t-delete-btn{position:absolute;top:.5rem;right:.5rem;background:transparent;border:none;color:var(--text-muted);font-size:1.2rem;line-height:1;padding:.25rem;border-radius:4px;opacity:0;transition:opacity .2s}.t-delete-btn:hover{background:#ef444433;color:#ef4444}.tournament-summary-card:hover .t-delete-btn{opacity:1}#back-to-setup-btn{align-self:flex-start}.text-input{background:#0000004d;border:1px solid var(--glass-border);border-radius:12px;padding:.75rem 1rem;color:var(--text-main);font-family:var(--font-family);font-size:1rem;width:100%;outline:none;transition:border-color .2s}.round-nav{display:flex;align-items:center;gap:1rem}.icon-btn{font-size:1.2rem;padding:.25rem .75rem;line-height:1}.icon-btn.disabled{opacity:.3;cursor:not-allowed;pointer-events:none}.winner-actions{display:flex;gap:1rem;justify-content:center;margin-top:1rem}.past-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.past-header h3{margin-bottom:0!important}footer{margin-top:auto;padding-top:3rem;text-align:center;display:flex;flex-direction:column;gap:.5rem;opacity:.8}.copyright{font-size:.8rem;color:var(--text-muted)}.powered-by{font-size:.9rem;color:var(--text-main);font-weight:500;display:flex;align-items:center;justify-content:center;gap:.4rem}.powered-by span{font-weight:800;background:linear-gradient(to right,#22d3ee,#818cf8);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;font-size:1.1rem;text-transform:uppercase;letter-spacing:1px;position:relative}.powered-by span:after{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:100%;height:100%;background:inherit;filter:blur(10px);opacity:.3;z-index:-1}.logo-icon{display:inline-block;width:.8em;height:.8em;background:linear-gradient(to right,#c084fc,#6366f1);-webkit-mask:url(/logo.svg) no-repeat center / contain;mask:url(/logo.svg) no-repeat center / contain;vertical-align:-.05em;margin-right:.1em}.context-menu{position:absolute;background:#1e293bf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:12px;padding:.5rem;min-width:180px;box-shadow:0 10px 25px -5px #00000080;z-index:9999;display:flex;flex-direction:column;gap:.25rem;animation:scaleIn .1s ease-out}.context-menu-item{padding:.5rem .75rem;border-radius:8px;color:var(--text-main);cursor:pointer;display:flex;align-items:center;gap:.5rem;font-size:.9rem;transition:background .2s}.context-menu-item:hover{background:#ffffff1a}.context-menu-item.danger{color:#f87171}.context-menu-item.danger:hover{background:#ef444433}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.toast-container{position:fixed;bottom:2rem;right:2rem;display:flex;flex-direction:column;gap:1rem;z-index:10000;pointer-events:none}.toast{background:#1e293bf2;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-left:4px solid var(--primary);padding:1rem 1.5rem;border-radius:12px;color:var(--text-main);box-shadow:0 10px 30px -5px #00000080;min-width:300px;max-width:400px;pointer-events:auto;animation:slideInRight .3s cubic-bezier(.16,1,.3,1);display:flex;align-items:center;gap:.75rem;font-size:.95rem}.toast.error{border-left-color:#f87171;background:#7f1d1de6}.toast.success{border-left-color:#10b981}.toast.info{border-left-color:#3b82f6}@keyframes slideInRight{0%{opacity:0;transform:translate(100px)}to{opacity:1;transform:translate(0)}}.modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10001;display:flex;justify-content:center;align-items:center;animation:fadeIn .2s ease-out}.modal{background:#1e293b;border:1px solid var(--glass-border);border-radius:24px;padding:2rem;width:90%;max-width:400px;box-shadow:0 25px 50px -12px #00000080;animation:scaleIn .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;gap:1.5rem}.modal h3{font-size:1.5rem;color:var(--text-main)}.modal p{color:var(--text-muted);line-height:1.6}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;margin-top:.5rem}.modal input{width:100%}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}
