*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-primary: #6366f1;--color-primary-hover: #4f46e5;--color-primary-light: #818cf8;--color-secondary: #8b5cf6;--color-accent: #f59e0b;--color-accent-hover: #d97706;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #3b82f6;--bg-primary: #ffffff;--bg-secondary: #f8fafc;--bg-tertiary: #f1f5f9;--bg-card: #ffffff;--bg-hover: #f1f5f9;--text-primary: #0f172a;--text-secondary: #475569;--text-tertiary: #64748b;--text-inverse: #ffffff;--border-color: #e2e8f0;--border-color-hover: #cbd5e1;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -2px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -4px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 8px 10px -6px rgba(0, 0, 0, .1);--shadow-glow: 0 0 40px rgba(99, 102, 241, .15);--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-size-5xl: 3.5rem;--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--z-dropdown: 100;--z-modal: 200;--z-tooltip: 300;--cell-orange: #fed7aa;--cell-pink: #fbcfe8;--cell-blue: #bfdbfe;--cell-purple: #ddd6fe;--cell-green: #bbf7d0;--cell-yellow: #fef08a;--cell-default: #f1f5f9}[data-theme=dark]{--bg-primary: #0f172a;--bg-secondary: #1e293b;--bg-tertiary: #334155;--bg-card: #1e293b;--bg-hover: #334155;--text-primary: #f8fafc;--text-secondary: #cbd5e1;--text-tertiary: #64748b;--border-color: #334155;--border-color-hover: #475569;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .4);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4);--shadow-glow: 0 0 40px rgba(99, 102, 241, .25);--cell-orange: #7c2d12;--cell-pink: #831843;--cell-blue: #1e3a5f;--cell-purple: #4c1d95;--cell-green: #14532d;--cell-yellow: #713f12;--cell-default: #334155}html{scroll-behavior:smooth}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:1.6;color:var(--text-primary);background-color:var(--bg-secondary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh;display:flex;flex-direction:column}h1,h2,h3,h4,h5,h6{font-weight:700;line-height:1.2;color:var(--text-primary)}h1{font-size:var(--font-size-5xl)}h2{font-size:var(--font-size-4xl)}h3{font-size:var(--font-size-3xl)}h4{font-size:var(--font-size-2xl)}h5{font-size:var(--font-size-xl)}h6{font-size:var(--font-size-lg)}p{color:var(--text-secondary)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-lg);font-size:var(--font-size-sm);font-weight:600;border-radius:var(--radius-lg);border:none;cursor:pointer;transition:all var(--transition-base);text-decoration:none;white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:var(--text-inverse);box-shadow:var(--shadow-md)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-lg)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border-color)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover);border-color:var(--border-color-hover)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.btn-success{background:var(--color-success);color:#fff}.btn-success:hover:not(:disabled){filter:brightness(1.1)}.btn-lg{padding:var(--space-md) var(--space-xl);font-size:var(--font-size-base)}.btn-icon{padding:var(--space-sm);width:40px;height:40px}.card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);box-shadow:var(--shadow-sm);transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-glass{background:#fffc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}[data-theme=dark] .card-glass{background:#1e293bcc}.input{width:100%;padding:var(--space-sm) var(--space-md);font-size:var(--font-size-base);font-family:var(--font-family);color:var(--text-primary);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.input::placeholder{color:var(--text-tertiary)}textarea.input{resize:vertical;min-height:80px}.select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%2364748b' d='M2 4l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.toggle{position:relative;display:inline-block;width:48px;height:26px}.toggle input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:var(--bg-tertiary);border-radius:var(--radius-full);transition:var(--transition-base)}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;border-radius:50%;transition:var(--transition-base);box-shadow:var(--shadow-sm)}.toggle input:checked+.toggle-slider{background-color:var(--color-primary)}.toggle input:checked+.toggle-slider:before{transform:translate(22px)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--space-lg)}.flex{display:flex}.flex-center{display:flex;align-items:center;justify-content:center}.flex-between{display:flex;align-items:center;justify-content:space-between}.grid{display:grid}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.text-center{text-align:center}.text-gradient{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-10px)}}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-5px)}75%{transform:translate(5px)}}@keyframes confetti{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(-100vh) rotate(720deg);opacity:0}}@keyframes lineComplete{0%{transform:scale(1)}50%{transform:scale(1.1);box-shadow:0 0 30px var(--color-primary)}to{transform:scale(1)}}@keyframes winCelebration{0%{transform:scale(1) rotate(0)}25%{transform:scale(1.2) rotate(-5deg)}50%{transform:scale(1.2) rotate(5deg)}75%{transform:scale(1.2) rotate(-5deg)}to{transform:scale(1) rotate(0)}}.animate-fadeIn{animation:fadeIn .5s ease}.animate-slideUp{animation:slideUp .5s ease}.animate-pulse{animation:pulse 2s infinite}.animate-bounce{animation:bounce 1s infinite}.animate-line{animation:lineComplete .6s ease}.animate-win{animation:winCelebration 1s ease}@media(max-width:768px){h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}.container{padding:0 var(--space-md)}}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}::selection{background:var(--color-primary);color:#fff}.watermark{position:fixed;bottom:var(--space-md);right:var(--space-md);display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:#6366f11a;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-full);font-size:var(--font-size-xs);color:var(--text-tertiary);text-decoration:none;z-index:50;transition:all var(--transition-fast);opacity:.7}.watermark:hover{opacity:1;background:#6366f126;color:var(--color-primary)}.watermark-icon{width:16px;height:16px}.header{position:sticky;top:0;z-index:50;background:var(--bg-card);border-bottom:1px solid var(--border-color);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px)}.header-content{display:flex;align-items:center;justify-content:space-between;height:64px;gap:var(--space-lg)}.logo{display:flex;align-items:center;gap:var(--space-sm);text-decoration:none;color:var(--text-primary);font-weight:700;font-size:var(--font-size-xl)}.logo-icon{width:36px;height:36px}.logo-text{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav-links{display:flex;align-items:center;gap:var(--space-lg)}.nav-link{color:var(--text-secondary);font-weight:500;font-size:var(--font-size-sm);text-decoration:none;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:all var(--transition-fast)}.nav-link:hover{color:var(--text-primary);background:var(--bg-hover)}.nav-link.active{color:var(--color-primary);background:#6366f11a}.header-actions{display:flex;align-items:center;gap:var(--space-sm)}.lang-switcher{display:flex;align-items:center;gap:2px;padding:2px;background:var(--bg-tertiary);border-radius:var(--radius-md)}.lang-btn{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-base);background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;opacity:.6;transition:all var(--transition-fast)}.lang-btn:hover{opacity:.8}.lang-btn.active{background:var(--bg-card);opacity:1;box-shadow:var(--shadow-sm)}.theme-toggle{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;color:var(--text-secondary);transition:all var(--transition-fast)}.theme-toggle:hover{background:var(--bg-hover);color:var(--text-primary)}@media(max-width:768px){.nav-links,.logo-text{display:none}.header-actions{gap:var(--space-xs)}}.hero{position:relative;min-height:100vh;display:flex;align-items:center;overflow:hidden;padding-top:64px}.hero-bg{position:absolute;inset:0;z-index:-1}.hero-gradient{position:absolute;inset:0;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.15) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(139,92,246,.15) 0%,transparent 50%),var(--bg-primary)}.hero-grid{position:absolute;inset:0;background-image:linear-gradient(var(--border-color) 1px,transparent 1px),linear-gradient(90deg,var(--border-color) 1px,transparent 1px);background-size:100px 100px;opacity:.3;mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%);-webkit-mask-image:radial-gradient(ellipse at center,black 30%,transparent 70%)}.hero-content{text-align:center;padding:var(--space-3xl) 0;animation:slideUp .6s ease}.hero-badge{display:inline-flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--text-secondary);margin-bottom:var(--space-xl)}.badge-dot{width:8px;height:8px;background:var(--color-success);border-radius:50%;animation:pulse 2s infinite}.hero-title{font-size:clamp(2.5rem,8vw,4.5rem);font-weight:800;line-height:1.1;margin-bottom:var(--space-lg);letter-spacing:-.02em}.hero-subtitle{font-size:var(--font-size-xl);color:var(--text-secondary);max-width:600px;margin:0 auto var(--space-xl);line-height:1.6}.hero-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap;margin-bottom:var(--space-3xl)}.hero-preview{perspective:1000px;margin-top:var(--space-xl)}.preview-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-lg);box-shadow:var(--shadow-xl),var(--shadow-glow);max-width:300px;margin:0 auto;transform:rotateX(10deg) rotateY(-5deg);transition:transform var(--transition-slow)}.preview-card:hover{transform:rotateX(0) rotateY(0)}.preview-bingo{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-sm)}.preview-cell{aspect-ratio:1;background:var(--bg-tertiary);border-radius:var(--radius-md);border:2px solid var(--border-color);transition:all var(--transition-base)}.preview-cell.highlighted{background:var(--cell-blue);border-color:var(--color-primary)}.preview-cell.center{background:var(--cell-yellow);border-color:var(--color-accent)}.hero-wave{position:absolute;bottom:0;left:0;right:0;line-height:0}.hero-wave svg{width:100%;height:80px}.features{padding:var(--space-3xl) 0;background:var(--bg-secondary)}.section-title{text-align:center;margin-bottom:var(--space-2xl);font-size:var(--font-size-3xl)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:var(--space-lg)}.feature-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl);text-align:center;transition:all var(--transition-base)}.feature-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--accent)}.feature-icon{display:inline-flex;align-items:center;justify-content:center;width:64px;height:64px;background:linear-gradient(135deg,var(--accent),color-mix(in srgb,var(--accent) 70%,purple));border-radius:var(--radius-lg);color:#fff;margin-bottom:var(--space-md)}.feature-title{font-size:var(--font-size-lg);margin-bottom:var(--space-sm)}.feature-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:1.6}.ideas{padding:var(--space-3xl) 0;background:var(--bg-primary)}.ideas-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-lg)}.idea-card{position:relative;padding:var(--space-xl);border-radius:var(--radius-xl);background:var(--gradient);color:#fff;overflow:hidden;transition:all var(--transition-base)}.idea-card:before{content:"";position:absolute;inset:0;background:#0000001a;opacity:0;transition:opacity var(--transition-base)}.idea-card:hover{transform:translateY(-4px) scale(1.02);box-shadow:var(--shadow-xl)}.idea-card:hover:before{opacity:1}.idea-emoji{font-size:3rem;margin-bottom:var(--space-md)}.idea-title{font-size:var(--font-size-lg);margin-bottom:var(--space-sm);color:#fff}.idea-description{font-size:var(--font-size-sm);opacity:.9;color:#fff;line-height:1.6}.faq{padding:var(--space-3xl) 0;background:var(--bg-secondary)}.faq-list{max-width:700px;margin:0 auto;display:flex;flex-direction:column;gap:var(--space-md)}.faq-item{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);overflow:hidden}.faq-question{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);font-weight:600;cursor:pointer;list-style:none;transition:background var(--transition-fast)}.faq-question::-webkit-details-marker{display:none}.faq-question:hover{background:var(--bg-hover)}.faq-arrow{transition:transform var(--transition-fast);flex-shrink:0;color:var(--text-tertiary)}.faq-item[open] .faq-arrow{transform:rotate(180deg)}.faq-answer{padding:0 var(--space-lg) var(--space-lg);color:var(--text-secondary);line-height:1.7;animation:slideUp .2s ease}.about{padding:var(--space-3xl) 0;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))}.about-content{text-align:center;max-width:700px;margin:0 auto}.about .section-title{color:#fff}.about-text{color:#ffffffe6;font-size:var(--font-size-lg);line-height:1.7;margin-bottom:var(--space-xl)}.about .btn-primary{background:#fff;color:var(--color-primary)}.about .btn-primary:hover{background:#ffffffe6;transform:translateY(-2px)}.footer{background:var(--bg-primary);border-top:1px solid var(--border-color);padding:var(--space-xl) 0}.footer-content{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-md)}.footer-brand{display:flex;align-items:center;gap:var(--space-md)}.footer-brand .logo-text{font-size:var(--font-size-lg)}.footer-brand p{font-size:var(--font-size-sm)}.footer-copy{font-size:var(--font-size-sm);color:var(--text-secondary)}@media(max-width:768px){.hero{min-height:auto;padding:100px 0 60px}.hero-actions{flex-direction:column;align-items:center}.preview-card{transform:none}.footer-content{flex-direction:column;text-align:center}.footer-brand{flex-direction:column}}.boards-page{min-height:calc(100vh - 64px);padding:var(--space-xl) 0;animation:fadeIn .3s ease}.boards-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);margin-bottom:var(--space-xl);flex-wrap:wrap}.boards-title{font-size:var(--font-size-3xl);font-weight:700}.boards-actions{display:flex;gap:var(--space-sm);flex-wrap:wrap}.boards-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl);text-align:center}.empty-icon{color:var(--text-tertiary);margin-bottom:var(--space-lg);opacity:.5}.empty-text{font-size:var(--font-size-lg);color:var(--text-secondary);margin-bottom:var(--space-xl)}.empty-actions{display:flex;gap:var(--space-md);flex-wrap:wrap;justify-content:center}.import-error-toast{position:fixed;top:var(--space-xl);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--color-error);color:#fff;border-radius:var(--radius-lg);font-weight:500;box-shadow:var(--shadow-lg);z-index:200;animation:slideUp .3s ease}.boards-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-lg)}.board-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);cursor:pointer;transition:all var(--transition-base);animation:slideUp .3s ease}.board-card:hover{transform:translateY(-4px);box-shadow:var(--shadow-lg);border-color:var(--color-primary)}.board-card-header{margin-bottom:var(--space-md)}.board-card-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-xs);color:var(--text-primary)}.board-card-description{font-size:var(--font-size-sm);color:var(--text-tertiary)}.board-preview{margin-bottom:var(--space-md)}.preview-grid{display:grid;gap:4px;aspect-ratio:1}.preview-cell{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;overflow:hidden;padding:2px}.preview-cell-text{font-size:7px;color:var(--text-secondary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.board-card-footer{display:flex;align-items:center;justify-content:space-between;gap:var(--space-md);padding-top:var(--space-md);border-top:1px solid var(--border-color)}.board-card-actions{display:flex;gap:var(--space-xs)}.btn-sm{padding:var(--space-xs) var(--space-md);font-size:var(--font-size-sm)}.btn-icon-sm{padding:var(--space-xs);width:32px;height:32px}.btn-danger{color:var(--color-error)}.btn-danger:hover{background:#ef44441a;color:var(--color-error)}@media(max-width:768px){.boards-header{flex-direction:column;align-items:flex-start}.boards-actions{width:100%}.boards-actions .btn{flex:1;justify-content:center}.boards-grid{grid-template-columns:1fr}}.editor-page{min-height:calc(100vh - 64px);padding:var(--space-lg) 0;animation:fadeIn .3s ease}.editor-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-md);min-height:calc(100vh - 64px);color:var(--text-secondary)}.loading-spinner{width:24px;height:24px;border:3px solid var(--border-color);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite}.editor-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.editor-layout{display:grid;grid-template-columns:1fr 320px;gap:var(--space-xl);align-items:start}.editor-main{display:flex;flex-direction:column;gap:var(--space-lg)}.editor-title-bar{display:flex;gap:var(--space-md)}.editor-title-input{flex:1;font-size:var(--font-size-lg);font-weight:600}.bingo-board{display:grid;gap:8px;aspect-ratio:1;max-width:600px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg);box-shadow:var(--shadow-md)}.bingo-cell{aspect-ratio:1;display:flex;align-items:center;justify-content:center;padding:var(--space-sm);border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:var(--font-size-sm);text-align:center;word-break:break-word;overflow:hidden;color:var(--text-primary)}.bingo-cell:hover{border-color:var(--color-primary);transform:scale(1.02)}.bingo-cell.selected{border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f133}.bingo-cell.free-space{background:var(--cell-yellow)!important;font-weight:700;color:var(--text-primary)}.cell-text{line-height:1.2;max-height:100%;overflow:hidden}.editor-sidebar{display:flex;flex-direction:column;gap:var(--space-lg);position:sticky;top:80px}.settings-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg)}.settings-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-xs)}.settings-subtitle{font-size:var(--font-size-sm);color:var(--text-tertiary);margin-bottom:var(--space-lg)}.settings-group{margin-bottom:var(--space-md)}.settings-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-xs)}.settings-row{display:flex;align-items:center;gap:var(--space-md)}.settings-row .settings-label{margin-bottom:0}.color-picker{display:flex;gap:var(--space-sm);flex-wrap:wrap}.color-swatch{width:36px;height:36px;border-radius:var(--radius-md);border:2px solid var(--border-color);cursor:pointer;transition:all var(--transition-fast)}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--color-primary);box-shadow:0 0 0 2px #6366f14d}.cell-editor{border-color:var(--color-primary)}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl);width:90%;max-width:500px;animation:slideUp .2s ease}@media(max-width:968px){.editor-layout{grid-template-columns:1fr}.editor-sidebar{position:static;order:-1}.bingo-board{max-width:100%}}@media(max-width:480px){.editor-title-bar{flex-direction:column}.bingo-cell{font-size:10px;padding:4px}.bingo-board{padding:var(--space-sm);gap:4px}}.play-page{min-height:calc(100vh - 64px);padding:var(--space-lg) 0;position:relative;overflow:hidden;animation:fadeIn .3s ease}.play-loading{display:flex;align-items:center;justify-content:center;gap:var(--space-md);min-height:calc(100vh - 64px);color:var(--text-secondary)}.confetti-container{position:fixed;inset:0;pointer-events:none;z-index:100;overflow:hidden}.confetti-piece{position:absolute;width:10px;height:10px;top:-20px;animation:confettiFall linear forwards}@keyframes confettiFall{0%{transform:translateY(0) rotate(0);opacity:1}to{transform:translateY(100vh) rotate(720deg);opacity:0}}.win-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:150;animation:fadeIn .3s ease}.win-content{background:var(--bg-card);border-radius:var(--radius-2xl);padding:var(--space-3xl);text-align:center;box-shadow:var(--shadow-xl),var(--shadow-glow)}.win-title{font-size:var(--font-size-4xl);background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:var(--space-xl)}.win-actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.play-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);margin-bottom:var(--space-lg);flex-wrap:wrap}.play-header-left{display:flex;align-items:center;gap:var(--space-lg);flex-wrap:wrap}.play-title{font-size:var(--font-size-2xl);font-weight:600}.play-header-right{display:flex;gap:var(--space-sm);flex-wrap:wrap}.multiplayer-badge{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:#6366f11a;border:1px solid rgba(99,102,241,.2);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-primary)}.play-layout{display:flex;gap:var(--space-xl);align-items:flex-start}.play-layout.with-sidebar{display:grid;grid-template-columns:1fr 280px;gap:var(--space-xl)}.play-main{flex:1;display:flex;flex-direction:column}.play-board-container{display:flex;justify-content:center;padding:var(--space-lg) 0}.play-board{display:grid;gap:10px;width:100%;max-width:600px;aspect-ratio:1;background:var(--bg-card);border:2px solid var(--border-color);border-radius:var(--radius-2xl);padding:var(--space-lg);box-shadow:var(--shadow-lg)}.play-cell{position:relative;display:flex;align-items:center;justify-content:center;padding:var(--space-sm);background:var(--cell-color);border:3px solid var(--border-color);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);font-size:clamp(10px,2vw,14px);font-weight:500;text-align:center;overflow:hidden;color:var(--text-primary)}.play-cell:hover{transform:scale(1.03);border-color:var(--color-primary)}.play-cell:active{transform:scale(.97)}.play-cell.marked{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))!important;border-color:var(--color-primary);color:#fff}.play-cell.winning{box-shadow:0 0 20px var(--color-primary);border-color:var(--color-accent)}.play-cell.free-space{background:var(--cell-yellow)!important}.play-cell.free-space.marked{background:linear-gradient(135deg,#f59e0b,#d97706)!important}.play-cell-text{line-height:1.2;word-break:break-word;z-index:1}.cell-marker{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000001a}.cell-marker svg{width:40%;height:40%;color:#fffc}.play-progress{display:flex;justify-content:center;gap:var(--space-2xl);margin-top:var(--space-xl)}.progress-stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-xs)}.progress-label{font-size:var(--font-size-sm);color:var(--text-tertiary)}.progress-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}.winning-count{color:var(--color-primary)}.play-sidebar{display:flex;flex-direction:column;gap:var(--space-md);position:sticky;top:80px}.sidebar-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-lg)}.sidebar-title{display:flex;align-items:center;gap:var(--space-sm);font-size:var(--font-size-sm);font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-md);text-transform:uppercase;letter-spacing:.05em}.room-code-display{display:block;font-family:monospace;font-size:var(--font-size-2xl);font-weight:700;color:var(--color-primary);letter-spacing:.15em;text-align:center;padding:var(--space-md);background:#6366f11a;border-radius:var(--radius-lg)}.btn-full{width:100%}.players-list{display:flex;flex-direction:column;gap:var(--space-sm)}.player-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-tertiary);border-radius:var(--radius-md)}.player-avatar{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary),var(--color-secondary));color:#fff;font-weight:600;font-size:var(--font-size-sm);border-radius:var(--radius-md)}.player-name{font-weight:500;color:var(--text-primary)}.sidebar-stats{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.sidebar-stat{text-align:center;padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-lg)}.sidebar-stat.highlight{background:linear-gradient(135deg,var(--color-primary),var(--color-secondary))}.sidebar-stat.highlight .stat-value,.sidebar-stat.highlight .stat-label{color:#fff}.stat-value{display:block;font-size:var(--font-size-2xl);font-weight:700;color:var(--text-primary)}.stat-label{font-size:var(--font-size-xs);color:var(--text-tertiary)}.connection-dot{width:8px;height:8px;border-radius:50%;background:var(--color-error);transition:background var(--transition-base)}.connection-dot.connected{background:var(--color-success);animation:pulse 2s infinite}.toast{position:fixed;bottom:var(--space-xl);left:50%;transform:translate(-50%);display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md) var(--space-lg);background:var(--color-success);color:#fff;border-radius:var(--radius-full);font-weight:500;box-shadow:var(--shadow-lg);z-index:200}.play-cell.animate-line{animation:lineComplete .6s ease}@keyframes lineComplete{0%{transform:scale(1);box-shadow:none}50%{transform:scale(1.15);box-shadow:0 0 30px var(--color-primary)}to{transform:scale(1);box-shadow:0 0 20px var(--color-primary)}}.modal-overlay{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;animation:fadeIn .2s ease}.modal{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-xl);padding:var(--space-xl);width:90%;max-width:400px;animation:slideUp .2s ease}.modal-title{font-size:var(--font-size-xl);margin-bottom:var(--space-lg)}.modal-actions{display:flex;gap:var(--space-md);justify-content:flex-end;margin-top:var(--space-lg)}.loading-spinner-small{width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:968px){.play-layout.with-sidebar{grid-template-columns:1fr}.play-sidebar{position:static;order:-1;display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-md)}.sidebar-card{padding:var(--space-md)}}@media(max-width:768px){.play-header{flex-direction:column;align-items:flex-start}.play-header-right{width:100%}.play-header-right .btn{flex:1;justify-content:center}.play-board{padding:var(--space-sm);gap:6px}.play-cell{border-width:2px;border-radius:var(--radius-md)}.progress-value{font-size:var(--font-size-xl)}.win-content{margin:var(--space-lg);padding:var(--space-xl)}.win-title{font-size:var(--font-size-2xl)}.play-sidebar{grid-template-columns:1fr}}@media(max-width:480px){.play-cell{padding:2px;font-size:9px}.cell-marker svg{width:30%;height:30%}}
