.theme-toggle{background:var(--color-bg-secondary);border:2px solid var(--color-border);border-radius:12px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease;font-size:1.5rem}.theme-toggle:hover{background:var(--color-bg-tertiary);transform:scale(1.1) rotate(15deg);box-shadow:0 4px 12px #00000026}.theme-toggle:active{transform:scale(.95) rotate(0)}.theme-toggle-icon{display:block;transition:transform .3s ease}.theme-toggle:hover .theme-toggle-icon{animation:bounce .5s ease-in-out}.btn{font-family:Nunito,sans-serif;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center;gap:.5rem;border:2px solid transparent;position:relative;overflow:hidden}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:not(:disabled):hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.btn:not(:disabled):active{transform:translateY(0)}.btn-small{padding:.5rem 1rem;font-size:.875rem}.btn-medium{padding:.75rem 1.5rem;font-size:1rem}.btn-large{padding:1rem 2rem;font-size:1.125rem}.btn-primary{background:var(--gradient-primary);color:#fff;border-color:transparent}.btn-primary:hover:not(:disabled){box-shadow:0 4px 16px #6366f166}.btn-secondary{background:var(--gradient-secondary);color:#fff;border-color:transparent}.btn-secondary:hover:not(:disabled){box-shadow:0 4px 16px #ec489966}.btn-accent{background:var(--color-accent);color:#fff;border-color:transparent}.btn-accent:hover:not(:disabled){background:var(--color-accent-dark);box-shadow:0 4px 16px #f59e0b66}.btn-outline{background:transparent;color:var(--color-primary);border-color:var(--color-primary)}.btn-outline:hover:not(:disabled){background:var(--color-primary);color:#fff}.btn-ghost{background:transparent;color:var(--color-text);border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-bg-secondary)}.header{background:var(--color-card-bg);border-bottom:1px solid var(--color-border);padding:1rem 0;position:sticky;top:0;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffffe6}[data-theme=dark] .header{background:#1f2937e6}.header-content{display:flex;justify-content:space-between;align-items:center}.header-logo{text-decoration:none;color:var(--color-text)}.header-logo h2{margin:0;font-size:1.5rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;align-items:center;gap:1.5rem}.header-nav a{color:var(--color-text);font-weight:600;text-decoration:none;transition:color .2s ease}.header-nav a:hover{color:var(--color-primary)}@media (max-width: 768px){.header-nav{gap:1rem;font-size:.875rem}}.footer{background:var(--color-bg-secondary);border-top:1px solid var(--color-border);padding:2rem 0;margin-top:4rem;text-align:center;color:var(--color-text-secondary)}.card{background:var(--color-card-bg);border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px var(--color-card-shadow);transition:all .3s ease;border:1px solid var(--color-border)}.card-hover:hover{transform:translateY(-4px);box-shadow:0 8px 24px var(--color-card-shadow)}.card-clickable{cursor:pointer}.card-clickable:active{transform:translateY(-2px)}.game-card{display:flex;flex-direction:column;height:100%;padding:0;overflow:hidden}.game-card-image{position:relative;width:100%;padding-top:56.25%;background:var(--color-bg-tertiary);overflow:hidden}.game-card-image img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover;transition:transform .3s ease}.game-card:hover .game-card-image img{transform:scale(1.05)}.game-card-image-placeholder{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:var(--color-text-tertiary);font-size:.875rem}.game-card-badges{position:absolute;top:.75rem;right:.75rem;display:flex;flex-direction:column;gap:.5rem}.game-card-badge{background:#000000b3;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.game-card-content{padding:1.5rem;display:flex;flex-direction:column;gap:.75rem;flex:1}.game-card-title{margin:0;font-size:1.25rem;color:var(--color-text);line-height:1.3}.game-card-description{margin:0;color:var(--color-text-secondary);font-size:.875rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.game-card-meta{display:flex;justify-content:space-between;align-items:center;margin-top:auto;padding-top:.75rem;border-top:1px solid var(--color-border);font-size:.75rem;color:var(--color-text-tertiary)}.floating-element{position:absolute;pointer-events:none;z-index:1}.float-slow{animation:floatSlow 6s ease-in-out infinite}.float-medium{animation:float 4s ease-in-out infinite}.float-fast{animation:floatFast 2s ease-in-out infinite}.float-star:before{content:"⭐";font-size:2rem}.float-confetti:before{content:"🎉";font-size:1.5rem}.float-balloon:before{content:"🎈";font-size:2rem}.float-circle{width:20px;height:20px;border-radius:50%;background:var(--gradient-primary);opacity:.6}.home-page{min-height:100vh;padding:2rem 0;background:var(--color-bg);position:relative;overflow:hidden}.home-header{text-align:center;margin-bottom:3rem;animation:slideIn .5s ease-out}.home-header h1{font-size:3.5rem;margin-bottom:1rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.home-subtitle{font-size:1.25rem;color:var(--color-text-secondary);margin-bottom:2rem}.home-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.home-search{margin-bottom:2rem;max-width:500px;margin-left:auto;margin-right:auto}.home-search-input{width:100%;padding:1rem 1.5rem;border-radius:12px;font-size:1rem;border:2px solid var(--color-border);background:var(--color-bg);transition:all .3s ease}.home-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 4px #6366f11a}.home-loading,.home-empty{text-align:center;padding:4rem 2rem;color:var(--color-text-secondary)}.home-empty{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.home-games{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}@media (max-width: 768px){.home-header h1{font-size:2.5rem}.home-games{grid-template-columns:1fr}}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 0;background:var(--color-bg)}.login-card{max-width:400px;width:100%;margin:0 auto;animation:scaleIn .3s ease-out}.login-card h1{text-align:center;margin-bottom:2rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-form{display:flex;flex-direction:column;gap:1.5rem}.login-error{background:var(--color-error);color:#fff;padding:.75rem 1rem;border-radius:12px;font-size:.875rem;animation:shake .5s ease-in-out}.login-button{width:100%}.login-signup{text-align:center;margin-top:1.5rem;color:var(--color-text-secondary)}.login-signup a{color:var(--color-primary);font-weight:600}.signup-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem 0;background:var(--color-bg)}.signup-card{max-width:400px;width:100%;margin:0 auto;animation:scaleIn .3s ease-out}.signup-card h1{text-align:center;margin-bottom:2rem;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.signup-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group input{padding:.75rem;border-radius:12px;font-size:1rem;width:100%}.signup-error{background:var(--color-error);color:#fff;padding:.75rem 1rem;border-radius:12px;font-size:.875rem;animation:shake .5s ease-in-out}.signup-button{width:100%}.signup-login{text-align:center;margin-top:1.5rem;color:var(--color-text-secondary)}.signup-login a{color:var(--color-primary);font-weight:600}.image-uploader{display:flex;flex-direction:column;gap:1.5rem}.image-uploader-inputs{display:flex;gap:1rem;flex-wrap:wrap}.image-uploader-url{flex:1;min-width:200px;display:flex;gap:.5rem}.image-uploader-url input{flex:1;padding:.75rem;border-radius:12px;font-size:1rem}.image-uploader-file{display:flex}.image-uploader-error{background:var(--color-error);color:#fff;padding:.75rem 1rem;border-radius:12px;font-size:.875rem;animation:shake .5s ease-in-out}.image-uploader-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:1rem}.image-uploader-item{position:relative;background:var(--color-bg-secondary);border-radius:12px;overflow:hidden;border:2px solid var(--color-border);transition:all .3s ease}.image-uploader-item:hover{transform:translateY(-4px);box-shadow:0 8px 16px #00000026;border-color:var(--color-primary)}.image-uploader-item-preview{position:relative;width:100%;padding-top:100%;background:var(--color-bg-tertiary)}.image-uploader-item-preview img{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.image-uploader-item-loading{position:absolute;top:0;left:0;right:0;bottom:0;background:#000000b3;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600}.image-uploader-item-controls{display:flex;gap:.25rem;padding:.5rem;background:var(--color-bg);justify-content:center}.image-uploader-item-controls button{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:6px;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1rem;color:var(--color-text);transition:all .2s ease}.image-uploader-item-controls button:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.image-uploader-item-controls button:disabled{opacity:.3;cursor:not-allowed}.image-uploader-item-remove{color:var(--color-error)!important}.image-uploader-item-remove:hover:not(:disabled){background:var(--color-error)!important;color:#fff!important}.image-uploader-item-order{position:absolute;top:.5rem;left:.5rem;background:var(--color-primary);color:#fff;padding:.25rem .5rem;border-radius:8px;font-size:.75rem;font-weight:700}.image-uploader-empty{text-align:center;padding:3rem 1rem;color:var(--color-text-secondary);background:var(--color-bg-secondary);border-radius:12px;border:2px dashed var(--color-border)}.create-game-page{min-height:100vh;padding:2rem 0;background:var(--color-bg)}.create-game-page h1{margin-bottom:2rem;text-align:center;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.create-game-form{max-width:800px;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.create-game-section{animation:slideIn .3s ease-out}.create-game-section h2{margin:0 0 1rem;color:var(--color-text);font-size:1.5rem}.section-description{margin:0 0 1.5rem;color:var(--color-text-secondary);font-size:.875rem}.form-group{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.5rem}.form-group label{font-weight:600;color:var(--color-text);font-size:.875rem}.form-group input,.form-group textarea,.form-group select{padding:.75rem;border-radius:12px;font-size:1rem;width:100%}.form-group textarea{resize:vertical;min-height:80px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.create-game-error{background:var(--color-error);color:#fff;padding:1rem;border-radius:12px;animation:shake .5s ease-in-out}.create-game-actions{display:flex;gap:1rem;justify-content:flex-end}@media (max-width: 768px){.form-row{grid-template-columns:1fr}}.my-games-page{min-height:100vh;padding:2rem 0;background:var(--color-bg)}.my-games-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.my-games-header h1{margin:0;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.my-games-empty{text-align:center;padding:4rem 2rem;color:var(--color-text-secondary);display:flex;flex-direction:column;align-items:center;gap:1.5rem}.my-games-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:2rem}.my-games-item{display:flex;flex-direction:column;gap:1rem}.my-games-item-actions{display:flex;gap:.5rem;justify-content:center}@media (max-width: 768px){.my-games-list{grid-template-columns:1fr}}.play-game-page{min-height:100vh;padding:2rem 0;background:var(--color-bg)}.play-game-header{text-align:center;margin-bottom:2rem}.play-game-header h1{margin:1rem 0;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.play-game-info{display:flex;gap:1rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}.play-game-badge,.play-game-images{background:var(--color-bg-secondary);padding:.5rem 1rem;border-radius:12px;font-size:.875rem;font-weight:600;color:var(--color-text)}.play-game-description{max-width:600px;margin:0 auto 2rem;text-align:center}.play-game-actions{display:flex;justify-content:center;margin-top:2rem}.play-game-error{text-align:center;padding:4rem 2rem;display:flex;flex-direction:column;align-items:center;gap:1.5rem}.timer{display:flex;flex-direction:column;align-items:center;gap:1.5rem;padding:2rem}.timer-display{position:relative}.timer-circle{position:relative;width:200px;height:200px}.timer-svg{width:100%;height:100%;transform:rotate(-90deg)}.timer-track{fill:none;stroke:var(--color-bg-tertiary);stroke-width:8}.timer-progress{fill:none;stroke:var(--color-primary);stroke-width:8;stroke-linecap:round;transition:stroke-dashoffset .3s ease,stroke .3s ease}.timer-urgent .timer-progress{stroke:var(--color-error);animation:timer-pulse 1s ease-in-out infinite}.timer-complete .timer-progress{stroke:var(--color-success)}.timer-time{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);text-align:center}.timer-seconds{display:block;font-family:Fredoka One,cursive;font-size:3rem;color:var(--color-text);line-height:1}.timer-label{display:block;font-size:.875rem;color:var(--color-text-secondary);margin-top:.5rem;text-transform:uppercase;letter-spacing:.1em}.timer-controls{display:flex;gap:1rem}.timer-button{background:var(--color-primary);color:#fff;border:none;border-radius:12px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s ease}.timer-button:hover{background:var(--color-primary-dark);transform:translateY(-2px);box-shadow:0 4px 12px #6366f166}.timer-button:active{transform:translateY(0)}.image-display{display:flex;flex-direction:column;align-items:center;gap:1rem}.image-display-empty{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-secondary)}.image-display-container{position:relative;width:100%;max-width:600px;display:flex;align-items:center;gap:1rem}.image-display-image-wrapper{flex:1;position:relative;border-radius:16px;overflow:hidden;box-shadow:0 8px 24px #00000026;background:var(--color-bg-secondary);animation:fadeIn .3s ease-out}.image-display-image{width:100%;height:auto;display:block;object-fit:contain;max-height:500px;transition:transform .3s ease}.image-display-image:hover{transform:scale(1.02)}.image-display-nav{background:var(--color-primary);color:#fff;border:none;border-radius:50%;width:48px;height:48px;font-size:2rem;line-height:1;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1;flex-shrink:0}.image-display-nav:hover{background:var(--color-primary-dark);transform:scale(1.1);box-shadow:0 4px 12px #6366f166}.image-display-nav:active{transform:scale(.95)}.image-display-indicator{color:var(--color-text-secondary);font-size:.875rem;font-weight:600}.scoreboard{background:var(--color-card-bg);border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px var(--color-card-shadow);border:1px solid var(--color-border)}.scoreboard-title{margin:0 0 1.5rem;text-align:center;color:var(--color-text);font-size:1.5rem}.scoreboard-teams{display:flex;flex-direction:column;gap:1rem}.scoreboard-team{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-bg-secondary);border-radius:12px;border:2px solid transparent;transition:all .3s ease}.scoreboard-team:hover{transform:translate(4px);box-shadow:0 4px 12px #0000001a}.scoreboard-team-current{border-color:var(--color-primary);background:var(--color-primary);background:linear-gradient(135deg,#6366f11a,#ec48991a)}.scoreboard-team-winning{border-color:var(--color-accent);background:linear-gradient(135deg,#f59e0b1a,#ec48991a);animation:pulse 2s ease-in-out infinite}.scoreboard-team-position{font-size:1.5rem;font-weight:700;min-width:48px;text-align:center;color:var(--color-primary)}.scoreboard-team-winning .scoreboard-team-position{color:var(--color-accent);font-size:2rem}.scoreboard-team-info{flex:1}.scoreboard-team-name{font-weight:700;font-size:1.125rem;color:var(--color-text);margin-bottom:.25rem}.scoreboard-team-score{font-size:.875rem;color:var(--color-text-secondary);font-weight:600}.scoreboard-team-badge{background:var(--color-primary);color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.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;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal{background:var(--color-card-bg);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:scaleIn .2s ease-out;border:1px solid var(--color-border)}.modal-small{width:90%;max-width:400px}.modal-medium{width:90%;max-width:600px}.modal-large{width:90%;max-width:900px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid var(--color-border)}.modal-header h3{margin:0;color:var(--color-text)}.modal-close{background:transparent;border:none;font-size:2rem;line-height:1;color:var(--color-text-secondary);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s ease}.modal-close:hover{background:var(--color-bg-secondary);color:var(--color-text)}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}.modal-footer{padding:1.5rem;border-top:1px solid var(--color-border);display:flex;gap:1rem;justify-content:flex-end}.game-session-page{min-height:100vh;padding:2rem 0;background:var(--color-bg)}.game-session-header{margin-bottom:2rem}.game-session-header h1{text-align:center;margin:1rem 0;background:var(--gradient-primary);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-session-info{display:flex;gap:1rem;justify-content:center;margin-top:1rem;flex-wrap:wrap}.game-session-info span{background:var(--color-bg-secondary);padding:.5rem 1rem;border-radius:12px;font-weight:600;color:var(--color-text)}.game-session-setup{max-width:600px;margin:0 auto}.game-session-teams{display:flex;flex-direction:column;gap:.75rem;margin:1.5rem 0}.game-session-team{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--color-bg-secondary);border-radius:12px;font-weight:600}.game-session-start{margin-top:2rem;text-align:center}.game-session-playing{display:grid;grid-template-columns:1fr 350px;gap:2rem;align-items:start}.game-session-main{display:flex;flex-direction:column;gap:2rem}.game-session-sidebar{display:flex;flex-direction:column;gap:1.5rem;position:sticky;top:2rem}.game-session-controls{display:flex;flex-direction:column;gap:1rem}.game-session-finished{max-width:600px;margin:0 auto;text-align:center}.game-session-actions{display:flex;gap:1rem;justify-content:center;margin-top:2rem}.game-session-modal-content{display:flex;flex-direction:column;gap:1rem}.game-session-modal-content input{padding:.75rem;border-radius:12px;font-size:1rem}.game-session-modal-actions{display:flex;gap:.5rem;justify-content:flex-end}@media (max-width: 1024px){.game-session-playing{grid-template-columns:1fr}.game-session-sidebar{position:static}}*{margin:0;padding:0;box-sizing:border-box}:root{font-family:Nunito,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:var(--color-text);background-color:var(--color-bg);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh;transition:background-color .3s ease,color .3s ease}h1,h2,h3,h4,h5,h6{font-family:Fredoka One,cursive;font-weight:400;line-height:1.2;color:var(--color-text)}h1{font-size:3rem}h2{font-size:2.5rem}h3{font-size:2rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{color:var(--color-text-secondary)}a{color:var(--color-primary);text-decoration:none;transition:color .2s ease}a:hover{color:var(--color-primary-dark)}button{font-family:Nunito,sans-serif;cursor:pointer;border:none;outline:none;transition:all .2s ease}input,textarea,select{font-family:Nunito,sans-serif;color:var(--color-text);background-color:var(--color-bg);border:2px solid var(--color-border);transition:all .2s ease}input:focus,textarea:focus,select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.container{max-width:1200px;margin:0 auto;padding:0 1rem}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:var(--color-bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-primary);border-radius:5px}::-webkit-scrollbar-thumb:hover{background:var(--color-primary-dark)}:root{--color-primary: #6366f1;--color-primary-dark: #4f46e5;--color-primary-light: #818cf8;--color-secondary: #ec4899;--color-secondary-dark: #db2777;--color-secondary-light: #f472b6;--color-accent: #f59e0b;--color-accent-dark: #d97706;--color-accent-light: #fbbf24;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-bg: #ffffff;--color-bg-secondary: #f9fafb;--color-bg-tertiary: #f3f4f6;--color-text: #111827;--color-text-secondary: #6b7280;--color-text-tertiary: #9ca3af;--color-border: #e5e7eb;--color-border-light: #f3f4f6;--color-card-bg: #ffffff;--color-card-shadow: rgba(0, 0, 0, .1);--gradient-primary: linear-gradient(135deg, #6366f1 0%, #ec4899 100%);--gradient-secondary: linear-gradient(135deg, #f59e0b 0%, #ec4899 100%);--gradient-accent: linear-gradient(135deg, #10b981 0%, #6366f1 100%)}[data-theme=dark]{--color-primary: #818cf8;--color-primary-dark: #6366f1;--color-primary-light: #a5b4fc;--color-secondary: #f472b6;--color-secondary-dark: #ec4899;--color-secondary-light: #f9a8d4;--color-accent: #fbbf24;--color-accent-dark: #f59e0b;--color-accent-light: #fcd34d;--color-success: #34d399;--color-warning: #fbbf24;--color-error: #f87171;--color-bg: #111827;--color-bg-secondary: #1f2937;--color-bg-tertiary: #374151;--color-text: #f9fafb;--color-text-secondary: #d1d5db;--color-text-tertiary: #9ca3af;--color-border: #374151;--color-border-light: #4b5563;--color-card-bg: #1f2937;--color-card-shadow: rgba(0, 0, 0, .3);--gradient-primary: linear-gradient(135deg, #818cf8 0%, #f472b6 100%);--gradient-secondary: linear-gradient(135deg, #fbbf24 0%, #f472b6 100%);--gradient-accent: linear-gradient(135deg, #34d399 0%, #818cf8 100%)}@keyframes float{0%,to{transform:translateY(0) rotate(0)}33%{transform:translateY(-20px) rotate(5deg)}66%{transform:translateY(-10px) rotate(-5deg)}}@keyframes floatSlow{0%,to{transform:translateY(0) translate(0)}50%{transform:translateY(-30px) translate(10px)}}@keyframes floatFast{0%,to{transform:translateY(0) translate(0) rotate(0)}25%{transform:translateY(-15px) translate(-10px) rotate(5deg)}50%{transform:translateY(-25px) translate(10px) rotate(-5deg)}75%{transform:translateY(-10px) translate(-5px) rotate(3deg)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}@keyframes pulse-strong{0%,to{transform:scale(1);box-shadow:0 0 #6366f1b3}50%{transform:scale(1.1);box-shadow:0 0 0 10px #6366f100}}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-5px)}20%,40%,60%,80%{transform:translate(5px)}}@keyframes slideIn{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInLeft{0%{opacity:0;transform:translate(-30px)}to{opacity:1;transform:translate(0)}}@keyframes slideInRight{0%{opacity:0;transform:translate(30px)}to{opacity:1;transform:translate(0)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes scaleIn{0%{opacity:0;transform:scale(.9)}to{opacity:1;transform:scale(1)}}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes confetti{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}@keyframes timer-pulse{0%,to{transform:scale(1);box-shadow:0 0 #ef4444b3}50%{transform:scale(1.05);box-shadow:0 0 0 15px #ef444400}}@keyframes timer-urgent{0%,to{background-color:var(--color-error)}50%{background-color:var(--color-warning)}}.animate-float{animation:float 3s ease-in-out infinite}.animate-float-slow{animation:floatSlow 4s ease-in-out infinite}.animate-float-fast{animation:floatFast 2s ease-in-out infinite}.animate-bounce{animation:bounce 1s ease-in-out infinite}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-pulse-strong{animation:pulse-strong 1.5s ease-in-out infinite}.animate-shake{animation:shake .5s ease-in-out}.animate-slide-in{animation:slideIn .3s ease-out}.animate-slide-in-left{animation:slideInLeft .3s ease-out}.animate-slide-in-right{animation:slideInRight .3s ease-out}.animate-fade-in{animation:fadeIn .3s ease-out}.animate-fade-out{animation:fadeOut .3s ease-out}.animate-scale-in{animation:scaleIn .3s ease-out}.animate-timer-pulse{animation:timer-pulse 1s ease-in-out infinite}.animate-timer-urgent{animation:timer-urgent .5s ease-in-out infinite}.transition-all{transition:all .3s ease}.transition-colors{transition:color .3s ease,background-color .3s ease,border-color .3s ease}.transition-transform{transition:transform .3s ease}[data-theme=dark]{transition:background-color .3s ease,color .3s ease}[data-theme=dark] img{opacity:.9;transition:opacity .3s ease}[data-theme=dark] img:hover{opacity:1}[data-theme=dark] ::-webkit-scrollbar-track{background:var(--color-bg-tertiary)}[data-theme=dark] ::-webkit-scrollbar-thumb{background:var(--color-primary)}[data-theme=dark] ::-webkit-scrollbar-thumb:hover{background:var(--color-primary-light)}.app{min-height:100vh;display:flex;flex-direction:column}.app-main{flex:1}
