:root{--font-display: "Cinzel", serif;--font-body: "Nunito", "Segoe UI", system-ui, sans-serif;--card-compact-scale: .71;--card-compact-scale-tight: .64;--card-hover-scale: 1.57;--card-font-name: .7rem;--card-font-text: .6rem;--card-font-type-bar: .6rem;--card-badge-font: .7rem;--card-badge-padding: 2px 4px;--card-badge-min-width: 18px;--card-pip-size: 18px;--card-pip-font: .7rem;--card-exp-size: 18px;--card-exp-font: .7rem;--color-bg: #1a1a2e;--color-surface: #16213e;--color-primary: #e94560;--color-secondary: #0f3460;--color-text: #eaeaea;--color-text-muted: #a0a0a0;--color-x: #e94560;--color-o: #00d9ff;--color-winning: #ffd700;--border-radius: 8px;--transition-speed: .2s;--color-p1: #e94560;--color-p2: #00d9ff;--color-p3: #4ade80;--color-p4: #f59e0b;--color-capstone-gold: #ffd700;--color-capstone-gold-dark: #b8860b;--color-prestige: #a855f7;--color-prestige-dark: #7c3aed;--color-prestige-gradient: linear-gradient(135deg, #a855f7, #7c3aed);--color-prestige-text: #1a1a2e;--color-wildcard-gradient: linear-gradient(to right, #60a5fa 0%, #60a5fa 33.33%, #fbbf24 33.33%, #fbbf24 66.66%, #f87171 66.66%, #f87171 100%);--color-colorless: #9ca3af;--color-colorless-dark: #6b7280;--color-colorless-gradient: linear-gradient(135deg, #9ca3af, #6b7280)}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-body);background:var(--color-bg);color:var(--color-text);min-height:100vh;display:flex;justify-content:center;align-items:center;position:relative}body:before{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background:radial-gradient(ellipse at center,transparent 0%,rgba(0,0,0,.4) 100%);pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.03;pointer-events:none;z-index:0}#root{width:100%;position:relative;z-index:1}.app{display:flex;flex-direction:column;align-items:center;padding:2rem}@keyframes pulse{0%{transform:scale(1)}to{transform:scale(1.05)}}@keyframes pulse-turn{0%{transform:scale(1)}to{transform:scale(1.02)}}@keyframes pulse-action{0%{transform:scale(1)}to{transform:scale(1.02)}}@keyframes slot-pulse{0%{box-shadow:0 0 10px #c9a0ff4d}to{box-shadow:0 0 20px #c9a0ff99}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes card-hover-fade-in{0%{opacity:0;transform:translateY(5px)}to{opacity:1;transform:translateY(0)}}.card{position:relative;width:70px;height:100px;font-size:1.75rem;font-weight:700;border:none;border-radius:var(--border-radius);display:flex;flex-direction:column;align-items:center;justify-content:center;transition:all var(--transition-speed) ease;overflow:visible}.card--visible{background:linear-gradient(135deg,#2d5a87,#1a3a5c);color:var(--color-text);cursor:pointer;border:2px solid #3d7ab5}.card--visible:hover{transform:translateY(-8px);box-shadow:0 8px 20px #0006;background:linear-gradient(135deg,#3d7ab5,#2d5a87)}.card--deck{background:linear-gradient(135deg,#2a2a40,#1a1a2e);color:var(--color-text);border:2px solid #4a4a6a}.card-back{font-size:2rem}.card-value{text-shadow:0 2px 4px rgba(0,0,0,.3)}.card--disabled{opacity:.5;cursor:not-allowed!important}.card--disabled:hover{transform:none!important;box-shadow:none!important}.card--interaction-disabled{cursor:not-allowed!important}.card--interaction-disabled:hover{transform:none!important;box-shadow:none!important}.bid-marker{position:absolute;left:50%;transform:translate(-50%);padding:2px 6px;border-radius:4px;font-size:.7rem;font-weight:700;min-width:20px;text-align:center}.bid-marker--top{bottom:calc(100% + 4px)}.bid-marker--bottom{bottom:4px}.bid-marker--p1{background:linear-gradient(135deg,#e94560,#b83550);color:var(--color-text);box-shadow:0 2px 8px #e9456066}.bid-marker--p2{background:linear-gradient(135deg,#00d9ff,#0099b3);color:var(--color-bg);box-shadow:0 2px 8px #00d9ff66}.bid-marker--p3{background:linear-gradient(135deg,#4ade80,#22c55e);color:var(--color-bg);box-shadow:0 2px 8px #4ade8066}.bid-marker--p4{background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--color-bg);box-shadow:0 2px 8px #f59e0b66}.card--has-bid{border-color:gold;box-shadow:0 0 12px #ffd7004d}.card-board{display:flex;align-items:center;gap:1.5rem;padding:1.5rem;background:var(--color-surface);border-radius:var(--border-radius);box-shadow:0 8px 32px #0000004d}.deck-area{display:flex;flex-direction:column;align-items:center;min-width:80px}.deck-stack{position:relative;display:flex;flex-direction:column;align-items:center}.deck-count{margin-top:.5rem;font-size:.875rem;color:var(--color-text-muted)}.deck-empty{width:70px;height:100px;display:flex;align-items:center;justify-content:center;border:2px dashed var(--color-text-muted);border-radius:var(--border-radius);color:var(--color-text-muted);font-size:.875rem}.visible-cards{display:flex;gap:.75rem;padding-top:24px}.visible-card-wrapper{position:relative;display:flex;flex-direction:column;align-items:center}.visible-card-wrapper--removal{opacity:.8}.visible-card-wrapper--removal .card{border-color:#f59e0b;box-shadow:0 0 8px #f59e0b4d}.removal-indicator{position:absolute;bottom:-24px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#f59e0b,#d97706);color:#1a1a2e;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;white-space:nowrap;text-transform:uppercase;letter-spacing:.02em;box-shadow:0 2px 8px #f59e0b66}.removal-indicator--x{background:linear-gradient(135deg,#e94560,#b83550);color:#fff;font-size:1rem;font-weight:700;padding:4px 10px;border-radius:50%;width:28px;height:28px;display:flex;align-items:center;justify-content:center;cursor:help;box-shadow:0 2px 8px #e9456080}.card--empty-slot{width:140px;height:195px;border:2px dashed rgba(255,255,255,.2);border-radius:var(--border-radius);background:#ffffff08}.visible-card-wrapper--empty{opacity:.5}.visible-card-wrapper--has-starting-trait .trait-stack{margin-top:4px}@media (max-width: 768px){.card--empty-slot{width:120px;height:168px}}@media (max-width: 480px){.card--empty-slot{width:100px;height:140px}}.discard-pile-area{display:flex;flex-direction:column;align-items:center;margin-left:1.5rem;padding-left:1.5rem;border-left:2px solid rgba(255,255,255,.1)}.discard-pile{display:flex;flex-direction:column;align-items:center;gap:.5rem}.discard-pile-visual{width:70px;height:100px;display:flex;align-items:center;justify-content:center;border:2px dashed var(--color-text-muted);border-radius:var(--border-radius);background:#ffffff05}.discard-pile-icon{font-size:2rem;opacity:.5}.discard-pile-label{font-family:var(--font-display);font-size:.8rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.card--pending{cursor:pointer;transition:all var(--transition-speed) ease}.card--pending:hover{transform:translateY(-8px);box-shadow:0 8px 20px #c9a0ff66}.card--selected{border-color:#c9a0ff!important;box-shadow:0 0 20px #c9a0ff99;transform:translateY(-8px) scale(1.05)}.card--slotted{position:relative}.card--slotted:hover{transform:translateY(-4px);box-shadow:0 8px 20px #e945604d}.card--locked{opacity:.7;border:2px solid #666!important}.card--locked:hover{transform:none;box-shadow:none;cursor:not-allowed}.remove-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--color-text-muted);white-space:nowrap;opacity:0;transition:opacity var(--transition-speed) ease}.card--slotted:hover .remove-hint{opacity:1}.locked-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.55rem;color:#888;white-space:nowrap;opacity:.8}.card-abilities{margin-bottom:4px;text-align:left}.card-ability{font-size:inherit;line-height:1.3;color:var(--color-text);text-align:left}.card-flavor-text{font-style:italic;color:var(--color-text-muted);line-height:1.3;text-align:left}@media (max-width: 480px){.card{width:55px;height:80px;font-size:1.5rem}.deck-empty{width:55px;height:80px}.card-board{padding:1rem;gap:1rem}.visible-cards{gap:.5rem}.bid-marker{font-size:.6rem;padding:1px 4px}}.card--student{width:140px;height:195px;padding:0;background:linear-gradient(135deg,#2a2a40,#1a1a2e);border:3px solid #4a4a6a;border-radius:8px;box-shadow:0 0 0 1px #2a2a40 inset}.card--student:hover{transform:translateY(-8px);box-shadow:0 8px 24px #00000080}.card--student.card--compact{width:90px;height:126px}.student-card-frame{display:flex;flex-direction:column;width:100%;height:100%;padding:6px;box-sizing:border-box}.student-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:4px;margin-bottom:4px;min-height:28px}.card--compact .student-card-header{min-height:20px;gap:2px}.student-card-cost{background:var(--color-prestige-gradient);color:var(--color-prestige-text);font-size:var(--card-badge-font);font-weight:700;padding:var(--card-badge-padding);border-radius:4px;min-width:var(--card-badge-min-width);text-align:center;box-shadow:0 1px 3px #0000004d}.card--compact .student-card-cost{font-size:calc(var(--card-badge-font) * var(--card-compact-scale));padding:1px 2px;min-width:calc(var(--card-badge-min-width) * var(--card-compact-scale))}.student-card-name{font-family:var(--font-display);font-size:var(--card-font-name);font-weight:600;color:var(--color-text);letter-spacing:.01em;text-align:left;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1;min-width:0}.card--compact .student-card-name{font-size:calc(var(--card-font-name) * var(--card-compact-scale-tight));-webkit-line-clamp:2}.student-card-image{flex:1;min-height:0;background:linear-gradient(135deg,#3d3d5c,#2d2d4a);border-radius:4px;display:flex;align-items:center;justify-content:center;margin-bottom:4px;overflow:hidden}.student-card-image img{width:100%;height:100%;object-fit:cover}.student-card-type-bar{background:linear-gradient(135deg,#4a4a6a,#3a3a5a);border-top:1px solid #5a5a7a;border-bottom:1px solid #5a5a7a;padding:2px 4px;font-size:var(--card-font-type-bar);font-weight:600;color:var(--color-text);text-align:center;letter-spacing:.03em}.card--compact .student-card-type-bar{font-size:calc(var(--card-font-type-bar) * var(--card-compact-scale));padding:1px 2px}.student-card-text{flex:1;min-height:0;font-size:var(--card-font-text);color:var(--color-text-muted);line-height:1.3;overflow:hidden;margin-bottom:4px;display:flex;flex-direction:column}.card--compact .student-card-text{font-size:calc(var(--card-font-text) * var(--card-compact-scale));margin-bottom:2px}.student-card-footer{display:flex;justify-content:flex-end;align-items:center}.student-card-pips{display:flex;gap:3px}.pip{width:12px;height:12px;border-radius:50%;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 2px #0000004d}.card--compact .pip{width:7px;height:7px}.pip--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.pip--yellow{background:linear-gradient(135deg,gold,#b8860b)}.pip--red{background:linear-gradient(135deg,#e94560,#b83550)}.pip-group{display:flex;align-items:center;gap:2px}.pip-count{font-size:.75rem;font-weight:600;color:var(--color-text)}.card--compact .pip-count{font-size:.5rem}.pip-mana{display:inline-flex;align-items:center;justify-content:center;width:var(--card-pip-size);height:var(--card-pip-size);border-radius:50%;font-size:var(--card-pip-font);font-weight:700;color:#1a1a2e;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 3px #0006}.card--compact .pip-mana{width:calc(var(--card-pip-size) * var(--card-compact-scale));height:calc(var(--card-pip-size) * var(--card-compact-scale));font-size:calc(var(--card-pip-font) * var(--card-compact-scale))}.pip-mana--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.pip-mana--yellow{background:linear-gradient(135deg,gold,#b8860b)}.pip-mana--red{background:linear-gradient(135deg,#e94560,#b83550)}.pending-card-wrapper{cursor:pointer;transition:transform .2s,box-shadow .2s;border-radius:var(--border-radius)}.pending-card-wrapper:hover{transform:translateY(-4px)}.pending-card-wrapper--selected{box-shadow:0 0 0 3px var(--color-primary),0 0 20px #e9456066}.pending-card-wrapper--selected .card{border-color:var(--color-primary)}.slotted-card-wrapper{position:relative;display:flex;flex-direction:column;align-items:center;gap:.5rem}.slotted-card-wrapper .remove-hint,.slotted-card-wrapper .locked-hint{font-size:.6rem;white-space:nowrap;margin-top:.25rem}.slotted-card-wrapper .remove-hint{color:var(--color-primary)}.slotted-card-wrapper .locked-hint{color:var(--color-text-muted)}.slotted-card-wrapper--locked .card{opacity:.7}.slotted-card-wrapper--removable:hover .card{border-color:var(--color-primary)}.visible-cards{padding-top:28px;gap:1rem}.slot-display--filled .card--student{width:70px;height:98px}.slot-display--filled .card--student .student-card-frame{padding:4px}.slot-display--filled .card--student .student-card-cost{font-size:.5rem;padding:1px 2px;min-width:14px}.slot-display--filled .card--student .student-card-name{font-size:.4rem;-webkit-line-clamp:2}.slot-display--filled .card--student .student-card-header{min-height:16px}.slot-display--filled .card--student .student-card-text{display:none}.slot-display--filled .card--student .student-card-phase{font-size:.4rem}.slot-display--filled .card--student .pip{width:5px;height:5px}@media (max-width: 768px){.card--student{width:120px;height:168px}.card--student.card--compact{width:75px;height:105px}.student-card-cost{font-size:.65rem}.student-card-name{font-size:.55rem}.student-card-header{min-height:24px}.student-card-text{font-size:.5rem}}@media (max-width: 480px){.card--student{width:100px;height:140px}.card--student.card--compact{width:65px;height:91px}.visible-cards{gap:.5rem}}.card--trait{width:140px;height:195px;padding:0;background:linear-gradient(135deg,#2a3040,#1a2030);border:3px solid #3a5a7a;border-radius:8px;box-shadow:0 0 0 1px #2a3040 inset}.card--trait:hover:not(:disabled){transform:translateY(-8px);box-shadow:0 8px 24px #00649666}.card--trait.card--capstone{border-color:var(--color-capstone-gold);box-shadow:0 0 0 1px var(--color-capstone-gold-dark) inset,0 0 8px #ffd7004d}.card--trait.card--capstone:hover:not(:disabled){box-shadow:0 8px 24px #ffd70066,0 0 12px #ffd7004d}.card--trait.card--compact{width:90px;height:126px}.trait-card-frame{display:flex;flex-direction:column;width:100%;height:100%;padding:6px;box-sizing:border-box}.trait-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:4px;margin-bottom:4px;min-height:28px}.card--compact .trait-card-header{min-height:20px;gap:2px}.trait-card-exp{display:flex;justify-content:flex-end;gap:2px;min-width:24px}.exp-cost-item{display:flex;align-items:center;font-size:.8rem;font-weight:600;color:var(--color-text)}.exp-cost-free{font-size:.55rem;color:var(--color-text-muted);font-style:italic}.card--compact .exp-cost-item{font-size:.5rem}.card--compact .exp-cost-free{font-size:.45rem}.exp-square{display:inline-block;width:10px;height:10px;margin-left:1px;border-radius:2px;box-shadow:inset 0 1px 2px #fff3,0 1px 2px #0000004d}.card--compact .exp-square{width:6px;height:6px}.exp-square--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.exp-square--yellow{background:linear-gradient(135deg,gold,#b8860b)}.exp-square--red{background:linear-gradient(135deg,#e94560,#b83550)}.exp-square--wildcard{background:var(--color-wildcard-gradient);border:1px solid rgba(255,255,255,.3)}.exp-square--colorless{background:var(--color-colorless-gradient);border:1px solid rgba(255,255,255,.3)}.exp-mana{display:inline-flex;align-items:center;justify-content:center;width:var(--card-exp-size);height:var(--card-exp-size);border-radius:3px;font-size:var(--card-exp-font);font-weight:700;color:#1a1a2e;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 3px #0006}.card--compact .exp-mana{width:calc(var(--card-exp-size) * var(--card-compact-scale));height:calc(var(--card-exp-size) * var(--card-compact-scale));font-size:calc(var(--card-exp-font) * var(--card-compact-scale))}.exp-mana--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.exp-mana--yellow{background:linear-gradient(135deg,gold,#b8860b)}.exp-mana--red{background:linear-gradient(135deg,#e94560,#b83550)}.exp-mana--wildcard{background:var(--color-wildcard-gradient);color:#1a1a2e}.exp-mana--colorless{background:var(--color-colorless-gradient);color:#1a1a2e}.trait-card-name{font-family:var(--font-display);font-size:var(--card-font-name);font-weight:600;color:var(--color-text);text-align:left;letter-spacing:.01em;line-height:1.2;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;flex:1;min-width:0}.card--compact .trait-card-name{font-size:calc(var(--card-font-name) * var(--card-compact-scale-tight));-webkit-line-clamp:2}.trait-card-image{flex:1;min-height:0;background:linear-gradient(135deg,#3d4d5c,#2d3d4a);border-radius:4px;display:flex;align-items:center;justify-content:center;margin-bottom:4px;overflow:hidden}.trait-card-image img{width:100%;height:100%;object-fit:cover}.trait-card-type-bar{background:linear-gradient(135deg,#3a5a7a,#2a4a6a);border-top:1px solid #4a6a8a;border-bottom:1px solid #4a6a8a;padding:2px 4px;font-size:var(--card-font-type-bar);font-weight:600;color:var(--color-text);text-align:center;letter-spacing:.03em}.card--compact .trait-card-type-bar{font-size:calc(var(--card-font-type-bar) * var(--card-compact-scale));padding:1px 2px}.trait-card-text{flex:1;min-height:0;font-size:var(--card-font-text);color:var(--color-text-muted);line-height:1.3;overflow:hidden;margin-bottom:4px;display:flex;flex-direction:column}.card--compact .trait-card-text{font-size:calc(var(--card-font-text) * var(--card-compact-scale));margin-bottom:2px}.trait-card-footer{display:flex;justify-content:space-between;align-items:center}.trait-card-prestige{background:var(--color-prestige-gradient);color:var(--color-prestige-text);font-size:var(--card-badge-font);font-weight:700;padding:var(--card-badge-padding);border-radius:4px;min-width:var(--card-badge-min-width);text-align:center;box-shadow:0 1px 3px #0000004d}.trait-card-prestige--negative{background:linear-gradient(135deg,#f87171,#dc2626);color:#1a1a2e}.trait-card-pts-per{display:inline-flex;align-items:center;gap:2px;color:var(--color-text)}.trait-card-pts-per-separator{color:var(--color-text-muted);font-size:var(--card-badge-font);font-weight:400}.card--compact .trait-card-pts-per-separator{font-size:calc(var(--card-badge-font) * var(--card-compact-scale))}.card--compact .trait-card-prestige{font-size:calc(var(--card-badge-font) * var(--card-compact-scale));padding:1px 2px;min-width:calc(var(--card-badge-min-width) * var(--card-compact-scale))}.trait-card-type{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.card--compact .trait-card-type{font-size:.4rem}.trait-card-pips{display:flex;gap:4px}.pip-count-item{display:flex;align-items:center;font-size:.8rem;font-weight:600;color:var(--color-text)}.card--compact .pip-count-item{font-size:.5rem}@media (max-width: 768px){.card--trait{width:120px;height:168px}.card--trait.card--compact{width:75px;height:105px}.trait-card-name{font-size:.55rem}.trait-card-header{min-height:24px}}@media (max-width: 480px){.card--trait{width:100px;height:140px}.card--trait.card--compact{width:65px;height:91px}}.trait-stack{width:140px;display:flex;flex-direction:column;margin-top:-2px}.trait-stack--clickable{cursor:pointer}.trait-stack--clickable:hover .trait-stack-footer{background:linear-gradient(135deg,#a78bfa40,#8b5cf626)}.trait-stack--clickable:hover .trait-stack-footer--assign{background:linear-gradient(135deg,#a78bfa59,#8b5cf640)}.trait-stack-footer{width:100%;padding:4px 8px;background:linear-gradient(135deg,#3a5a7ae6,#2a405ae6);border:2px solid #3a5a7a;border-top:1px solid #4a6a8a;border-radius:0 0 6px 6px;box-sizing:border-box;transition:background var(--transition-speed) ease}.trait-stack-footer:first-child{border-top:2px solid #3a5a7a;border-radius:0}.trait-stack-footer:last-child{border-radius:0 0 6px 6px}.trait-stack-footer:only-child{border-radius:0 0 6px 6px}.trait-stack-footer-name{font-family:var(--font-display);font-size:.65rem;font-weight:600;color:var(--color-text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;line-height:1.2;margin-bottom:2px}.trait-stack-footer-stats{display:flex;justify-content:space-between;align-items:center;gap:4px}.trait-stack-prestige{background:var(--color-prestige-gradient);color:var(--color-prestige-text);font-size:.6rem;font-weight:700;padding:1px 4px;border-radius:3px;min-width:20px;text-align:center;box-shadow:0 1px 2px #0000004d}.trait-stack-prestige--negative{background:linear-gradient(135deg,#f87171,#dc2626)}.trait-stack-pips{display:flex;gap:2px}.trait-stack-pip{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;font-size:.55rem;font-weight:700;color:#1a1a2e;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 2px #0000004d}.trait-stack-pip--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.trait-stack-pip--yellow{background:linear-gradient(135deg,gold,#b8860b)}.trait-stack-pip--red{background:linear-gradient(135deg,#e94560,#b83550)}.trait-stack-footer--capstone{border-color:var(--color-capstone-gold);box-shadow:0 0 6px #ffd7004d}.trait-stack-footer--assign{background:linear-gradient(135deg,#a78bfa33,#8b5cf61a);border-color:#a78bfa80;border-style:dashed}.trait-stack-assign-prompt{font-size:.7rem;font-weight:600;color:#a78bfa;text-align:center;padding:4px 0}.trait-stack-preview{pointer-events:none;animation:card-hover-fade-in .15s ease-out}.trait-stack-preview .card--trait{width:220px;height:308px;box-shadow:0 10px 40px #00000080,0 0 0 2px #c9a0ff4d}.trait-stack-preview .trait-card-name{font-size:calc(var(--card-font-name) * var(--card-hover-scale))}.trait-stack-preview .trait-card-text{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.trait-stack-preview .trait-card-type-bar{font-size:calc(var(--card-font-type-bar) * var(--card-hover-scale))}.trait-stack-preview .trait-card-footer{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.trait-stack-preview .trait-card-prestige{font-size:calc(var(--card-badge-font) * var(--card-hover-scale));min-width:calc(var(--card-badge-min-width) * var(--card-hover-scale))}.trait-stack-preview .pip-mana{width:calc(var(--card-pip-size) * var(--card-hover-scale));height:calc(var(--card-pip-size) * var(--card-hover-scale));font-size:calc(var(--card-pip-font) * var(--card-hover-scale))}.trait-stack-preview .exp-mana{width:calc(var(--card-exp-size) * var(--card-hover-scale));height:calc(var(--card-exp-size) * var(--card-hover-scale));font-size:calc(var(--card-exp-font) * var(--card-hover-scale))}@media (max-width: 768px){.trait-stack{width:120px}.trait-stack-footer{padding:3px 6px}.trait-stack-footer-name{font-size:.6rem}.trait-stack-prestige{font-size:.55rem;padding:1px 3px;min-width:18px}.trait-stack-pip{width:12px;height:12px;font-size:.5rem}}@media (max-width: 480px){.trait-stack{width:100px}.trait-stack-footer{padding:2px 4px}.trait-stack-footer-name{font-size:.55rem}.trait-stack-prestige{font-size:.5rem;min-width:16px}.trait-stack-pip{width:11px;height:11px;font-size:.45rem}.trait-stack-assign-prompt{font-size:.6rem;padding:2px 0}}.restart-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:var(--color-primary);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease}.restart-button:hover{background:#ff5a75;transform:translateY(-2px);box-shadow:0 4px 12px #e9456066}.restart-button:disabled{opacity:.5;cursor:not-allowed}.restart-button:disabled:hover{transform:none;box-shadow:none}.pass-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#4a4a4a,#2a2a2a);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease;border:2px solid #666}.pass-button:hover:not(:disabled){background:linear-gradient(135deg,#5a5a5a,#3a3a3a);transform:translateY(-2px);box-shadow:0 4px 12px #6464644d}.pass-button:disabled{opacity:.5;cursor:not-allowed}.create-room-button{width:100%;padding:1rem 2rem;font-size:1.125rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,var(--color-primary),#b83550);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease}.create-room-button:hover:not(:disabled){background:linear-gradient(135deg,#ff5a75,var(--color-primary));transform:translateY(-2px);box-shadow:0 4px 16px #e9456066}.create-room-button:disabled{opacity:.6;cursor:not-allowed}.join-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,var(--color-o),#0099b3);color:var(--color-bg);cursor:pointer;transition:all var(--transition-speed) ease}.join-button:hover:not(:disabled){background:linear-gradient(135deg,#33e0ff,var(--color-o));transform:translateY(-2px);box-shadow:0 4px 12px #00d9ff66}.join-button:disabled{opacity:.6;cursor:not-allowed}.start-game-button{width:100%;padding:1rem 2rem;font-size:1.125rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#4ade80,#22c55e);color:var(--color-bg);cursor:pointer;transition:all var(--transition-speed) ease}.start-game-button:hover:not(:disabled){background:linear-gradient(135deg,#6ee7a0,#4ade80);transform:translateY(-2px);box-shadow:0 4px 16px #4ade8066}.start-game-button:disabled{opacity:.5;cursor:not-allowed;background:var(--color-secondary)}.leave-room-button{width:100%;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid var(--color-text-muted);border-radius:var(--border-radius);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-speed) ease}.leave-room-button:hover{border-color:var(--color-primary);color:var(--color-primary);background:#e945601a}.reset-action-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#6b7280,#4b5563);color:#e5e7eb;cursor:pointer;transition:all var(--transition-speed) ease}.reset-action-button:hover:not(:disabled){background:linear-gradient(135deg,#7b8290,#5b6573);transform:translateY(-2px);box-shadow:0 4px 12px #6b728066}.reset-action-button:disabled{opacity:.5;cursor:not-allowed}.confirm-assignment-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#6b4fa3,#4a3580);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease}.confirm-assignment-button:hover:not(:disabled){background:linear-gradient(135deg,#8a6bc4,#6b4fa3);transform:translateY(-2px);box-shadow:0 4px 12px #6b4fa366}.confirm-assignment-button:disabled{opacity:.5;cursor:not-allowed}.finish-action-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#6b4fa3,#4a3580);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease}.finish-action-button:hover:not(:disabled){background:linear-gradient(135deg,#8a6bc4,#6b4fa3);transform:translateY(-2px);box-shadow:0 4px 12px #6b4fa366}.finish-action-button:disabled{opacity:.5;cursor:not-allowed}.confirm-graduation-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#22c55e,#16a34a);color:#fff;cursor:pointer;transition:all var(--transition-speed) ease}.confirm-graduation-button:hover:not(:disabled){background:linear-gradient(135deg,#4ade80,#22c55e);transform:translateY(-2px);box-shadow:0 4px 12px #22c55e66}.confirm-graduation-button:disabled{opacity:.5;cursor:not-allowed}.auto-assign-button{padding:.25rem .75rem;font-size:.75rem;font-weight:600;border:1px solid #c9a0ff;border-radius:4px;background:#c9a0ff33;color:#c9a0ff;cursor:pointer;transition:all var(--transition-speed) ease;margin-left:.5rem}.auto-assign-button:hover{background:#c9a0ff4d;border-color:#c9a0ff}.cancel-selection{padding:.25rem .75rem;font-size:.75rem;font-weight:600;border:1px solid var(--color-text-muted);border-radius:4px;background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-speed) ease}.cancel-selection:hover{border-color:var(--color-primary);color:var(--color-primary)}.kick-button{padding:4px 12px;background:#ef4444;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .2s}.kick-button:hover{background:#dc2626}.kick-button--inline{margin-left:8px}.kick-button--small{padding:2px 8px;font-size:.65rem;margin-left:8px}.player-count-button{width:40px;height:40px;font-size:1rem;font-weight:600;border:2px solid rgba(255,255,255,.2);border-radius:var(--border-radius);background:var(--color-secondary);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-speed) ease}.player-count-button:hover{border-color:var(--color-o);color:var(--color-text)}.player-count-button--active{background:linear-gradient(135deg,#00d9ff,#0099b3);border-color:#00d9ff;color:var(--color-bg);box-shadow:0 2px 10px #00d9ff66}.action-buttons{display:flex;gap:1rem;align-items:center}.wildcard-adjust-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:4px;color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease}.wildcard-adjust-btn:hover:not(:disabled){background:#a78bfa4d;border-color:#a78bfa80}.wildcard-adjust-btn:disabled{opacity:.3;cursor:not-allowed}.recruit-commoner-wrapper{position:relative;display:inline-block}.recruit-commoner-button{padding:.75rem 2rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);background:linear-gradient(135deg,#4ade80,#22c55e);color:#1a1a2e;cursor:pointer;transition:all var(--transition-speed) ease}.recruit-commoner-button:hover:not(:disabled){background:linear-gradient(135deg,#6ee7a0,#4ade80);transform:translateY(-2px);box-shadow:0 4px 12px #4ade8066}.recruit-commoner-button:disabled{opacity:.5;cursor:not-allowed}.recruit-commoner-button:disabled:hover{transform:none;box-shadow:none}.commoner-hover-preview{position:absolute;bottom:calc(100% + 10px);left:50%;transform:translate(-50%);z-index:100;pointer-events:none;animation:card-hover-fade-in .15s ease-out}.commoner-hover-preview .card--student{width:220px;height:308px}.commoner-hover-preview .student-card-name{font-size:calc(var(--card-font-name) * var(--card-hover-scale))}.commoner-hover-preview .student-card-text{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.commoner-hover-preview .student-card-type-bar{font-size:calc(var(--card-font-type-bar) * var(--card-hover-scale))}.commoner-hover-preview .student-card-footer{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.commoner-hover-preview .student-card-cost{font-size:calc(var(--card-badge-font) * var(--card-hover-scale));min-width:calc(var(--card-badge-min-width) * var(--card-hover-scale))}.commoner-hover-preview .pip-mana{width:calc(var(--card-pip-size) * var(--card-hover-scale));height:calc(var(--card-pip-size) * var(--card-hover-scale));font-size:calc(var(--card-pip-font) * var(--card-hover-scale))}.commoner-count-display{font-size:.85rem;color:var(--color-text-muted);margin-top:.5rem}.commoner-count-you{color:var(--color-text);font-weight:600}@media (max-width: 480px){.action-buttons{flex-direction:column;width:100%}.pass-button,.restart-button,.recruit-commoner-button{width:100%}.commoner-hover-preview{display:none}}.prestige-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.prestige-modal{background:var(--color-surface);padding:2rem;border-radius:var(--border-radius);box-shadow:0 8px 32px #00000080;max-width:320px;width:90%;text-align:center}.prestige-modal h2{margin-bottom:1rem;color:#c9a0ff}.prestige-modal p{margin-bottom:.5rem;color:var(--color-text)}.prestige-available{color:var(--color-text);font-weight:500;margin-bottom:.5rem!important}.prestige-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--color-prestige-gradient);color:var(--color-prestige-text);font-size:.85rem;font-weight:700;padding:2px 6px;border-radius:4px;box-shadow:0 1px 3px #0000004d}.favors-hint{color:var(--color-text-muted);font-size:.85rem;margin-bottom:1rem!important}.prestige-input{width:100%;padding:.75rem;font-size:1.25rem;text-align:center;border:2px solid var(--color-secondary);border-radius:var(--border-radius);background:var(--color-bg);color:var(--color-text);margin-bottom:1rem}.prestige-input:focus{outline:none;border-color:#6b4fa3}.prestige-modal-buttons{display:flex;gap:1rem;justify-content:center}.modal-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease}.modal-button--cancel{background:var(--color-secondary);color:var(--color-text)}.modal-button--cancel:hover{background:#1a4a80}.modal-button--confirm{background:#6b4fa3;color:var(--color-text)}.modal-button--confirm:hover:not(:disabled){background:#8a6bc4}.modal-button--confirm:disabled{opacity:.5;cursor:not-allowed}.trait-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.trait-modal{background:var(--color-surface);border-radius:var(--border-radius);border:2px solid #6b4fa3;max-width:1200px;max-height:95vh;width:95%;display:flex;flex-direction:column;box-shadow:0 10px 40px #6b4fa366}.trait-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.trait-modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:#c9a0ff}.trait-modal-close{padding:.5rem 1rem;font-size:1rem;font-weight:600;border:1px solid var(--color-text-muted);border-radius:var(--border-radius);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-speed) ease}.trait-modal-close:hover{border-color:var(--color-primary);color:var(--color-primary)}.trait-modal-exp{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem 1rem;background:#0003;border-bottom:1px solid rgba(255,255,255,.1)}.trait-modal--split{max-width:1400px}.trait-modal-body{display:flex;flex:1;overflow:hidden}.trait-modal-student-panel{display:flex;flex-direction:column;align-items:center;padding:1rem;background:#0003;border-right:1px solid rgba(255,255,255,.1);min-width:180px;transition:min-width .3s ease,padding .3s ease;position:relative}.trait-modal-student-panel--collapsed{min-width:40px;padding:1rem .25rem}.trait-modal-collapse-btn{position:absolute;top:.5rem;right:.5rem;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:#6b4fa34d;border:1px solid rgba(167,139,250,.4);border-radius:4px;color:var(--color-text-muted);cursor:pointer;font-size:.75rem;transition:all var(--transition-speed) ease;z-index:1}.trait-modal-collapse-btn:hover{background:#6b4fa380;border-color:#a78bfa99;color:var(--color-text)}.trait-modal-student-panel--collapsed .trait-modal-collapse-btn{position:static;margin-bottom:.5rem}.trait-modal-collapsed-label{display:flex;flex-direction:column;align-items:center;gap:2px;font-size:.75rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:.5rem}.trait-modal-collapsed-label span{line-height:1.2}.trait-modal-student-content{display:flex;flex-direction:column;align-items:center;margin-top:2rem}.trait-modal-student-content .card--student{width:140px;height:195px}.trait-modal-selection-panel{display:flex;flex-direction:column;flex:1;overflow:hidden}.trait-modal-selection-panel .trait-modal-exp{border-bottom:1px solid rgba(255,255,255,.1);border-radius:0}.trait-modal-content{padding:1.5rem;overflow-y:auto;flex:1;display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:1rem;justify-items:center}.trait-option .card--trait{width:140px;height:195px}.trait-option{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.5rem;background:#ffffff08;border:1px solid rgba(255,255,255,.1);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease}.trait-option:hover:not(.trait-option--disabled){background:#a78bfa1a;border-color:#a78bfa66;transform:translateY(-2px)}.trait-option--selected{background:#a78bfa33;border-color:#a78bfa}.trait-option--disabled{opacity:.5;cursor:not-allowed}.trait-option-info{display:flex;flex-direction:column;align-items:center;gap:.25rem;font-size:.7rem}.trait-option-selected-badge{color:#4ade80;font-weight:600}.trait-option-cant-afford,.trait-option-unavailable{color:#f87171}.trait-option-remaining{color:var(--color-text-muted)}.trait-option-cost{display:flex;align-items:center;gap:4px;color:var(--color-text-muted);font-weight:600;font-size:.7rem}.trait-option-cost--discounted{color:#4ade80}.trait-cost-free{color:#4ade80;margin-left:4px}.exp-cost{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:3px;font-size:.65rem;font-weight:700;color:#1a1a2e;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 3px #0006}.exp-cost--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.exp-cost--yellow{background:linear-gradient(135deg,gold,#b8860b)}.exp-cost--red{background:linear-gradient(135deg,#e94560,#b83550)}.exp-cost--wildcard{background:var(--color-wildcard-gradient);color:#1a1a2e}.exp-cost--colorless{background:var(--color-colorless-gradient);color:#1a1a2e}.colorless-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1100;animation:fadeIn .2s ease}.colorless-modal{background:var(--color-surface);border-radius:var(--border-radius);border:2px solid #a78bfa;max-width:90%;width:400px;display:flex;flex-direction:column;box-shadow:0 10px 40px #a78bfa66}.colorless-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.colorless-modal-header h2{margin:0;font-size:1rem;color:#c9a0ff}.colorless-modal-close{background:transparent;border:none;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition-speed) ease}.colorless-modal-close:hover{color:var(--color-text)}.colorless-modal-content{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.colorless-modal-info{text-align:center;font-size:.95rem;color:var(--color-text-muted);line-height:1.5}.colorless-modal-info strong{color:var(--color-text)}.colorless-exp-remaining{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem;background:#0003;border-radius:var(--border-radius)}.colorless-allocation-inputs{display:flex;flex-direction:column;gap:.75rem}.colorless-allocation-row{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:.5rem;background:#ffffff08;border-radius:var(--border-radius)}.colorless-label{display:flex;align-items:center;gap:.5rem;min-width:80px;font-size:.9rem;font-weight:500}.colorless-label--blue{color:#60a5fa}.colorless-label--yellow{color:#facc15}.colorless-label--red{color:#f87171}.colorless-label--wildcard{color:#c084fc}.colorless-value{font-size:1.5rem;font-weight:700;min-width:40px;text-align:center;color:var(--color-text)}.colorless-allocation-total{text-align:center;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.colorless-total{font-size:1rem;font-weight:600;color:#f87171}.colorless-total--complete{color:#4ade80}.colorless-modal-buttons{display:flex;gap:1rem;justify-content:center;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.commoner-modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.commoner-modal{background:var(--color-surface);border-radius:var(--border-radius);border:2px solid #4ade80;max-width:90%;width:280px;display:flex;flex-direction:column;box-shadow:0 10px 40px #4ade804d}.commoner-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.commoner-modal-header h2{margin:0;font-size:1.25rem;color:#4ade80}.commoner-modal-close{background:transparent;border:none;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition-speed) ease}.commoner-modal-close:hover{color:var(--color-text)}.commoner-modal-content{padding:1.5rem;display:flex;flex-direction:column;align-items:center;gap:1rem}.commoner-modal-info{text-align:center;font-size:.95rem;color:var(--color-text-muted);line-height:1.5}.commoner-modal-info strong{color:var(--color-text)}.commoner-modal-card{margin:.5rem 0}.commoner-modal-card .card--student{width:140px;height:195px}.commoner-modal-buttons{display:flex;gap:1rem;justify-content:center;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}.player-info{display:flex;align-items:center;gap:1rem;margin-bottom:.5rem}.lobby-button{padding:.35rem .75rem;background:var(--color-secondary);color:var(--color-text-muted);border:1px solid var(--color-border, #444);border-radius:var(--border-radius);font-size:.8rem;font-weight:600;cursor:pointer;transition:all var(--transition-speed) ease}.lobby-button:hover{background:var(--color-surface);color:var(--color-text)}.player-badge{padding:.5rem 1rem;border-radius:var(--border-radius);font-weight:600;font-size:.875rem}.player-badge--p1{background:linear-gradient(135deg,#e94560,#b83550);color:var(--color-text)}.player-badge--p2{background:linear-gradient(135deg,#00d9ff,#0099b3);color:var(--color-bg)}.player-badge--p3{background:linear-gradient(135deg,#4ade80,#22c55e);color:var(--color-bg)}.player-badge--p4{background:linear-gradient(135deg,#f59e0b,#d97706);color:var(--color-bg)}.player-badge--spectator{background:var(--color-secondary);color:var(--color-text-muted)}.player-count{font-size:.875rem;color:var(--color-text-muted)}.turn-indicator{padding:.75rem 1.5rem;border-radius:var(--border-radius);font-weight:600;background:var(--color-surface);color:var(--color-text-muted);transition:all var(--transition-speed) ease}.turn-indicator--your-turn{background:linear-gradient(135deg,#2d5a87,#1a3a5c);color:var(--color-winning);animation:pulse-turn 1s ease infinite alternate;box-shadow:0 0 20px #ffd7004d}.turn-indicator--action{background:linear-gradient(135deg,#4a3f6b,#2d2445);color:#c9a0ff;animation:pulse-action 1.5s ease infinite alternate;box-shadow:0 0 20px #c9a0ff4d}.error-message{padding:.75rem 1.5rem;background:#e9456033;border:1px solid var(--color-primary);border-radius:var(--border-radius);color:var(--color-primary);font-weight:500}.passed-badge{margin-left:.75rem;padding:.25rem .5rem;background:#666;color:var(--color-text);border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.action-done-badge{margin-left:.75rem;padding:.25rem .5rem;background:linear-gradient(135deg,#4ade80,#22c55e);color:var(--color-bg);border-radius:4px;font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.round-badge{padding:.5rem 1rem;background:linear-gradient(135deg,#4a3f6b,#2d2445);border:1px solid #6b4fa3;border-radius:var(--border-radius);font-size:.875rem;font-weight:600;color:#c9a0ff}.starting-player-star{color:gold;font-size:1rem;margin-right:.25rem;text-shadow:0 0 5px rgba(255,215,0,.5)}.passed-indicator{color:var(--color-text-muted);font-style:italic;font-size:.875rem}.prestige-counter{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:1rem 2rem;background:linear-gradient(135deg,#2d1f4e,#1a1235);border:2px solid #6b4fa3;border-radius:var(--border-radius);box-shadow:0 4px 16px #6b4fa34d}.prestige-label{font-size:.875rem;text-transform:uppercase;letter-spacing:.1em;color:var(--color-text-muted)}.prestige-value{font-size:2rem;font-weight:700;color:#c9a0ff;text-shadow:0 0 10px rgba(201,160,255,.5)}.prestige-counter--p1{background:linear-gradient(135deg,#3d1f2e,#2a1520);border-color:#e94560;box-shadow:0 4px 16px #e9456033}.prestige-counter--p1 .prestige-value{color:#e94560;text-shadow:0 0 10px rgba(233,69,96,.5)}.prestige-counter--p2{background:linear-gradient(135deg,#1a3a5c,#0d2840);border-color:#00d9ff;box-shadow:0 4px 16px #00d9ff33}.prestige-counter--p2 .prestige-value{color:#00d9ff;text-shadow:0 0 10px rgba(0,217,255,.5)}.prestige-counter--p3{background:linear-gradient(135deg,#1a3d2e,#0d2820);border-color:#4ade80;box-shadow:0 4px 16px #4ade8033}.prestige-counter--p3 .prestige-value{color:#4ade80;text-shadow:0 0 10px rgba(74,222,128,.5)}.prestige-counter--p4{background:linear-gradient(135deg,#3d2a1a,#28200d);border-color:#f59e0b;box-shadow:0 4px 16px #f59e0b33}.prestige-counter--p4 .prestige-value{color:#f59e0b;text-shadow:0 0 10px rgba(245,158,11,.5)}.disconnected-indicator{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background:#ef4444;color:#fff;border-radius:50%;font-size:.7rem;font-weight:700;margin-right:4px}.disconnected-badge{display:inline-block;padding:2px 8px;background:#ef4444;color:#fff;font-size:.7rem;font-weight:600;border-radius:4px;margin-left:8px;text-transform:uppercase}.disconnection-warning{display:flex;align-items:center;justify-content:center;gap:12px;padding:12px 20px;background:linear-gradient(135deg,#f59e0b20,#ef444420);border:1px solid #f59e0b;border-radius:var(--border-radius);color:#fbbf24;font-weight:500;margin-bottom:8px}.ability-pip{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:50%;font-size:.55rem;font-weight:700;color:#1a1a2e;vertical-align:middle;margin:0 1px;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 2px #0000004d}.ability-pip--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.ability-pip--yellow{background:linear-gradient(135deg,gold,#b8860b)}.ability-pip--red{background:linear-gradient(135deg,#e94560,#b83550)}.ability-exp{display:inline-flex;align-items:center;justify-content:center;width:14px;height:14px;border-radius:3px;font-size:.55rem;font-weight:700;color:#1a1a2e;vertical-align:middle;margin:0 1px;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 2px #0000004d}.ability-exp--blue{background:linear-gradient(135deg,#00d9ff,#0099b3)}.ability-exp--yellow{background:linear-gradient(135deg,gold,#b8860b)}.ability-exp--red{background:linear-gradient(135deg,#e94560,#b83550)}.ability-exp--wildcard{background:var(--color-wildcard-gradient);color:#1a1a2e}.ability-prestige{display:inline-flex;align-items:center;justify-content:center;background:var(--color-prestige-gradient);color:var(--color-prestige-text);font-size:.55rem;font-weight:700;padding:1px 3px;border-radius:3px;vertical-align:middle;margin:0 1px;box-shadow:0 1px 2px #0000004d}.ability-arrow{display:inline-flex;align-items:center;margin:0 2px;font-weight:600;color:var(--color-text)}.ability-arrow-symbol{font-size:.8em;margin-right:1px}.ability-arrow-multiplier{font-size:.7em;vertical-align:super;margin-left:-1px}.ability-symbol-group{display:inline-flex;align-items:center;gap:1px}.ability-track{display:inline-block;width:6px;height:14px;border-radius:2px;vertical-align:middle;margin:0 2px;box-shadow:inset 0 1px 2px #ffffff4d,0 1px 2px #0000004d}.ability-track--blue{background:linear-gradient(180deg,#00d9ff,#0099b3)}.ability-track--yellow{background:linear-gradient(180deg,gold,#b8860b)}.ability-track--red{background:linear-gradient(180deg,#e94560,#b83550)}.card--compact .ability-pip,.card--compact .ability-exp{width:10px;height:10px;font-size:.45rem}.card--compact .ability-prestige{font-size:.45rem;padding:0 2px}.card--compact .ability-track{width:4px;height:10px}.card--hover-preview .ability-pip,.card--hover-preview .ability-exp{width:16px;height:16px;font-size:.6rem}.card--hover-preview .ability-prestige{font-size:.6rem;padding:1px 4px}.card--hover-preview .ability-track{width:7px;height:16px}.ability-track--notched{display:inline-block;width:8px;height:14px;border-radius:2px;vertical-align:middle;margin:0 2px;position:relative;box-shadow:0 1px 2px #0000004d}.ability-track--notched:before,.ability-track--notched:after{content:"";position:absolute;left:0;right:0;height:1px;background:#0006}.ability-track--notched:before{top:33%}.ability-track--notched:after{top:66%}.ability-track--notched.ability-track--blue{background:linear-gradient(180deg,#00d9ff,#0099b3)}.ability-track--notched.ability-track--yellow{background:linear-gradient(180deg,gold,#b8860b)}.ability-track--notched.ability-track--red{background:linear-gradient(180deg,#e94560,#b83550)}.ability-track--stacked{display:inline-flex!important;align-items:center;justify-content:center;width:16px!important;height:16px!important;border-radius:3px!important;vertical-align:middle;margin:0 2px;box-shadow:none!important;position:relative}.ability-track--stacked span{display:block;width:8px;height:8px;border-radius:50%;box-shadow:0 1px 2px #0000004d}.ability-track--stacked span:after{content:"";position:absolute;top:5px;left:5px;width:3px;height:3px;background:#fff6;border-radius:50%}.ability-track--stacked.ability-track--blue{background:#60a5fa40!important;border:1px solid rgba(96,165,250,.5)}.ability-track--stacked.ability-track--blue span{background:linear-gradient(135deg,#60a5fa,#2563eb)}.ability-track--stacked.ability-track--yellow{background:#fbbf2440!important;border:1px solid rgba(251,191,36,.5)}.ability-track--stacked.ability-track--yellow span{background:linear-gradient(135deg,#fbbf24,#d97706)}.ability-track--stacked.ability-track--red{background:#f8717140!important;border:1px solid rgba(248,113,113,.5)}.ability-track--stacked.ability-track--red span{background:linear-gradient(135deg,#f87171,#dc2626)}.card--compact .ability-track--notched{width:6px;height:10px}.card--compact .ability-track--stacked{width:12px!important;height:12px!important}.card--compact .ability-track--stacked span{width:6px;height:6px}.card--compact .ability-track--stacked span:after{top:4px;left:4px;width:2px;height:2px}.card--hover-preview .ability-track--notched{width:9px;height:16px}.card--hover-preview .ability-track--stacked{width:18px!important;height:18px!important}.card--hover-preview .ability-track--stacked span{width:10px;height:10px}.card--hover-preview .ability-track--stacked span:after{top:5px;left:5px;width:4px;height:4px}.lobby{display:flex;flex-direction:column;align-items:center;gap:2rem;max-width:500px;width:100%}.lobby h1{font-family:var(--font-display);font-size:3rem;font-weight:700;letter-spacing:.06em;background:linear-gradient(135deg,var(--color-x),var(--color-o));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;text-shadow:0 0 40px rgba(233,69,96,.3),0 0 80px rgba(0,217,255,.15);filter:drop-shadow(0 0 20px rgba(233,69,96,.2)) drop-shadow(0 0 40px rgba(0,217,255,.1));position:relative}.lobby h1:after{content:"";position:absolute;bottom:-.5rem;left:50%;transform:translate(-50%);width:60%;height:2px;background:linear-gradient(90deg,transparent,var(--color-o),var(--color-x),var(--color-o),transparent);opacity:.6}.lobby-rejoin-code{font-size:.9rem;color:var(--color-text-muted)}.rejoin-code-value{font-weight:700;color:#c9a0ff;cursor:pointer;letter-spacing:.05em}.rejoin-code-value:hover{text-decoration:underline}.private-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--color-text-muted);cursor:pointer;margin-bottom:.75rem}.private-toggle input[type=checkbox]{accent-color:var(--color-primary);width:16px;height:16px;cursor:pointer}.lobby-section{width:100%;padding:1.5rem;background:var(--color-surface);border-radius:var(--border-radius);box-shadow:0 4px 16px #0003,inset 0 1px #ffffff08;border:1px solid rgba(255,255,255,.04)}.lobby-section--active-games{border:1px solid rgba(201,160,255,.2);background:linear-gradient(135deg,var(--color-surface),rgba(45,31,78,.5))}.lobby-section h2{font-family:var(--font-display);font-size:1.15rem;font-weight:600;margin-bottom:.5rem;color:var(--color-text);letter-spacing:.02em}.lobby-section p{font-size:.875rem;color:var(--color-text-muted);margin-bottom:1rem}.room-code-input{display:flex;gap:.75rem}.room-code-input input{flex:1;padding:.75rem 1rem;font-size:1.25rem;font-weight:600;text-align:center;letter-spacing:.2em;text-transform:uppercase;border:2px solid var(--color-secondary);border-radius:var(--border-radius);background:var(--color-bg);color:var(--color-text)}.room-code-input input:focus{outline:none;border-color:var(--color-o)}.room-code-input input::placeholder{color:var(--color-text-muted);letter-spacing:.3em}.room-list{display:flex;flex-direction:column;gap:.75rem}.room-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--color-bg);border-radius:var(--border-radius);border:1px solid var(--color-secondary)}.room-info{display:flex;flex-direction:column;gap:.25rem}.room-code{font-size:1.125rem;font-weight:600;letter-spacing:.1em;color:var(--color-o)}.room-players{font-size:.75rem;color:var(--color-text-muted)}.no-rooms{text-align:center;color:var(--color-text-muted);font-style:italic}.player-name-input{width:100%;max-width:300px;padding:.75rem 1rem;margin-bottom:.75rem;font-size:1rem;background:var(--color-secondary);border:2px solid rgba(255,255,255,.1);border-radius:var(--border-radius);color:var(--color-text);transition:all var(--transition-speed) ease}.player-name-input:focus{outline:none;border-color:var(--color-o);box-shadow:0 0 10px #00d9ff33}.player-name-input::placeholder{color:var(--color-text-muted)}.player-count-selector{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.player-count-label{color:var(--color-text);font-weight:500}.player-count-buttons{display:flex;gap:.5rem}.ruleset-selector{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.ruleset-label{color:var(--color-text);font-weight:500}.ruleset-dropdown{padding:.5rem .75rem;font-size:.9rem;background:var(--color-bg);border:2px solid var(--color-secondary);border-radius:var(--border-radius);color:var(--color-text);cursor:pointer}.ruleset-dropdown:focus{outline:none;border-color:var(--color-o)}.download-rules-button{padding:.4rem .75rem;font-size:.8rem;font-weight:500;color:var(--color-o);text-decoration:none;border:1px solid var(--color-o);border-radius:var(--border-radius);transition:all var(--transition-speed) ease}.download-rules-button:hover{background:#00d9ff1a}.custom-rules-button{padding:.4rem .75rem;font-size:.8rem;font-weight:500;color:#c9a0ff;background:transparent;border:1px solid #c9a0ff;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease}.custom-rules-button:hover{background:#a78bfa1a}.custom-ruleset-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.custom-ruleset-modal{background:var(--color-surface);border-radius:var(--border-radius);border:2px solid #c9a0ff;max-width:500px;width:90%;display:flex;flex-direction:column;box-shadow:0 10px 40px #a78bfa4d}.custom-ruleset-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.custom-ruleset-header h2{margin:0;font-size:1.25rem;color:#c9a0ff}.custom-ruleset-close{background:transparent;border:none;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:.25rem;line-height:1;transition:color var(--transition-speed) ease}.custom-ruleset-close:hover{color:var(--color-text)}.custom-ruleset-content{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.custom-ruleset-info{font-size:.875rem;color:var(--color-text-muted);line-height:1.5}.custom-ruleset-files{display:flex;flex-direction:column;gap:.75rem}.custom-ruleset-file-row{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#0003;border-radius:var(--border-radius);border:1px solid rgba(255,255,255,.06)}.custom-ruleset-file-info{display:flex;flex-direction:column;gap:.15rem}.custom-ruleset-file-name{font-size:.9rem;font-weight:600;color:var(--color-text);font-family:monospace}.custom-ruleset-file-desc{font-size:.75rem;color:var(--color-text-muted)}.custom-ruleset-file-actions{display:flex;align-items:center;gap:.5rem}.custom-ruleset-file-selected{font-size:.8rem;color:#4ade80;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.custom-ruleset-file-clear{background:transparent;border:none;color:var(--color-text-muted);font-size:1.25rem;cursor:pointer;padding:0 .25rem;line-height:1}.custom-ruleset-file-clear:hover{color:#f87171}.custom-ruleset-file-upload{padding:.35rem .75rem;font-size:.8rem;font-weight:500;color:var(--color-o);border:1px solid var(--color-o);border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease}.custom-ruleset-file-upload:hover{background:#00d9ff1a}.custom-ruleset-errors{padding:.75rem;background:#f871711a;border:1px solid rgba(248,113,113,.3);border-radius:var(--border-radius);color:#f87171;font-size:.8rem}.custom-ruleset-errors strong{display:block;margin-bottom:.5rem}.custom-ruleset-errors ul{margin:0;padding-left:1.25rem}.custom-ruleset-errors li{margin-bottom:.25rem;word-break:break-word}.custom-ruleset-success{padding:.75rem;background:#4ade801a;border:1px solid rgba(74,222,128,.3);border-radius:var(--border-radius);color:#4ade80;font-size:.875rem;font-weight:500}.custom-ruleset-warnings{margin:.5rem 0 0;padding-left:1.25rem;color:#fbbf24;font-weight:400;font-size:.8rem}.custom-ruleset-buttons{display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.5rem;border-top:1px solid rgba(255,255,255,.1)}@media (max-width: 480px){.lobby{padding:0 1rem}.lobby h1{font-size:2.25rem;letter-spacing:.04em}.lobby h1:after{width:80%}.room-code-input{flex-direction:column}.room-code-input input,.join-button{width:100%}}.waiting-room{display:flex;flex-direction:column;align-items:center;gap:1.5rem;max-width:500px;width:100%}.waiting-room h1{font-family:var(--font-display);font-size:2rem;font-weight:700;color:var(--color-text);letter-spacing:.04em}.room-code-section{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:1.5rem;background:var(--color-surface);border-radius:var(--border-radius);width:100%}.room-code-section p{font-size:.875rem;color:var(--color-text-muted)}.room-code-display{font-family:var(--font-display);font-size:2.5rem;font-weight:700;letter-spacing:.3em;padding:1rem 2rem;background:linear-gradient(135deg,#2d5a87,#1a3a5c);border:2px solid var(--color-o);border-radius:var(--border-radius);color:var(--color-o);cursor:pointer;transition:all var(--transition-speed) ease;text-shadow:0 0 10px rgba(0,217,255,.3)}.room-code-display:hover{background:linear-gradient(135deg,#3d7ab5,#2d5a87);transform:scale(1.02)}.copied-message{font-size:.875rem;color:#4ade80;font-weight:500}.player-slots{display:flex;flex-direction:column;gap:.75rem;width:100%}.player-slot{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.25rem;background:var(--color-surface);border-radius:var(--border-radius);border:2px solid var(--color-secondary);transition:all var(--transition-speed) ease}.player-slot--p1{border-color:#e9456040}.player-slot--p2{border-color:#00d9ff40}.player-slot--p3{border-color:#4ade8040}.player-slot--p4{border-color:#f59e0b40}.player-slot--filled.player-slot--p1{border-color:var(--color-x);background:linear-gradient(135deg,rgba(233,69,96,.1),transparent)}.player-slot--filled.player-slot--p2{border-color:var(--color-o);background:linear-gradient(135deg,rgba(0,217,255,.1),transparent)}.player-slot--filled.player-slot--p3{border-color:var(--color-p3);background:linear-gradient(135deg,rgba(74,222,128,.1),transparent)}.player-slot--filled.player-slot--p4{border-color:var(--color-p4);background:linear-gradient(135deg,rgba(245,158,11,.1),transparent)}.player-slot-label{font-weight:600;font-size:1rem}.player-slot--p1 .player-slot-label{color:var(--color-x)}.player-slot--p2 .player-slot-label{color:var(--color-o)}.player-slot--p3 .player-slot-label{color:var(--color-p3)}.player-slot--p4 .player-slot-label{color:var(--color-p4)}.player-slot-status{font-size:.875rem;color:#4ade80;font-weight:500}.player-slot-waiting{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.player-slot--disconnected{opacity:.7;border-style:dashed}.player-slot--disconnected .player-slot-status{display:flex;flex-wrap:wrap;align-items:center;gap:4px}.waiting-status{padding:1rem;background:var(--color-surface);border-radius:var(--border-radius);text-align:center;width:100%}.waiting-status p{color:var(--color-text-muted)}.waiting-actions{display:flex;flex-direction:column;gap:.75rem;width:100%}.waiting-info{font-size:.875rem;color:var(--color-text-muted);text-align:center}.room-code-badge{padding:.5rem 1rem;background:var(--color-secondary);border-radius:var(--border-radius);font-size:.875rem;font-weight:600;color:var(--color-o);letter-spacing:.05em}.rejoin-code-badge{padding:.5rem 1rem;background:var(--color-secondary);border-radius:var(--border-radius);font-size:.875rem;font-weight:600;color:var(--color-o);letter-spacing:.05em;cursor:pointer}.rejoin-code-badge:hover{opacity:.8}.rejoin-code-section{text-align:center;margin-bottom:1rem;font-size:.9rem;color:var(--color-text-secondary, #aaa)}.rejoin-code-label{font-weight:400}.rejoin-code-value{font-weight:700;font-family:monospace;font-size:1rem;letter-spacing:.1em;cursor:pointer;color:var(--color-text, #fff)}.rejoin-code-value:hover{opacity:.8}@media (max-width: 480px){.waiting-room{padding:0 1rem}.room-code-display{font-size:1.75rem;padding:.75rem 1.5rem;letter-spacing:.2em}.waiting-actions{gap:.5rem}}.connecting-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem;min-height:50vh}.connecting-screen h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--color-x),var(--color-o));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.connecting-screen p{color:var(--color-text-muted);font-size:1.125rem}.player-area{width:100%;max-width:600px;padding:1rem;border-radius:var(--border-radius);background:var(--color-surface);box-shadow:0 4px 16px #0003}.player-area--p1{border:2px solid #e94560;background:linear-gradient(135deg,rgba(233,69,96,.1),transparent)}.player-area--p2{border:2px solid #00d9ff;background:linear-gradient(135deg,rgba(0,217,255,.1),transparent)}.player-area--p3{border:2px solid #4ade80;background:linear-gradient(135deg,rgba(74,222,128,.1),transparent)}.player-area--p4{border:2px solid #f59e0b;background:linear-gradient(135deg,rgba(245,158,11,.1),transparent)}.area-label{display:flex;align-items:center;gap:.75rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.1em;margin-bottom:.75rem;padding-bottom:.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.area-label-name{display:flex;align-items:center;gap:.25rem}.area-label-prestige{font-family:var(--font-display);font-size:1rem;font-weight:700;padding:.15rem .5rem;background:#a855f726;border:1px solid rgba(168,85,247,.3);border-radius:4px;color:var(--color-prestige)}.area-label-prestige--p1{color:#e94560;border-color:#e9456066;background:#e9456026}.area-label-prestige--p2{color:#00d9ff;border-color:#00d9ff66;background:#00d9ff26}.area-label-prestige--p3{color:#4ade80;border-color:#4ade8066;background:#4ade8026}.area-label-prestige--p4{color:#f59e0b;border-color:#f59e0b66;background:#f59e0b26}.player-area--p1 .area-label{color:#e94560}.player-area--p2 .area-label{color:#00d9ff}.player-area--p3 .area-label{color:#4ade80}.player-area--p4 .area-label{color:#f59e0b}.player-area-content{display:flex;flex-direction:column;gap:1rem}.player-top-row{display:flex;align-items:flex-start;gap:1.5rem}.player-bottom-row{width:100%}.slot-display-content{display:flex;flex-direction:column;align-items:center;gap:.25rem}.slot-display-trait{background:#c9a0ff33;border:1px solid rgba(201,160,255,.4);border-radius:4px;padding:2px 6px;font-size:.6rem;color:#c9a0ff;max-width:70px;text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.slot-display-trait-name{font-weight:500}.game--new-layout{width:100%;max-width:900px}.players-container{display:flex;gap:1rem;width:100%;align-items:stretch}.player-area--primary{flex:1.5;transform:scale(1.02)}.player-area--secondary{flex:1;opacity:.9}.spectator-player--p1{border-left:3px solid #e94560}.spectator-player--p2{border-left:3px solid #00d9ff}.spectator-player--p1 .spectator-player-label{color:#e94560}.spectator-player--p2 .spectator-player-label{color:#00d9ff}.spectator-player--p3{border-left:3px solid #4ade80}.spectator-player--p4{border-left:3px solid #f59e0b}.spectator-player--p3 .spectator-player-label{color:#4ade80}.spectator-player--p4 .spectator-player-label{color:#f59e0b}.selected-cards-area{flex:1;display:flex;flex-direction:column;gap:.5rem}.selected-cards-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.selected-cards{display:flex;gap:.5rem;flex-wrap:wrap;min-height:60px;align-items:center}.selected-cards .card{width:50px;height:70px;font-size:1.25rem}.no-cards{font-size:.875rem;color:var(--color-text-muted);font-style:italic}.spectator-info{display:flex;gap:2rem;padding:1rem;background:var(--color-surface);border-radius:var(--border-radius)}.spectator-player{display:flex;flex-direction:column;gap:.25rem;padding:.5rem 1rem}.spectator-player-label{font-weight:600;font-size:.875rem}.spectator-player:first-child .spectator-player-label{color:#e94560}.spectator-player:last-child .spectator-player-label{color:#00d9ff}.collected-cards-area{flex:1;display:flex;flex-direction:column;gap:.5rem}.collected-cards-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.collected-cards{display:flex;gap:.5rem;flex-wrap:wrap;min-height:60px;align-items:center}.collected-cards .card{width:50px;height:70px;font-size:1.25rem}.player-left-section{display:flex;flex-direction:column;gap:1rem}.player-slots-display{display:flex;flex-direction:column;gap:.5rem}.slots-display-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.slots-display{display:flex;gap:.5rem}.slot-display{width:50px;height:70px;display:flex;align-items:center;justify-content:center;border-radius:4px}.slot-display--empty{border:1px dashed var(--color-text-muted)}.slot-display--filled .card{width:50px;height:70px;font-size:1.25rem}.slot-display-empty{color:var(--color-text-muted);font-size:1.5rem}.pending-cards-display{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#c9a0ff1a;border:1px solid rgba(201,160,255,.3);border-radius:var(--border-radius)}.pending-cards-display-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:#c9a0ff;font-weight:600}.pending-cards-display-list{display:flex;gap:.5rem;flex-wrap:wrap}.pending-cards-display-list .card{width:45px;height:63px;font-size:1.1rem}.players-container--tabbed{flex-direction:column;gap:0}.player-tabs{display:flex;gap:0;width:100%}.player-tab{flex:1;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid transparent;border-bottom:none;border-radius:var(--border-radius) var(--border-radius) 0 0;background:var(--color-secondary);color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-speed) ease;position:relative}.player-tab:hover:not(.player-tab--active){background:#1a4a80;color:var(--color-text)}.player-tab--p1{border-color:#e94560;color:#e94560;background:linear-gradient(135deg,rgba(233,69,96,.15),transparent)}.player-tab--p2{border-color:#00d9ff;color:#00d9ff;background:linear-gradient(135deg,rgba(0,217,255,.15),transparent)}.player-tab--p3{border-color:#4ade80;color:#4ade80;background:linear-gradient(135deg,rgba(74,222,128,.15),transparent)}.player-tab--p4{border-color:#f59e0b;color:#f59e0b;background:linear-gradient(135deg,rgba(245,158,11,.15),transparent)}.player-tab--active.player-tab--p1{background:linear-gradient(135deg,rgba(233,69,96,.3),transparent);border-bottom:2px solid transparent;box-shadow:inset 0 -2px 8px #e945604d}.player-tab--active.player-tab--p2{background:linear-gradient(135deg,rgba(0,217,255,.3),transparent);border-bottom:2px solid transparent;box-shadow:inset 0 -2px 8px #00d9ff4d}.player-tab--active.player-tab--p3{background:linear-gradient(135deg,rgba(74,222,128,.3),transparent);border-bottom:2px solid transparent;box-shadow:inset 0 -2px 8px #4ade804d}.player-tab--active.player-tab--p4{background:linear-gradient(135deg,rgba(245,158,11,.3),transparent);border-bottom:2px solid transparent;box-shadow:inset 0 -2px 8px #f59e0b4d}.player-tab-prestige{margin-left:.5rem;background:var(--color-prestige-gradient);color:var(--color-prestige-text);font-size:.85rem;font-weight:700;padding:2px 6px;border-radius:3px;min-width:24px;text-align:center;box-shadow:0 1px 3px #0000004d;cursor:help}.player-tab--you:after{content:"";position:absolute;bottom:-2px;left:50%;transform:translate(-50%);width:6px;height:6px;background:currentColor;border-radius:50%;opacity:.7}.player-tab--active.player-tab--you:after{opacity:1}.player-tab--disconnected{opacity:.6;border-style:dashed}.player-tab--disconnected:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(45deg,transparent,transparent 5px,rgba(0,0,0,.1) 5px,rgba(0,0,0,.1) 10px);pointer-events:none}.player-tab--passed{opacity:.5;filter:grayscale(.4)}.player-tab--passed .passed-out-indicator{display:inline-block;margin-left:.4rem;font-size:.7rem;font-weight:600;color:#f59e0b;text-transform:uppercase;letter-spacing:.05em}.player-area--tabbed{border-radius:0 0 var(--border-radius) var(--border-radius);max-width:none;width:100%}.student-slot-display--graduating{outline:3px solid #4ade80;outline-offset:2px;background:#4ade801a;border-radius:var(--border-radius)}.student-slot-display--must-graduate{outline:2px dashed #f59e0b;outline-offset:2px;border-radius:var(--border-radius)}.student-slot-content--clickable{cursor:pointer}.student-slot-content--clickable:hover{transform:translateY(-2px);transition:transform var(--transition-speed) ease}.student-slot-permanent-traits{display:flex;flex-wrap:wrap;gap:.25rem;margin-top:.5rem;justify-content:center}.student-slot-trait-area{width:100%;padding:.5rem;margin-top:.5rem;background:#a78bfa1a;border:1px dashed rgba(167,139,250,.4);border-radius:4px;cursor:pointer;text-align:center;transition:all var(--transition-speed) ease}.student-slot-trait-area:hover{background:#a78bfa33;border-color:#a78bfa99}.student-slot-trait-area--assigned{background:#a78bfa26;border-style:solid;border-color:#a78bfa80}.student-slot-trait-badge{display:flex;flex-direction:column;gap:.125rem}.student-slot-trait-name{font-size:.75rem;font-weight:600;color:#c9a0ff}.student-slot-trait-change{font-size:.65rem;color:var(--color-text-muted)}.student-slot-trait-prompt{font-size:.75rem;color:#a78bfa;font-weight:500}.student-slot-graduation-marker{display:block;margin-top:.5rem;padding:.25rem .5rem;background:linear-gradient(135deg,#4ade80,#22c55e);color:#1a1a2e;font-size:.7rem;font-weight:700;border-radius:4px;text-align:center}.student-slot-must-graduate{display:block;margin-top:.5rem;padding:.25rem .5rem;background:#f59e0b33;border:1px solid #f59e0b;color:#f59e0b;font-size:.65rem;font-weight:600;border-radius:4px;text-align:center}.student-slot-graduate-hint{display:block;margin-top:.5rem;font-size:.65rem;color:var(--color-text-muted);text-align:center}.student-slot-locked-hint{display:block;margin-top:.25rem;font-size:.6rem;color:var(--color-text-muted);text-align:center;font-style:italic}.players-container--tabbed .player-area{border-top-left-radius:0;border-top-right-radius:0}@media (max-width: 768px){.players-container{flex-direction:column}.player-area--primary{transform:none}.player-area--secondary{opacity:1}}@media (max-width: 480px){.opponent-content,.my-content{flex-direction:column;align-items:stretch}.prestige-counter,.prestige-counter--opponent{width:100%}.selected-cards .card,.collected-cards .card{width:40px;height:56px;font-size:1rem}.player-tab{padding:.5rem 1rem;font-size:.875rem}.slot-display{width:40px;height:56px}.slot-display--filled .card{width:40px;height:56px;font-size:1rem}}.action-phase-section{width:100%;display:flex;flex-direction:column;gap:.75rem;padding:1rem;background:#6b4fa31a;border-radius:var(--border-radius);border:1px solid rgba(107,79,163,.3);margin-top:.5rem}.action-phase-buttons{display:flex;gap:.75rem;justify-content:center;padding-top:.5rem}.action-phase-buttons button{padding:.75rem 1.5rem;font-size:.875rem;font-weight:600;border:none;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease}.action-phase-buttons .confirm-assignment-button,.action-phase-buttons .confirm-graduation-button{background:linear-gradient(135deg,#6b4fa3,#9b59b6);color:#fff}.action-phase-buttons .confirm-assignment-button:hover:not(:disabled),.action-phase-buttons .confirm-graduation-button:hover:not(:disabled){background:linear-gradient(135deg,#7b5fb3,#ab69c6);transform:translateY(-1px)}.action-phase-buttons button:disabled{opacity:.5;cursor:not-allowed}.action-phase-buttons .finish-action-button{background:linear-gradient(135deg,#4ade80,#22c55e);color:#1a1a2e}.action-phase-buttons .finish-action-button:hover{background:linear-gradient(135deg,#5aee90,#32d56e)}.action-phase-buttons .reset-action-button{background:linear-gradient(135deg,#6b7280,#4b5563);color:#e5e7eb}.action-phase-buttons .reset-action-button:hover{background:linear-gradient(135deg,#7b8290,#5b6573);transform:translateY(-1px)}.action-header-pending{background:#c9a0ff1a;border-radius:var(--border-radius);padding:.75rem}.action-header-pending .pending-cards{justify-content:center}.action-phase-indicator{display:flex;align-items:center;justify-content:center;gap:1rem;padding:.75rem;background:#6b4fa31a;border-radius:var(--border-radius)}.phase-step{padding:.5rem 1rem;border-radius:4px;font-size:.875rem;font-weight:600;color:var(--color-text-muted);background:transparent;border:1px solid var(--color-text-muted);transition:all var(--transition-speed) ease}.phase-step--active{color:#c9a0ff;border-color:#c9a0ff;background:#c9a0ff26;box-shadow:0 0 10px #c9a0ff4d}.phase-step--complete{color:#4ade80;border-color:#4ade80;background:#4ade801a}.phase-arrow{color:var(--color-text-muted);font-size:1.25rem}.card-slot--removable:hover{border-color:var(--color-primary);background:#e945601a}.pending-cards-section{display:flex;flex-direction:column;gap:.75rem}.pending-cards-label{display:flex;align-items:center;gap:1rem;font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#c9a0ff}.pending-cards{display:flex;gap:.75rem;flex-wrap:wrap}.card-slots-section{display:flex;flex-direction:column;gap:.75rem}.card-slots-label{font-size:.875rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text)}.slots-hint{font-size:.75rem;font-weight:400;text-transform:none;letter-spacing:normal;color:var(--color-text-muted)}.card-slots{display:flex;gap:1rem;justify-content:center}.card-slot{width:110px;min-height:200px;display:flex;align-items:flex-start;justify-content:center;padding-top:.5rem;border-radius:var(--border-radius);transition:all var(--transition-speed) ease;cursor:pointer}.card-slot--empty{border:2px dashed var(--color-text-muted);background:#ffffff05}.card-slot--empty:hover{border-color:#c9a0ff;background:#c9a0ff1a}.card-slot--filled{border:2px solid transparent}.card-slot--target{border-color:#c9a0ff!important;background:#c9a0ff26!important;animation:slot-pulse .8s ease infinite alternate}.card-slot--locked{cursor:default;opacity:.8}.slot-empty-label{color:var(--color-text-muted);font-size:.875rem}.slotted-card-area{display:flex;flex-direction:column;align-items:center}.slot-permanent-traits{display:flex;flex-wrap:wrap;gap:.25rem;padding:.25rem;margin-top:.5rem}.slot-permanent-trait{font-size:.55rem;padding:2px 4px;background:#6464644d;border:1px solid rgba(150,150,150,.4);border-radius:3px;color:var(--color-text-muted)}.slot-trait-area{width:100%;padding:.5rem;margin-top:.5rem;background:#a78bfa1a;border:1px dashed rgba(167,139,250,.4);border-radius:4px;cursor:pointer;text-align:center;transition:all var(--transition-speed) ease}.slot-trait-area:hover:not(.slot-trait-area--locked){background:#a78bfa33;border-color:#a78bfa99}.slot-trait-area--assigned{background:#a78bfa26;border-style:solid;border-color:#a78bfa80}.slot-trait-area--locked{opacity:.7;cursor:default}.slot-trait-prompt{font-size:.75rem;color:#a78bfa;font-weight:500}.slot-trait-badge{display:flex;flex-direction:column;gap:.125rem}.slot-trait-name{font-size:.75rem;font-weight:600;color:#c9a0ff}.slot-trait-change{font-size:.65rem;color:var(--color-text-muted)}.discard-warning{padding:.75rem;background:#e9456026;border:1px solid var(--color-primary);border-radius:var(--border-radius);color:var(--color-primary);font-weight:500;text-align:center}.traits-warning{padding:.75rem;background:#fbbf2426;border:1px solid #fbbf24;border-radius:var(--border-radius);color:#fbbf24;font-weight:500;text-align:center}.outbid-warning{color:orange;font-weight:600;padding:.5rem;background:#ffa5001a;border-radius:4px;margin-bottom:.5rem}.cannot-afford{color:#f44;font-weight:600;padding:.5rem;background:#ff44441a;border-radius:4px}.exp-display{display:flex;align-items:center;flex-wrap:wrap;gap:.5rem 1rem;padding:.75rem;background:#a78bfa1a;border-radius:var(--border-radius);border:1px solid rgba(167,139,250,.3)}.exp-display-label{font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.exp-amount{display:flex;align-items:center;gap:.25rem;font-size:.875rem;font-weight:600}.exp-amount--blue{color:#60a5fa}.exp-amount--yellow{color:#fbbf24}.exp-amount--red{color:#f87171}.exp-square{width:12px;height:12px;border-radius:2px}.exp-square--blue{background:#60a5fa}.exp-square--yellow{background:#fbbf24}.exp-square--red{background:#f87171}.exp-amount--wildcard{color:#c4b5fd}.exp-square--wildcard{background:var(--color-wildcard-gradient)}@media (max-width: 480px){.action-round-container{padding:1rem;gap:1rem}.card-slots{gap:.5rem}.card-slot{width:70px;height:100px}.pending-cards{gap:.5rem}.pending-cards .card{width:55px;height:80px;font-size:1.5rem}}.tracks-container{width:100%;display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem;padding:.75rem;background:#0003;border-radius:var(--border-radius)}.tracks-exp-row{display:flex;align-items:center;gap:.25rem;margin-bottom:.25rem}.tracks-exp-label{width:80px;font-size:.7rem;color:var(--color-text-muted);text-align:right;padding-right:.5rem}.track-exp{height:20px;display:flex;align-items:center;justify-content:center;font-size:.7rem;color:#a78bfa;background:#a78bfa1a;border-radius:4px}.track-exp--start{width:36px}.track-exp--step{width:56px;text-align:center}.track{display:flex;align-items:center;gap:.25rem}.track-label{width:80px;font-size:.75rem;font-weight:500;text-align:right;padding-right:.5rem}.track--yellow .track-label{color:#fbbf24}.track--blue .track-label{color:#60a5fa}.track--red .track-label{color:#f87171}.track-steps{display:flex;gap:.25rem}.track-steps-with-connectors,.track-step-group{display:flex;align-items:center}.track-connector{width:24px;display:flex;align-items:center;justify-content:center;position:relative}.track-connector-line{position:absolute;width:100%;height:2px;background:#fff3}.track-connector-cost{font-size:.6rem;color:var(--color-text-muted);background:#0009;padding:1px 4px;border-radius:3px;z-index:1}.track-step{width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:4px;position:relative;transition:all var(--transition-speed)}.track-step--start{background:#ffffff1a;border:2px dashed rgba(255,255,255,.2)}.track--yellow .track-step:not(.track-step--start){background:#fbbf2426;border:1px solid rgba(251,191,36,.3)}.track--blue .track-step:not(.track-step--start){background:#60a5fa26;border:1px solid rgba(96,165,250,.3)}.track--red .track-step:not(.track-step--start){background:#f8717126;border:1px solid rgba(248,113,113,.3)}.track-step--current{box-shadow:0 0 8px #ffffff4d}.track--yellow .track-step--passed{background:#fbbf2466}.track--blue .track-step--passed{background:#60a5fa66}.track--red .track-step--passed{background:#f8717166}.track-token{width:24px;height:24px;border-radius:50%;box-shadow:0 2px 4px #0000004d;position:relative}.track-token:after{content:"";position:absolute;top:4px;left:4px;width:8px;height:8px;background:#fff6;border-radius:50%}.track-token--yellow{background:linear-gradient(135deg,#fbbf24,#d97706)}.track-token--blue{background:linear-gradient(135deg,#60a5fa,#2563eb)}.track-token--red{background:linear-gradient(135deg,#f87171,#dc2626)}.track-resources-needed{font-size:.7rem;font-weight:700;color:var(--color-text);background:#00000080;padding:2px 6px;border-radius:4px}.track-resources-ready{color:#4ade80;background:#4ade8033}.track-progress{font-size:.65rem;color:var(--color-text-muted);padding-left:.5rem;min-width:40px}@media (max-width: 600px){.tracks-container{padding:.5rem}.track-label{width:60px;font-size:.65rem}.tracks-costs-label{width:60px;font-size:.6rem}.track-step{width:28px;height:28px}.track-cost{width:28px;font-size:.6rem}.track-token{width:18px;height:18px}.track-token:after{width:6px;height:6px;top:3px;left:3px}.track-resources-needed{font-size:.6rem;padding:1px 4px}.track-progress{font-size:.55rem;min-width:30px}}.graduation-preview{display:flex;flex-direction:column;gap:.5rem;padding:.75rem;background:#4ade801a;border:1px solid rgba(74,222,128,.4);border-radius:var(--border-radius)}.graduation-preview-label{font-size:.8rem;font-weight:600;color:#4ade80}.graduation-preview-rewards{display:flex;flex-direction:column;gap:.25rem}.graduation-reward{font-size:.875rem;font-weight:600}.graduation-reward--prestige{color:#fbbf24}.graduation-reward--pips{display:flex;align-items:center;gap:.25rem;color:var(--color-text-muted)}.pip-preview{font-weight:700;margin-left:.25rem}.pip-preview--blue{color:#60a5fa}.pip-preview--yellow{color:#fbbf24}.pip-preview--red{color:#f87171}.graduation-preview-hint{font-size:.75rem;color:var(--color-text-muted);font-style:italic}.graduation-warning{padding:.75rem;background:#fbbf2426;border:1px solid #fbbf24;border-radius:var(--border-radius);color:#fbbf24;font-weight:500;text-align:center;font-size:.875rem}.card-slot--graduating{border-color:#4ade80!important;background:#4ade8026!important;box-shadow:0 0 15px #4ade8066}.card-slot--must-graduate:not(.card-slot--graduating){border-color:#fbbf24!important;box-shadow:0 0 10px #fbbf244d}.slotted-card-wrapper--graduating{position:relative}.slotted-card-wrapper--graduating .card{border-color:#4ade80!important}.graduation-marker{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);background:#4ade80e6;color:#0a0a0a;font-size:.6rem;font-weight:700;padding:4px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap;z-index:10}.must-graduate-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.55rem;color:#fbbf24;white-space:nowrap;font-weight:600}.graduate-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.55rem;color:var(--color-text-muted);white-space:nowrap;opacity:0;transition:opacity var(--transition-speed) ease}.card-slot:hover .graduate-hint{opacity:1}.slot-traits-display{display:flex;flex-direction:column;gap:2px;margin-top:4px;max-width:100%}.slot-trait-name{font-size:.55rem;padding:2px 4px;background:#6464644d;border:1px solid rgba(150,150,150,.4);border-radius:3px;color:var(--color-text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.pending-card-wrapper--discardable{position:relative;cursor:pointer}.pending-card-wrapper--discardable:hover .card{border-color:var(--color-primary)!important;box-shadow:0 0 15px #e9456066}.discard-hint{position:absolute;bottom:-18px;left:50%;transform:translate(-50%);font-size:.55rem;color:var(--color-primary);white-space:nowrap;font-weight:600}.discard-phase-section{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;background:#e945601a;border:1px solid rgba(233,69,96,.4);border-radius:var(--border-radius)}.discard-phase-label{font-size:1rem;font-weight:600;color:var(--color-primary);text-align:center}.discard-cost-warning{font-size:.85rem;color:#f59e0b;background:#f59e0b1a;padding:.4rem .8rem;border-radius:var(--border-radius);border:1px solid rgba(245,158,11,.3);text-align:center}.discard-students{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding-bottom:1.5rem}.discard-card-wrapper{position:relative;cursor:pointer;transition:transform var(--transition-speed) ease}.discard-card-wrapper:hover{transform:translateY(-4px)}.discard-card-wrapper:hover .card{border-color:var(--color-primary)!important;box-shadow:0 0 15px #e9456080}.discard-card-wrapper .discard-hint{position:absolute;bottom:-20px;left:50%;transform:translate(-50%);font-size:.6rem;color:var(--color-primary);white-space:nowrap;font-weight:600;opacity:.8}.traits-toggle-button{padding:.75rem 1.5rem;font-size:1rem;font-weight:600;border:2px solid #3a5a7a;border-radius:var(--border-radius);background:linear-gradient(135deg,#2a3040,#1a2030);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease}.traits-toggle-button:hover{background:linear-gradient(135deg,#3a4050,#2a3040);border-color:#4a7a9a;transform:translateY(-2px);box-shadow:0 4px 12px #0064964d}.traits-panel-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.traits-panel{background:var(--color-surface);border-radius:var(--border-radius);box-shadow:0 8px 32px #00000080;max-width:1200px;width:95%;max-height:95vh;overflow:hidden;display:flex;flex-direction:column}.traits-panel-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.traits-panel-header h2{font-size:1.5rem;font-weight:600;color:var(--color-text);margin:0}.traits-panel-close{padding:.5rem 1rem;font-size:1rem;font-weight:600;border:1px solid var(--color-text-muted);border-radius:var(--border-radius);background:transparent;color:var(--color-text-muted);cursor:pointer;transition:all var(--transition-speed) ease}.traits-panel-close:hover{border-color:var(--color-primary);color:var(--color-primary)}.traits-panel-content{padding:1.5rem;overflow-y:auto;flex:1}.traits-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(135px,1fr));gap:1rem;justify-items:center}.trait-wrapper{display:flex;flex-direction:column;align-items:center;gap:.25rem}.trait-wrapper--compact .card--trait{width:140px;height:195px}.trait-count{font-size:.875rem;font-weight:600;color:var(--color-text-muted)}.trait-count--infinite{color:#4ade80}.trait-count--limited{color:#fbbf24}.trait-count--out{color:#f87171}@media (max-width: 768px){.traits-panel-overlay,.traits-panel-header{padding:1rem}.traits-panel-header h2{font-size:1.25rem}.traits-panel-content{padding:1rem}.traits-grid{grid-template-columns:repeat(auto-fill,minmax(110px,1fr));gap:.75rem}.trait-wrapper--compact .card--trait{width:105px;height:147px}}@media (max-width: 480px){.traits-toggle-button{padding:.5rem 1rem;font-size:.875rem}.traits-grid{grid-template-columns:repeat(auto-fill,minmax(95px,1fr));gap:.5rem}.trait-wrapper--compact .card--trait{width:90px;height:126px}}.active-alumni-abilities{display:flex;flex-direction:column;gap:.5rem;padding:.5rem .75rem .75rem;background:#8a2be214;border:2px solid rgba(138,43,226,.4);border-radius:var(--border-radius);position:relative}.active-alumni-abilities-label{font-family:var(--font-display);font-size:.7rem;font-weight:600;color:#b388ff;text-transform:uppercase;letter-spacing:.08em;background:var(--color-bg);padding:.15rem .5rem;position:absolute;top:-.6rem;left:.75rem;border-radius:3px}.active-alumni-abilities-list{display:flex;flex-direction:row;flex-wrap:wrap;gap:.35rem;margin-top:.25rem}.alumni-ability-item{display:flex;align-items:center;padding:.25rem .5rem;background:#8a2be226;border-radius:4px;font-size:.75rem;color:var(--color-text);cursor:help}.alumni-ability-item:hover{background:#8a2be240}.alumni-ability-count{font-weight:700;color:#b388ff;margin-right:.25rem}.alumni-ability-source{font-weight:600;color:#b388ff}.alumni-ability-text{color:var(--color-text-muted)}.active-alumni-abilities-empty{font-size:.75rem;color:var(--color-text-muted);font-style:italic;padding:.25rem 0}.alumni-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.alumni-modal{background:var(--color-surface);border:2px solid rgba(138,43,226,.5);border-radius:var(--border-radius);max-width:90vw;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #00000080}.alumni-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;border-bottom:1px solid rgba(138,43,226,.3)}.alumni-modal-header h2{font-family:var(--font-display);font-size:1.25rem;color:#b388ff;margin:0}.alumni-modal-close{background:none;border:none;color:var(--color-text-muted);font-size:1.5rem;cursor:pointer;padding:0 .5rem;line-height:1}.alumni-modal-close:hover{color:var(--color-text)}.alumni-modal-content{padding:1.5rem;overflow-y:auto;flex:1}.alumni-modal-empty{text-align:center;color:var(--color-text-muted);font-style:italic;padding:2rem}.alumni-modal-grid{display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:center}.alumni-modal-student{display:flex;flex-direction:column;align-items:center}.alumni-button{background:#8a2be233;border:1px solid rgba(138,43,226,.5);border-radius:4px;color:#b388ff;font-size:.7rem;font-weight:600;padding:.25rem .5rem;cursor:pointer;transition:all var(--transition-speed) ease}.alumni-button:hover{background:#8a2be259;border-color:#8a2be2b3}.alumni-button:disabled{opacity:.5;cursor:not-allowed}.final-round-badge{color:var(--color-gold);font-weight:700;animation:pulse-glow 1.5s ease-in-out infinite}@keyframes pulse-glow{0%,to{opacity:1;text-shadow:0 0 4px var(--color-gold)}50%{opacity:.8;text-shadow:0 0 8px var(--color-gold)}}.game-over-container{background:linear-gradient(135deg,#1e1e32f2,#141423fa);border:2px solid var(--color-gold);border-radius:12px;padding:1.5rem 2rem;margin:1rem auto;max-width:500px;text-align:center;box-shadow:0 8px 32px #0006,0 0 20px #daa52033}.game-over-winner{display:flex;flex-direction:column;align-items:center;gap:.25rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid rgba(255,255,255,.1)}.winner-crown{font-size:3rem;line-height:1;animation:crown-bounce 2s ease-in-out infinite}@keyframes crown-bounce{0%,to{transform:translateY(0) rotate(0)}25%{transform:translateY(-4px) rotate(-3deg)}75%{transform:translateY(-4px) rotate(3deg)}}.winner-name{font-size:1.75rem;font-weight:700;color:var(--color-gold);text-shadow:0 2px 4px rgba(0,0,0,.3)}.winner-names{font-size:1.5rem;font-weight:700;color:var(--color-gold)}.winner-label{font-size:1.5rem;color:#ffffffe6;font-weight:600}.winner-prestige{font-size:1.25rem;color:var(--color-gold);display:flex;align-items:center;gap:.25rem;margin-top:.5rem}.game-over-rankings{text-align:left}.game-over-rankings h3{text-align:center;color:#ffffffe6;font-size:1.1rem;margin-bottom:.75rem}.rankings-list{display:flex;flex-direction:column;gap:.5rem}.ranking-row{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;background:#ffffff0d;border-radius:6px;border-left:3px solid transparent;transition:background .2s}.ranking-row:hover{background:#ffffff14}.ranking-row--winner{background:#daa52026;border-left-color:var(--color-gold)}.ranking-row--p1{border-left-color:var(--color-p1)}.ranking-row--p2{border-left-color:var(--color-p2)}.ranking-row--p3{border-left-color:var(--color-p3)}.ranking-row--p4{border-left-color:var(--color-p4)}.ranking-row--winner.ranking-row--p1{border-left-color:var(--color-p1);background:#e9456026}.ranking-row--winner.ranking-row--p2{border-left-color:var(--color-p2);background:#00d9ff26}.ranking-row--winner.ranking-row--p3{border-left-color:var(--color-p3);background:#4ade8026}.ranking-row--winner.ranking-row--p4{border-left-color:var(--color-p4);background:#f59e0b26}.ranking-position{font-weight:700;color:#fff9;min-width:1.5rem}.ranking-name{flex:1;color:#ffffffe6}.ranking-row--winner .ranking-name{color:var(--color-gold);font-weight:600}.ranking-prestige{color:var(--color-gold);font-weight:500}.graduation-notice--final{background:linear-gradient(135deg,#daa52033,#ffc1071a);border:1px solid var(--color-gold);color:var(--color-gold);padding:.75rem 1rem;border-radius:8px;font-weight:600;text-align:center;margin-bottom:1rem;animation:pulse-border 2s ease-in-out infinite}@keyframes pulse-border{0%,to{box-shadow:0 0 4px #daa52066}50%{box-shadow:0 0 12px #daa52099}}.favors-badge{display:inline-flex;align-items:center;gap:.25rem;background:#8b0000;color:gold;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;margin-left:.5rem}.favors-badge--zero{background:#3c3c3c80;color:#fff9}.favors-indicator{color:#ff6b6b;font-weight:600}.favors-indicator--zero{color:#ffffff80}.favors-info{color:#ff6b6b}.favors-warning{color:gold;background:#8b00004d;padding:.5rem;border-radius:4px;font-size:.85rem;margin-bottom:.5rem!important}.favors-payoff-button{background:linear-gradient(135deg,#8b0000,#6b0000);color:gold;border:2px solid #ffd700;padding:.6rem 1rem;font-size:.9rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease}.favors-payoff-button:hover{background:linear-gradient(135deg,#a00000,#8b0000);transform:translateY(-2px);box-shadow:0 4px 12px #8b000066}.favors-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.favors-modal{background:var(--color-surface);border:2px solid #8b0000;padding:0;border-radius:var(--border-radius);box-shadow:0 8px 32px #8b000080;max-width:400px;width:90%}.favors-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#8b0000,#6b0000);border-radius:var(--border-radius) var(--border-radius) 0 0}.favors-modal-header h2{color:gold;margin:0;font-size:1.25rem}.favors-modal-close{background:none;border:none;color:gold;font-size:1.5rem;cursor:pointer;opacity:.7;transition:opacity var(--transition-speed) ease}.favors-modal-close:hover{opacity:1}.favors-modal-content{padding:1.5rem}.favors-modal-info,.favors-modal-cost,.favors-modal-available{margin-bottom:.75rem;color:var(--color-text)}.favors-modal-info strong{color:#ff6b6b}.favors-modal-cost strong{color:gold}.favors-modal-available strong{color:#c9a0ff}.favors-modal-selector{display:flex;align-items:center;justify-content:space-between;gap:1rem;margin:1rem 0;padding:1rem;background:#0003;border-radius:var(--border-radius)}.favors-modal-selector label{font-weight:600;color:var(--color-text)}.favors-modal-controls{display:flex;align-items:center;gap:.5rem}.favors-adjust-btn{width:36px;height:36px;background:#8b0000;border:2px solid #ffd700;color:gold;font-size:1.25rem;font-weight:700;border-radius:4px;cursor:pointer;transition:all var(--transition-speed) ease}.favors-adjust-btn:hover:not(:disabled){background:#a00000}.favors-adjust-btn:disabled{opacity:.4;cursor:not-allowed}.favors-units-value{font-size:1.5rem;font-weight:700;color:gold;min-width:40px;text-align:center}.favors-modal-total{text-align:center;font-size:1.1rem;margin-top:1rem;color:var(--color-text)}.favors-modal-total strong{color:#ff6b6b}.favors-modal-buttons{display:flex;gap:1rem;justify-content:center;padding:1rem 1.5rem 1.5rem}.interest-notification-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1001}.interest-notification-modal{background:var(--color-surface);border:2px solid #8b0000;border-radius:var(--border-radius);box-shadow:0 8px 32px #8b000080;max-width:360px;width:90%;text-align:center;overflow:hidden}.interest-notification-modal h3{background:linear-gradient(135deg,#8b0000,#6b0000);color:gold;margin:0;padding:1rem;font-size:1.1rem}.interest-notification-content{padding:1.25rem}.interest-notification-content p{margin:0 0 .75rem;color:var(--color-text)}.interest-notification-content p:last-child{margin-bottom:0}.interest-notification-content strong{color:#ff6b6b}.interest-warning{background:#8b00004d;padding:.75rem;border-radius:4px;color:gold!important;margin-top:.5rem!important}.interest-notification-dismiss{background:linear-gradient(135deg,#8b0000,#6b0000);color:gold;border:2px solid #ffd700;padding:.6rem 2rem;font-size:1rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;margin:0 1.25rem 1.25rem;transition:all var(--transition-speed) ease}.interest-notification-dismiss:hover{background:linear-gradient(135deg,#a00000,#8b0000)}.favors-payoff-container{width:100%;max-width:800px;margin:1rem auto;background:var(--color-surface);border:2px solid #8b0000;border-radius:var(--border-radius);box-shadow:0 4px 20px #8b00004d;overflow:hidden}.favors-payoff-header{background:linear-gradient(135deg,#8b0000,#6b0000);padding:.75rem 1.5rem;text-align:center}.favors-payoff-header h3{margin:0;color:gold;font-size:1.1rem;font-weight:600;letter-spacing:.05em}.favors-payoff-content{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;padding:1rem 1.5rem;gap:1rem}.favors-payoff-info{flex:1;min-width:250px}.favors-payoff-info p{margin:0 0 .5rem;color:var(--color-text);line-height:1.5}.favors-payoff-info p:last-child{margin-bottom:0}.favors-payoff-info strong{color:gold}.favors-payoff-hint{font-size:.9rem;color:#ffffffb3!important}.favors-payoff-prestige{background:#0003;padding:.5rem .75rem;border-radius:4px;display:inline-block}.favors-payoff-actions{display:flex;flex-direction:column;gap:.5rem;min-width:180px}.favors-payoff-proceed-button{background:linear-gradient(135deg,#4a4a4a,#333);color:#fff;border:2px solid #666;padding:.6rem 1.25rem;font-size:.9rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease;text-align:center}.favors-payoff-proceed-button:hover{background:linear-gradient(135deg,#5a5a5a,#444);border-color:#888}@media (max-width: 600px){.favors-payoff-content{flex-direction:column;text-align:center}.favors-payoff-actions{width:100%}}.waiting-for-favors-payoff{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);background:#000000d9;color:gold;padding:1.5rem 2rem;border-radius:var(--border-radius);border:2px solid #8b0000;font-size:1.1rem;z-index:999;text-align:center}.convert-exp-button{background:linear-gradient(135deg,#2d4a6f,#1e3a5f);color:#8ec8f8;border:2px solid #5a9bd4;padding:.4rem .75rem;font-size:.8rem;font-weight:600;border-radius:var(--border-radius);cursor:pointer;transition:all var(--transition-speed) ease;margin-left:.75rem}.convert-exp-button:hover{background:linear-gradient(135deg,#3d5a7f,#2e4a6f);transform:translateY(-1px);box-shadow:0 2px 8px #5a9bd44d}.conversion-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000}.conversion-modal{background:var(--color-surface);border:2px solid #5a9bd4;padding:0;border-radius:var(--border-radius);box-shadow:0 8px 32px #5a9bd466;max-width:450px;width:90%;max-height:80vh;display:flex;flex-direction:column}.conversion-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:linear-gradient(135deg,#2d4a6f,#1e3a5f);border-radius:var(--border-radius) var(--border-radius) 0 0;flex-shrink:0}.conversion-modal-header h2{color:#8ec8f8;margin:0;font-size:1.25rem}.conversion-modal-close{background:none;border:none;color:#8ec8f8;font-size:1.5rem;cursor:pointer;opacity:.7;transition:opacity var(--transition-speed) ease}.conversion-modal-close:hover{opacity:1}.conversion-modal-content{padding:1.25rem 1.5rem;overflow-y:auto;flex:1}.conversion-error{background:#8b00004d;border:1px solid #8b0000;color:#ff6b6b;padding:.75rem;border-radius:4px;margin-bottom:1rem;font-size:.9rem;text-align:center}.conversion-exp-section{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:#0003;border-radius:4px;margin-bottom:1rem}.conversion-exp-section--result{background:#5a9bd426;border:1px solid rgba(90,155,212,.3)}.conversion-exp-label{font-weight:600;color:var(--color-text);font-size:.9rem}.conversion-exp-values{display:flex;gap:.75rem}.exp-amount--changed{font-weight:700;text-shadow:0 0 4px currentColor}.conversion-abilities{display:flex;flex-direction:column;gap:1rem;margin-bottom:1rem}.conversion-ability{background:#00000026;border-radius:var(--border-radius);padding:.75rem;border:1px solid rgba(255,255,255,.1)}.conversion-ability-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;font-weight:600;font-size:.9rem;flex-wrap:wrap}.conversion-from{display:flex;align-items:center;gap:.25rem;text-transform:capitalize}.conversion-arrow{color:#ffffff80;font-size:1.1rem}.conversion-targets{text-transform:capitalize;color:#ffffffe6}.conversion-limit{margin-left:auto;font-size:.8rem;color:#fff9;font-weight:400}.conversion-target-controls{display:flex;flex-direction:column;gap:.5rem}.conversion-target-row{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:#0003;border-radius:4px}.conversion-target-name{text-transform:capitalize;min-width:60px;font-size:.85rem}.conversion-controls{display:flex;align-items:center;gap:.5rem;margin-left:auto}.conversion-btn{width:32px;height:32px;background:#2d4a6f;border:2px solid #5a9bd4;color:#8ec8f8;font-size:1.1rem;font-weight:700;border-radius:4px;cursor:pointer;transition:all var(--transition-speed) ease;display:flex;align-items:center;justify-content:center}.conversion-btn:hover:not(:disabled){background:#3d5a7f}.conversion-btn:disabled{opacity:.4;cursor:not-allowed}.conversion-btn--plus{background:#2d5f2d;border-color:#4a9f4a;color:#8fdf8f}.conversion-btn--plus:hover:not(:disabled){background:#3d6f3d}.conversion-btn--minus{background:#5f2d2d;border-color:#9f4a4a;color:#df8f8f}.conversion-btn--minus:hover:not(:disabled){background:#6f3d3d}.conversion-amount{font-size:1.1rem;font-weight:700;min-width:32px;text-align:center;color:#8ec8f8}.conversion-modal-buttons{display:flex;gap:1rem;justify-content:center;padding:1rem 1.5rem 1.5rem;flex-shrink:0}@media (max-width: 480px){.conversion-modal{max-width:95%}.conversion-exp-section{flex-direction:column;gap:.5rem;text-align:center}.conversion-ability-header{flex-direction:column;align-items:flex-start}.conversion-limit{margin-left:0}}.player-area-content--two-rows{display:flex;flex-direction:column;gap:1rem}.player-row{width:100%}.player-row--students{display:flex;align-items:flex-start;gap:1.5rem;flex-wrap:wrap}.students-section{display:flex;flex-direction:column;gap:.5rem}.player-info-sidebar{display:flex;flex-direction:column;gap:.75rem;min-width:180px;flex:1}.students-section .row-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.player-row--tracks{width:100%}.students-display--large{display:flex;gap:1rem;justify-content:flex-start}.student-slot-display{display:flex;flex-direction:column;align-items:center;gap:.25rem}.student-slot-display--empty{width:140px;height:195px;display:flex;align-items:center;justify-content:center;border:2px dashed var(--color-text-muted);border-radius:var(--border-radius);color:var(--color-text-muted)}.student-slot-content{display:flex;flex-direction:column;align-items:center;gap:.5rem}.student-slot-empty{font-size:.875rem;color:var(--color-text-muted)}.student-slot-traits{display:flex;flex-wrap:wrap;gap:4px;justify-content:center;max-width:140px}.student-slot-trait{background:#c9a0ff33;border:1px solid rgba(201,160,255,.4);border-radius:4px;padding:2px 8px;font-size:.7rem;color:#c9a0ff;white-space:nowrap}.phase-round-indicator{display:flex;justify-content:center;align-items:center;padding:.5rem 1rem;margin-bottom:.5rem;font-size:1rem;font-weight:600;color:var(--color-text);background:#0003;border-radius:var(--border-radius)}.phase-round-indicator .status--game-over{color:#fbbf24;font-size:1.25rem}.game{display:flex;flex-direction:column;align-items:center;gap:1.5rem}.game h1{font-size:2.5rem;font-weight:700;background:linear-gradient(135deg,var(--color-x),var(--color-o));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.game-status{font-size:1.25rem;font-weight:500;padding:.75rem 1.5rem;background:var(--color-surface);border-radius:var(--border-radius);min-width:200px;text-align:center}.status--game-over{color:var(--color-winning);font-weight:700}.game-info{font-size:.875rem;color:var(--color-text-muted)}.board{display:flex;flex-direction:column;gap:8px;padding:1rem;background:var(--color-surface);border-radius:var(--border-radius);box-shadow:0 8px 32px #0000004d}.board-row{display:flex;gap:8px}.square{width:80px;height:80px;font-size:2.5rem;font-weight:700;border:none;border-radius:var(--border-radius);background:var(--color-secondary);color:var(--color-text);cursor:pointer;transition:all var(--transition-speed) ease;display:flex;align-items:center;justify-content:center}.square:hover:not(:disabled){background:#1a4a80;transform:scale(1.05)}.square:disabled{cursor:default}.square--x{color:var(--color-x)}.square--o{color:var(--color-o)}.square--winning{background:var(--color-winning);color:var(--color-bg);animation:pulse .5s ease infinite alternate}@media (max-width: 768px){.students-display--large{gap:.75rem}.student-slot-display--empty{width:120px;height:168px}.student-slot-traits{max-width:120px}}@media (max-width: 480px){.students-display--large{gap:.5rem;flex-wrap:wrap;justify-content:center}.student-slot-display--empty{width:100px;height:140px}.student-slot-traits{max-width:100px}.student-slot-trait{font-size:.6rem;padding:2px 6px}.player-row--students{flex-direction:column;gap:1rem}.square{width:60px;height:60px;font-size:2rem}.game h1{font-size:2rem}}.card-hover-wrapper{display:inline-block;position:relative}.card-hover-preview{animation:card-hover-fade-in .15s ease-out}.card-hover-preview-content{box-shadow:0 20px 60px #0009,0 0 0 2px #ffd7004d;border-radius:10px}.card-hover-preview .card--student,.card-hover-preview .card--trait{transform:none;pointer-events:none}.card--hover-preview{width:220px;height:308px;pointer-events:none}.card--hover-preview .student-card-name,.card--hover-preview .trait-card-name{font-size:calc(var(--card-font-name) * var(--card-hover-scale))}.card--hover-preview .student-card-text,.card--hover-preview .trait-card-text{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.card--hover-preview .student-card-type-bar,.card--hover-preview .trait-card-type-bar{font-size:calc(var(--card-font-type-bar) * var(--card-hover-scale))}.card--hover-preview .student-card-footer,.card--hover-preview .trait-card-footer{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.card--hover-preview .student-card-cost,.card--hover-preview .trait-card-prestige{font-size:calc(var(--card-badge-font) * var(--card-hover-scale));min-width:calc(var(--card-badge-min-width) * var(--card-hover-scale))}.card--hover-preview .pip-mana{width:calc(var(--card-pip-size) * var(--card-hover-scale));height:calc(var(--card-pip-size) * var(--card-hover-scale));font-size:calc(var(--card-pip-font) * var(--card-hover-scale))}.card--hover-preview .exp-mana{width:calc(var(--card-exp-size) * var(--card-hover-scale));height:calc(var(--card-exp-size) * var(--card-hover-scale));font-size:calc(var(--card-exp-font) * var(--card-hover-scale))}.card--hover-preview .pip{width:12px;height:12px}.trait-name-hover{cursor:help;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:2px}.trait-name-hover:hover{color:#c9a0ff}.trait-name-hover-preview{animation:card-hover-fade-in .15s ease-out}.trait-name-hover-preview .card--trait{width:220px;height:308px;box-shadow:0 10px 40px #00000080,0 0 0 2px #c9a0ff4d}.trait-name-hover-preview .trait-card-name{font-size:calc(var(--card-font-name) * var(--card-hover-scale))}.trait-name-hover-preview .trait-card-text{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.trait-name-hover-preview .trait-card-type-bar{font-size:calc(var(--card-font-type-bar) * var(--card-hover-scale))}.trait-name-hover-preview .trait-card-footer{font-size:calc(var(--card-font-text) * var(--card-hover-scale))}.trait-name-hover-preview .trait-card-prestige{font-size:calc(var(--card-badge-font) * var(--card-hover-scale));min-width:calc(var(--card-badge-min-width) * var(--card-hover-scale))}.trait-name-hover-preview .pip-mana{width:calc(var(--card-pip-size) * var(--card-hover-scale));height:calc(var(--card-pip-size) * var(--card-hover-scale));font-size:calc(var(--card-pip-font) * var(--card-hover-scale))}.trait-name-hover-preview .exp-mana{width:calc(var(--card-exp-size) * var(--card-hover-scale));height:calc(var(--card-exp-size) * var(--card-hover-scale));font-size:calc(var(--card-exp-font) * var(--card-hover-scale))}
