.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:24px;position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 40%,rgba(59,130,246,.08) 0%,transparent 50%),radial-gradient(circle at 70% 60%,rgba(168,85,247,.06) 0%,transparent 50%);animation:subtle-drift 20s ease-in-out infinite;pointer-events:none}.auth-card{background:#ffffff08;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:20px;padding:40px 36px;max-width:400px;width:100%;box-shadow:0 24px 64px #0006,inset 0 1px #ffffff0f;position:relative;z-index:1}.auth-header{text-align:center;margin-bottom:32px}.auth-title{font-family:Satoshi,Inter,system-ui,sans-serif;font-size:36px;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 4px;letter-spacing:-.02em}.auth-subtitle{color:#64748b;font-size:14px;margin:0;text-transform:uppercase;letter-spacing:.15em;font-weight:500}.auth-tabs{display:flex;gap:4px;background:#0003;padding:4px;border-radius:12px;margin-bottom:28px}.auth-tab{flex:1;background:transparent;border:none;padding:12px 16px;border-radius:10px;color:#94a3b8;font-weight:600;font-size:14px;cursor:pointer;transition:all .2s ease}.auth-tab:hover:not(.active){color:#cbd5e1;background:#ffffff08;transform:none;box-shadow:none}.auth-tab.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 12px #3b82f64d}.auth-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:13px;font-weight:600;color:#94a3b8;letter-spacing:.02em}.form-group input{padding:14px 16px;border-radius:12px;border:1px solid rgba(255,255,255,.1);background:#0003;color:#f1f5f9;font-size:15px;transition:all .2s ease}.form-group input::placeholder{color:#475569}.form-group input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633;background:#0000004d}.form-group input:disabled{opacity:.6;cursor:not-allowed}.auth-error{color:#f87171;font-size:13px;font-weight:500;padding:12px 16px;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:10px}.auth-message{color:#4ade80;font-size:13px;font-weight:500;padding:12px 16px;background:#4ade801a;border:1px solid rgba(74,222,128,.2);border-radius:10px}.auth-submit{margin-top:4px;padding:14px 24px;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .2s ease;box-shadow:0 4px 16px #3b82f64d}.auth-submit:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.auth-submit:active:not(:disabled){transform:translateY(0)}.auth-submit:disabled{opacity:.7;cursor:not-allowed;transform:none}.auth-footer{text-align:center;margin-top:28px;padding-top:24px;border-top:1px solid rgba(255,255,255,.06)}.auth-footer p{color:#64748b;font-size:14px;margin:0}.auth-link{background:none;border:none;color:#3b82f6;font-weight:600;cursor:pointer;padding:0;font-size:inherit;transition:color .2s ease}.auth-link:hover{color:#60a5fa;transform:none;box-shadow:none}.lobby-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:24px;position:relative;overflow:hidden}.lobby-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 25% 35%,rgba(234,179,8,.06) 0%,transparent 50%),radial-gradient(circle at 75% 65%,rgba(59,130,246,.06) 0%,transparent 50%);animation:subtle-drift 20s ease-in-out infinite;pointer-events:none}.lobby-card{background:#ffffff08;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:48px 40px;max-width:440px;width:100%;box-shadow:0 24px 64px #0006,inset 0 1px #ffffff0f;position:relative;z-index:1}.lobby-header{text-align:center;margin-bottom:40px}.lobby-title{font-family:Satoshi,Inter,system-ui,sans-serif;font-size:42px;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px;letter-spacing:-.02em}.lobby-subtitle{color:#64748b;font-size:15px;margin:0;text-transform:uppercase;letter-spacing:.2em;font-weight:500}.lobby-actions{display:flex;flex-direction:column;gap:20px;margin-bottom:24px}.lobby-btn{width:100%;padding:16px 24px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none}.create-btn{background:linear-gradient(135deg,#eab308,#ca8a04);color:#0f172a;box-shadow:0 4px 16px #eab3084d}.create-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #eab30866}.create-btn:disabled{opacity:.6;cursor:not-allowed}.divider{display:flex;align-items:center;gap:16px;color:#475569;font-size:13px;text-transform:uppercase;letter-spacing:.1em}.divider:before,.divider:after{content:"";flex:1;height:1px;background:#ffffff1a}.join-form{display:flex;flex-direction:column;gap:12px}.join-input{width:100%;padding:14px 16px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#ffffff0d;color:#f1f5f9;font-size:15px;transition:all .2s ease;box-sizing:border-box}.join-input::placeholder{color:#64748b}.join-input:focus{outline:none;border-color:#3b82f680;background:#ffffff14}.join-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 4px 16px #3b82f64d}.join-btn:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 24px #3b82f666}.join-btn:disabled{opacity:.6;cursor:not-allowed}.lobby-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:12px 16px;border-radius:10px;font-size:14px;margin-bottom:24px}.existing-games{border-top:1px solid rgba(255,255,255,.06);padding-top:24px;margin-bottom:24px}.games-heading{color:#94a3b8;font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin:0 0 16px}.games-list{display:flex;flex-direction:column;gap:8px}.game-item{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;border-radius:10px;background:#ffffff08;border:1px solid rgba(255,255,255,.06);cursor:pointer;transition:all .2s ease}.game-item:hover{background:#ffffff0f;border-color:#ffffff1a}.game-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:15px;font-weight:600;color:#f1f5f9;text-transform:uppercase;letter-spacing:.05em}.game-meta{font-size:13px;color:#64748b}.lobby-footer{display:flex;align-items:center;justify-content:space-between;padding-top:24px;border-top:1px solid rgba(255,255,255,.06)}.user-email{color:#64748b;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.sign-out-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#94a3b8;padding:8px 16px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease}.sign-out-btn:hover{background:#ffffff1a;color:#e2e8f0}.waiting-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:24px;position:relative;overflow:hidden}.waiting-container:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 25% 35%,rgba(234,179,8,.06) 0%,transparent 50%),radial-gradient(circle at 75% 65%,rgba(59,130,246,.06) 0%,transparent 50%);animation:subtle-drift 20s ease-in-out infinite;pointer-events:none}@keyframes subtle-drift{0%,to{transform:translate(0)}50%{transform:translate(-2%,2%)}}.waiting-card{background:#ffffff08;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:24px;padding:48px 40px;max-width:440px;width:100%;box-shadow:0 24px 64px #0006,inset 0 1px #ffffff0f;position:relative;z-index:1;text-align:center}.waiting-header{margin-bottom:32px}.waiting-title{font-family:Satoshi,Inter,system-ui,sans-serif;font-size:28px;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px;letter-spacing:-.02em}.waiting-subtitle{color:#64748b;font-size:14px;margin:0}.invite-section{margin-bottom:40px}.invite-label{display:block;color:#94a3b8;font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}.invite-display{display:flex;align-items:center;gap:12px;justify-content:center}.invite-code{font-family:JetBrains Mono,Fira Code,monospace;font-size:32px;font-weight:700;color:#f1f5f9;text-transform:uppercase;letter-spacing:.15em;padding:16px 24px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:12px}.copy-btn{padding:12px 20px;border-radius:10px;border:1px solid rgba(59,130,246,.3);background:#3b82f61a;color:#60a5fa;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.copy-btn:hover{background:#3b82f633;border-color:#3b82f680}.waiting-animation{position:relative;width:120px;height:120px;margin:0 auto 32px;display:flex;align-items:center;justify-content:center}.pulse-ring{position:absolute;width:100%;height:100%;border-radius:50%;border:2px solid rgba(234,179,8,.3);animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}.pulse-ring.delay-1{animation-delay:.5s}.pulse-ring.delay-2{animation-delay:1s}@keyframes pulse{0%{transform:scale(.5);opacity:1}to{transform:scale(1.5);opacity:0}}.waiting-text{color:#94a3b8;font-size:14px;font-weight:600;z-index:1}.back-btn{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);color:#94a3b8;padding:12px 24px;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.back-btn:hover{background:#ffffff1a;color:#e2e8f0}.deck-builder-container{min-height:100vh;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:32px 24px;position:relative;overflow-x:hidden}.deck-builder-container:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 20% 30%,rgba(234,179,8,.04) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(59,130,246,.04) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(168,85,247,.03) 0%,transparent 50%);pointer-events:none;z-index:0}.deck-builder-header{max-width:1400px;margin:0 auto 32px;display:flex;justify-content:space-between;align-items:center;position:relative;z-index:1}.header-content{flex:1}.deck-builder-title{font-family:Satoshi,Inter,system-ui,sans-serif;font-size:48px;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 0 8px;letter-spacing:-.02em}.deck-builder-subtitle{color:#64748b;font-size:16px;margin:0;font-weight:500}.deck-counter{display:flex;align-items:baseline;gap:4px;background:#ffffff0d;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.1);border-radius:16px;padding:16px 28px}.deck-counter .count{font-family:JetBrains Mono,Fira Code,monospace;font-size:42px;font-weight:700;color:#94a3b8;transition:all .3s ease}.deck-counter .count.complete{color:#22c55e;text-shadow:0 0 24px rgba(34,197,94,.4)}.deck-counter .separator{font-size:32px;color:#475569;margin:0 2px}.deck-counter .total{font-family:JetBrains Mono,Fira Code,monospace;font-size:24px;font-weight:600;color:#475569}.filter-bar{max-width:1400px;margin:0 auto 24px;display:flex;flex-wrap:wrap;gap:8px;position:relative;z-index:1}.filter-btn{padding:10px 18px;border-radius:20px;border:1px solid rgba(255,255,255,.1);background:#ffffff08;color:#94a3b8;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s ease;text-transform:capitalize}.filter-btn:hover{background:#ffffff14;border-color:#fff3}.filter-btn.active{background:#ffffff1a;border-color:#ffffff4d;color:#f1f5f9}.cards-grid{max-width:1400px;margin:0 auto;display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:16px;padding-bottom:120px;position:relative;z-index:1}.deck-card{background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:2px solid rgba(255,255,255,.08);border-radius:16px;padding:20px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);position:relative;overflow:hidden}.deck-card:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(135deg,transparent 0%,rgba(255,255,255,.02) 100%);pointer-events:none}.deck-card:hover:not(.disabled){transform:translateY(-4px);border-color:#fff3;box-shadow:0 12px 32px #0000004d}.deck-card.selected{border-color:#22c55e;background:#22c55e14;box-shadow:0 0 32px #22c55e26}.deck-card.selected:hover{border-color:#16a34a}.deck-card.disabled{opacity:.4;cursor:not-allowed;filter:grayscale(.5)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.card-type-badge{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:5px 10px;border-radius:6px;color:#0f172a}.card-points{font-family:JetBrains Mono,Fira Code,monospace;font-size:14px;font-weight:600;color:#94a3b8}.card-name{font-size:18px;font-weight:700;color:#f1f5f9;margin:0 0 10px;line-height:1.3}.card-effect{font-size:13px;color:#94a3b8;margin:0 0 16px;line-height:1.5;min-height:60px}.card-cost{display:flex;flex-wrap:wrap;gap:8px}.resource-cost{display:flex;align-items:center;gap:4px;background:#0000004d;padding:4px 8px;border-radius:6px}.resource-icon{width:20px;height:20px;object-fit:contain}.resource-amount{font-family:JetBrains Mono,Fira Code,monospace;font-size:12px;font-weight:600;color:#cbd5e1}.no-cost{font-size:12px;font-weight:600;color:#64748b;font-style:italic}.selected-badge{position:absolute;top:12px;right:12px;width:28px;height:28px;background:#22c55e;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #22c55e66;animation:pop-in .2s cubic-bezier(.4,0,.2,1)}@keyframes pop-in{0%{transform:scale(0);opacity:0}50%{transform:scale(1.2)}to{transform:scale(1);opacity:1}}.checkmark{color:#0f172a;font-size:14px;font-weight:700}.deck-error{max-width:1400px;margin:24px auto;background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#fca5a5;padding:14px 20px;border-radius:12px;font-size:14px;position:relative;z-index:1}.deck-builder-footer{position:fixed;bottom:0;left:0;right:0;background:#0f172af2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border-top:1px solid rgba(255,255,255,.08);padding:20px 24px;display:flex;justify-content:center;gap:16px;z-index:100}.deck-builder-footer .back-btn{padding:14px 28px;border-radius:12px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;background:#ffffff0d;border:1px solid rgba(255,255,255,.15);color:#94a3b8}.deck-builder-footer .back-btn:hover:not(:disabled){background:#ffffff1a;color:#f1f5f9}.deck-builder-footer .back-btn:disabled{opacity:.5;cursor:not-allowed}.deck-builder-footer .confirm-btn{padding:14px 36px;border-radius:12px;font-size:15px;font-weight:700;cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1);border:none;background:#ffffff1a;color:#64748b;min-width:200px}.deck-builder-footer .confirm-btn.ready{background:linear-gradient(135deg,#22c55e,#16a34a);color:#0f172a;box-shadow:0 4px 20px #22c55e59}.deck-builder-footer .confirm-btn.ready:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 8px 28px #22c55e73}.deck-builder-footer .confirm-btn:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.deck-builder-header{flex-direction:column;gap:20px;text-align:center}.deck-builder-title{font-size:32px}.deck-counter{padding:12px 20px}.deck-counter .count{font-size:32px}.cards-grid{grid-template-columns:1fr}.deck-builder-footer{flex-direction:column;gap:12px}.deck-builder-footer .back-btn,.deck-builder-footer .confirm-btn{width:100%}}.admin-container{min-height:100vh;background:#f8fafc;padding:24px}.admin-loading,.admin-denied{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:60vh;text-align:center}.admin-denied h2{margin:0 0 8px;color:#1e293b}.admin-denied p{color:#64748b;margin:4px 0}.admin-denied .user-id code{background:#e2e8f0;padding:4px 8px;border-radius:4px;font-size:12px}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:16px}.admin-header h1{margin:0;font-size:28px;color:#1e293b}.admin-subtitle{margin:4px 0 0;color:#64748b;font-size:14px}.admin-actions{display:flex;gap:8px}.btn-primary{background:#2563eb;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer}.btn-primary:hover{background:#1d4ed8}.btn-secondary{background:#e2e8f0;color:#475569;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer}.btn-secondary:hover{background:#cbd5e1}.btn-new{background:#22c55e;color:#fff;border:none;padding:10px 16px;border-radius:8px;font-weight:600;cursor:pointer}.btn-new:hover{background:#16a34a}.admin-filters{display:flex;gap:8px;margin-bottom:16px;flex-wrap:wrap}.admin-filters .filter-btn{padding:8px 14px;border:1px solid #e2e8f0;background:#fff;border-radius:6px;font-size:13px;font-weight:500;color:#64748b;cursor:pointer}.admin-filters .filter-btn:hover{border-color:#cbd5e1;color:#1e293b}.admin-filters .filter-btn.active{background:#1e293b;color:#fff;border-color:#1e293b}.card-table{background:#fff;border-radius:12px;border:1px solid #e2e8f0;overflow:hidden}.table-header{display:grid;grid-template-columns:180px 100px 50px 1fr 120px 60px 120px;gap:12px;padding:12px 16px;background:#f1f5f9;font-weight:600;font-size:12px;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.table-row{display:grid;grid-template-columns:180px 100px 50px 1fr 120px 60px 120px;gap:12px;padding:12px 16px;border-bottom:1px solid #f1f5f9;align-items:center;font-size:14px}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8fafc}.col-name{font-weight:600;color:#1e293b}.col-type{font-size:11px;font-weight:600;text-transform:uppercase;padding:4px 8px;border-radius:4px;text-align:center}.type-fundamental{background:#dcfce7;color:#166534}.type-legendary{background:#fef3c7;color:#a16207}.type-movement{background:#dbeafe;color:#1d4ed8}.type-counter{background:#f3e8ff;color:#7c3aed}.type-diversion{background:#fce7f3;color:#be185d}.type-abnormal{background:#ffedd5;color:#c2410c}.type-illegal{background:#fee2e2;color:#b91c1c}.col-pts{font-weight:600;text-align:center}.col-effect{color:#475569;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.col-art{font-size:12px;color:#64748b;font-family:monospace}.col-active{text-align:center}.col-actions{display:flex;gap:6px}.btn-edit{padding:4px 10px;background:#e0f2fe;color:#0369a1;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer}.btn-edit:hover{background:#bae6fd}.btn-delete{padding:4px 10px;background:#fee2e2;color:#b91c1c;border:none;border-radius:4px;font-size:12px;font-weight:600;cursor:pointer}.btn-delete:hover{background:#fecaca}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px}.modal-card{background:#fff;border-radius:16px;padding:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.modal-card h2{margin:0 0 20px;font-size:20px;color:#1e293b}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group.full-width{grid-column:span 2}.form-group label{font-size:13px;font-weight:600;color:#475569}.form-group input[type=text],.form-group input[type=number],.form-group select,.form-group textarea{padding:10px 12px;border:1px solid #cbd5e1;border-radius:8px;font-size:14px;background:#fff;color:#1e293b}.form-group input::placeholder,.form-group textarea::placeholder{color:#94a3b8}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#3b82f6}.form-group textarea{resize:vertical;font-family:inherit}.form-hint{font-size:11px;color:#94a3b8}.resource-inputs{display:flex;flex-wrap:wrap;gap:8px}.resource-input{display:flex;align-items:center;gap:6px;padding:6px 10px;background:#f8fafc;border-radius:6px}.resource-label{font-size:13px;font-weight:500;color:#1e293b;min-width:90px}.resource-input input{width:50px;padding:6px 8px;border:1px solid #cbd5e1;border-radius:4px;text-align:center;font-size:14px;font-weight:600;color:#1e293b;background:#fff}.checkbox-label{display:flex;align-items:center;gap:8px;font-size:14px;color:#475569;cursor:pointer}.checkbox-label input{width:18px;height:18px}.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #e2e8f0}.admin-footer{margin-top:24px;padding:16px;background:#f1f5f9;border-radius:8px;text-align:center}.admin-footer p{margin:0;color:#64748b;font-size:13px}.admin-footer code{background:#e2e8f0;padding:2px 6px;border-radius:4px;font-size:12px}@media (max-width: 900px){.table-header,.table-row{grid-template-columns:1fr 80px 40px 100px}.col-effect,.col-art,.col-active{display:none}.form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}}:root{color:#f1f5f9;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}.app{min-height:100vh;padding:24px;color:#f1f5f9;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);position:relative}.app:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 20% 30%,rgba(234,179,8,.04) 0%,transparent 40%),radial-gradient(circle at 80% 70%,rgba(59,130,246,.04) 0%,transparent 40%),radial-gradient(circle at 50% 50%,rgba(168,85,247,.03) 0%,transparent 50%);pointer-events:none;z-index:0}.page-header{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:12px;position:relative;z-index:20}h1{margin:0 0 8px;font-size:28px;font-family:Satoshi,Inter,system-ui,sans-serif;font-weight:800;background:linear-gradient(135deg,#f8fafc,#94a3b8);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.subtitle{margin:0;color:#64748b}.master-resources-bar{background:#ffffff0a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:12px 16px;margin-bottom:14px;position:relative;z-index:1}.master-resources-heading{margin-bottom:8px;color:#94a3b8}.master-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.master-item{border:1px solid rgba(255,255,255,.1);background:#ffffff08;border-radius:12px;padding:14px;min-height:88px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease}.master-item:hover{transform:translateY(-2px);border-color:#fff3;box-shadow:0 8px 24px #0000004d}.board{display:grid;grid-template-columns:1fr 320px;gap:16px;position:relative;z-index:1}@media (max-width: 900px){.board{grid-template-columns:1fr}}.gate{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);padding:24px}.gate-card{background:#ffffff08;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:20px;max-width:420px;width:100%;box-shadow:0 24px 64px #0006,inset 0 1px #ffffff0f;display:flex;flex-direction:column;gap:12px}.gate-card input{padding:12px 14px;border-radius:10px;border:1px solid rgba(255,255,255,.1);background:#0003;color:#f1f5f9;font-size:14px;transition:all .2s ease}.gate-card input::placeholder{color:#475569}.gate-card input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f633;background:#0000004d}.gate-actions{display:flex;gap:10px}.error-text{color:#f87171;font-weight:600;font-size:13px}.note{color:#64748b;font-size:13px}.panel{background:#ffffff0a;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid rgba(255,255,255,.08);border-radius:14px;padding:14px;display:flex;flex-direction:column;gap:14px}.panel-header{display:flex;justify-content:space-between;align-items:center;gap:12px;border-bottom:1px solid rgba(255,255,255,.08);padding-bottom:10px}.panel-header h3{color:#f1f5f9;margin:0}.deck-info{display:flex;align-items:center;gap:8px}.deck-count{font-size:12px;color:#94a3b8;padding:4px 8px;background:#3b82f626;border:1px solid rgba(59,130,246,.3);border-radius:8px}.resource-grid{display:flex;flex-wrap:wrap;gap:10px;justify-content:space-between}@media (max-width: 900px){.resource-grid{justify-content:flex-start}}.resource{padding:12px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:#ffffff08;display:flex;flex-direction:column;align-items:center;gap:8px;flex:1;min-width:100px}@media (max-width: 900px){.resource{flex:0 0 calc(33.333% - 8px)}}@media (max-width: 600px){.resource{flex:0 0 calc(50% - 6px)}}.icon{font-size:18px}.resource-controls{display:flex;align-items:center;gap:8px;justify-content:center}.resource-value{min-width:28px;text-align:center;font-weight:700;color:#f1f5f9}button{border:none;background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;padding:8px 12px;border-radius:8px;cursor:pointer;font-weight:600;transition:all .2s ease;box-shadow:0 4px 12px #3b82f640}button:hover{transform:translateY(-1px);box-shadow:0 6px 16px #3b82f659}button.secondary{background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#94a3b8;box-shadow:none}button.secondary:hover{background:#ffffff1f;color:#f1f5f9;box-shadow:none}button.danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 12px #ef444440}button.danger:hover{box-shadow:0 6px 16px #ef444459}.section-block h3{margin:0 0 8px;color:#f1f5f9}.card-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:12px}.placeholder{color:#64748b;margin:0}.settings{position:relative}.settings-menu{position:absolute;right:0;top:42px;background:#0f172af2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:10px;padding:8px;display:flex;flex-direction:column;gap:6px;box-shadow:0 12px 32px #0006;z-index:10}.card{border:2px solid rgba(255,255,255,.1);border-radius:14px;padding:14px;background:#ffffff0a;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);box-shadow:0 10px 24px #0000004d;display:flex;flex-direction:column;gap:10px;max-width:250px;width:100%;transition:all .25s cubic-bezier(.4,0,.2,1)}.card:hover{border-color:#fff3;transform:translateY(-2px);box-shadow:0 16px 32px #0006}.card-top{display:flex;justify-content:space-between;gap:8px;align-items:center}.card-title{flex:1;text-align:left;font-weight:700;font-size:15px;color:#f1f5f9}.card-points{font-weight:700;color:#60a5fa;min-width:52px;text-align:right}.card-graphic{height:120px;border:1px solid rgba(255,255,255,.1);border-radius:10px;background:#0003;position:relative;overflow:hidden}.card-art-img{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;border-radius:8px}.card-art-placeholder{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;color:#64748b;font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em}.card-effect{color:#cbd5e1;font-size:13px;line-height:1.45;background:#0003;padding:8px;border-radius:8px}.resource-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 8px;border-radius:999px;background:#3b82f626;border:1px solid rgba(59,130,246,.3);font-size:12px;color:#93c5fd;transition:all .2s ease}.resource-chip-sufficient{background:#22c55e33;border-color:#22c55e80;color:#4ade80}.card-type-badge{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:4px 10px;border-radius:6px;white-space:nowrap;align-self:flex-start}.card-resources{display:flex;flex-wrap:wrap;gap:6px;margin-top:auto}.card-actions{display:flex;gap:8px}.card-move-actions{flex-direction:column;position:relative}.move-btn{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:12px;font-weight:600;transition:all .2s ease;box-shadow:0 4px 12px #6366f140}.move-btn:hover{transform:translateY(-1px);box-shadow:0 6px 16px #6366f159}.move-menu{position:absolute;bottom:100%;left:0;right:0;background:#0f172af2;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.1);border-radius:8px;padding:6px;margin-bottom:6px;display:flex;flex-direction:column;gap:4px;box-shadow:0 8px 24px #0006;z-index:10}.move-menu button{background:#ffffff0d;border:1px solid rgba(255,255,255,.1);padding:8px 10px;border-radius:6px;cursor:pointer;font-size:11px;font-weight:500;text-align:left;transition:all .2s ease;color:#94a3b8;box-shadow:none}.move-menu button:hover{background:#3b82f626;border-color:#3b82f64d;color:#60a5fa;transform:none}.played-header{display:flex;justify-content:space-between;align-items:center;gap:8px}.tally{display:flex;align-items:center;gap:6px}.tally-value{font-weight:700;color:#60a5fa}.loading-container{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#0f172a,#1e293b,#0f172a);color:#94a3b8;gap:16px}.loading-spinner{width:40px;height:40px;border:3px solid rgba(255,255,255,.1);border-top-color:#3b82f6;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.waiting-for-opponent{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px 24px;text-align:center}.waiting-for-opponent h2{margin:0 0 12px;color:#f1f5f9}.waiting-for-opponent p{margin:0;color:#64748b}.waiting-for-opponent strong{font-family:JetBrains Mono,Fira Code,monospace;background:#3b82f626;border:1px solid rgba(59,130,246,.3);padding:4px 8px;border-radius:6px;color:#60a5fa}.loading-container button{margin-top:8px}.resource-value-static{font-size:20px;font-weight:700;color:#f1f5f9}.hand-slots{display:flex;gap:10px;flex-wrap:wrap}.hand-slot{width:60px;height:84px;border-radius:10px;display:flex;align-items:center;justify-content:center;transition:all .2s ease}.hand-slot.empty{border:2px dashed rgba(255,255,255,.15);background:#ffffff05}.hand-slot.filled{border:2px solid #3b82f6;background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 12px #3b82f64d}.card-back{font-size:28px;font-weight:800;color:#ffffffe6}.hand-row{display:flex;gap:12px;flex-wrap:wrap}.card-slot{width:250px;min-height:280px;border-radius:14px;display:flex;align-items:center;justify-content:center}.card-slot.empty{border:2px dashed rgba(255,255,255,.1);background:repeating-linear-gradient(45deg,#ffffff05,#ffffff05 10px,#ffffff0a 10px,#ffffff0a 20px)}.slot-label{font-size:13px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.panel-opponent{padding:12px;gap:12px;background:#ffffff08;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px)}.panel-opponent .panel-header{padding-bottom:8px;border-bottom:1px solid rgba(255,255,255,.08)}.panel-opponent .panel-header h3{margin:0;font-size:14px;color:#94a3b8}.opponent-stats{display:flex;gap:6px}.stat-pill{font-size:11px;font-weight:600;padding:4px 8px;background:#ffffff14;border-radius:6px;color:#94a3b8}.stat-pill.score{background:#3b82f626;border:1px solid rgba(59,130,246,.3);color:#60a5fa}.opponent-row{display:flex;gap:12px;align-items:flex-start}.opponent-resources{display:flex;flex-wrap:wrap;gap:6px;flex:1}.opponent-resource{display:flex;align-items:center;gap:4px;padding:4px 8px;background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:6px}.opponent-resource-icon{width:20px;height:20px;object-fit:contain}.opponent-resource-value{font-size:13px;font-weight:700;color:#f1f5f9}.opponent-hand{display:flex;gap:4px}.opponent-card-slot{width:28px;height:40px;border-radius:4px;display:flex;align-items:center;justify-content:center}.opponent-card-slot.empty{border:1px dashed rgba(255,255,255,.15);background:#ffffff05}.opponent-card-slot.filled{border:1px solid #3b82f6;background:linear-gradient(135deg,#3b82f6,#1d4ed8)}.card-back-small{font-size:14px;font-weight:700;color:#ffffffe6}.opponent-played{display:flex;flex-direction:column;gap:6px}.opponent-played-label{font-size:11px;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.opponent-played-cards{display:flex;flex-direction:column;gap:4px}.opponent-played-card{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:#ffffff0a;border:2px solid;border-radius:8px;cursor:default;transition:all .2s ease}.opponent-played-card:hover{background:#ffffff0f}.opc-name{font-size:13px;font-weight:600;color:#f1f5f9;flex:1}.opc-pts{font-size:12px;font-weight:700;color:#60a5fa}.opc-expand{font-size:10px;color:#64748b;margin-left:6px;transition:transform .2s ease}.opponent-played-card:hover .opc-expand{color:#94a3b8}.opponent-expanded-card{display:flex;flex-direction:column;gap:8px}.opponent-expanded-card .card{max-width:100%}.collapse-btn{padding:6px 12px;font-size:11px;background:#ffffff14;border:1px solid rgba(255,255,255,.15);color:#94a3b8;border-radius:6px;align-self:flex-start;box-shadow:none}.collapse-btn:hover{background:#ffffff1f;color:#f1f5f9;box-shadow:none;transform:none}*{box-sizing:border-box}body{margin:0}
