*{margin:0;padding:0;box-sizing:border-box}body{margin:0;font-family:-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:#f7fafc;color:#2d3748}code{font-family:Monaco,Courier New,Courier,monospace}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#f7fafc}::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#a0aec0}.text-center{text-align:center}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;font-size:1.25rem;color:#718096}*:focus-visible{outline:2px solid #4299e1;outline-offset:2px}button:focus-visible{outline:2px solid #4299e1}a,button{transition:all .2s ease}.auth-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);padding:2rem 1rem}.auth-card{background:#fff;border-radius:20px;padding:3rem 2.5rem;box-shadow:0 10px 40px #00000014;max-width:480px;width:100%}.auth-logo{text-align:center;margin-bottom:2.5rem}.logo-icon{display:inline-block;margin-bottom:1.5rem}.logo-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:6px;padding:20px;background:#fff;border-radius:18px;box-shadow:0 4px 12px #0000001a}.logo-square{width:24px;height:24px;border-radius:4px}.auth-title{font-size:2.5rem;font-weight:600;color:#1a202c;margin:0 0 .5rem}.auth-subtitle{font-size:1.1rem;color:#718096;margin:0}.auth-error{background:#fee;color:#c53030;padding:.875rem 1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.95rem;border-left:3px solid #fc8181}.auth-form,.form-group{margin-bottom:1.5rem}.form-group label{display:flex;align-items:center;gap:.5rem;font-weight:500;color:#2d3748;margin-bottom:.5rem;font-size:.95rem}.label-icon{font-size:1.1rem}.form-group input{width:100%;padding:.875rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;transition:all .2s;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#4299e1;box-shadow:0 0 0 3px #4299e11a}.form-group input::placeholder{color:#a0aec0}.form-group input:disabled{background:#f7fafc;cursor:not-allowed}.btn-primary{width:100%;padding:.875rem 1rem;background:#2d3748;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover:not(:disabled){background:#1a202c;transform:translateY(-1px);box-shadow:0 4px 12px #2d37484d}.btn-primary:disabled{background:#cbd5e0;cursor:not-allowed;transform:none}.btn-google{width:100%;padding:.875rem 1rem;background:#fff;color:#2d3748;border:2px solid #e2e8f0;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.75rem}.btn-google:hover:not(:disabled){background:#f7fafc;border-color:#cbd5e0;transform:translateY(-1px);box-shadow:0 2px 8px #0000001a}.btn-google:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-divider{text-align:center;position:relative;margin:1.5rem 0}.auth-divider span{background:#fff;padding:0 1rem;color:#718096;font-size:.9rem;position:relative;z-index:1}.auth-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e2e8f0}.auth-footer{text-align:center;margin-top:1.5rem}.auth-footer p{color:#718096;font-size:.95rem;margin:0}.auth-link{color:#4299e1;text-decoration:none;font-weight:500}.auth-link:hover{text-decoration:underline}.auth-bottom-links{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:2rem;color:#718096;font-size:.9rem}.auth-bottom-links a{color:#718096;text-decoration:none;transition:color .2s}.auth-bottom-links a:hover{color:#2d3748;text-decoration:underline}.auth-bottom-links span{color:#cbd5e0}@media (max-width: 640px){.auth-card{padding:2rem 1.5rem}.auth-title{font-size:2rem}.logo-grid{gap:4px;padding:15px}.logo-square{width:20px;height:20px}}.challenges-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:80px 20px 40px}.challenges-container{max-width:1200px;margin:0 auto}.challenges-header{text-align:center;margin-bottom:50px;color:#fff}.challenges-header h1{font-size:3rem;font-weight:700;margin-bottom:10px;text-shadow:2px 2px 4px rgba(0,0,0,.2)}.challenges-header p{font-size:1.2rem;opacity:.9}.challenges-stats{display:flex;justify-content:center;gap:30px;margin:30px 0;flex-wrap:wrap}.stat-card{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:15px;padding:20px 30px;text-align:center;border:1px solid rgba(255,255,255,.2)}.stat-card .stat-value{font-size:2rem;font-weight:700;color:#fff;display:block}.stat-card .stat-label{font-size:.9rem;color:#fffc;text-transform:uppercase;letter-spacing:1px}.challenge-section{margin-bottom:50px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:25px}.section-header h2{font-size:1.8rem;color:#fff;font-weight:600}.upgrade-badge{background:linear-gradient(135deg,#f093fb,#f5576c);color:#fff;padding:8px 20px;border-radius:20px;font-size:.9rem;font-weight:600;text-decoration:none;transition:transform .2s}.upgrade-badge:hover{transform:translateY(-2px)}.challenges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:25px}.challenge-card{background:#fff;border-radius:20px;padding:25px;box-shadow:0 10px 30px #0003;transition:all .3s ease;position:relative;overflow:hidden}.challenge-card:hover{transform:translateY(-5px);box-shadow:0 15px 40px #0000004d}.challenge-card.locked{opacity:.6;cursor:not-allowed}.challenge-card.locked:after{content:"🔒";position:absolute;top:20px;right:20px;font-size:2rem}.challenge-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:15px}.challenge-date{font-size:.9rem;color:#666;font-weight:500}.challenge-difficulty{padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.challenge-difficulty.easy{background:#e8f5e9;color:#2e7d32}.challenge-difficulty.medium{background:#fff3e0;color:#ef6c00}.challenge-difficulty.hard{background:#ffebee;color:#c62828}.challenge-difficulty.expert{background:#f3e5f5;color:#6a1b9a}.challenge-title{font-size:1.4rem;font-weight:700;color:#333;margin-bottom:10px}.challenge-description{color:#666;font-size:.95rem;line-height:1.6;margin-bottom:20px}.challenge-info{display:flex;gap:20px;margin-bottom:20px;padding:15px;background:#f8f9fa;border-radius:10px}.challenge-info-item{display:flex;flex-direction:column}.challenge-info-item .label{font-size:.8rem;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:5px}.challenge-info-item .value{font-size:1.1rem;font-weight:600;color:#333}.challenge-status{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding:12px;border-radius:10px;font-size:.9rem;font-weight:600}.challenge-status.completed{background:#e8f5e9;color:#2e7d32}.challenge-status.in-progress{background:#fff3e0;color:#ef6c00}.challenge-status.available{background:#e3f2fd;color:#1565c0}.challenge-actions{display:flex;gap:10px}.btn-challenge{flex:1;padding:12px 20px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;text-align:center;text-decoration:none;display:inline-block}.btn-challenge.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.btn-challenge.primary:hover{transform:translateY(-2px);box-shadow:0 5px 15px #667eea66}.btn-challenge.secondary{background:#f0f0f0;color:#333}.btn-challenge.secondary:hover{background:#e0e0e0}.btn-challenge:disabled{opacity:.5;cursor:not-allowed}.no-challenges{text-align:center;padding:60px 20px;color:#fff}.no-challenges-icon{font-size:4rem;margin-bottom:20px}.no-challenges h3{font-size:1.5rem;margin-bottom:10px}.no-challenges p{font-size:1rem;opacity:.8}.challenges-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;color:#fff}.challenges-loading .spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}.challenges-loading p{margin-top:20px;font-size:1.1rem}@keyframes spin{to{transform:rotate(360deg)}}.challenge-card.today{border:3px solid #ffd700;box-shadow:0 0 20px #ffd7004d}.challenge-card.today:before{content:"⭐ TODAY'S CHALLENGE";position:absolute;top:0;left:0;right:0;background:linear-gradient(135deg,gold,#ffed4e);color:#333;padding:6px;font-size:.8rem;font-weight:700;text-align:center;letter-spacing:1px}.challenge-card.today .challenge-card-header{margin-top:20px}@media (max-width: 768px){.challenges-page{padding:60px 15px 30px}.challenges-header h1{font-size:2rem}.challenges-header p{font-size:1rem}.challenges-stats{gap:15px}.stat-card{padding:15px 20px}.stat-card .stat-value{font-size:1.5rem}.challenges-grid{grid-template-columns:1fr}.section-header{flex-direction:column;align-items:flex-start;gap:10px}}.challenge-player-page{min-height:100vh;background:#f5f5f5;display:flex;flex-direction:column}.player-header{background:#fff;padding:20px 30px;box-shadow:0 2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.player-header-left{display:flex;align-items:center;gap:20px}.btn-back{padding:10px 20px;background:#f0f0f0;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-back:hover{background:#e0e0e0}.player-title h2{font-size:1.5rem;color:#333;margin-bottom:5px}.player-title p{font-size:.9rem;color:#666}.player-header-right{display:flex;align-items:center;gap:20px}.challenge-timer{display:flex;flex-direction:column;align-items:center;padding:15px 25px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;color:#fff}.challenge-timer .timer-label{font-size:.8rem;text-transform:uppercase;letter-spacing:1px;opacity:.9;margin-bottom:5px}.challenge-timer .timer-value{font-size:2rem;font-weight:700;font-family:Courier New,monospace}.challenge-timer.warning .timer-value{color:#ffeb3b}.challenge-timer.danger .timer-value{color:#ff5252}.challenge-instructions{background:#fff;padding:20px;margin:20px;border-radius:12px;box-shadow:0 2px 10px #0000001a}.challenge-instructions h3{font-size:1.2rem;color:#333;margin-bottom:10px}.challenge-instructions p{color:#666;line-height:1.6}.allowed-shapes{display:flex;gap:10px;margin-top:15px}.shape-badge{padding:6px 15px;background:#e3f2fd;color:#1565c0;border-radius:20px;font-size:.85rem;font-weight:600}.challenge-canvas-container{flex:1;position:relative;background:#fff;margin:20px;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.challenge-actions-panel{background:#fff;padding:20px 30px;box-shadow:0 -2px 10px #0000001a;display:flex;justify-content:space-between;align-items:center}.actions-left,.actions-right{display:flex;gap:10px}.btn-action{padding:12px 25px;border:none;border-radius:10px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-action.view-solution{background:#ff9800;color:#fff}.btn-action.view-solution:hover{background:#f57c00;transform:translateY(-2px)}.btn-action.submit{background:linear-gradient(135deg,#4caf50,#45a049);color:#fff}.btn-action.submit:hover{transform:translateY(-2px);box-shadow:0 5px 15px #4caf5066}.btn-action.leaderboard{background:#2196f3;color:#fff}.btn-action.leaderboard:hover{background:#1976d2}.btn-action:disabled{opacity:.5;cursor:not-allowed}.solution-viewer{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .3s}.solution-viewer-content{background:#fff;border-radius:20px;padding:30px;max-width:800px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.solution-viewer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.solution-viewer-header h2{font-size:1.8rem;color:#333}.btn-close{background:none;border:none;font-size:2rem;cursor:pointer;color:#666;transition:color .2s}.btn-close:hover{color:#333}.solution-warning{background:#fff3e0;border-left:4px solid #ff9800;padding:15px;margin-bottom:20px;border-radius:8px}.solution-warning p{color:#e65100;font-weight:600;margin:0}.solution-canvas{border:2px solid #e0e0e0;border-radius:12px;margin:20px 0}.solution-instructions{margin-top:20px}.solution-instructions h3{font-size:1.2rem;color:#333;margin-bottom:10px}.solution-instructions ol{padding-left:20px;color:#666;line-height:1.8}.leaderboard-page{min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);padding:80px 20px 40px}.leaderboard-container{max-width:1000px;margin:0 auto;background:#fff;border-radius:20px;padding:40px;box-shadow:0 20px 60px #0000004d}.leaderboard-header{text-align:center;margin-bottom:40px}.leaderboard-header h1{font-size:2.5rem;color:#333;margin-bottom:10px}.leaderboard-header p{color:#666;font-size:1.1rem}.leaderboard-tabs{display:flex;gap:10px;margin-bottom:30px;border-bottom:2px solid #e0e0e0}.leaderboard-tab{padding:12px 30px;background:none;border:none;font-size:1rem;font-weight:600;color:#666;cursor:pointer;transition:all .2s;border-bottom:3px solid transparent}.leaderboard-tab.active{color:#667eea;border-bottom-color:#667eea}.leaderboard-tab:hover{color:#667eea}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table th{text-align:left;padding:15px;background:#f8f9fa;color:#666;font-weight:600;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px}.leaderboard-table td{padding:15px;border-bottom:1px solid #e0e0e0}.leaderboard-table tr:hover{background:#f8f9fa}.leaderboard-table tr.current-user{background:#e3f2fd;font-weight:600}.rank-medal{font-size:1.5rem}.player-info{display:flex;align-items:center;gap:12px}.player-avatar{width:40px;height:40px;border-radius:50%;background:#667eea;color:#fff;display:flex;align-items:center;justify-content:center;font-weight:600}.player-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.player-name{font-weight:600;color:#333}.completion-time{font-family:Courier New,monospace;font-weight:600;color:#667eea}.completion-date{color:#999;font-size:.9rem}.leaderboard-empty{text-align:center;padding:60px 20px}.leaderboard-empty-icon{font-size:4rem;margin-bottom:20px}.leaderboard-empty h3{font-size:1.5rem;color:#333;margin-bottom:10px}.leaderboard-empty p{color:#666}.connection-indicator{position:fixed;bottom:20px;left:20px;display:flex;align-items:center;gap:.75rem;background:#fff;padding:.75rem 1.25rem;border-radius:12px;box-shadow:0 4px 12px #00000026;z-index:1000;transition:opacity .3s ease,transform .3s ease;font-size:.9rem;font-weight:500}.connection-indicator.visible{opacity:1;transform:translateY(0)}.connection-indicator.hidden{opacity:0;transform:translateY(10px);pointer-events:none}.status-icon{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:.85rem;flex-shrink:0}.status-text{color:#2d3748;white-space:nowrap}.status-connected{border-left:4px solid #10b981}.status-connected .status-icon{animation:pulse-green 2s ease-in-out infinite}.status-connecting{border-left:4px solid #f59e0b}.status-connecting .status-icon{animation:spin 1s linear infinite}.status-disconnected{border-left:4px solid #ef4444}.status-disconnected .status-icon{animation:pulse-red 1s ease-in-out infinite}@keyframes pulse-green{0%,to{box-shadow:0 0 #10b98166}50%{box-shadow:0 0 0 6px #10b98100}}@keyframes pulse-red{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 6px #ef444400}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (max-width: 640px){.connection-indicator{bottom:15px;left:15px;padding:.625rem 1rem;font-size:.85rem}.status-icon{width:20px;height:20px;font-size:.75rem}}.chat-container{position:fixed;bottom:20px;right:20px;width:380px;max-width:calc(100vw - 40px);background:#fff;border-radius:16px;box-shadow:0 8px 32px #00000026;display:flex;flex-direction:column;z-index:1000;transition:all .3s ease}.chat-container.closed{height:56px}.chat-container.open{height:500px;max-height:calc(100vh - 100px)}.chat-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:16px 16px 0 0;cursor:pointer}.chat-title{display:flex;align-items:center;gap:10px;font-weight:600;font-size:15px}.ai-icon{font-size:20px}.chat-toggle{background:#fff3;border:none;color:#fff;width:28px;height:28px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:20px;font-weight:700;transition:background .2s ease}.chat-toggle:hover{background:#ffffff4d}.chat-messages{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:12px;background:#f8f9fa}.chat-messages::-webkit-scrollbar{width:6px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:#cbd5e0;border-radius:3px}.chat-messages::-webkit-scrollbar-thumb:hover{background:#a0aec0}.chat-message{display:flex;flex-direction:column;max-width:85%;animation:messageSlideIn .3s ease}@keyframes messageSlideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.user-message{align-self:flex-end}.ai-message{align-self:flex-start}.message-content{padding:10px 14px;border-radius:16px;word-wrap:break-word;line-height:1.5;font-size:14px}.user-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-bottom-right-radius:4px}.ai-message .message-content{background:#fff;color:#2d3748;border-bottom-left-radius:4px;box-shadow:0 2px 4px #0000000d}.message-timestamp{font-size:11px;color:#718096;margin-top:4px;padding:0 4px}.user-message .message-timestamp{text-align:right}.ai-message .message-timestamp{text-align:left}.ai-status{display:flex;align-items:center;gap:8px;padding:10px 14px;border-radius:16px;background:#fff;box-shadow:0 2px 4px #0000000d;max-width:85%;align-self:flex-start;animation:messageSlideIn .3s ease}.status-icon{font-size:16px}.status-text{font-size:13px;color:#4a5568;font-style:italic}.ai-status-error{background:#fed7d7;color:#c53030}.typing-indicator{display:flex;gap:4px;margin-left:auto}.typing-indicator span{width:6px;height:6px;background:#718096;border-radius:50%;animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{transform:translateY(0);opacity:.5}30%{transform:translateY(-8px);opacity:1}}.chat-input-container{display:flex;gap:8px;padding:12px;background:#fff;border-top:1px solid #e2e8f0;border-radius:0 0 16px 16px}.chat-input{flex:1;padding:10px 14px;border:1px solid #e2e8f0;border-radius:20px;font-size:14px;outline:none;transition:border-color .2s ease,box-shadow .2s ease}.chat-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.chat-input:disabled{background:#f7fafc;cursor:not-allowed}.chat-send-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;width:40px;height:40px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:transform .2s ease,box-shadow .2s ease}.chat-send-button:hover:not(:disabled){transform:scale(1.05);box-shadow:0 4px 12px #667eea66}.chat-send-button:active:not(:disabled){transform:scale(.95)}.chat-send-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.chat-container{width:calc(100vw - 40px);right:20px;bottom:20px}.chat-container.open{height:400px}}@media (max-width: 480px){.chat-container{width:calc(100vw - 20px);right:10px;bottom:10px}.chat-container.open{height:60vh;max-height:500px}.message-content{font-size:13px}}.canvas-wrapper{display:flex;flex-direction:column;height:100%;background:#f8fafc}.canvas-toolbar{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;background:#fff;border-bottom:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d;flex-wrap:nowrap;overflow-x:auto}.toolbar-group{display:flex;align-items:center;gap:.5rem;flex-wrap:nowrap}.toolbar-divider{width:1px;height:32px;background:#e2e8f0}.tool-btn{width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s;color:#64748b;flex:0 0 auto}.tool-btn:hover{background:#f1f5f9;border-color:#cbd5e0;transform:translateY(-2px)}.tool-btn.active{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.shape-icon{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:6px;color:#fff;font-size:1.2rem;font-weight:700}.zoom-controls{display:flex;align-items:center;gap:.25rem;background:#f8fafc;border:2px solid #e2e8f0;border-radius:8px;padding:.25rem}.zoom-controls button{width:32px;height:32px;background:#fff;border:1px solid #e2e8f0;border-radius:6px;cursor:pointer;font-size:1.1rem;color:#64748b;transition:all .2s}.zoom-controls button:hover{background:#f1f5f9;color:#3b82f6}.zoom-controls span{min-width:60px;text-align:center;font-size:.875rem;font-weight:600;color:#475569;padding:0 .5rem}.btn-reset,.btn-clear{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-weight:500;font-size:.875rem;color:#475569;transition:all .2s}.btn-reset:hover{background:#eff6ff;border-color:#3b82f6;color:#3b82f6}.btn-clear{color:#dc2626}.btn-clear:hover{background:#fef2f2;border-color:#dc2626}.btn-undo,.btn-redo{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:#fff;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;font-weight:500;font-size:.875rem;color:#3b82f6;transition:all .2s}.btn-undo:hover:not(:disabled),.btn-redo:hover:not(:disabled){background:#eff6ff;border-color:#3b82f6}.btn-undo:disabled,.btn-redo:disabled{opacity:.4;cursor:not-allowed;color:#94a3b8;border-color:#e2e8f0}.canvas-container{flex:1;position:relative;overflow:hidden;background:#f1f5f9}.main-canvas{display:block;width:100%;height:100%;cursor:crosshair}.main-canvas.panning{cursor:grab}.main-canvas.panning:active{cursor:grabbing}.canvas-instructions{position:absolute;bottom:1rem;left:1rem;background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid #e2e8f0;border-radius:12px;padding:1rem 1.25rem;box-shadow:0 4px 6px #0000000d;font-size:.875rem;color:#64748b;pointer-events:none}.canvas-instructions p{margin:.25rem 0;line-height:1.6}.canvas-instructions strong{color:#1e293b;font-weight:600}.grab-mode-indicator{position:absolute;top:1rem;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:.75rem 1.5rem;border-radius:12px;box-shadow:0 4px 12px #10b9814d;font-size:.875rem;font-weight:600;display:flex;flex-direction:column;align-items:center;gap:.25rem;pointer-events:none;animation:slideDown .3s ease-out;z-index:100}.grab-mode-indicator span{font-size:1rem}.grab-mode-indicator small{font-size:.75rem;opacity:.9;font-weight:400}@keyframes slideDown{0%{opacity:0;transform:translate(-50%) translateY(-10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.canvas-loading{display:flex;align-items:center;justify-content:center;height:100%;font-size:1.1rem;color:#64748b}@media (max-width: 992px){.tool-btn{width:36px;height:36px}.shape-icon{width:24px;height:24px;font-size:1rem}}@media (max-width: 768px){.canvas-toolbar{padding:.5rem;gap:.5rem;flex-wrap:nowrap}.tool-btn{width:28px;height:28px}.shape-icon{width:20px;height:20px;font-size:.9rem}.zoom-controls span{min-width:50px;font-size:.75rem}.btn-reset span,.btn-clear span{display:none}.canvas-instructions{font-size:.75rem;padding:.75rem}}@media (max-width: 576px){.canvas-toolbar{padding:.4rem;gap:.4rem}.tool-btn{width:22px;height:22px;border-width:1px}.shape-icon{width:16px;height:16px;font-size:.8rem}.zoom-controls button{width:26px;height:26px}.zoom-controls span{min-width:44px;font-size:.7rem}}.canvas-wrapper{animation:fadeIn .3s ease}.context-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:998}.context-menu{position:fixed;background:#fff;border:1px solid #e2e8f0;border-radius:12px;box-shadow:0 10px 25px #00000026;padding:.5rem;min-width:200px;z-index:999;animation:contextMenuIn .15s ease}@keyframes contextMenuIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu-section{padding:.5rem}.context-menu-title{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.color-palette{display:grid;grid-template-columns:repeat(4,1fr);gap:.5rem}.color-btn{width:36px;height:36px;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.color-btn:hover{transform:scale(1.1);border-color:#94a3b8;box-shadow:0 4px 8px #0000001a}.context-menu-divider{height:1px;background:#e2e8f0;margin:.5rem 0}.context-menu-item{width:100%;display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#fff;border:none;border-radius:8px;cursor:pointer;font-size:.875rem;font-weight:500;color:#1e293b;text-align:left;transition:all .2s}.context-menu-item:hover{background:#f8fafc;color:#3b82f6}.context-menu-item span{font-size:1.1rem}.puzzle-container{width:100%;height:100%;display:flex;flex-direction:column;background:linear-gradient(135deg,#f5f7fa,#c3cfe2);overflow:hidden}.shapes-palette{display:block;background:#fff;padding:1rem 1.5rem;border-bottom:2px solid #e2e8f0;box-shadow:0 4px 6px #0000000d;flex-shrink:0}@media (max-width: 768px){.shapes-palette{padding:.75rem 1rem}}.shapes-palette h3{margin:0 0 .75rem;font-size:1.1rem;color:#2d3748;font-weight:600}.shapes-palette-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(44px,1fr));gap:.5rem;max-height:150px;overflow-y:auto}.shape-button{position:relative;padding:.25rem;border:2px solid rgba(0,0,0,.15);border-radius:8px;cursor:pointer;transition:all .2s ease;color:#fff;font-weight:700;font-size:1rem;text-shadow:0 2px 4px rgba(0,0,0,.2);width:100%;aspect-ratio:1 / 1;display:grid;place-items:center;box-shadow:0 2px 4px #0000001a}.shape-button:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0003;border-color:#0000004d}.shape-button:active{transform:translateY(0);box-shadow:0 1px 2px #0000001a}.shape-button.placed{border-style:dashed;cursor:pointer}.shape-button.active{border-width:3px;border-color:gold;box-shadow:0 0 12px #ffd70080}.shape-label{font-size:1rem;letter-spacing:.5px}.placed-indicator{position:absolute;top:4px;right:4px;background:#0000004d;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;font-size:14px}.puzzle-canvas{flex:1;position:relative;overflow:hidden;min-height:0;display:flex;align-items:center;justify-content:center}.zoom-controls{position:absolute;top:20px;right:20px;display:flex;gap:.5rem;z-index:100;background:#fff;padding:.5rem;border-radius:8px;box-shadow:0 2px 8px #0000001a}@media (max-width: 640px){.zoom-controls{top:12px;right:12px;z-index:1200}}.zoom-btn{width:40px;height:40px;border:2px solid #667eea;border-radius:6px;background:#fff;color:#667eea;font-size:1.2rem;font-weight:700;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.zoom-btn:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.zoom-btn:active{transform:translateY(0)}.zoom-reset{width:auto;min-width:60px;padding:0 .75rem;font-size:.9rem}.puzzle-canvas::-webkit-scrollbar{width:10px;height:10px}.puzzle-canvas::-webkit-scrollbar-track{background:#0000000d;border-radius:5px}.puzzle-canvas::-webkit-scrollbar-thumb{background:#667eea80;border-radius:5px}.puzzle-canvas::-webkit-scrollbar-thumb:hover{background:#667eeab3}.puzzle-grid{pointer-events:none;-webkit-user-select:none;user-select:none}.grid-square{box-sizing:border-box}.puzzle-instructions{background:#fff;border-top:2px solid #e2e8f0;box-shadow:0 -4px 6px #0000000d;flex-shrink:0;transition:all .3s ease}.puzzle-instructions.collapsed{padding:0}.puzzle-instructions.expanded{padding:.75rem 1.5rem}.instructions-header{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1.5rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .2s ease}.puzzle-instructions.expanded .instructions-header{padding:0 0 .5rem;cursor:pointer}.instructions-header:hover{background:#667eea0d;animation:bounce .6s ease}@keyframes bounce{0%,to{transform:translateY(0)}25%{transform:translateY(-5px)}50%{transform:translateY(0)}75%{transform:translateY(-3px)}}.instructions-header h3{margin:0;font-size:1rem;color:#2d3748;font-weight:600}.instructions-toggle-btn{background:transparent;border:none;font-size:1.2rem;color:#667eea;cursor:pointer;padding:.25rem .5rem;transition:all .2s ease}.instructions-toggle-btn:hover{color:#764ba2;transform:scale(1.2)}.instruction-grid{display:flex;flex-wrap:wrap;gap:.75rem;margin-bottom:.5rem}.instruction-item{padding:.5rem .75rem;background:#f7fafc;border-radius:6px;border:1px solid #e2e8f0;font-size:.8rem;color:#4a5568;flex:1;min-width:180px}.instruction-item strong{color:#2d3748;display:inline;margin-right:.25rem}.instruction-item kbd{display:inline-block;padding:.2rem .4rem;background:#667eea;color:#fff;border-radius:4px;font-family:Courier New,monospace;font-weight:700;font-size:.85em;box-shadow:0 2px 4px #667eea4d}.active-shape-indicator{padding:.5rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:6px;text-align:center;font-weight:500;font-size:.875rem;box-shadow:0 2px 4px #667eea4d;animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.02)}}.active-shape-indicator span{font-size:1.1em;text-shadow:0 2px 4px rgba(0,0,0,.2)}.shapes-palette-grid::-webkit-scrollbar{height:8px}.shapes-palette-grid::-webkit-scrollbar-track{background:#0000000d;border-radius:4px}.shapes-palette-grid::-webkit-scrollbar-thumb{background:#667eea80;border-radius:4px}.shapes-palette-grid::-webkit-scrollbar-thumb:hover{background:#667eeab3}@media (max-width: 768px){.shapes-palette-grid{grid-template-columns:repeat(auto-fill,minmax(44px,1fr));max-height:120px}.shape-button{min-height:44px;padding:.5rem}.shape-label{font-size:1rem}.puzzle-instructions{padding:1rem}.instruction-grid{grid-template-columns:1fr;gap:.5rem}.puzzle-instructions h3{font-size:1rem}}@media (min-width: 1024px){.shapes-palette-grid{grid-template-columns:repeat(auto-fill,minmax(72px,1fr))}.shape-button{min-height:64px}}@media (min-width: 1400px){.shapes-palette-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}}.collab-container{display:flex;flex-direction:column;height:100vh;background:#e8f1f8}.stats-bar{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:.75rem 1rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 6px #0000001a;flex-wrap:nowrap}.app-title{font-size:1.75rem;font-weight:700;margin:0;color:#fff}.app-subtitle{font-size:.875rem;opacity:.9;margin:.25rem 0 0;color:#ffffffe6}.stats-container{display:flex;gap:.5rem;margin-left:auto;flex:0 1 auto;flex-wrap:nowrap;justify-content:flex-end;overflow-x:auto;-webkit-overflow-scrolling:touch}.stat-card{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);border-radius:10px;padding:.5rem .75rem;min-width:auto;display:flex;align-items:center;gap:.5rem;transition:all .3s}.stat-card:hover{background:#ffffff40;transform:translateY(-2px)}.stat-card.cta{background:#fbbf2433;border-color:#fbbf2480;cursor:pointer;padding:.6rem 1rem;white-space:nowrap;flex:0 0 auto}.stat-card.cta:hover{background:#fbbf244d}.stat-icon{font-size:1.75rem}.stat-content{display:flex;flex-direction:column;gap:.125rem;white-space:nowrap}.stat-value{font-size:1.25rem;font-weight:700;color:#fff}.stat-label{font-size:.75rem;opacity:.85;text-transform:uppercase;letter-spacing:.5px;color:#ffffffe6}.header-actions{display:flex;gap:.5rem;margin-left:.75rem;flex:0 0 auto}.btn-header-action{width:44px;height:44px;background:#fff3;border:1px solid rgba(255,255,255,.3);border-radius:10px;cursor:pointer;font-size:1.25rem;transition:all .2s;display:flex;align-items:center;justify-content:center}.btn-header-action:hover{background:#ffffff4d;transform:scale(1.05)}.btn-menu{display:none}.workspace-header{background:#fff;border-bottom:1px solid #e2e8f0;padding:.75rem 2rem;box-shadow:0 1px 3px #0000000d;display:flex;align-items:center;justify-content:space-between;gap:2rem}.workspace-title{font-size:1.125rem;font-weight:600;color:#1a202c;margin:0}.canvas-type-selector{display:flex;gap:.5rem;background:#f7fafc;padding:.25rem;border-radius:8px;border:1px solid #e2e8f0}.canvas-type-btn{padding:.5rem 1rem;border:none;background:transparent;color:#4a5568;font-size:.875rem;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.canvas-type-btn:hover{background:#667eea1a;color:#667eea}.canvas-type-btn.active{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 2px 4px #667eea4d}.header-left{display:flex;align-items:center;gap:1.5rem}.logo-small{display:flex;align-items:center}.logo-grid-small{display:grid;grid-template-columns:repeat(3,1fr);gap:3px;padding:6px;background:#f7fafc;border-radius:8px}.logo-square-small{width:12px;height:12px;border-radius:2px}.collab-header h1{font-size:1.5rem;font-weight:600;color:#1a202c;margin:0}.session-info{display:flex;align-items:center;gap:.5rem;background:#f7fafc;padding:.5rem 1rem;border-radius:8px}.session-label{font-size:.875rem;color:#718096;font-weight:500}.session-id{font-family:Monaco,Courier New,monospace;font-size:.95rem;color:#2d3748;font-weight:600;background:#fff;padding:.25rem .5rem;border-radius:4px}.btn-copy{background:none;border:none;cursor:pointer;font-size:1.2rem;padding:.25rem;opacity:.7;transition:opacity .2s}.btn-copy:hover{opacity:1}.header-right,.user-info{display:flex;align-items:center;gap:1rem}.user-name{font-size:.95rem;color:#2d3748;font-weight:500}.btn-logout{padding:.5rem 1rem;background:#e2e8f0;color:#2d3748;border:none;border-radius:6px;cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.btn-logout:hover{background:#cbd5e0}.collab-content{display:flex;flex:1;overflow:hidden}.presence-panel{width:280px;background:#fff;border-right:1px solid #e2e8f0;padding:1.5rem;overflow-y:auto;transition:all .3s ease}.presence-panel.collapsed{width:60px;padding:1rem .5rem}.presence-panel-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.presence-panel.collapsed .presence-panel-header{flex-direction:column;gap:.5rem}.presence-panel h3{font-size:1rem;font-weight:600;color:#2d3748;margin:0;white-space:nowrap}.presence-panel.collapsed h3{writing-mode:vertical-rl;text-orientation:mixed;font-size:.85rem}.user-list{display:flex;flex-direction:column;gap:.75rem}.user-item{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:#f7fafc;border-radius:8px;transition:background .2s}.user-item:hover{background:#edf2f7}.user-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:.95rem;flex-shrink:0}.user-item-name{flex:1;font-size:.95rem;color:#2d3748;font-weight:500}.user-badge{font-size:.75rem;color:#718096;background:#fff;padding:.125rem .5rem;border-radius:4px;font-weight:500}.no-users{color:#a0aec0;font-size:.875rem;text-align:center;padding:2rem 0;line-height:1.6}.canvas-area{flex:1;display:flex;overflow:auto;background:#f1f5f9}.objects-panel{width:280px;background:#fff;border-left:1px solid #e2e8f0;padding:1.5rem;overflow-y:auto;transition:all .3s ease}.objects-panel.collapsed{width:60px;padding:1rem .5rem}.objects-panel.collapsed .objects-panel-header{justify-content:center}.objects-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.objects-panel h3{font-size:1rem;font-weight:600;color:#2d3748;margin:0}.panel-collapse-btn{background:transparent;border:none;border-radius:6px;padding:.4rem .6rem;cursor:pointer;font-size:1.2rem;color:#667eea;transition:all .2s ease;flex-shrink:0;line-height:1}.panel-collapse-btn:hover{color:#764ba2;transform:scale(1.2);background:#667eea1a}.objects-panel.collapsed .panel-collapse-btn{transform:rotate(0)}.objects-panel.collapsed h3{display:none}.puzzle-objects-panel{background:#fff;border-left:1px solid #e2e8f0;padding:1.5rem;overflow-y:auto;transition:all .3s ease;display:flex;flex-direction:column}.puzzle-objects-panel.state-collapsed{width:60px;padding:1rem .5rem}.puzzle-objects-panel.state-buttons{width:min(10vw,160px);padding:1rem}.puzzle-objects-panel.state-expanded{width:320px;padding:1.5rem}.puzzle-panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-shrink:0}.puzzle-panel-header h3{font-size:1.1rem;font-weight:600;color:#2d3748;margin:0}.puzzle-shapes-section{margin-bottom:1.5rem;flex-shrink:0}.puzzle-shapes-section h4{font-size:.85rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem}.puzzle-shape-buttons{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem}.puzzle-objects-panel.state-buttons .puzzle-shape-buttons{grid-template-columns:1fr}.puzzle-shape-btn{padding:.75rem;border:2px solid rgba(0,0,0,.2);border-radius:8px;color:#fff;font-weight:700;font-size:1.1rem;cursor:pointer;transition:all .2s ease;min-height:50px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #00000026;text-shadow:0 2px 4px rgba(0,0,0,.2)}.puzzle-shape-btn:hover{transform:translateY(-2px);box-shadow:0 4px 8px #667eea4d}.puzzle-shape-btn.placed{border-style:dashed;opacity:.7}.puzzle-objects-section{flex:1;overflow-y:auto;min-height:0}.puzzle-objects-section h4{font-size:.85rem;font-weight:600;color:#667eea;text-transform:uppercase;letter-spacing:.5px;margin:0 0 .75rem}.puzzle-objects-panel.state-collapsed .puzzle-shapes-section,.puzzle-objects-panel.state-collapsed .puzzle-objects-section{display:none}.objects-message{text-align:center;color:#a0aec0;padding:2rem 0;font-size:.875rem;line-height:1.6}.objects-message p{margin:.5rem 0}.objects-list{display:flex;flex-direction:column;gap:.5rem}.object-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;transition:all .2s;cursor:pointer}.object-item:hover{background:#e0f2fe;border-color:#0ea5e9;transform:translate(4px);box-shadow:0 2px 8px #0ea5e933}.object-color-indicator{width:16px;height:16px;border-radius:4px;border:2px solid #e2e8f0;flex-shrink:0}.object-info{flex:1;min-width:0}.object-name{font-size:.8125rem;font-weight:600;color:#1e293b;margin:0}.object-meta{font-size:.75rem;color:#64748b}.creator-avatar{width:24px;height:24px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:700;color:#fff;flex-shrink:0;cursor:help;border:2px solid white;box-shadow:0 2px 4px #0000001a;transition:transform .2s}.creator-avatar:hover{transform:scale(1.2)}.sub-object-item{background:linear-gradient(to right,#f1f5f9,#f8fafc 20%);border-left:3px solid #cbd5e1;margin-left:.5rem;font-size:.75rem}.sub-object-item:hover{background:linear-gradient(to right,#e0f2fe,#f0f9ff 20%);border-left-color:#0ea5e9;box-shadow:0 2px 8px #0ea5e926}.history-log-item{display:flex;gap:1rem;padding:1rem;background:#fff;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s}.history-log-item:hover{background:#f8fafc;border-color:#cbd5e1;transform:translate(4px)}.history-log-icon{font-size:1.5rem;flex-shrink:0}.history-log-details{flex:1;min-width:0}.history-log-action{font-weight:600;color:#1e293b;margin-bottom:.25rem}.history-log-meta{display:flex;align-items:center;gap:.5rem;font-size:.75rem;color:#64748b}.history-log-user{font-weight:500;color:#3b82f6}.history-log-separator{color:#cbd5e1}.history-log-time{color:#94a3b8}.welcome-message{text-align:center;max-width:600px}.welcome-message h2{font-size:2rem;color:#1a202c;margin:0 0 .5rem}.welcome-message>p{color:#718096;font-size:1.1rem;margin:0 0 2rem}.session-share-box{background:#fff;border:2px solid #e2e8f0;border-radius:12px;padding:2rem;margin:2rem 0}.session-share-box h3{font-size:1.25rem;color:#2d3748;margin:0 0 1rem}.session-share-box h3 code{color:#4299e1;background:#ebf8ff;padding:.25rem .5rem;border-radius:4px}.session-share-box>p{color:#718096;margin:0 0 1rem}.share-link-box{display:flex;gap:.5rem}.share-link-box input{flex:1;padding:.75rem 1rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.95rem;font-family:Monaco,Courier New,monospace}.share-link-box input:focus{outline:none;border-color:#4299e1}.btn-copy-large{padding:.75rem 1.5rem;background:#4299e1;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.btn-copy-large:hover{background:#3182ce;transform:translateY(-1px)}.btn-new-session{padding:.75rem 1.5rem;background:#10b981;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;white-space:nowrap}.btn-new-session:hover{background:#059669;transform:translateY(-1px)}.btn-history{padding:.75rem 1.5rem;background:#8b5cf6;color:#fff;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s;white-space:nowrap}.btn-history:hover{background:#7c3aed;transform:translateY(-1px)}.connection-status{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:2rem;color:#718096;font-size:.875rem}.status-dot{width:10px;height:10px;border-radius:50%}.status-connected{background:#10b981;box-shadow:0 0 8px #10b98180}.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}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal-content{background:#fff;border-radius:12px;max-width:600px;width:90%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;animation:slideUp .3s ease}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid #e2e8f0}.modal-header h2{margin:0;font-size:1.5rem;color:#1a202c;font-weight:600}.modal-close{background:none;border:none;font-size:2rem;color:#718096;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .2s}.modal-close:hover{background:#edf2f7;color:#2d3748}.modal-body{padding:1.5rem;overflow-y:auto;flex:1}@media (max-width: 992px){.stats-bar{padding:.75rem 1rem}.app-subtitle{display:none}.stat-card{padding:.5rem .75rem;gap:.5rem}.stat-icon{font-size:1.25rem}.stat-value{font-size:1rem}}.no-history{text-align:center;color:#a0aec0;padding:3rem 1rem;font-size:1rem;line-height:1.6}.history-list{display:flex;flex-direction:column;gap:.75rem}.history-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f7fafc;border:2px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.history-item:hover{background:#edf2f7;border-color:#cbd5e0;transform:translateY(-2px)}.history-item.current{background:#ebf8ff;border-color:#4299e1}.history-item-main{display:flex;align-items:center;gap:1rem;flex:1}.history-icon{font-size:1.5rem}.history-details{display:flex;flex-direction:column;gap:.25rem}.history-session-id{font-family:Monaco,Courier New,monospace;font-size:.95rem;color:#2d3748;font-weight:600}.history-time{font-size:.875rem;color:#718096}.current-badge{background:#4299e1;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}@media (max-width: 768px){.stats-bar{padding:1rem;gap:.75rem}.stats-container{flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;gap:.5rem}.stat-card{min-width:120px}.stat-card.cta{min-width:140px}.stats-bar{padding:.5rem .75rem;gap:.5rem;flex-wrap:nowrap}.app-title{font-size:1rem;white-space:nowrap}.app-subtitle{display:none}.stats-container{gap:.25rem;margin-left:0;flex:1 1 auto;justify-content:flex-start}.stat-card{padding:.25rem .35rem;gap:.25rem;min-width:auto;border-radius:8px;flex:0 0 auto}.stat-label,.stat-card.stat-connection .stat-content{display:none}.stat-card.stat-connection{padding:.25rem}.stat-card.stat-online{display:none}.stat-icon{font-size:.95rem}.stat-value{font-size:.85rem}.stat-card.stat-time .stat-value,.stat-card.stat-moves .stat-value{font-size:.75rem}.stat-label{font-size:.6rem}.stat-card.cta{width:clamp(120px,22vw,200px);min-width:unset;justify-content:center}.presence-panel{width:220px;padding:1rem}.header-left{gap:1rem}.session-info{display:none}.workspace-header{padding:.5rem .75rem;gap:.75rem}.workspace-title{font-size:1rem}.canvas-type-selector{padding:.125rem}.canvas-type-btn{padding:.35rem .6rem;font-size:.8rem}.welcome-message h2{font-size:1.5rem}.share-link-box{flex-direction:column}.btn-copy-large,.btn-new-session,.btn-history{width:100%}.modal-content{width:95%;max-height:90vh}.modal-header,.modal-body{padding:1rem}}@media (max-width: 700px){.header-actions .btn-header-action:not(.btn-menu){display:none}.btn-menu{display:flex}}@media (max-width: 992px){.stats-bar{padding:.75rem 1rem;gap:.75rem}.app-subtitle{display:none}.stat-card{padding:.5rem .75rem;min-width:auto;gap:.5rem}.stat-icon{font-size:1.2rem}.stat-value{font-size:1rem}}@media (max-width: 576px){.stats-bar{padding:.25rem .5rem;gap:.35rem;flex-wrap:nowrap;overflow-x:auto;-webkit-overflow-scrolling:touch;max-height:10vh;justify-content:center}.app-title{font-size:.95rem;white-space:nowrap}.stat-card{padding:.2rem .35rem;border-radius:8px;gap:.25rem}.stat-card.cta{padding:.35rem .6rem;width:clamp(160px,50vw,300px);margin-right:.25rem}.stats-container{margin-left:0;justify-content:center}.stat-icon{font-size:.85rem}.stat-value{font-size:.8rem}.stat-label,.stat-card.stat-online{display:none}.header-actions .btn-header-action{width:36px;height:36px}}@media (max-width: 576px){.stats-bar{padding:.4rem .5rem;gap:.4rem;max-height:10vh}.app-title{font-size:.9rem}.stat-icon{font-size:.85rem}.stat-value{font-size:.7rem}.stat-card{padding:.2rem .3rem}}@media (max-width: 768px){.presence-panel,.objects-panel,.puzzle-objects-panel{display:none!important}.collab-content{padding:0}.canvas-area{width:100%}}.side-menu-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:1200;display:flex}.side-menu{width:280px;max-width:85vw;background:#fff;border-right:1px solid #e2e8f0;height:100%;box-shadow:6px 0 20px #00000026;display:flex;flex-direction:column;animation:sideSlide .2s ease}@keyframes sideSlide{0%{transform:translate(-10px);opacity:0}to{transform:translate(0);opacity:1}}.side-menu-header{display:flex;align-items:center;justify-content:space-between;padding:1rem;border-bottom:1px solid #e2e8f0}.side-menu-close{border:none;background:#eef2f7;border-radius:6px;width:32px;height:32px;cursor:pointer}.side-menu-actions{display:flex;flex-direction:column;padding:.75rem;gap:.5rem}.side-menu-btn{padding:.75rem 1rem;border:1px solid #e2e8f0;border-radius:8px;background:#f8fafc;text-align:left;cursor:pointer;font-weight:600}.side-menu-btn:hover{background:#eef2f7}.static-page{min-height:100vh;background:linear-gradient(135deg,#f5f7fa,#e4e8ec);padding:4rem 2rem}.static-content{max-width:800px;margin:0 auto;background:#fff;border-radius:12px;padding:3rem;box-shadow:0 4px 12px #00000014}.static-content h1{font-size:2.5rem;color:#1a202c;margin:0 0 .5rem}.last-updated{color:#718096;font-size:.95rem;margin:0 0 2rem}.subtitle{color:#718096;font-size:1.1rem;margin:0 0 2rem}.static-content section{margin-bottom:2.5rem}.static-content h2{font-size:1.5rem;color:#2d3748;margin:0 0 1rem}.static-content p{color:#4a5568;line-height:1.7;margin:0 0 1rem}.static-content ul{list-style:disc;padding-left:1.5rem;color:#4a5568;line-height:1.7}.static-content li{margin-bottom:.5rem}.back-link{display:inline-block;margin-top:2rem;color:#4299e1;text-decoration:none;font-weight:500;transition:color .2s}.back-link:hover{color:#3182ce;text-decoration:underline}@media (max-width: 768px){.static-page{padding:2rem 1rem}.static-content{padding:2rem 1.5rem}.static-content h1{font-size:2rem}.static-content h2{font-size:1.25rem}.landing-hero{padding:16px 12px!important}.hero-grid{display:grid!important;grid-template-columns:1fr!important;gap:16px!important}.hero-title{font-size:2rem!important;line-height:1.2!important;margin-top:4px!important}.hero-copy{font-size:1rem!important}}
